<div dir="ltr">Thanks for all of the feedback. I think Hammond and I should make a pass on the list and see if we can pare it down to address orthogonality and composability concerns. We'll move any info keys that we remove to the work in progress bin so that we don't lose them.<div>
<br></div><div> ~Jim.</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Dec 16, 2013 at 5:48 PM, Jeff Hammond <span dir="ltr"><<a href="mailto:jeff.science@gmail.com" target="_blank">jeff.science@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">MPI implementations should use JiT compilation to generate an optimal<br>
message queue for every possible usage. I am mostly joking, but isn't<br>
that possibility part of the rationale for the datatypes design?<br>
<br>
Jeff<br>
<br>
On Mon, Dec 16, 2013 at 4:44 PM, Jeff Squyres (jsquyres)<br>
<div class="HOEnZb"><div class="h5"><<a href="mailto:jsquyres@cisco.com">jsquyres@cisco.com</a>> wrote:<br>
> Just to re-iterate my concern from the info keys ticket discussion today...<br>
><br>
> I worry that we're making so many info keys:<br>
><br>
> a) we need to examine and make sure that they're all "mostly" (if not entirely) orthogonal from each other -- and then at least look at the implications of users asking for multiple of them in a single communicator. Jim (rightfully) pointed out that all the proposed ones are *likely* pretty orthogonal already; my point is that we should look through them and see if there are any unintended 2nd- or 3rd-level interactions when you compose various info key requests.<br>
><br>
> b) I think one possible/likely usage scenario is that a user will say "I don't use MPI semantics A-J on this communicator, so I'll ask for these 10 info keys." But assuming that the real win for each these info keys is actually *removing code* from the progress engine (vs. adding more "if" statements that could be costly because of a memory dereference), then an MPI implementation may have something like:<br>
><br>
> - a different progress engine for no-any-source<br>
> - a different progress engine for no-any-tag<br>
> - a different progress engine for no-any-source+no-any-tag<br>
> - ...and maybe a few others<br>
> - the default progress engine<br>
><br>
> So if you ask for N info keys, you actually don't get an optimized progress engine because there isn't one supports the particular N info keys that the user requested.<br>
><br>
> We all know that at least a bunch of the proposed info keys are well-known optimizations that would be great to expose. My question is asking whether this is the right way to expose them -- e.g., should we really present some kind of interface that shows which optimizations are available in what combinations, so that a user can ask for something that will actually result in a nice optimization/speedup/whatever, rather than "you asked for N things that I don't have a particular implementation for, so you just get the default progress engine." And it's basically a russian roulette game of picking subsets of N info keys -- apps have programatic way to know which combination will do something and which will not.<br>
><br>
> My point: is there a better way to do the composition of the various optimizations?<br>
><br>
><br>
><br>
><br>
> On Dec 16, 2013, at 12:07 PM, Jeff Hammond <<a href="mailto:jeff.science@gmail.com">jeff.science@gmail.com</a>> wrote:<br>
><br>
>> i will dial in now. sorry, didn't know it was happening.<br>
>><br>
>> On Mon, Dec 16, 2013 at 11:05 AM, Jeff Squyres (jsquyres)<br>
>> <<a href="mailto:jsquyres@cisco.com">jsquyres@cisco.com</a>> wrote:<br>
>>> Dan and I are on the webex -- is anyone else coming?<br>
>>><br>
>>> If not, we'll happily cede the time to the next meeting (Jan 13, 2014). :-)<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/" target="_blank">http://www.cisco.com/web/about/doing_business/legal/cri/</a><br>
>>><br>
>>> _______________________________________________<br>
>>> mpiwg-hybridpm mailing list<br>
>>> <a href="mailto:mpiwg-hybridpm@lists.mpi-forum.org">mpiwg-hybridpm@lists.mpi-forum.org</a><br>
>>> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm</a><br>
>><br>
>><br>
>><br>
>> --<br>
>> Jeff Hammond<br>
>> <a href="mailto:jeff.science@gmail.com">jeff.science@gmail.com</a><br>
>> _______________________________________________<br>
>> mpiwg-hybridpm mailing list<br>
>> <a href="mailto:mpiwg-hybridpm@lists.mpi-forum.org">mpiwg-hybridpm@lists.mpi-forum.org</a><br>
>> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm</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/" target="_blank">http://www.cisco.com/web/about/doing_business/legal/cri/</a><br>
><br>
> _______________________________________________<br>
> mpiwg-hybridpm mailing list<br>
> <a href="mailto:mpiwg-hybridpm@lists.mpi-forum.org">mpiwg-hybridpm@lists.mpi-forum.org</a><br>
> <a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm</a><br>
<br>
<br>
<br>
--<br>
Jeff Hammond<br>
<a href="mailto:jeff.science@gmail.com">jeff.science@gmail.com</a><br>
_______________________________________________<br>
mpiwg-hybridpm mailing list<br>
<a href="mailto:mpiwg-hybridpm@lists.mpi-forum.org">mpiwg-hybridpm@lists.mpi-forum.org</a><br>
<a href="http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm" target="_blank">http://lists.mpi-forum.org/mailman/listinfo.cgi/mpiwg-hybridpm</a><br>
</div></div></blockquote></div><br></div>