<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, May 7, 2019 at 11:38 AM GIRET Jean-Christophe via petsc-users <<a href="mailto:petsc-users@mcs.anl.gov">petsc-users@mcs.anl.gov</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">





<div lang="FR">
<div class="gmail-m_5400229876258405851WordSection1">
<p class="MsoNormal"><span lang="EN-US">Dear PETSc users,<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US">I would like to use Petsc4Py for a project extension, which consists mainly of:<u></u><u></u></span></p>
<p class="gmail-m_5400229876258405851MsoListParagraph" style="margin-left:27pt">
<u></u><span lang="EN-US"><span>-<span style="font:7pt "Times New Roman"">         
</span></span></span><u></u><span lang="EN-US">Storing data and matrices on several rank/nodes which could not fit on a single node.<u></u><u></u></span></p>
<p class="gmail-m_5400229876258405851MsoListParagraph" style="margin-left:27pt">
<u></u><span lang="EN-US"><span>-<span style="font:7pt "Times New Roman"">         
</span></span></span><u></u><span lang="EN-US">Performing some linear algebra in a parallel fashion (solving sparse linear system for instance)<u></u><u></u></span></p>
<p class="gmail-m_5400229876258405851MsoListParagraph" style="margin-left:27pt">
<u></u><span lang="EN-US"><span>-<span style="font:7pt "Times New Roman"">         
</span></span></span><u></u><span lang="EN-US">Exchanging those data structures (parallel vectors) between non-overlapping MPI communicators, created for instance by splitting MPI_COMM_WORLD.<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US">While the two first items seems to be well addressed by PETSc, I am wondering about the last one.<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US">Is it possible to access the data of a vector, defined on a communicator from another, non-overlapping communicator? From what I have seen from the documentation and the several threads on the user mailing-list, I would
 say no. But maybe I am missing something? If not, is it possible to transfer a vector defined on a given communicator on a communicator which is a subset of the previous one?</span></p></div></div></blockquote><div><br></div><div>If you are sending to a subset of processes then VecGetSubVec + Jed's tricks might work.</div><div><br></div><div><a href="https://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Vec/VecGetSubVector.html">https://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Vec/VecGetSubVector.html</a><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div lang="FR"><div class="gmail-m_5400229876258405851WordSection1"><p class="MsoNormal"><span lang="EN-US">
<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US">Best regards, <u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US">Jean-Christophe<u></u><u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
<p class="MsoNormal"><span lang="EN-US"><u></u> <u></u></span></p>
</div>
</div>

</blockquote></div></div>