$extrastylesheet
explicit_system.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_EXPLICIT_SYSTEM_H
00021 #define LIBMESH_EXPLICIT_SYSTEM_H
00022 
00023 // Local Includes
00024 #include "libmesh/system.h"
00025 
00026 // C++ includes
00027 
00028 namespace libMesh
00029 {
00030 
00031 
00032 // Forward Declarations
00033 
00034 
00043 // ------------------------------------------------------------
00044 // ExplicitSystem class definition
00045 
00046 class ExplicitSystem : public System
00047 {
00048 public:
00049 
00054   ExplicitSystem (EquationSystems& es,
00055                   const std::string& name,
00056                   const unsigned int number);
00057 
00061   ~ExplicitSystem ();
00062 
00066   typedef ExplicitSystem sys_type;
00067 
00071   typedef System Parent;
00072 
00076   sys_type & system () { return *this; }
00077 
00082   virtual void clear ();
00083 
00088   virtual void reinit ();
00089 
00095   virtual void assemble_qoi
00096   (const QoISet& qoi_indices = QoISet());
00097 
00103   virtual void assemble_qoi_derivative
00104   (const QoISet &qoi_indices = QoISet(),
00105    bool include_liftfunc = true,
00106    bool apply_constraints = true);
00107 
00111   virtual void solve ();
00112 
00117   virtual std::string system_type () const { return "Explicit"; }
00118 
00124   NumericVector<Number> * rhs;
00125 
00126 
00127 protected:
00128 
00129 
00134   virtual void init_data ();
00135 
00136 
00137 private:
00138 
00139 
00144   void add_system_rhs ();
00145 };
00146 
00147 
00148 
00149 // ------------------------------------------------------------
00150 // ExplicitSystem inline methods
00151 
00152 } // namespace libMesh
00153 
00154 
00155 #endif // LIBMESH_EXPLICIT_SYSTEM_H