GRINS-0.8.0
constant_viscosity.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 
26 #ifndef GRINS_CONSTANT_VISCOSITY_H
27 #define GRINS_CONSTANT_VISCOSITY_H
28 
29 //GRINS
30 #include "grins/viscosity_base.h"
31 #include "grins/assembly_context.h"
32 #include "grins/parameter_user.h"
33 
34 // libMesh
35 #include "libmesh/libmesh_common.h"
36 
37 #include "libmesh/fem_system.h"
38 
39 class GetPot;
40 
41 namespace GRINS
42 {
44  public ViscosityBase
45  {
46  public:
47 
49 
51  ConstantViscosity( const GetPot& input, const std::string& material );
52 
54  ConstantViscosity( const GetPot& input );
55  virtual ~ConstantViscosity();
56 
57  libMesh::Real operator()() const;
58 
59  libMesh::Real operator()(AssemblyContext& context, unsigned int qp) const;
60 
61  libMesh::Real operator()( const libMesh::Point& p, const libMesh::Real time );
62 
63  libMesh::Real operator()( const libMesh::Real T ) const;
64 
65  libMesh::Real deriv( const libMesh::Real T ) const;
66 
67  private:
68 
70 
71  libMesh::Real _mu;
72 
73  };
74 
75  /* ------------------------- Inline Functions -------------------------*/
76  inline
77  libMesh::Real ConstantViscosity::operator()() const
78  {
79  return _mu;
80  }
81 
82  inline
83  libMesh::Real ConstantViscosity::operator()(AssemblyContext& /*context*/, unsigned int /*qp*/) const
84  {
85  return _mu;
86  }
87 
88  inline
89  libMesh::Real ConstantViscosity::operator()( const libMesh::Point& /*p*/,
90  const libMesh::Real /*time*/ )
91  {
92  return _mu;
93  }
94 
95  inline
96  libMesh::Real ConstantViscosity::operator()( const libMesh::Real /*T*/ ) const
97  {
98  return (*this)();
99  }
100 
101  inline
102  libMesh::Real ConstantViscosity::deriv( const libMesh::Real /*T*/ ) const
103  {
104  return 0.0;
105  }
106 
107 } // end namespace GRINS
108 
109 #endif // GRINS_CONSTANT_VISCOSITY_H
Base class for viscosity models.
GRINS namespace.
libMesh::Real deriv(const libMesh::Real T) const
ParameterUser base class. Utility methods for subclasses.
libMesh::Real operator()() const

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