nonlinear_solver.C
Go to the documentation of this file.00001 // The libMesh Finite Element Library. 00002 // Copyright (C) 2002-2012 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 // C++ includes 00021 00022 // Local Includes 00023 #include "libmesh/nonlinear_solver.h" 00024 #include "libmesh/petsc_nonlinear_solver.h" 00025 #include "libmesh/petsc_dm_nonlinear_solver.h" 00026 #include "libmesh/trilinos_nox_nonlinear_solver.h" 00027 #include "libmesh/auto_ptr.h" 00028 00029 namespace libMesh 00030 { 00031 00032 00033 //------------------------------------------------------------------ 00034 // NonlinearSolver members 00035 #if defined(LIBMESH_HAVE_PETSC) || defined(LIBMESH_HAVE_NOX) 00036 template <typename T> 00037 AutoPtr<NonlinearSolver<T> > 00038 NonlinearSolver<T>::build(sys_type& s, const SolverPackage solver_package) 00039 { 00040 AutoPtr<NonlinearSolver<T> > ap; 00041 00042 // Build the appropriate solver 00043 switch (solver_package) 00044 { 00045 00046 #ifdef LIBMESH_HAVE_PETSC 00047 case PETSC_SOLVERS: 00048 #if PETSC_VERSION_LESS_THAN(3,3,0) 00049 ap.reset(new PetscNonlinearSolver<T>(s)); 00050 break; 00051 #else 00052 if (libMesh::on_command_line ("--use-petsc-dm")){ 00053 ap.reset(new PetscDMNonlinearSolver<T>(s)); 00054 } 00055 else { 00056 ap.reset(new PetscNonlinearSolver<T>(s)); 00057 } 00058 break; 00059 #endif 00060 #endif // LIBMESH_HAVE_PETSC 00061 00062 #ifdef LIBMESH_HAVE_NOX 00063 case TRILINOS_SOLVERS: 00064 ap.reset(new NoxNonlinearSolver<T>(s)); 00065 break; 00066 #endif 00067 00068 default: 00069 libMesh::err << "ERROR: Unrecognized solver package: " 00070 << solver_package 00071 << std::endl; 00072 libmesh_error(); 00073 } 00074 00075 return ap; 00076 } 00077 #else // LIBMESH_HAVE_PETSC || LIBMESH_HAVE_NOX 00078 template <typename T> 00079 AutoPtr<NonlinearSolver<T> > 00080 NonlinearSolver<T>::build(sys_type&, const SolverPackage) 00081 { 00082 libMesh::err << "ERROR: libMesh was compiled without nonlinear solver support" 00083 << std::endl; 00084 libmesh_not_implemented(); 00085 } 00086 #endif 00087 00088 00089 template <typename T> 00090 void 00091 NonlinearSolver<T>::attach_preconditioner(Preconditioner<T> * preconditioner) 00092 { 00093 if(this->_is_initialized) 00094 { 00095 libMesh::err << "Preconditioner must be attached before the solver is initialized!"<<std::endl; 00096 libmesh_error(); 00097 } 00098 00099 _preconditioner = preconditioner; 00100 } 00101 00102 00103 //------------------------------------------------------------------ 00104 // Explicit instantiations 00105 template class NonlinearSolver<Number>; 00106 00107 } // namespace libMesh 00108 00109 00110
Site Created By: libMesh Developers
Last modified: February 05 2013 19:54:48 UTC
Hosted By: