<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Wed, Aug 6, 2014 at 5:55 PM, Justin Chang <span dir="ltr"><<a href="mailto:jychang48@gmail.com" target="_blank">jychang48@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div><div><div>Hi,<br><br>So in ex62 of SNES it solves the stokes equation with P2-P1 elements. I want to solve the darcy equation with P2-P1 elements in a similar fashion.<br>
<br></div>The difference between stokes and darcy is that in the weak form of darcy, the velocity-velocity term is v*u whereas in stokes it's grad[v]*grad[u]<br>
<br></div>In ex62, the function g3_uu (lines 172-183) formulates the grad[v]*grad[u] term but how would I do it for Darcy's equation where its simply v*u (assuming drag coefficient is scalar quantity of 1.0)? <br></div>
</div></blockquote><div><br></div><div>So you would want to define g0 instead of g3, since its the u-u term:</div><div><br></div><div><div>void g0_uu(const PetscScalar u[], const PetscScalar u_t[], const PetscScalar u_x[], const PetscScalar a[], const PetscScalar a_t[], const PetscScalar a_x[], const PetscReal x[], PetscScalar g3[])</div>
<div>{</div><div>  const PetscInt Ncomp = spatialDim;<br></div><div>  PetscInt       compI;</div><div><br></div><div>  for (compI = 0; compI < Ncomp; ++compI) g0[compI] = u[compI];</div><div>}</div></div><div><br></div>
<div>and then register it in SetupProblem:</div><div><br></div><div><div>  ierr = PetscDSSetJacobian(prob, 0, 0, g0_uu, NULL,  NULL,  NULL);CHKERRQ(ierr);</div></div><div><br></div><div>and do not forget to change the residual definition in f0/f1.</div>
<div><br></div><div>  Thanks,</div><div><br></div><div>     Matt</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div dir="ltr"><div>
</div>Thanks,<br>Justin<br></div>
</blockquote></div><br><br clear="all"><div><br></div>-- <br>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>