<div dir="ltr">Bill,<div><br></div><div>I was about to suggest the possibility of using BIND(C) for the other types, e.g., MPI_REAL_INTEGER_TYPE but Jeff pointed out to me this morning that MPI_FLOAT_INT are not really C structs. The MPI standard reads</div><div><br></div><div>"The datatype MPI_FLOAT_INT is as if defined by the following ..."<br></div><div><br></div><div>and goes on to define an MPI Datatype that is a C float followed immediately in memory by a C int. So the MPI standard actually defines a memory representation rather than a C struct.</div><div><br></div><div>Thus SEQUENCE is really what Jeff wants although I just checked the Fortran standard and <span style="font-size:13px">SEQUENCE really looks to be archaic (removed from the standard).</span></div><div><span style="font-size:13px"><br></span></div><div><span style="font-size:13px">It seems to me that the MPI standard shouldn't use features that are no longer in the Fortran standard. So I no longer can think of an effective way to use this feature of the MPI standard.</span></div><div><span style="font-size:13px"><br></span></div><div><span style="font-size:13px">My question to Jeff: How do C users use this facility (or even how do you implement it)? Specifically, a C struct doesn't define the representation in memory of the data members (although is does define the order). According to the C standard:</span></div><div><span style="font-size:13px"><br></span></div><div>"Each non-bit-field member of a structure or union object is aligned in an implementation-defined manner appropriate to its type."<br></div><div><br></div><div>and is thus free to add padding. So how in C can you legally implement and use MPI_FLOAT_INT? The only way I can think of is to use memory offsets and cast the resulting address. Not really pretty code but at least legal.</div><div><br></div><div>-craig</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Dec 8, 2015 at 1:14 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 Dec 8, 2015, at 2:13 PM, Jeff Squyres (jsquyres) <<a href="mailto:jsquyres@cisco.com">jsquyres@cisco.com</a>> wrote:<br>
<br>
> We talked about this in detail at the SJC meeting this morning.<br>
><br>
> 1. In MPI 3.1 section 5.9.4 p180, the following types are defined for fortran:<br>
><br>
> -----<br>
> MPI_2REAL<br>
> MPI_2DOUBLE_PRECISION<br>
> MPI_2INTEGER<br>
> -----<br>
><br>
> The following types are defined for C:<br>
><br>
> -----<br>
> MPI_FLOAT_INT<br>
> MPI_DOUBLE_INT<br>
> MPI_LONG_INT<br>
> MPI_2INT<br>
> MPI_SHORT_INT<br>
> MPI_LONG_DOUBLE_INT<br>
</span>> ——<br>
<br>
<br>
I assume the C versions are structs with two members of the obvious types. One could mimic these in Fortran:<br>
<br>
use,intrinsic :: iso_c_binding<br>
<br>
type,bind(c) :: mpi_float_int ! the bind(c) ensures the C compiler’s memory layout<br>
real(c_float) :: val<br>
integer(c_int) :: loc<br>
end type<br>
<br>
and facilitate calling the C routines directly.<br>
<br>
When you say REAL , DOUBLE PRECISION, and INTEGER, do you mean the “default” ones. I.e. the ones with a bit-size that can depend on compiler options? That complicates things, combinatorially if the compile specifies -r8, -i4, for example.<br>
<span class=""><br>
<br>
><br>
> 2. What Jeff Hammond asks is quite reasonable; it seems like we should use the Fortran derived types for MINLOC and MAXLOC functionality. The old Fortran types (2REAL, 2DOUBLE_PRECISION, 2INTEGER) exist because there were no derived types back in the early 90's.<br>
><br>
> I think we can make three proposals (NOTE: we need to cross reference these proposals with the RMA and collective working groups, but I want to get the Fortran stuff correct first):<br>
><br>
> 2a. Change the definition of MPI_INTEGER from<br>
><br>
> -----<br>
> INTEGER FOO(2)<br>
> -----<br>
><br>
> to (please correct my fortran syntax; you all know I have some of it wrong below...)<br>
><br>
> ------<br>
> TYPE :: MPI_2INTEGER_TYPE, SEQUENCE<br>
> INTEGER VAL<br>
> INTEGER LOC<br>
> END TYPE<br>
</span>> ——<br>
<br>
<br>
This syntax would be<br>
<br>
TYPE :: MPI_2INTEGER_TYPE<br>
SEQUENCE<br>
<span class=""> NTEGER VAL<br>
INTEGER LOC<br>
END TYPE<br>
<br>
<br>
</span>However, apart from using default types, most Fortran gurus would be revolted at the use of the archaic SEQUENCE specification. This is something that should already have been on the MPI deprecated list.<br>
<div><div class="h5"><br>
<br>
<br>
><br>
> Craig assures me that these two Fortran types are exactly the same in memory representation. Hence, even though we're technically changing the back-end representation of MPI_2INTEGER, we're changing it to an exactly equivalent definition. Hence, old codes will not break -- we're just updating to use newer Fortran syntax.<br>
><br>
> Also, create two new types:<br>
><br>
> -----<br>
> TYPE :: MPI_REAL_INTEGER_TYPE, SEQUENCE<br>
> REAL VAL<br>
> INTEGER LOC<br>
> END TYPE<br>
><br>
> TYPE :: MPI_DOUBLE_PRECISION_INTEGER_TYPE, SEQUENCE<br>
> DOUBLE PRECISION VAL<br>
> INTEGER LOC<br>
> END TYPE<br>
> -----<br>
><br>
> And MPI datatypes corresponding to these two new types: MPI_REAL_INTEGER, MPI_DOUBLE_PRECISION_INTEGER<br>
><br>
> Note: with this one old type (2INTEGER) and the 2 new types (REAL_INTEGER and DOUBLE_PRECISION_INTEGER) correspond to the C types MPI_2INT, MPI_FLOAT_INT, MPI_DOUBLE_INT, respectively.<br>
><br>
> 2b. Create three additional new Fortran types to make parity with the remaining C types (MPI_LONG_INT, MPI_SHORT_INT, MPI_LONG_DOUBLE_INT) -- the names below are completely up for negotiation, and may even be longer than 31 characters:<br>
><br>
> -----<br>
> TYPE :: MPI_LONGINTEGER_INTEGER_TYPE, SEQUENCE<br>
> INTEGER(KIND=whatever) VAL<br>
> INTEGER LOC<br>
> END TYPE<br>
><br>
> TYPE :: MPI_SHORTINTEGER_INTEGER_TYPE, SEQUENCE<br>
> INTEGER(KIND=whatever) VAL<br>
> INTEGER LOC<br>
> END TYPE<br>
><br>
> TYPE :: MPI_QUAD_PRECISION_INTEGER_TYPE, SEQUENCE<br>
> DOUBLE PRECISION(KIND=whatever) VAL<br>
<br>
</div></div>REAL(KIND=whatever) VAL<br>
<br>
The single, double, and quad versions would be identical except for the values for “whatever”.<br>
<span class=""><br>
<br>
> INTEGER LOC<br>
> END TYPE<br>
> -----<br>
><br>
> These 3 new Fortran types would then make Fortran support the same types as C.<br>
<br>
</span>I would recommend use of the bind(c) types instead, as illustrated above, if you want to duplicate the C types.<br>
<span class=""><br>
><br>
> 3. Deprecate the 2 old MPI datatypes that we don't want to encourage use of anymore:<br>
><br>
> -----<br>
> MPI_2REAL<br>
> MPI_2DOUBLE_PRECISION<br>
<br>
</span>Seems like a good idea.<br>
<br>
Cheers,<br>
Bill<br>
<div><div class="h5"><br>
> -----<br>
><br>
> Thoughts?<br>
><br>
><br>
><br>
>> On Dec 8, 2015, at 10:31 AM, Rolf Rabenseifner <<a href="mailto:rabenseifner@hlrs.de">rabenseifner@hlrs.de</a>> wrote:<br>
>><br>
>> Sorry, but I was too fast with my negative answer.<br>
>> Yes, we have both arguments in the reduction<br>
>> and therefore it would be simple to add a new<br>
>> datatype to the list of allowed datatypes for<br>
>> MIN/MAXLOC in Fortran.<br>
>><br>
>> Deprecation is too expensive and there is no need.<br>
>><br>
>> Rolf<br>
>><br>
>><br>
>> ----- Original Message -----<br>
>>> From: "Rolf Rabenseifner" <<a href="mailto:rabenseifner@hlrs.de">rabenseifner@hlrs.de</a>><br>
>>> To: "MPI-WG Fortran working group" <<a href="mailto:mpiwg-fortran@lists.mpi-forum.org">mpiwg-fortran@lists.mpi-forum.org</a>><br>
>>> Sent: Tuesday, December 8, 2015 7:22:45 PM<br>
>>> Subject: Re: [MPIWG Fortran] F08 and pair types?<br>
>><br>
>>> I'm sorry, but I expect that deprecation of a language binding<br>
>>> is not possible for a feature that is still valid in other languages (here C).<br>
>>><br>
>>> This means, that MINLOC and MAXLOC are as they are defined<br>
>>> and there is no reason to deprecate them.<br>
>>> They are not wrong and nobody want to pay the maintenance costs<br>
>>> for modifying existing applications that use MIN/MAXLOC.<br>
>>><br>
>>> The only way to do it better, is to add a new feature, e.g.,<br>
>>> MINLOC_F08 and MAXLOC_F08 which is valid only for the new<br>
>>> mpi_f08 module.<br>
>>><br>
>>> Rolf<br>
>>><br>
>>> ----- Original Message -----<br>
>>>> From: "Craig Rasmussen" <<a href="mailto:rasmus@cas.uoregon.edu">rasmus@cas.uoregon.edu</a>><br>
>>>> To: "MPI-WG Fortran working group" <<a href="mailto:mpiwg-fortran@lists.mpi-forum.org">mpiwg-fortran@lists.mpi-forum.org</a>><br>
>>>> Sent: Tuesday, December 8, 2015 6:30:37 PM<br>
>>>> Subject: Re: [MPIWG Fortran] F08 and pair types?<br>
>>><br>
>>>> The old stuff could be deprecated because all existing compilers that I know of<br>
>>>> support user-defined types. I assume that "deprecated" means that it still<br>
>>>> exists in libraries for legacy apps but is no longer really defined in the<br>
>>>> standard.<br>
>>>><br>
>>>> -craig<br>
>>>><br>
>>>> On Tue, Dec 8, 2015 at 9:19 AM, Craig Rasmusen < <a href="mailto:rasmus@cas.uoregon.edu">rasmus@cas.uoregon.edu</a> > wrote:<br>
>>>><br>
>>>><br>
>>>><br>
>>>> Fortran is a modern language? Wut...<br>
>>>><br>
>>>> Actually seems like a simple and good change. For example, could define:<br>
>>>><br>
>>>> MPI_REAL_INT and MPI_INTEGER_INT<br>
>>>><br>
>>>> However, I'm not sure what would be in the structs (user-defined types). I'll<br>
>>>> have to ask Squyres what the text following<br>
>>>><br>
>>>> "The datatype MPI_FLOAT_INT is as if defined by the following sequence of<br>
>>>> instructions"<br>
>>>><br>
>>>> means.<br>
>>>><br>
>>>> -craig<br>
>>>><br>
>>>> On Mon, Dec 7, 2015 at 4:20 PM, Jeff Hammond < <a href="mailto:jeff.science@gmail.com">jeff.science@gmail.com</a> > wrote:<br>
>>>><br>
>>>><br>
>>>><br>
>>>> I have a reasonable understanding of why the legacy Fortran bindings use 2REAL,<br>
>>>> 2DOUBLE_PRECISION and 2INTEGER with {MAX,MIN}LOC reductions.<br>
>>>><br>
>>>> Doesn't modern Fortran provide a way to create struct-like things along the<br>
>>>> lines of C, such that more appropriate pair types could be used for these?<br>
>>>><br>
>>>> The relevant text is section 5.9.4 of MPI 3.1.<br>
>>>><br>
>>>> Jeff<br>
>>>><br>
>>>> --<br>
>>>> Jeff Hammond<br>
>>>> <a href="mailto:jeff.science@gmail.com">jeff.science@gmail.com</a><br>
>>>> <a href="http://jeffhammond.github.io/" rel="noreferrer" target="_blank">http://jeffhammond.github.io/</a><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>
>>>><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>
>>><br>
>>> --<br>
>>> Dr. Rolf Rabenseifner . . . . . . . . . .. email <a href="mailto:rabenseifner@hlrs.de">rabenseifner@hlrs.de</a><br>
>>> High Performance Computing Center (HLRS) . phone <a href="tel:%2B%2B49%280%29711%2F685-65530" value="+4971168565530">++49(0)711/685-65530</a><br>
>>> University of Stuttgart . . . . . . . . .. fax <a href="tel:%2B%2B49%280%29711%20%2F%20685-65832" value="+4971168565832">++49(0)711 / 685-65832</a><br>
>>> Head of Dpmt Parallel Computing . . . <a href="http://www.hlrs.de/people/rabenseifner" rel="noreferrer" target="_blank">www.hlrs.de/people/rabenseifner</a><br>
>>> Nobelstr. 19, D-70550 Stuttgart, Germany . . . . (Office: Room 1.307)<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>
>> --<br>
>> Dr. Rolf Rabenseifner . . . . . . . . . .. email <a href="mailto:rabenseifner@hlrs.de">rabenseifner@hlrs.de</a><br>
>> High Performance Computing Center (HLRS) . phone <a href="tel:%2B%2B49%280%29711%2F685-65530" value="+4971168565530">++49(0)711/685-65530</a><br>
>> University of Stuttgart . . . . . . . . .. fax <a href="tel:%2B%2B49%280%29711%20%2F%20685-65832" value="+4971168565832">++49(0)711 / 685-65832</a><br>
>> Head of Dpmt Parallel Computing . . . <a href="http://www.hlrs.de/people/rabenseifner" rel="noreferrer" target="_blank">www.hlrs.de/people/rabenseifner</a><br>
>> Nobelstr. 19, D-70550 Stuttgart, Germany . . . . (Office: Room 1.307)<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>
><br>
> --<br>
> Jeff Squyres<br>
> <a href="mailto:jsquyres@cisco.com">jsquyres@cisco.com</a><br>
> For corporate legal information go to: <a href="http://www.cisco.com/web/about/doing_business/legal/cri/" rel="noreferrer" target="_blank">http://www.cisco.com/web/about/doing_business/legal/cri/</a><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>
<br>
</div></div>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>
<div class="HOEnZb"><div class="h5"><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>
</div></div></blockquote></div><br></div>