GRINS-0.7.0
isothermal_dirichlet_old_style_bc_factory.C
Go to the documentation of this file.
1 //-----------------------------------------------------------------------bl-
2 //--------------------------------------------------------------------------
3 //
4 // GRINS - General Reacting Incompressible Navier-Stokes
5 //
6 // Copyright (C) 2014-2016 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 // This class
27 #include "grins/string_utils.h"
28 
29 // libMesh
30 #include "libmesh/const_function.h"
31 
32 namespace GRINS
33 {
34  libMesh::UniquePtr<libMesh::FunctionBase<libMesh::Number> >
36  MultiphysicsSystem& /*system*/,
37  std::vector<std::string>& var_names,
38  const std::string& section )
39  {
40  libmesh_assert_equal_to(DirichletBCFactoryAbstract::_bc_ids->size(), 1 );
41  libmesh_assert_equal_to(var_names.size(), 1 );
42 
43  std::string bc_id_string = StringUtilities::T_to_string<BoundaryID>( *(_bc_ids->begin()) );
44 
45  std::string input_var = section+"/T_wall_"+bc_id_string;
46 
47  if( !input.have_variable(input_var) )
48  libmesh_error_msg("ERROR: Could not find input variable "+input_var+"!");
49 
50  libMesh::Number value = input(input_var, 0.0);
51 
52  return libMesh::UniquePtr<libMesh::FunctionBase<libMesh::Number> >( new libMesh::ConstFunction<libMesh::Number>(value) );
53  }
54 
55  // Instantiate factory
58 } // end namespace GRINS
static const std::set< BoundaryID > * _bc_ids
BoundaryID for constructing a particular boundary condition.
IsothermalDirichletOldStyleBCFactory grins_factory_isothermal_wall_old_style("isothermal_wall_old_style")
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.
IsothermalDirichletOldStyleBCFactory grins_factory_isothermal_old_style("isothermal_old_style")

Generated on Thu Jun 2 2016 21:52:27 for GRINS-0.7.0 by  doxygen 1.8.10