<div dir="ltr">In OpenMPI F08, those predefined MPI datatypes are not "parameter variables".  Thus OMPI failed to compile an MPICH F08 test, which has<div><br></div><div><div>  INTEGER, PARAMETER :: nb=2</div><div>  TYPE(MPI_DATATYPE) :: types(nb)=(/MPI_DOUBLE_PRECISION, MPI_CHAR/)<br></div><div><br></div><div>Jeff Squyres and I discussed in emails.  I don't know whether this is correct according to the MPI spec.</div><div><br></div><div> </div></div></div><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature"><div dir="ltr">--Junchao Zhang</div></div></div>
<br><div class="gmail_quote">On Thu, Jun 18, 2015 at 12:48 PM, Bill Long <span dir="ltr"><<a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class=""><br>
On Jun 18, 2015, at 11:05 AM, Junchao Zhang <<a href="mailto:jczhang@mcs.anl.gov">jczhang@mcs.anl.gov</a>> wrote:<br>
<br>
> Hello, Fortran experts,<br>
>   I am a little puzzled by MPI-3.1 Chapter 2.5.4,<br>
<br>
</span>Not surprising.  The (mis)use of terminology is confusing at best.<br>
<span class=""><br>
><br>
> All named constants, with the exceptions noted below for Fortran, can be used in<br>
> initialization expressions or assignments, but not necessarily in array declarations or as<br>
> labels in C switch or Fortran select/case statements.  This implies named constants<br>
> to be link-time but not necessarily compile-time constants.<br>
<br>
</span>In Fortran “named constant” is a defined term.  They are declared with the PARAMETER attribute.  And can be used in most places where literal constants can be used, including array declarations.  They cannot be used as statement labels, though I think the reference to “Fortran select/case statements” intends to talk about case-values, and not labels.  Named constants can be used as case-values.<br>
<span class=""><br>
><br>
>  Then in F08, should MPI_INTEGER be declared as a parameter variable?<br>
<br>
</span>Yes.  That’s what I did in my prototype mpi_f08 modules.<br>
<span class=""><br>
>  If no, then I get an error when compiling this initialization expression with gfortran<br>
>           type(MPI_Datatype) :: dtype = MPI_INTEGER<br>
><br>
>     Error: Parameter 'mpi_integer' at (1) has not been declared or is a variable, which does not reduce to a constant expression<br>
><br>
> If yes, then of course I can use MPI_INTEGER in Fortran select/case.<br>
<br>
</span>Right.<br>
<span class=""><br>
><br>
> Another question is what is the meaning of "link-time constants". I could not find in MPI. Does it mean I can use MPI_INTEGER after main before MPI_Init?<br>
<br>
</span>I suspect this is a historical artifact where some special head standing was needed to correctly define MPI_INTEGER based on whether the code was compiled with -i4 or -i8 (or equivalent, depending on the compiler).  For the modern case of using the mpi_f08 module, you just compile the mpi_f08 module twice (once with -i4 and once with -i8) and then have the compile command select the right actual module to reference based on how the using program unit is compiled.   Generally, values of objects are not set at link time;  addresses of objects are set at link time.   MPI objects that represent addresses  (MPI_BOTTOM ??) are examples.  If MPI_INTEGER is accessible, you can reference it.  If should not have anything to do with whether MPI_Init has been called.<br>
<br>
Perhaps some of the MPI historians can shed more light on this terminology.  I suspect it would be completely moot if we got rid of mpif.h.<br>
<br>
Cheers,<br>
Bill<br>
<br>
<br>
><br>
> Thank you!<br>
><br>
> --Junchao Zhang<br>
> _______________________________________________<br>
> mpiwg-fortran mailing list<br>
> <a href="mailto:mpiwg-fortran@lists.mpi-forum.org">mpiwg-fortran@lists.mpi-forum.org</a><br>
> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" rel="noreferrer" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
<br>
Bill Long                                                                       <a href="mailto:longb@cray.com">longb@cray.com</a><br>
Fortran Technical Support  &                                  voice:  <a href="tel:651-605-9024" value="+16516059024">651-605-9024</a><br>
Bioinformatics Software Development                     fax:  <a href="tel:651-605-9142" value="+16516059142">651-605-9142</a><br>
Cray Inc./ Cray Plaza, Suite 210/ 380 Jackson St./ St. Paul, MN 55101<br>
<br>
<br>
_______________________________________________<br>
mpiwg-fortran mailing list<br>
<a href="mailto:mpiwg-fortran@lists.mpi-forum.org">mpiwg-fortran@lists.mpi-forum.org</a><br>
<a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" rel="noreferrer" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
</blockquote></div><br></div>