⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 equation_systems.h

📁 一个用来实现偏微分方程中网格的计算库
💻 H
📖 第 1 页 / 共 2 页
字号:
// $Id: equation_systems.h 2789 2008-04-13 02:24:40Z roystgnr $// The libMesh Finite Element Library.// Copyright (C) 2002-2007  Benjamin S. Kirk, John W. Peterson  // This library is free software; you can redistribute it and/or// modify it under the terms of the GNU Lesser General Public// License as published by the Free Software Foundation; either// version 2.1 of the License, or (at your option) any later version.  // This library is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU// Lesser General Public License for more details.  // You should have received a copy of the GNU Lesser General Public// License along with this library; if not, write to the Free Software// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA#ifndef __equation_systems_h__#define __equation_systems_h__// C++ includes#include <set>#include <map>#include <vector>#include <string>// Local Includes#include "libmesh_common.h"#include "parameters.h"#include "system.h"#include "enum_xdr_mode.h"// HP aCC needs these for some reason#ifdef __HP_aCC# include "frequency_system.h"# include "transient_system.h"# include "newmark_system.h"# include "steady_system.h"#endif// Forward Declarationsclass MeshData;class Elem;class MeshBase;/** * This is the \p EquationSystems class.  It is in charge * of handling all the various equation systems defined * for a \p MeshBase.  It may have multiple systems, which may * be active or inactive, so that at different solution * stages only a sub-set may be solved for.  Also, through * the templated access, @e different types of systems * may be handled.  Also other features, like flags,  * parameters, I/O etc are provided. * * @author Benjamin S. Kirk, 2002-2007 */// ------------------------------------------------------------// EquationSystems class definitionclass EquationSystems{public:  /**   * Define enumeration to set properties in EquationSystems::read()   */  enum ReadFlags { READ_HEADER           = 1,                   READ_DATA             = 2,                   READ_ADDITIONAL_DATA  = 4,                   READ_LEGACY_FORMAT    = 8 };  /**   * Define enumeration to set properties in EquationSystems::write()   */  enum WriteFlags { WRITE_DATA             = 1,                    WRITE_ADDITIONAL_DATA  = 2,                    WRITE_PARALLEL_FILES   = 4 };    /**   * Constructor.   */  EquationSystems (MeshBase& mesh, MeshData* mesh_data=NULL);  /**   * Destructor.  Should be virtual, since the user may want to derive   * subclasses of EquationSystems.   */  virtual ~EquationSystems ();   /**   * Returns tha data structure to a pristine state.   */  void clear ();    /**   * Initialize all the systems   */  void init ();    /**   * Reinitialize all the systems   */  void reinit ();  /**   * Updates local values for all the systems   */  void update ();  /**   * @returns the number of equation systems.   */  unsigned int n_systems() const;  /**   * @returns true if the system named \p name exists within   * this EquationSystems object.   */  bool has_system (const std::string& name) const;  /**   * @returns a constant reference to the system named \p name.   * The template argument defines the return type.  For example,   * const SteadySystem& sys = eq.get_system<SteadySystem> ("sys");   * is an example of how the method might be used   */  template <typename T_sys>  const T_sys & get_system (const std::string& name) const;  /**   * @returns a writeable referene to the system named \p name.   * The template argument defines the return type.  For example,   * const SteadySystem& sys = eq.get_system<SteadySystem> ("sys");   * is an example of how the method might be used   */  template <typename T_sys>  T_sys & get_system (const std::string& name);  /**   * @returns a constant reference to system number \p num.   * The template argument defines the return type.  For example,   * const SteadySystem& sys = eq.get_system<SteadySystem> (0);   * is an example of how the method might be used   */  template <typename T_sys>  const T_sys & get_system (const unsigned int num) const;  /**   * @returns a writeable referene to the system number \p num.   * The template argument defines the return type.  For example,   * const SteadySystem& sys = eq.get_system<SteadySystem> (0);   * is an example of how the method might be used   */  template <typename T_sys>  T_sys & get_system (const unsigned int num);  /**   * @returns a constant reference to the system named \p name.   */  const System & get_system (const std::string& name) const;  /**   * @returns a writeable referene to the system named \p name.   */  System & get_system (const std::string& name);  /**   * @returns a constant reference to system number \p num.   */  const System & get_system (const unsigned int num) const;  /**   * @returns a writeable referene to the system number \p num.   */  System & get_system (const unsigned int num);    /**   * Add the system of type \p system_type named \p name to the   * systems array.   */  System & add_system (const std::string& system_type,		       const std::string& name);    /**   * Add the system named \p name to the systems array.   */  template <typename T_sys>  T_sys & add_system (const std::string& name);    /**   * Remove the system named \p name from the systems array.   * This function is now deprecated - write the   * libmesh-devel mailing list if you need it reimplemented.   */  void delete_system (const std::string& name);  /**   * @returns the total number of variables in all   * systems.   */  unsigned int n_vars () const;    /**   * @returns the total number of degrees of freedom   * in all systems.   */  unsigned int n_dofs () const;  /**   * Returns the number of active degrees of freedom   * for the EquationSystems object.   */  unsigned int n_active_dofs() const;    /**   * Call \p solve on all the individual equation systems.   *   * By default this function solves each equation system once,   * in the order they were added.  For more sophisticated decoupled   * problems the user may with to override this behavior in a derived   * class.   */  virtual void solve ();    /**   * Fill the input vector \p var_names with the names   * of the variables for each system.   */  void build_variable_names (std::vector<std::string>& var_names) const;  /**   * Fill the input vector \p soln with the solution values for the   * system named \p name.  Note that the input   * vector \p soln will only be assembled on processor 0, so this   * method is only applicable to outputting plot files from processor 0.   */  void build_solution_vector (std::vector<Number>& soln,                              const std::string& system_name,                              const std::string& variable_name = "all_vars") const;    /**   * Fill the input vector \p soln with solution values.  The   * entries will be in variable-major format (corresponding to   * the names from \p build_variable_names()).   */  void build_solution_vector (std::vector<Number>& soln) const;    /**   * Fill the input vector \p soln with solution values.  The   * entries will be in variable-major format (corresponding to   * the names from \p build_variable_names()).   */  void build_discontinuous_solution_vector (std::vector<Number>& soln) const;    /**   * Read & initialize the systems from disk using the XDR data format.   * This format allows for machine-independent binary output.   *   * Set which sections of the file to read by bitwise OR'ing the    * EquationSystems::ReadFlags enumeration together. For example, to    * read all sections of the file, set read_flags to:   * (READ_HEADER | READ_DATA | READ_ADDITIONAL_DATA)   *   * Note that the equation system can be defined without initializing   * the data vectors to any solution values.  This can be done   * by omitting READ_DATA in the read_flags parameter.   */  void read (const std::string& name,	     const libMeshEnums::XdrMODE,             const unsigned int read_flags=(READ_HEADER | READ_DATA));  /**   * Write the systems to disk using the XDR data format.   * This format allows for machine-independent binary output.   *   * Set the writing properties using the EquationSystems::WriteFlags   * enumeration. Set which sections to write out by bitwise OR'ing   * the enumeration values. Write everything by setting write_flags to:   * (WRITE_DATA | WRITE_ADDITIONAL_DATA)   *   * Note that the solution data can be omitted by calling   * this routine with WRITE_DATA omitted in the write_flags argument.   */  void write (const std::string& name,	      const libMeshEnums::XdrMODE,              const unsigned int write_flags=(WRITE_DATA)) const;  /**   * @returns \p true when this equation system contains   * identical data, up to the given threshold.  Delegates   * most of the comparisons to perform to the responsible   * systems   */  bool compare (const EquationSystems& other_es,                 const Real threshold,                const bool verbose) const;  /**   * @returns a string containing information about the   * systems, flags, and parameters.   */  std::string get_info() const;      /**   * Prints information about the equation systems.   */  void print_info (std::ostream& os=std::cout) const;  /**   * Same as above, but allows you to also use stream syntax.   */  friend std::ostream& operator << (std::ostream& os, const EquationSystems& es);  /**   * @returns a constant reference to the mesh   */  const MeshBase & get_mesh() const;  /**   * @returns a reference to the mesh   */  MeshBase & get_mesh();  /**   * @returns true when the _mesh_data pointer is not NULL.   * This is needed because get_mesh_data will fail if it is NULL   */  bool has_mesh_data() const;  /**   * @returns a constant reference to the mesh_data   */  const MeshData & get_mesh_data() const;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -