$extrastylesheet
petsc_diff_solver.h
Go to the documentation of this file.
00001 // The libMesh Finite Element Library.
00002 // Copyright (C) 2002-2014 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
00003 
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Lesser General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2.1 of the License, or (at your option) any later version.
00008 
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Lesser General Public License for more details.
00013 
00014 // You should have received a copy of the GNU Lesser General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00017 
00018 
00019 
00020 #ifndef LIBMESH_PETSC_DIFF_SOLVER_H
00021 #define LIBMESH_PETSC_DIFF_SOLVER_H
00022 
00023 #include "libmesh/libmesh_common.h"
00024 
00025 #ifdef LIBMESH_HAVE_PETSC
00026 
00027 // Local includes
00028 #include "libmesh/diff_solver.h"
00029 #include "libmesh/petsc_macro.h"
00030 
00031 // PETSc includes
00032 EXTERN_C_FOR_PETSC_BEGIN
00033 # include <petscsnes.h>
00034 EXTERN_C_FOR_PETSC_END
00035 
00036 // C++ includes
00037 
00038 namespace libMesh
00039 {
00040 
00052 // ------------------------------------------------------------
00053 // Solver class definition
00054 class PetscDiffSolver : public DiffSolver
00055 {
00056 public:
00061   explicit
00062   PetscDiffSolver (sys_type& system);
00063 
00067   virtual ~PetscDiffSolver ();
00068 
00069   typedef DiffSolver Parent;
00070 
00075   virtual void reinit ();
00076 
00081   void init ();
00082 
00087   void clear ();
00088 
00094   virtual unsigned int solve ();
00095 
00096 protected:
00097 
00101   SNES _snes;
00102 };
00103 
00104 } // namespace libMesh
00105 
00106 #endif // #ifdef LIBMESH_HAVE_PETSC
00107 
00108 #endif // LIBMESH_PETSC_DIFF_SOLVER_H