GRINS-0.8.0
isothermal_dirichlet_old_style_bc_factory.h
Go to the documentation of this file.
1 //-----------------------------------------------------------------------bl-
2 //--------------------------------------------------------------------------
3 //
4 // GRINS - General Reacting Incompressible Navier-Stokes
5 //
6 // Copyright (C) 2014-2017 Paul T. Bauman, Roy H. Stogner
7 // Copyright (C) 2010-2013 The PECOS Development Team
8 //
9 // This library is free software; you can redistribute it and/or
10 // modify it under the terms of the Version 2.1 GNU Lesser General
11 // Public License as published by the Free Software Foundation.
12 //
13 // This library is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 // Lesser General Public License for more details.
17 //
18 // You should have received a copy of the GNU Lesser General Public
19 // License along with this library; if not, write to the Free Software
20 // Foundation, Inc. 51 Franklin Street, Fifth Floor,
21 // Boston, MA 02110-1301 USA
22 //
23 //-----------------------------------------------------------------------el-
24 
25 #ifndef GRINS_ISOTHERMAL_DIRICHLET_OLD_STYLE_BC_FACTORY_H
26 #define GRINS_ISOTHERMAL_DIRICHLET_OLD_STYLE_BC_FACTORY_H
27 
28 // GRINS
30 #include "grins/string_utils.h"
31 
32 // libMesh
33 #include "libmesh/const_function.h"
34 
35 namespace GRINS
36 {
37  class IsothermalDirichletOldStyleBCFactory : public DirichletBCFactoryFunctionOldStyleBase<libMesh::FunctionBase<libMesh::Number> >
38  {
39  public:
40 
41  IsothermalDirichletOldStyleBCFactory( const std::string& bc_type_name )
42  : DirichletBCFactoryFunctionOldStyleBase<libMesh::FunctionBase<libMesh::Number> >(bc_type_name)
43  {}
44 
46 
47  protected:
48 
49  virtual libMesh::UniquePtr<libMesh::FunctionBase<libMesh::Number> >
50  build_func( const GetPot& input,
51  MultiphysicsSystem& system,
52  std::vector<std::string>& var_names,
53  const std::string& section );
54 
55  };
56 
57  libMesh::UniquePtr<libMesh::FunctionBase<libMesh::Number> >
58  inline
60  MultiphysicsSystem& /*system*/,
61  std::vector<std::string>& var_names,
62  const std::string& section )
63  {
64  libmesh_assert_equal_to(DirichletBCFactoryAbstract::_bc_ids->size(), 1 );
65  libmesh_assert_equal_to(var_names.size(), 1 );
66 
67  std::string bc_id_string = StringUtilities::T_to_string<BoundaryID>( *(_bc_ids->begin()) );
68 
69  std::string input_var = section+"/T_wall_"+bc_id_string;
70 
71  if( !input.have_variable(input_var) )
72  libmesh_error_msg("ERROR: Could not find input variable "+input_var+"!");
73 
74  libMesh::Number value = input(input_var, 0.0);
75 
76  return libMesh::UniquePtr<libMesh::FunctionBase<libMesh::Number> >( new libMesh::ConstFunction<libMesh::Number>(value) );
77  }
78 
79 } // end namespace GRINS
80 
81 #endif // GRINS_ISOTHERMAL_DIRICHLET_OLD_STYLE_BC_FACTORY_H
static const std::set< BoundaryID > * _bc_ids
BoundaryID for constructing a particular boundary condition.
GRINS namespace.
virtual libMesh::UniquePtr< libMesh::FunctionBase< libMesh::Number > > build_func(const GetPot &input, MultiphysicsSystem &system, std::vector< std::string > &var_names, const std::string &section)
Builds the FunctionBase object for boundary condition.
Interface with libMesh for solving Multiphysics problems.

Generated on Tue Dec 19 2017 12:47:27 for GRINS-0.8.0 by  doxygen 1.8.9.1