[petsc-users] Matlab gets a different solution to Petsc

Matthew Knepley knepley at gmail.com
Tue Jul 8 03:44:46 CDT 2014


On Tue, Jul 8, 2014 at 8:28 AM, Andrew Cramer <andrewdalecramer at gmail.com>
wrote:

> Doing a basic cantilever bending problem to test my code which results in
> the linear system Au = b.
>
>  - Using DMDA for the domain and KSPSetComputeOperators
>  - Solving it using various methods in petsc gets similar (within 1%)
> solutions
>  - Even using -pc_type lu
>  - Using KSPGetOperators and KSPGetRhs to export to matlab
>
> Exporting the matrix and and the rhs, importing them into matlab  and
> solving with backslash gives a solution which matches the Euler-Bernoulli
> beam model much closer (0.4% error vs 9.6%).
>

As Karl says, this is probably truncation error, but more to the point this
is accidental. You would not expect
a solution that is more accurate than the discretization error. If you are
comparing a discrete solution to a
continuous solution, you want to look at "mesh convergence" meaning that
you run on a series of refined
meshes, calculate the error, and usually plot log(error) against mesh size
h.

    Matt


> Calculating the residual of petsc's solution using matlab (
> norm(A*u-b)/norm(b)) I get 0.3 having solved with -pc_type lu.
>
> Is there a way I could have accidentally made petsc solve a different
> problem to Ax=b? I've been looking at this code for a while now (days) and
> can't seem to figure out what is wrong.
>



-- 
What most experimenters take for granted before they begin their
experiments is infinitely more interesting than any results to which their
experiments lead.
-- Norbert Wiener
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20140708/a3cd2a76/attachment.html>


More information about the petsc-users mailing list