www.mooseframework.org
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | List of all members
SpecificHeatConductionTimeDerivative Class Reference

A class for defining the time derivative of the heat equation. More...

#include <SpecificHeatConductionTimeDerivative.h>

Inheritance diagram for SpecificHeatConductionTimeDerivative:
[legend]

Public Types

typedef DerivativeMaterialPropertyNameInterface::SymbolName SymbolName
 

Public Member Functions

 SpecificHeatConductionTimeDerivative (const InputParameters &parameters)
 
const GenericMaterialProperty< U, is_ad > & getDefaultMaterialProperty (const std::string &name)
 
const GenericMaterialProperty< U, is_ad > & getDefaultMaterialPropertyByName (const std::string &name)
 
void validateDerivativeMaterialPropertyBase (const std::string &base)
 
const MaterialPropertyName derivativePropertyName (const MaterialPropertyName &base, const std::vector< SymbolName > &c) const
 
const MaterialPropertyName derivativePropertyNameFirst (const MaterialPropertyName &base, const SymbolName &c1) const
 
const MaterialPropertyName derivativePropertyNameSecond (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2) const
 
const MaterialPropertyName derivativePropertyNameThird (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2, const SymbolName &c3) const
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const std::vector< VariableName > &c)
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const std::vector< SymbolName > &c)
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const std::vector< VariableName > &c)
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const std::vector< SymbolName > &c)
 
GenericMaterialProperty< U, is_ad > & declarePropertyDerivative (const std::string &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const std::vector< VariableName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const std::vector< SymbolName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const SymbolName &c1, unsigned int v2, unsigned int v3=libMesh::invalid_uint)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, unsigned int v1, unsigned int v2=libMesh::invalid_uint, unsigned int v3=libMesh::invalid_uint)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const std::vector< VariableName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const std::vector< SymbolName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, const SymbolName &c1, unsigned int v2, unsigned int v3=libMesh::invalid_uint)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivative (const std::string &base, unsigned int v1, unsigned int v2=libMesh::invalid_uint, unsigned int v3=libMesh::invalid_uint)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const std::vector< VariableName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const std::vector< SymbolName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const std::vector< VariableName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const std::vector< SymbolName > &c)
 
const GenericMaterialProperty< U, is_ad > & getMaterialPropertyDerivativeByName (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2="", const SymbolName &c3="")
 
void validateCoupling (const MaterialPropertyName &base, const std::vector< VariableName > &c, bool validate_aux=true)
 
void validateCoupling (const MaterialPropertyName &base, const VariableName &c1="", const VariableName &c2="", const VariableName &c3="")
 
void validateCoupling (const MaterialPropertyName &base, const std::vector< VariableName > &c, bool validate_aux=true)
 
void validateCoupling (const MaterialPropertyName &base, const VariableName &c1="", const VariableName &c2="", const VariableName &c3="")
 
void validateNonlinearCoupling (const MaterialPropertyName &base, const VariableName &c1="", const VariableName &c2="", const VariableName &c3="")
 
void validateNonlinearCoupling (const MaterialPropertyName &base, const VariableName &c1="", const VariableName &c2="", const VariableName &c3="")
 
const MaterialPropertyName propertyName (const MaterialPropertyName &base, const std::vector< SymbolName > &c) const
 
const MaterialPropertyName propertyName (const MaterialPropertyName &base, const std::vector< SymbolName > &c) const
 
const MaterialPropertyName propertyNameFirst (const MaterialPropertyName &base, const SymbolName &c1) const
 
const MaterialPropertyName propertyNameFirst (const MaterialPropertyName &base, const SymbolName &c1) const
 
const MaterialPropertyName propertyNameSecond (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2) const
 
const MaterialPropertyName propertyNameSecond (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2) const
 
const MaterialPropertyName propertyNameThird (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2, const SymbolName &c3) const
 
const MaterialPropertyName propertyNameThird (const MaterialPropertyName &base, const SymbolName &c1, const SymbolName &c2, const SymbolName &c3) const
 

