<div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">On Tue, May 13, 2014 at 3:21 PM, William Gropp <span dir="ltr"><<a href="mailto:wgropp@illinois.edu" target="_blank">wgropp@illinois.edu</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word">You can always create a new MPI datatype that is the composition of the array section and the MPI datatype. For a vector of a simple (vector) section, for example, the new datatype simply has the product of the strides. Other types are more complex but always possible.</div>
</blockquote><div><br></div><div>OK. If MPI datatype is represented in a hierarchical tree, then one need to combine two MPI datatype trees, which is complicated in general. </div><div>In my view, if a user wants to have a complex derived datatype, he should create it explicitly with MPI datatype calls, instead of doing it implicitly with "subarray X datatype", since that makes code hard to understand. MPI standard is better not to support that. </div>
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div>
<div>Bill</div><div><span><font color="#888888"><br>
<div>
<span style="border-collapse:separate;color:rgb(0,0,0);font-family:Helvetica;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:-webkit-auto;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;font-size:medium"><span style="border-collapse:separate;color:rgb(0,0,0);font-family:Helvetica;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:-webkit-auto;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;font-size:medium"><div style="word-wrap:break-word">
<span style="border-collapse:separate;color:rgb(0,0,0);font-family:Helvetica;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;font-size:medium"><div style="word-wrap:break-word">
<div><div style="font-size:12px">William Gropp</div><div style="font-size:12px">Director, Parallel Computing Institute</div></div></div></span><span style="font-size:12px">Thomas M. Siebel Chair in Computer Science</span><span style="border-collapse:separate;color:rgb(0,0,0);font-family:Helvetica;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;font-size:medium"><div style="word-wrap:break-word">
<div><div style="font-size:12px">University of Illinois Urbana-Champaign</div></div><div><br></div></div></span><br></div></span><br></span><br>
</div></font></span><div><div>
<br><div><div>On May 13, 2014, at 3:02 PM, Junchao Zhang wrote:</div><br><blockquote type="cite"><div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">On Tue, May 13, 2014 at 2:56 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:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><br>
On May 13, 2014, at 2:48 PM, Junchao Zhang <<a href="mailto:jczhang@mcs.anl.gov" target="_blank">jczhang@mcs.anl.gov</a>> wrote:<br>
<br>
><br>
> On Tue, May 13, 2014 at 2:37 PM, Bill Long <<a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a>> wrote:<br>
><br>
> On May 13, 2014, at 2:19 PM, Junchao Zhang <<a href="mailto:jczhang@mcs.anl.gov" target="_blank">jczhang@mcs.anl.gov</a>> wrote:<br>
><br>
> ><br>
> > On Tue, May 13, 2014 at 2:00 PM, Bill Long <<a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a>> wrote:<br>
> ><br>
> > On May 13, 2014, at 12:44 PM, Junchao Zhang <<a href="mailto:jczhang@mcs.anl.gov" target="_blank">jczhang@mcs.anl.gov</a>> wrote:<br>
> ><br>
> > ><br>
> > > On Tue, May 13, 2014 at 11:56 AM, Rolf Rabenseifner <<a href="mailto:rabenseifner@hlrs.de" target="_blank">rabenseifner@hlrs.de</a>> wrote:<br>
> > > > REAL s(100)<br>
> > > > MPI_SEND(s (1:100:5) , 3, dtype, ...)<br>
> > > > dtype can only be MPI_REAL. In other words, dtype is kind of<br>
> > > > redundant here since the type map is actually specified by the<br>
> > > > subarray.<br>
> ><br>
> > Right. The descriptor for the first argument has a member whose value is a type code. In principal the library could verify this is compatible with the data type handle supplied as the third argument, and issue an error if not. Perhaps in a “debug” mode.<br>
> ><br>
> > ><br>
> > > No, if dtype is a vector then it is applied to a virtual<br>
> > > contiguous array that consists of s(1), s(6), s(11) …<br>
> ><br>
> > dtype is not a vector, is it? That argument is a scalar of type TYPE(MPI_DATATYPE). At least that is what the interface says.<br>
> ><br>
> > Rolf meant dtype is an MPI datatype created by MPI_Type_vector. For this case, I will have two datatypes, one from the MPI_Datatype argument, the other from the choice buffer itself. It is hard to implement that. Perhaps it is useless since it obscures the program.<br>
><br>
> OK. But one of the virtues of the new interface for users is that you do not have to create such data types anymore for array sections. Even if someone did do this, you can detect that the incoming data type is user-created, and in that case ignore the type code in the descriptor. If the program is valid at all, the element length, strides, and extents in the descriptor should be correct.<br>
><br>
> Yes, I can do that. The hard part is when the subarray is non-contiguous, and it is a non-blocking call. I need to allocate a scratch buffer and pack the subarray. Since it is non-blocking, I can not free the buffer.<br>
<br>
</div>Can you create, locally, a datatype that describes the layout of the array section, and then call MPI_Isend again with that data type? That avoids the contiguous local buffer and the problem of when to free it.<br>
</blockquote><div><br></div><div>That is my first thought. But then I realized I have to assume the MPI_Datatype argument is for subarray elements. </div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
Cheers,<br>
Bill<br>
<div><div><br>
<br>
<br>
<br>
><br>
><br>
> Cheers,<br>
> Bill<br>
><br>
><br>
><br>
> ><br>
> ><br>
> ><br>
> > Cheers,<br>
> > Bill<br>
> ><br>
> ><br>
> > ><br>
> > > That is nasty. Then I will have two data types. I even can not assume any relationship between the two types. I have to allocate a scratch buffer for the virtual contiguous array in MPI_ISEND etc, do memory copying and then free the buffer in MPI_WAIT. I'm not sure one can implement it efficiently.<br>
> > ><br>
> > ><br>
> > ><br>
> > > ----- Original Message -----<br>
> > > > From: "Junchao Zhang" <<a href="mailto:jczhang@mcs.anl.gov" target="_blank">jczhang@mcs.anl.gov</a>><br>
> > > > To: "MPI-WG Fortran working group" <<a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a>><br>
> > > > Sent: Tuesday, May 13, 2014 6:23:08 PM<br>
> > > > Subject: Re: [MPIWG Fortran] Data type of F08 subarray<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > Thanks, Rolf. And I feel there is a jump from contiguous subarray to<br>
> > > > non-contiguous subarray.<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > For contiguous subarray, such as<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > REAL s(100)<br>
> > > ><br>
> > > > MPI_SEND(s(2:50), 3, dtype, ...) s only gives the start address.<br>
> > > > dtype can be anything, e.g., either a basic type or a derived type<br>
> > > > created by MPI_Type_vector() etc.<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > For non-contiguous subarray, such as<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > REAL s(100)<br>
> > > > MPI_SEND(s (1:100:5) , 3, dtype, ...)<br>
> > > > dtype can only be MPI_REAL. In other words, dtype is kind of<br>
> > > > redundant here since the type map is actually specified by the<br>
> > > > subarray.<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > --Junchao Zhang<br>
> > > ><br>
> > > ><br>
> > > > On Tue, May 13, 2014 at 10:20 AM, Rolf Rabenseifner <<br>
> > > > <a href="mailto:rabenseifner@hlrs.de" target="_blank">rabenseifner@hlrs.de</a> > wrote:<br>
> > > ><br>
> > > ><br>
> > > > Dear Junchao,<br>
> > > ><br>
> > > > MPI-3.0 p25:7-8 describes only communication with language type<br>
> > > > of the buffer argument matches to the MPI datatype used<br>
> > > > in the datatype argument.<br>
> > > > Same p83:36-37.<br>
> > > ><br>
> > > > Therefore, the answer is no and the compiler cannot detect<br>
> > > > a mismatch beteen language buffer specification and<br>
> > > > MPI datatype specification.<br>
> > > ><br>
> > > > I hope my answer could help.<br>
> > > ><br>
> > > > Best regards<br>
> > > > Rolf<br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > ><br>
> > > > ----- Original Message -----<br>
> > > > > From: "Junchao Zhang" < <a href="mailto:jczhang@mcs.anl.gov" target="_blank">jczhang@mcs.anl.gov</a> ><br>
> > > > > To: "MPI-WG Fortran working group" <<br>
> > > > > <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a> ><br>
> > > > > Sent: Tuesday, May 13, 2014 5:08:30 PM<br>
> > > > > Subject: [MPIWG Fortran] Data type of F08 subarray<br>
> > > > ><br>
> > > > ><br>
> > > > ><br>
> > > > ><br>
> > > > > p626 of MPI-3.0 gives such an example<br>
> > > > ><br>
> > > > ><br>
> > > > > REAL s(100), r(100)<br>
> > > > > CALL MPI_Isend(s(1:100:5), 3, MPI_REAL, ..., rq, ierror)<br>
> > > > ><br>
> > > > > All nonblocking MPI functions behave as if the user-specified<br>
> > > > > elements of choice buffers are copied to a contiguous scratch<br>
> > > > > buffer<br>
> > > > > in the MPI runtime environment. All datatype descriptions (in the<br>
> > > > > example above, “3, MPI_REAL”) read and store data from and to this<br>
> > > > > virtual contiguous scratch buffer ...<br>
> > > > ><br>
> > > > > Here, data type of s(100) match with MPI_REAL, so everything is<br>
> > > > > fine.<br>
> > > > > But I want to know if MPI permits mismatched types, for example,<br>
> > > > > can<br>
> > > > > s(100) be an integer array? If the answer is no, then compilers can<br>
> > > > > not detect this error ; if yes, then it is hard to implement that.<br>
> > > > > To avoid memory copying to a scratch buffer, I want to use MPI<br>
> > > > > datatypes. But if I have two types, one is given by the choice<br>
> > > > > buffer itself, the other is given by the MPI_Datatype argument, how<br>
> > > > > could I do that?<br>
> > > > ><br>
> > > > > Any thoughts?<br>
> > > > ><br>
> > > > > Thanks<br>
> > > > ><br>
> > > > > --Junchao Zhang<br>
> > > > > _______________________________________________<br>
> > > > > mpiwg-fortran mailing list<br>
> > > > > <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > > > > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" 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" target="_blank">rabenseifner@hlrs.de</a><br>
> > > > High Performance Computing Center (HLRS) . phone <a href="tel:%2B%2B49%280%29711%2F685-65530" value="+4971168565530" target="_blank">++49(0)711/685-65530</a><br>
> > > > University of Stuttgart . . . . . . . . .. fax <a href="tel:%2B%2B49%280%29711%20%2F%20685-65832" value="+4971168565832" target="_blank">++49(0)711 / 685-65832</a><br>
> > > > Head of Dpmt Parallel Computing . . . <a href="http://www.hlrs.de/people/rabenseifner" 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" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > > > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
> > > ><br>
> > > > _______________________________________________<br>
> > > > mpiwg-fortran mailing list<br>
> > > > <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > > > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" 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" target="_blank">rabenseifner@hlrs.de</a><br>
> > > High Performance Computing Center (HLRS) . phone <a href="tel:%2B%2B49%280%29711%2F685-65530" value="+4971168565530" target="_blank">++49(0)711/685-65530</a><br>
> > > University of Stuttgart . . . . . . . . .. fax <a href="tel:%2B%2B49%280%29711%20%2F%20685-65832" value="+4971168565832" target="_blank">++49(0)711 / 685-65832</a><br>
> > > Head of Dpmt Parallel Computing . . . <a href="http://www.hlrs.de/people/rabenseifner" 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" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
> > ><br>
> > > _______________________________________________<br>
> > > mpiwg-fortran mailing list<br>
> > > <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
> ><br>
> > Bill Long <a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a><br>
> > Fortran Technical Suport & voice: <a href="tel:651-605-9024" value="+16516059024" target="_blank">651-605-9024</a><br>
> > Bioinformatics Software Development fax: <a href="tel:651-605-9142" value="+16516059142" target="_blank">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" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
> ><br>
> > _______________________________________________<br>
> > mpiwg-fortran mailing list<br>
> > <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> > <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
><br>
> Bill Long <a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a><br>
> Fortran Technical Suport & voice: <a href="tel:651-605-9024" value="+16516059024" target="_blank">651-605-9024</a><br>
> Bioinformatics Software Development fax: <a href="tel:651-605-9142" value="+16516059142" target="_blank">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" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
><br>
> _______________________________________________<br>
> mpiwg-fortran mailing list<br>
> <a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
<br>
Bill Long <a href="mailto:longb@cray.com" target="_blank">longb@cray.com</a><br>
Fortran Technical Suport & voice: <a href="tel:651-605-9024" value="+16516059024" target="_blank">651-605-9024</a><br>
Bioinformatics Software Development fax: <a href="tel:651-605-9142" value="+16516059142" target="_blank">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" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
<a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br>
</div></div></blockquote></div><br></div></div>
_______________________________________________<br>mpiwg-fortran mailing list<br><a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br><a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a></blockquote>
</div><br></div></div></div></div><br>_______________________________________________<br>
mpiwg-fortran mailing list<br>
<a href="mailto:mpiwg-fortran@lists.mpi-forum.org" target="_blank">mpiwg-fortran@lists.mpi-forum.org</a><br>
<a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-fortran</a><br></blockquote></div><br></div></div>