<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<div dir="ltr">
<div dir="ltr">
<div dir="ltr">
<div dir="ltr">
<div dir="ltr">Yingjie:<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">
<div dir="ltr">
<div>Dear Petsc developers:</div>
<div>Hi,</div>
<div>I am currently using Petsc to solve a two-dimensional system of non-linear PDEs, which is a thermal problem, including pressure field, temperature field and velocity field. Since it is not easy to construct Jacobian matrix explicitly, I adopt snes_mf method
and provide a preconditioning matrix. Now I want to adapt the program to parallel version.</div>
<div>The main steps of the current procedure are as fellows:</div>
<div>
<ul>
<li>A solution vector U is constructed. The dimension is the sum of the meshed of each physical field.</li><li>FormFunction is provided to calculate residual.</li><li>Preconditioning matrix Pmat is assembled using FormJacibian, but Amat (Jacobian matrix) is not assembled. </li><li>Compute with -snes_mf_operator.</li></ul>
There are following questions about the development of parallel version:</div>
<div>
<ol>
<li>If one processor is assigned to each physical field, such as pressure field P,velocity field V, temperature field T, belongs to three processors. Because the problem is nonlinear, the information of temperature T may be used in the calculation of pressure
P(in FormFunction). How to transfer the information?</li></ol>
</div>
</div>
</blockquote>
<div>Parallelization should be done to the domain, not physic components. See example petsc/src/snes/examples/tutorials/ex19.c </div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr">
<div>
<ol>
<li>Since the snes_mf method needs a good preconditioning matrix to ensure convergence. How to use preconditioning matrix in parallel? As far as I know, BJACOBI can run in parallel. How can it be used in snes_mf method?</li></ol>
</div>
</div>
</blockquote>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div dir="ltr">
<div>Because there are few snes_mf examples with parallel computation, I need some advice from you.</div>
</div>
</blockquote>
<div>petsc/src/snes/examples/tutorials/ex19.c incudes a test on '-snes_mf_operator':</div>
<div>...</div>
<div>
<div>test:</div>
<div> suffix: 13</div>
<div> nsize: 3</div>
<div> args: -snes_monitor_short -ksp_monitor_short -pc_type fieldsplit -pc_fieldsplit_type multiplicative -snes_view -da_refine 1 -ksp_type fgmres -snes_mf_operator</div>
</div>
<div><br>
</div>
<div>Hong</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>