https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
OneD3EqnMomentumFormLoss Class Reference

Computes the force per unit length due to form loss, provided a form loss coefficient per unit length function. More...

#include <OneD3EqnMomentumFormLoss.h>

Inheritance diagram for OneD3EqnMomentumFormLoss:
[legend]

Public Types

typedef DerivativeMaterialPropertyNameInterface::SymbolName SymbolName
 

Public Member Functions

 OneD3EqnMomentumFormLoss (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
 
MaterialProperty< U > & declarePropertyDerivativeTHM (const std::string &base, const std::string &var_name, const unsigned int i=0)
 Method for declaring derivative material properties. More...
 
const MaterialProperty< U > & getMaterialPropertyDerivativeTHM (const std::string &base, const std::string &var_name, const unsigned int i=0)
 Method for retrieving derivative material properties. More...
 
const MaterialProperty< U > & getMaterialPropertyDerivativeTHMPhase (const std::string &base, bool property_is_liquid, const std::string &var_name, bool var_is_liquid, const unsigned int i=0)
 Method for retrieving derivative material properties corresponding to phase-dependent derivatives. More...
 

Protected Attributes

const VariableValue_A
 area More...
 
const MaterialProperty< Real > & _rho
 density More...
 
const MaterialProperty< Real > & _drho_darhoA
 
const MaterialProperty< Real > & _vel
 velocity More...
 
const MaterialProperty< Real > & _dvel_darhoA
 
const MaterialProperty< Real > & _dvel_darhouA
 
const MaterialProperty< Real > & _K_prime
 form loss coefficient per unit length function More...
 
unsigned int _arhoA_var_number
 
unsigned int _arhouA_var_number
 
unsigned int _arhoEA_var_number
 

Detailed Description

Computes the force per unit length due to form loss, provided a form loss coefficient per unit length function.

See RELAP-7 Theory Manual, pg. 72, Equation (239) {eq:form_loss_force_2phase}

Definition at line 23 of file OneD3EqnMomentumFormLoss.h.

Constructor & Destructor Documentation

◆ OneD3EqnMomentumFormLoss()

OneD3EqnMomentumFormLoss::OneD3EqnMomentumFormLoss ( const InputParameters parameters)

Definition at line 33 of file OneD3EqnMomentumFormLoss.C.

35 
36  _A(coupledValue("A")),
37 
38  _rho(getMaterialProperty<Real>("rho")),
39  _drho_darhoA(getMaterialPropertyDerivativeTHM<Real>("rho", "arhoA")),
40 
41  _vel(getMaterialProperty<Real>("vel")),
42  _dvel_darhoA(getMaterialPropertyDerivativeTHM<Real>("vel", "arhoA")),
43  _dvel_darhouA(getMaterialPropertyDerivativeTHM<Real>("vel", "arhouA")),
44 
45  _K_prime(getMaterialProperty<Real>("K_prime")),
46 
47  _arhoA_var_number(coupled("arhoA")),
48  _arhouA_var_number(coupled("arhouA")),
49  _arhoEA_var_number(coupled("arhoEA"))
50 {
51 }
const MaterialProperty< Real > & _dvel_darhouA
const MaterialProperty< Real > & _vel
velocity
const VariableValue & _A
area
const MaterialProperty< Real > & _rho
density
const MaterialProperty< Real > & _dvel_darhoA
const MaterialProperty< Real > & _drho_darhoA
const MaterialProperty< Real > & _K_prime
form loss coefficient per unit length function

Member Function Documentation

◆ computeQpJacobian()

Real OneD3EqnMomentumFormLoss::computeQpJacobian ( )
overrideprotectedvirtual

Definition at line 61 of file OneD3EqnMomentumFormLoss.C.

62 {
63  return computeQpOffDiagJacobian(_var.number());
64 }
virtual Real computeQpOffDiagJacobian(unsigned int jvar) override

◆ computeQpOffDiagJacobian()

Real OneD3EqnMomentumFormLoss::computeQpOffDiagJacobian ( unsigned int  jvar)
overrideprotectedvirtual

Definition at line 67 of file OneD3EqnMomentumFormLoss.C.

Referenced by computeQpJacobian().

68 {
69  if (jvar == _arhoA_var_number)
70  {
71  const Real drhou2_darhoA = _drho_darhoA[_qp] * _vel[_qp] * std::abs(_vel[_qp]) +
72  2.0 * _rho[_qp] * std::abs(_vel[_qp]) * _dvel_darhoA[_qp];
73 
74  return _K_prime[_qp] * 0.5 * drhou2_darhoA * _A[_qp] * _phi[_j][_qp] * _test[_i][_qp];
75  }
76  else if (jvar == _arhouA_var_number)
77  {
78  const Real drhou2_darhouA = 2.0 * _rho[_qp] * std::abs(_vel[_qp]) * _dvel_darhouA[_qp];
79 
80  return _K_prime[_qp] * 0.5 * drhou2_darhouA * _A[_qp] * _phi[_j][_qp] * _test[_i][_qp];
81  }
82  else if (jvar == _arhoEA_var_number)
83  return 0.;
84  else
85  return 0;
86 }
const MaterialProperty< Real > & _dvel_darhouA
const MaterialProperty< Real > & _vel
velocity
const VariableValue & _A
area
const MaterialProperty< Real > & _rho
density
const MaterialProperty< Real > & _dvel_darhoA
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const MaterialProperty< Real > & _drho_darhoA
const MaterialProperty< Real > & _K_prime
form loss coefficient per unit length function

◆ computeQpResidual()

Real OneD3EqnMomentumFormLoss::computeQpResidual ( )
overrideprotectedvirtual

Definition at line 54 of file OneD3EqnMomentumFormLoss.C.

55 {
56  return _K_prime[_qp] * 0.5 * _rho[_qp] * _vel[_qp] * std::abs(_vel[_qp]) * _A[_qp] *
57  _test[_i][_qp];
58 }
const MaterialProperty< Real > & _vel
velocity
const VariableValue & _A
area
const MaterialProperty< Real > & _rho
density
const MaterialProperty< Real > & _K_prime
form loss coefficient per unit length function

◆ declarePropertyDerivativeTHM()

MaterialProperty< U > & DerivativeMaterialInterfaceTHM< Kernel >::declarePropertyDerivativeTHM ( const std::string &  base,
const std::string &  var_name,
const unsigned int  i = 0 
)
protectedinherited

Method for declaring derivative material properties.

Template Parameters
UThe material property type
Parameters
baseThe name of the property to take the derivative of
var_nameThe name of the coupled variable vector containing the variable to take the derivative with respect to
iThe index of the variable to take the derivative with respect to within the coupled variable vector

Definition at line 88 of file DerivativeMaterialInterfaceTHM.h.

91 {
92  return this->template declarePropertyDerivative<U>(base, this->coupledName(var_name, i));
93 }

◆ getMaterialPropertyDerivativeTHM()

const MaterialProperty< U > & DerivativeMaterialInterfaceTHM< Kernel >::getMaterialPropertyDerivativeTHM ( const std::string &  base,
const std::string &  var_name,
const unsigned int  i = 0 
)
protectedinherited

Method for retrieving derivative material properties.

Template Parameters
UThe material property type
Parameters
baseThe name of the property to take the derivative of
var_nameThe name of the coupled variable vector containing the variable to take the derivative with respect to
iThe index of the variable to take the derivative with respect to within the coupled variable vector

Definition at line 98 of file DerivativeMaterialInterfaceTHM.h.

101 {
102  // get the base property name
103  const std::string prop_name = this->getMaterialPropertyName(base);
104 
105  // get the name of the variable which derivative is respect to
106  const std::string der_var_name = this->coupledName(var_name, i);
107 
108  return this->template getMaterialPropertyByName<U>(
109  this->derivativePropertyNameFirst(prop_name, der_var_name));
110 }
const MaterialPropertyName derivativePropertyNameFirst(const MaterialPropertyName &base, const SymbolName &c1) const

◆ getMaterialPropertyDerivativeTHMPhase()

const MaterialProperty< U > & DerivativeMaterialInterfaceTHM< Kernel >::getMaterialPropertyDerivativeTHMPhase ( const std::string &  base,
bool  property_is_liquid,
const std::string &  var_name,
bool  var_is_liquid,
const unsigned int  i = 0 
)
protectedinherited

Method for retrieving derivative material properties corresponding to phase-dependent derivatives.

The intended behavior of this function is as follows. If the material property and derivative variable correspond to the same phase, then the material property is retrieved as usual. Else, a zero-valued material property is returned, as it is assumed that the material property depends only upon the variables corresponding to its phase.

Template Parameters
UThe material property type
Parameters
baseThe name of the property to take the derivative of
property_is_liquidDoes the property correspond to the liquid phase?
var_nameThe name of the coupled variable vector containing the variable to take the derivative with respect to
var_is_liquidDoes the derivative variable correspond to the liquid phase?
iThe index of the variable to take the derivative with respect to within the coupled variable vector

Definition at line 115 of file DerivativeMaterialInterfaceTHM.h.

121 {
122  if (property_is_liquid == var_is_liquid)
123  {
124  return getMaterialPropertyDerivativeTHM<U>(base, var_name, i);
125  }
126  else
127  {
128  const std::string prop_name = this->getMaterialPropertyName(base);
129  const std::string der_var_name = this->coupledName(var_name, i);
130  const std::string der_prop_name = this->derivativePropertyNameFirst(prop_name, der_var_name);
131  return this->template getZeroMaterialProperty<U>(der_prop_name);
132  }
133 }
const MaterialPropertyName derivativePropertyNameFirst(const MaterialPropertyName &base, const SymbolName &c1) const

◆ validParams()

InputParameters OneD3EqnMomentumFormLoss::validParams ( )
static

Definition at line 16 of file OneD3EqnMomentumFormLoss.C.

17 {
19 
20  params.addRequiredCoupledVar("arhoA", "Solution variable alpha*rho*A");
21  params.addRequiredCoupledVar("arhouA", "Solution variable alpha*rho*u*A");
22  params.addRequiredCoupledVar("arhoEA", "Solution variable alpha*rho*E*A");
23 
24  params.addRequiredCoupledVar("A", "Cross-sectional area");
25  params.addRequiredParam<MaterialPropertyName>("rho", "Density property");
26  params.addRequiredParam<MaterialPropertyName>("vel", "Velocity property");
27  params.addClassDescription(
28  "Computes a form loss term for the momentum equation for 1-phase flow");
29 
30  return params;
31 }
static InputParameters validParams()
void addRequiredParam(const std::string &name, const std::string &doc_string)
void addRequiredCoupledVar(const std::string &name, const std::string &doc_string)
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _A

const VariableValue& OneD3EqnMomentumFormLoss::_A
protected

area

Definition at line 34 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian(), and computeQpResidual().

◆ _arhoA_var_number

unsigned int OneD3EqnMomentumFormLoss::_arhoA_var_number
protected

Definition at line 48 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _arhoEA_var_number

unsigned int OneD3EqnMomentumFormLoss::_arhoEA_var_number
protected

Definition at line 50 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _arhouA_var_number

unsigned int OneD3EqnMomentumFormLoss::_arhouA_var_number
protected

Definition at line 49 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _drho_darhoA

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_drho_darhoA
protected

Definition at line 38 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _dvel_darhoA

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_dvel_darhoA
protected

Definition at line 42 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _dvel_darhouA

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_dvel_darhouA
protected

Definition at line 43 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian().

◆ _K_prime

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_K_prime
protected

form loss coefficient per unit length function

Definition at line 46 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian(), and computeQpResidual().

◆ _rho

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_rho
protected

density

Definition at line 37 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian(), and computeQpResidual().

◆ _vel

const MaterialProperty<Real>& OneD3EqnMomentumFormLoss::_vel
protected

velocity

Definition at line 41 of file OneD3EqnMomentumFormLoss.h.

Referenced by computeQpOffDiagJacobian(), and computeQpResidual().


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