<head><!-- BaNnErBlUrFlE-HeAdEr-start -->
<style>
  #pfptBannerynv24bx { all: revert !important; display: block !important; 
    visibility: visible !important; opacity: 1 !important; 
    background-color: #D0D8DC !important; 
    max-width: none !important; max-height: none !important }
  .pfptPrimaryButtonynv24bx:hover, .pfptPrimaryButtonynv24bx:focus {
    background-color: #b4c1c7 !important; }
  .pfptPrimaryButtonynv24bx:active {
    background-color: #90a4ae !important; }
</style>

<!-- BaNnErBlUrFlE-HeAdEr-end -->
</head><!-- BaNnErBlUrFlE-BoDy-start -->
<!-- Preheader Text : BEGIN -->
<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">
 On Fri, Mar 1, 2024 at 10: 28 AM Fabian Wermelinger <fab4100@ posteo. ch> wrote: Dear All, I am implementing a linear solver interface in a flow solver with support for PETSc. My application uses a parallel CSR representation and it manages
</div>
<!-- Preheader Text : END -->

<!-- Email Banner : BEGIN -->
<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">ZjQcmQRYFpfptBannerStart</div>

<!--[if ((ie)|(mso))]>
  <table border="0" cellspacing="0" cellpadding="0" width="100%" style="padding: 16px 0px 16px 0px; direction: ltr" ><tr><td>
    <table border="0" cellspacing="0" cellpadding="0" style="padding: 0px 10px 5px 6px; width: 100%; border-radius:4px; border-top:4px solid #90a4ae;background-color:#D0D8DC;"><tr><td valign="top">
      <table align="left" border="0" cellspacing="0" cellpadding="0" style="padding: 4px 8px 4px 8px">
        <tr><td style="color:#000000; font-family: 'Arial', sans-serif; font-weight:bold; font-size:14px; direction: ltr">
          This Message Is From an External Sender
        </td></tr>
        <tr><td style="color:#000000; font-weight:normal; font-family: 'Arial', sans-serif; font-size:12px; direction: ltr">
          This message came from outside your organization.
        </td></tr>

      </table>

    </td></tr></table>
  </td></tr></table>
<![endif]-->

<![if !((ie)|(mso))]>
  <div dir="ltr"  id="pfptBannerynv24bx" style="all: revert !important; display:block !important; text-align: left !important; margin:16px 0px 16px 0px !important; padding:8px 16px 8px 16px !important; border-radius: 4px !important; min-width: 200px !important; background-color: #D0D8DC !important; background-color: #D0D8DC; border-top: 4px solid #90a4ae !important; border-top: 4px solid #90a4ae;">
    <div id="pfptBannerynv24bx" style="all: unset !important; float:left !important; display:block !important; margin: 0px 0px 1px 0px !important; max-width: 600px !important;">
      <div id="pfptBannerynv24bx" style="all: unset !important; display:block !important; visibility: visible !important; background-color: #D0D8DC !important; color:#000000 !important; color:#000000; font-family: 'Arial', sans-serif !important; font-family: 'Arial', sans-serif; font-weight:bold !important; font-weight:bold; font-size:14px !important; line-height:18px !important; line-height:18px">
        This Message Is From an External Sender
      </div>
      <div id="pfptBannerynv24bx" style="all: unset !important; display:block !important; visibility: visible !important; background-color: #D0D8DC !important; color:#000000 !important; color:#000000; font-weight:normal; font-family: 'Arial', sans-serif !important; font-family: 'Arial', sans-serif; font-size:12px !important; line-height:18px !important; line-height:18px; margin-top:2px !important;">
This message came from outside your organization.
      </div>

    </div>

    <div style="clear: both !important; display: block !important; visibility: hidden !important; line-height: 0 !important; font-size: 0.01px !important; height: 0px"> </div>
  </div>
<![endif]>

<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">ZjQcmQRYFpfptBannerEnd</div>
<!-- Email Banner : END -->

<!-- BaNnErBlUrFlE-BoDy-end -->
<div dir="ltr"><div dir="ltr"><br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Mar 1, 2024 at 10:28 AM Fabian Wermelinger <<a href="mailto:fab4100@posteo.ch">fab4100@posteo.ch</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 class="msg-8377303523939057983"><u></u>


<div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">
 Dear All, I am implementing a linear solver interface in a flow solver with support for PETSc. My application uses a parallel CSR representation and it manages the memory for it. I would like to wrap PETSc matrices (and vectors) around it such
</div>



<div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">ZjQcmQRYFpfptBannerStart</div>



<u></u>
  <div dir="ltr" id="m_-8377303523939057983pfptBannerftj3wpq" style="display:block;text-align:left;margin:16px 0px;padding:8px 16px;border-radius:4px;min-width:200px;background-color:rgb(208,216,220);border-top:4px solid rgb(144,164,174)">
    <div id="m_-8377303523939057983pfptBannerftj3wpq" style="float:left;display:block;margin:0px 0px 1px;max-width:600px">
      <div id="m_-8377303523939057983pfptBannerftj3wpq" style="display:block;background-color:rgb(208,216,220);color:rgb(0,0,0);font-family:Arial,sans-serif;font-weight:bold;font-size:14px;line-height:18px">
        This Message Is From an External Sender
      </div>
      <div id="m_-8377303523939057983pfptBannerftj3wpq" style="font-weight:normal;display:block;background-color:rgb(208,216,220);color:rgb(0,0,0);font-family:Arial,sans-serif;font-size:12px;line-height:18px;margin-top:2px">
This message came from outside your organization.
      </div>

    </div>

    <div style="height:0px;clear:both;display:block;line-height:0;font-size:0.01px"> </div>
  </div>
<u></u>

<div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">ZjQcmQRYFpfptBannerEnd</div>








<div><pre style="font-family:sans-serif;font-size:100%;white-space:pre-wrap">Dear All,

I am implementing a linear solver interface in a flow solver with support for
PETSc.  My application uses a parallel CSR representation and it manages the
memory for it.  I would like to wrap PETSc matrices (and vectors) around it such
that I can use the PETSc solvers as well.  I plan to use
MatMPIBAIJSetPreallocationCSR and VecCreateMPIWithArray for lightweight
wrapping.  The matrix structure is static over the course of iterations.  I am
using a derived context class to host the PETSc related context.  This context
holds references to the PETSc matrix and vectors and KSP/PC required to call the
solver API later in the iteration loop.  I would like to create as much as
possible during creation of the context at the beginning of iterations (the
context will live through iterations).

My understanding is that MatMPIBAIJSetPreallocationCSR and VecCreateMPIWithArray
DO NOT copy such that I can wrap the PETSc types around the memory managed by
the hosting linear solver framework in the application.  The system matrix and
RHS (the pointers to these arrays are passed to MatMPIBAIJSetPreallocationCSR
and VecCreateMPIWithArray, respectively) is assembled by the application before
any call to a linear solver.

Given this setting: for every iteration, my plan is the PETSc information from
the context (Mat, Vec, KSP) and simply call KSPSolve without any other PETSc
calls (still assuming the matrix structure is static during iteration).

What is not clear to me:

Are there any MatSetValues/VecSetValues calls followed by
MatAssembly/VecAssembly(Begin/End) calls required for this setting?  </pre></div></div></blockquote><div>I don't believe so. </div><div>You are doing the assembly. </div><div>If you want to tell PETSc (KSP) that you changed the matrix so that it will re-setup the solvers (eg, refactor) then you can call KSPSetOperators.</div><div>(You might want to increment the state of the Mat so that other things like TS know the state has changed, maybe that is all that you need to do)</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 class="msg-8377303523939057983"><div><pre style="font-family:sans-serif;font-size:100%;white-space:pre-wrap">The data in
the arrays for which pointers have been passed to MatMPIBAIJSetPreallocationCSR
and VecCreateMPIWithArray is computed prior to any solver call in an iteration,
such that I am assuming no additional "set value" calls through PETSc are
required -> am I missing something important by assuming this?</pre></div></div></blockquote><div>That sounds fine, but keep in mind that you need to use our data layout for the blocks if you use our MatVec, etc.</div><div><br></div><div>Thanks,</div><div>Mark</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 class="msg-8377303523939057983"><div><pre style="font-family:sans-serif;font-size:100%;white-space:pre-wrap">Thank you for taking the time!

-- 
fabs
</pre></div>
</div></blockquote></div></div>