Static Public Member Functions

static InputParameters validParams ()
 

Protected Member Functions

virtual Real computeQpResidual () override
 
virtual Real computeQpJacobian () override
 
virtual Real computeQpOffDiagJacobian (unsigned int jvar) override
 

Protected Attributes

const MaterialProperty< Real > & _specific_heat
 Specific heat and its derivatives with respect to temperature and other coupled variables. More...
 
const MaterialProperty< Real > & _d_specific_heat_dT
 
std::vector< const MaterialProperty< Real > * > _d_specific_heat_dargs
 
const MaterialProperty< Real > & _density
 Density and its derivatives with respect to temperature and other coupled variables. More...
 
const MaterialProperty< Real > & _d_density_dT
 
std::vector< const MaterialProperty< Real > * > _d_density_dargs
 

Detailed Description

A class for defining the time derivative of the heat equation.

By default this Kernel computes: \( \rho * c_p * \frac{\partial T}{\partial t}, \) where \( \rho \) and \( c_p \) are material properties for "density" and "specific_heat", respectively.

Definition at line 27 of file SpecificHeatConductionTimeDerivative.h.

Constructor & Destructor Documentation

◆ SpecificHeatConductionTimeDerivative()

SpecificHeatConductionTimeDerivative::SpecificHeatConductionTimeDerivative ( const InputParameters parameters)

Definition at line 33 of file SpecificHeatConductionTimeDerivative.C.

36  _specific_heat(getMaterialProperty<Real>("specific_heat")),
37  _d_specific_heat_dT(getMaterialPropertyDerivative<Real>("specific_heat", _var.name())),
38  _density(getMaterialProperty<Real>("density")),
39  _d_density_dT(getMaterialPropertyDerivative<Real>("density", _var.name()))
40 {
41  // Get number of coupled variables
42  unsigned int nvar = _coupled_moose_vars.size();
43 
44  // reserve space for derivatives
45  _d_specific_heat_dargs.resize(nvar);
46  _d_density_dargs.resize(nvar);
47 
48  // Iterate over all coupled variables
49  for (unsigned int i = 0; i < nvar; ++i)
50  {
51  const std::string iname = _coupled_moose_vars[i]->name();
52  _d_specific_heat_dargs[i] = &getMaterialPropertyDerivative<Real>("specific_heat", iname);
53  _d_density_dargs[i] = &getMaterialPropertyDerivative<Real>("density", iname);
54  }
55 }
std::vector< const MaterialProperty< Real > * > _d_density_dargs
const MaterialProperty< Real > & _density
Density and its derivatives with respect to temperature and other coupled variables.
virtual unsigned int size() const override final
std::vector< const MaterialProperty< Real > * > _d_specific_heat_dargs
const MaterialProperty< Real > & _specific_heat
Specific heat and its derivatives with respect to temperature and other coupled variables.

Member Function Documentation

◆ computeQpJacobian()

Real SpecificHeatConductionTimeDerivative::computeQpJacobian ( )
overrideprotectedvirtual

Definition at line 64 of file SpecificHeatConductionTimeDerivative.C.

65 {
67 
68  // on-diagonal Jacobian with all terms that may depend on the kernel variable
70  _d_specific_heat_dT[_qp] * _phi[_j][_qp] * _density[_qp] * dT +
71  _specific_heat[_qp] * _d_density_dT[_qp] * _phi[_j][_qp] * dT;
72 }
virtual Real computeQpResidual() override
const MaterialProperty< Real > & _density
Density and its derivatives with respect to temperature and other coupled variables.
virtual Real computeQpJacobian() override
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const MaterialProperty< Real > & _specific_heat
Specific heat and its derivatives with respect to temperature and other coupled variables.

◆ computeQpOffDiagJacobian()

Real SpecificHeatConductionTimeDerivative::computeQpOffDiagJacobian ( unsigned int  jvar)
overrideprotectedvirtual

