<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Mar 21, 2022, at 3:33 PM, Mark Adams <<a href="mailto:mfadams@lbl.gov" class="">mfadams@lbl.gov</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">(I did suggest CG, he just has a pressure solve, which is a Laplacian, right?)</div></div></blockquote><div><br class=""></div>   His finite volume scheme is finite difference-ish in that it produces a non-symmetric matrix. The non-symmetric part A-A' is actually very cool looking; one of the coolest matrices I've ever seen :-)</div><div><br class=""></div><div><img apple-inline="yes" id="CA36FCDA-21BF-412A-A182-987FC544BECB" width="532" height="480" src="cid:1DFDD7DB-C8EA-4A36-84D0-4AAF68E37342" class=""></div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">Ugh, this is pretty bad. The logic might be a bit convoluted, but if SetOperator is called after SetFromOptions, as is usual I think, it could check if it has left a left PC, if the operator has a null space.</div><div class=""><br class=""></div><div class=""><br class=""></div></div><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Mar 21, 2022 at 2:48 PM Barry Smith <<a href="mailto:bsmith@petsc.dev" class="">bsmith@petsc.dev</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="overflow-wrap: break-word;" class=""><div class=""><br class=""></div>  Marco,<div class=""><br class=""></div><div class="">     I have confirmed your results. </div><div class=""><br class=""></div><div class="">     Urgg, it appears we do not have something well documented. The removal of the null space only works for left preconditioned solvers and FGMRES only works with right preconditioning. Here is the reasoning. </div><div class=""><br class=""></div><div class="">     The Krylov space for left preconditioning is built from [r, BAr, (BA)^2 r, ...] and the solution space is built from this basis. If A has a null space of n then the left preconditioned Krylov methods simply remove n from the "full" Krylov space after applying each B preconditioner and the resulting "reduced" Krylov space has no components in the n directions hence the solution built by GMRES naturally has no component in the n.  </div><div class=""><br class=""></div><div class="">     But with right preconditioning the Krylov space is [s ABs (AB)^2 s, ....] We would need to remove B^-1 n from the Krylov space so that (A B) B^-1 n = 0 In general we don't have any way of applying B^-1 to a vector so we cannot create the appropriate "reduced" Krylov space. </div><div class=""><br class=""></div><div class="">     If I run with GMRES (which defaults to left preconditioner) and the options <span style="font-family:Menlo;font-size:14px" class="">./testPreconditioners -pc_type gamg -ksp_type gmres -ksp_monitor_true_residual -ksp_rtol 1.e-12 -ksp_view -mg_coarse_pc_type svd</span></div><div class=""><br class=""></div><div class=""><div class="">  Then  it handles the null space correctly and the solution has <span style="font-family:Menlo;font-size:14px" class="">Solution mean = 4.51028e-17</span></div><div class=""><font face="Menlo" class=""><span style="font-size:14px" class=""><br class=""></span></font></div><div class="">Is there any reason to use FGMRES instead of GMRES? You just cannot use GMRES as the smoother inside GAMG if you use GMRES on the outside, but for pressure equations you don't want use such a strong smoother anyways.</div><div class=""><br class=""></div><div class="">  Barry</div><div class=""><br class=""></div><div class="">  I feel we should add some information to the documentation on the removal of the null space to the user's manual when using right preconditioning and maybe even have an error check in the code so that people don't fall into this trap. But I am not sure exactly what to do. When the A and B are both symmetric I think special stuff happens that doesn't require providing a null space; but I am not sure. </div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""><blockquote type="cite" class=""><div class="">On Mar 21, 2022, at 12:41 PM, Marco Cisternino <<a href="mailto:marco.cisternino@optimad.it" target="_blank" class="">marco.cisternino@optimad.it</a>> wrote:</div><br class=""><div class=""><div style="font-family:Helvetica;font-size:18px;font-style:normal;font-variant-caps:normal;font-weight:normal;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;text-decoration:none" class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Thank you, Mark.<br class="">However, doing this with my toy code<u class=""></u><u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">mpirun -n 1 ./testpreconditioner -pc_type gamg -pc_gamg_use_parallel_coarse_grid_solver -mg_coarse_pc_type jacobi -mg_coarse_ksp_type cg<u class=""></u><u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""><u class=""></u> <u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">I get 16 inf elements. Do I miss anything?<u class=""></u><u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""><u class=""></u> <u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Thanks again<u class=""></u><u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""><u class=""></u> <u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span lang="IT" style="font-family:"Mulish Medium"" class="">Marco Cisternino</span><span lang="IT" class=""><u class=""></u><u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span lang="IT" class=""><u class=""></u> <u class=""></u></span></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""><u class=""></u> <u class=""></u></span></div><div style="border-style:solid none none;border-top-width:1pt;border-top-color:rgb(225,225,225);padding:3pt 0cm 0cm" class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><b class=""><span lang="EN-US" class="">From:</span></b><span lang="EN-US" class=""><span class=""> </span>Mark Adams <<a href="mailto:mfadams@lbl.gov" style="color:blue;text-decoration:underline" target="_blank" class="">mfadams@lbl.gov</a>><span class=""> </span><br class=""><b class="">Sent:</b><span class=""> </span>lunedì 21 marzo 2022 17:31<br class=""><b class="">To:</b><span class=""> </span>Marco Cisternino <<a href="mailto:marco.cisternino@optimad.it" style="color:blue;text-decoration:underline" target="_blank" class="">marco.cisternino@optimad.it</a>><br class=""><b class="">Cc:</b><span class=""> </span><a href="mailto:petsc-users@mcs.anl.gov" style="color:blue;text-decoration:underline" target="_blank" class="">petsc-users@mcs.anl.gov</a><br class=""><b class="">Subject:</b><span class=""> </span>Re: [petsc-users] Null space and preconditioners<u class=""></u><u class=""></u></span></div></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">And for GAMG you can use:<u class=""></u><u class=""></u></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">-pc_gamg_use_parallel_coarse_grid_solver -mg_coarse_pc_type jacobi -mg_coarse_ksp_type cg<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">Note if you are using more that one MPI process you can use 'lu' instead of 'jacobi'<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">If GAMG converges fast enough it can solve before the constant creeps in and works without cleaning in the KSP method.<u class=""></u><u class=""></u></div></div></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div><div class=""><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">On Mon, Mar 21, 2022 at 12:06 PM Mark Adams <<a href="mailto:mfadams@lbl.gov" style="color:blue;text-decoration:underline" target="_blank" class="">mfadams@lbl.gov</a>> wrote:<u class=""></u><u class=""></u></div></div><blockquote style="border-style:none none none solid;border-left-width:1pt;border-left-color:rgb(204,204,204);padding:0cm 0cm 0cm 6pt;margin-left:4.8pt;margin-right:0cm" class=""><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">The solution for Neumann problems can "float away" if the constant is not controlled in some way because floating point errors can introduce it even if your RHS is exactly orthogonal to it.<u class=""></u><u class=""></u></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">You should use a special coarse grid solver for GAMG but it seems to be working for you.<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">I have lost track of the simply way to have the KSP solver clean the constant out, which is what you want.<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">can someone help Marco?<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">Mark<u class=""></u><u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div></div></div></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><u class=""></u> <u class=""></u></div><div class=""><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class="">On Mon, Mar 21, 2022 at 8:18 AM Marco Cisternino <<a href="mailto:marco.cisternino@optimad.it" style="color:blue;text-decoration:underline" target="_blank" class="">marco.cisternino@optimad.it</a>> wrote:<u class=""></u><u class=""></u></div></div><blockquote style="border-style:none none none solid;border-left-width:1pt;border-left-color:rgb(204,204,204);padding:0cm 0cm 0cm 6pt;margin-left:4.8pt;margin-right:0cm" class=""><div class=""><div class=""><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Good morning,</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">I’m observing an unexpected (to me) behaviour of my code.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">I tried to reduce the problem in a toy code here attached.<br class="">The toy code archive contains a small main, a matrix and a rhs.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">The toy code solves the linear system and check the norms and the mean of the solution.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">The problem into the matrix and the rhs is the finite volume discretization of the pressure equation of an incompressible NS solver.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">It has been cooked as tiny as possible (16 cells!).</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">It is important to say that it is an elliptic problem with homogeneous Neumann boundary conditions only, for this reason the toy code sets a null space containing the constant.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""> </span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">The unexpected (to me) behaviour is evident by launching the code using different preconditioners, using -pc-type <pctype><br class="">I tested using PCNONE (“none”), PCGAMG (“gamg”) and PCILU (“ilu”). The default solver is KSPFGMRES.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Using the three PC, I get 3 different solutions. It seems to me that they differ in the mean value, but GAMG is impressive.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">PCNONE gives me the zero mean solution I expected. What about the others?</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""> </span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Asking for residuals monitor, the ratio ||r||/||b|| shows convergence for PCNONE and PCILU (~10^-16), but it stalls for PCGAMG (~10^-4).</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">I cannot see why. Am I doing anything wrong or incorrectly thinking about the expected behaviour?</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""> </span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Generalizing to larger mesh the behaviour is similar.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""> </span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class="">Thank you for any help.</span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Light",serif" class=""> </span><u class=""></u><u class=""></u></div><div style="margin:0cm;font-size:11pt;font-family:Calibri,sans-serif" class=""><span style="font-family:"Mulish Medium"" class="">Marco Cisternino</span></div></div></div></blockquote></div></blockquote></div></div></div></blockquote></div><br class=""></div></div></blockquote></div>
</div></blockquote></div><br class=""></body></html>