<div dir="ltr"><div dir="ltr">On Sun, Mar 3, 2019 at 4:06 PM Appel, Thibaut via petsc-users <<a href="mailto:petsc-users@mcs.anl.gov">petsc-users@mcs.anl.gov</a>> wrote:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Assuming you preallocate/assemble a MPIAIJ matrix “by hand” using a ISLocalToGlobalMapping object obtained from DMDA: what’s the easiest way to get global column indices that do not belong to a process? <br>
<br>
Say, if you have a finite-difference stencil and the stencil exceeds the portion owned by the process.<br>
<br>
I think the way to go is to preallocate a MPIAIJ matrix using local information with MatPreallocateSetLocal and then fill values with MatSetLocal, those routines can’t work with rows/columns not owned by the process right?<br></blockquote><div><br></div><div>I can't quite understand what you want. Are you saying:</div><div><br></div><div>  Suppose I create a LocalToGlobalMapping, but I still want to set values on another process that are not in my map?</div><div><br></div><div>If you have no other structure, then you just need to know the global indices for the element. It sounds like then you</div><div>say, if I am using a DMDA and I declare a stencil width of s, but want to set value for point greater than s away from</div><div>the block I own, can I determine those indices? Yes, its just a pain. You can get everything you need from DMDAInfo</div><div>and DMDALocalInfo, but we have no function to do it.</div><div><br></div><div>   Matt</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">
Thank you,<br>
<br>
Thibaut</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div><div dir="ltr"><div>What most experimenters take for granted before they begin their experiments is infinitely more interesting than any results to which their experiments lead.<br>-- Norbert Wiener</div><div><br></div><div><a href="http://www.cse.buffalo.edu/~knepley/" target="_blank">https://www.cse.buffalo.edu/~knepley/</a><br></div></div></div></div></div></div></div></div>