Definition at line 75 of file SpecificHeatConductionTimeDerivative.C.

76 {
77  // get the coupled variable jvar is referring to
78  const unsigned int cvar = mapJvarToCvar(jvar);
79 
80  // off-diagonal contribution with terms that depend on coupled variables
82  return (*_d_specific_heat_dargs[cvar])[_qp] * _phi[_j][_qp] * _density[_qp] * dT +
83  _specific_heat[_qp] * (*_d_density_dargs[cvar])[_qp] * _phi[_j][_qp] * dT;
84 }
virtual Real computeQpResidual() override
std::vector< const MaterialProperty< Real > * > _d_density_dargs
const MaterialProperty< Real > & _density
Density and its derivatives with respect to temperature and other coupled variables.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
std::vector< const MaterialProperty< Real > * > _d_specific_heat_dargs
const MaterialProperty< Real > & _specific_heat
Specific heat and its derivatives with respect to temperature and other coupled variables.

◆ computeQpResidual()

Real SpecificHeatConductionTimeDerivative::computeQpResidual ( )
overrideprotectedvirtual

Definition at line 58 of file SpecificHeatConductionTimeDerivative.C.

59 {
61 }
virtual Real computeQpResidual() override
const MaterialProperty< Real > & _density
Density and its derivatives with respect to temperature and other coupled variables.
const MaterialProperty< Real > & _specific_heat
Specific heat and its derivatives with respect to temperature and other coupled variables.

◆ validParams()

InputParameters SpecificHeatConductionTimeDerivative::validParams ( )
static

Definition at line 15 of file SpecificHeatConductionTimeDerivative.C.

16 {
18  params.addClassDescription(
19  "Time derivative term $\\rho c_p \\frac{\\partial T}{\\partial t}$ of "
20  "the heat equation with the specific heat $c_p$ and the density $\\rho$ as arguments.");
21 
22  // Density may be changing with deformation, so we must integrate
23  // over current volume by setting the use_displaced_mesh flag.
24  params.set<bool>("use_displaced_mesh") = true;
25 
26  params.addParam<MaterialPropertyName>(
27  "specific_heat", "specific_heat", "Property name of the specific heat material property");
28  params.addParam<MaterialPropertyName>(
29  "density", "density", "Property name of the density material property");
30  return params;
31 }
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
T & set(const std::string &name, bool quiet_mode=false)
static InputParameters validParams()
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _d_density_dargs

std::vector<const MaterialProperty<Real> *> SpecificHeatConductionTimeDerivative::_d_density_dargs
protected

◆ _d_density_dT

const MaterialProperty<Real>& SpecificHeatConductionTimeDerivative::_d_density_dT
protected

Definition at line 48 of file SpecificHeatConductionTimeDerivative.h.

Referenced by computeQpJacobian().

◆ _d_specific_heat_dargs

std::vector<const MaterialProperty<Real> *> SpecificHeatConductionTimeDerivative::_d_specific_heat_dargs
protected

◆ _d_specific_heat_dT

const MaterialProperty<Real>& SpecificHeatConductionTimeDerivative::_d_specific_heat_dT
protected

Definition at line 42 of file SpecificHeatConductionTimeDerivative.h.

Referenced by computeQpJacobian().

◆ _density

const MaterialProperty<Real>& SpecificHeatConductionTimeDerivative::_density
protected

Density and its derivatives with respect to temperature and other coupled variables.

Definition at line 47 of file SpecificHeatConductionTimeDerivative.h.

Referenced by computeQpJacobian(), computeQpOffDiagJacobian(), and computeQpResidual().

◆ _specific_heat

const MaterialProperty<Real>& SpecificHeatConductionTimeDerivative::_specific_heat
protected

Specific heat and its derivatives with respect to temperature and other coupled variables.

Definition at line 41 of file SpecificHeatConductionTimeDerivative.h.

Referenced by computeQpJacobian(), computeQpOffDiagJacobian(), and computeQpResidual().


The documentation for this class was generated from the following files: