https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad > Class Template Reference

Material designed to provide the permeability tensor which is calculated from porosity using a form of the Kozeny-Carman equation (e.g. More...

#include <PorousFlowPermeabilityKozenyCarmanFromVar.h>

Inheritance diagram for PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >:
[legend]

Public Types

typedef DerivativeMaterialPropertyNameInterface::SymbolName SymbolName
 

Public Member Functions

 PorousFlowPermeabilityKozenyCarmanFromVarTempl (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

Real computeA () const override
 retrieve constant value for A computed in constructor More...
 
void computeQpProperties () override
 

Protected Attributes

const VariableValue_A
 Multiplying factor in k = k_ijk * A * phi^n / (1 - phi)^m. More...
 
 usingPorousFlowPermeabilityBaseMembers
 
const Real _m
 Exponent in k = k_ijk * A * phi^n / (1 - phi)^m. More...
 
const Real _n
 Exponent in k = k_ijk * A * phi^n / (1 - phi)^m. More...
 
const RealTensorValue _k_anisotropy
 Tensor multiplier k_ijk in k = k_ijk * A * phi^n / (1 - phi)^m. More...
 
const GenericMaterialProperty< Real, is_ad > & _porosity_qp
 Quadpoint porosity. More...
 
const MaterialProperty< std::vector< Real > > *const _dporosity_qp_dvar
 d(quadpoint porosity)/d(PorousFlow variable) More...
 
const MaterialProperty< std::vector< RealGradient > > *const _dporosity_qp_dgradvar
 d(quadpoint porosity)/d(grad(PorousFlow variable)) More...
 
GenericMaterialProperty< RealTensorValue, is_ad > & _permeability_qp
 Quadpoint permeability. More...
 
MaterialProperty< std::vector< RealTensorValue > > *const _dpermeability_qp_dvar
 d(quadpoint permeability)/d(PorousFlow variable) More...
 
MaterialProperty< std::vector< std::vector< RealTensorValue > > > *const _dpermeability_qp_dgradvar
 d(quadpoint permeability)/d(grad(PorousFlow variable)) More...
 
const unsigned int _num_phases
 Number of phases. More...
 
const unsigned int _num_components
 Number of fluid components. More...
 
const unsigned int _num_var
 Number of PorousFlow variables. More...
 

Detailed Description

template<bool is_ad>
class PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >

Material designed to provide the permeability tensor which is calculated from porosity using a form of the Kozeny-Carman equation (e.g.

Oelkers 1996: Reviews in Mineralogy v. 34, p. 131-192): k = k_ijk * A * phi^n / (1 - phi)^m where k_ijk is a tensor providing the anisotropy, phi is porosity, n and m are positive scalar constants. A is provided as an auxVariable.

Definition at line 24 of file PorousFlowPermeabilityKozenyCarmanFromVar.h.

Constructor & Destructor Documentation

◆ PorousFlowPermeabilityKozenyCarmanFromVarTempl()

Definition at line 28 of file PorousFlowPermeabilityKozenyCarmanFromVar.C.

29  : PorousFlowPermeabilityKozenyCarmanBaseTempl<is_ad>(parameters), _A(coupledValue("A"))
30 {
31 }
Base class for material designed to provide the permeability tensor which is calculated from porosity...
const VariableValue & _A
Multiplying factor in k = k_ijk * A * phi^n / (1 - phi)^m.

Member Function Documentation

◆ computeA()

template<bool is_ad>
Real PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >::computeA ( ) const
overrideprotectedvirtual

retrieve constant value for A computed in constructor

Implements PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >.

Definition at line 35 of file PorousFlowPermeabilityKozenyCarmanFromVar.C.

36 {
37  if (_A[_qp] < 0)
38  mooseError("The variable A must be greater than zero; A = ", _A[_qp], ".");
39  return _A[_qp];
40 }
void mooseError(Args &&... args)
const VariableValue & _A
Multiplying factor in k = k_ijk * A * phi^n / (1 - phi)^m.

◆ computeQpProperties()

template<bool is_ad>
void PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::computeQpProperties ( )
overrideprotectedinherited

Definition at line 56 of file PorousFlowPermeabilityKozenyCarmanBase.C.

57 {
58  Real A = computeA();
59  _permeability_qp[_qp] =
60  _k_anisotropy * A * std::pow(_porosity_qp[_qp], _n) / std::pow(1.0 - _porosity_qp[_qp], _m);
61 
62  if constexpr (!is_ad)
63  {
64  (*_dpermeability_qp_dvar)[_qp].resize(_num_var, RealTensorValue());
65  for (unsigned int v = 0; v < _num_var; ++v)
66  (*_dpermeability_qp_dvar)[_qp][v] = (*_dporosity_qp_dvar)[_qp][v] * _permeability_qp[_qp] *
67  (_n / _porosity_qp[_qp] + _m / (1.0 - _porosity_qp[_qp]));
68 
69  (*_dpermeability_qp_dgradvar)[_qp].resize(LIBMESH_DIM);
70  for (const auto i : make_range(Moose::dim))
71  {
72  (*_dpermeability_qp_dgradvar)[_qp][i].resize(_num_var, RealTensorValue());
73  for (unsigned int v = 0; v < _num_var; ++v)
74  (*_dpermeability_qp_dgradvar)[_qp][i][v] =
75  (*_dporosity_qp_dgradvar)[_qp][v](i) * _permeability_qp[_qp] *
76  (_n / _porosity_qp[_qp] + _m / (1.0 - _porosity_qp[_qp]));
77  }
78  }
79 }
const Real _m
Exponent in k = k_ijk * A * phi^n / (1 - phi)^m.
static constexpr std::size_t dim
TensorValue< Real > RealTensorValue
const unsigned int _num_var
Number of PorousFlow variables.
MaterialProperty< std::vector< RealTensorValue > > *const _dpermeability_qp_dvar
d(quadpoint permeability)/d(PorousFlow variable)
MaterialProperty< std::vector< std::vector< RealTensorValue > > > *const _dpermeability_qp_dgradvar
d(quadpoint permeability)/d(grad(PorousFlow variable))
GenericMaterialProperty< RealTensorValue, is_ad > & _permeability_qp
Quadpoint permeability.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static const std::string v
Definition: NS.h:84
IntRange< T > make_range(T beg, T end)
const GenericMaterialProperty< Real, is_ad > & _porosity_qp
Quadpoint porosity.
virtual Real computeA() const =0
function for returning A factor in Kozeny Carman equation
MooseUnits pow(const MooseUnits &, int)
const Real _n
Exponent in k = k_ijk * A * phi^n / (1 - phi)^m.
const RealTensorValue _k_anisotropy
Tensor multiplier k_ijk in k = k_ijk * A * phi^n / (1 - phi)^m.

◆ validParams()

template<bool is_ad>
InputParameters PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >::validParams ( )
static

Definition at line 17 of file PorousFlowPermeabilityKozenyCarmanFromVar.C.

18 {
20  params.addRequiredCoupledVar("A", "Variable used in permeability function.");
21  params.addClassDescription("This Material calculates the permeability tensor from the "
22  "Kozeny-Carman equation for spatially varying initial properties.");
23  return params;
24 }
void addRequiredCoupledVar(const std::string &name, const std::string &doc_string)
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _A

template<bool is_ad>
const VariableValue& PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >::_A
protected

Multiplying factor in k = k_ijk * A * phi^n / (1 - phi)^m.

Definition at line 37 of file PorousFlowPermeabilityKozenyCarmanFromVar.h.

◆ _dpermeability_qp_dgradvar

template<bool is_ad>
MaterialProperty<std::vector<std::vector<RealTensorValue> > >* const PorousFlowPermeabilityBaseTempl< is_ad >::_dpermeability_qp_dgradvar
protectedinherited

d(quadpoint permeability)/d(grad(PorousFlow variable))

Definition at line 33 of file PorousFlowPermeabilityBase.h.

◆ _dpermeability_qp_dvar

template<bool is_ad>
MaterialProperty<std::vector<RealTensorValue> >* const PorousFlowPermeabilityBaseTempl< is_ad >::_dpermeability_qp_dvar
protectedinherited

d(quadpoint permeability)/d(PorousFlow variable)

Definition at line 30 of file PorousFlowPermeabilityBase.h.

◆ _dporosity_qp_dgradvar

template<bool is_ad>
const MaterialProperty<std::vector<RealGradient> >* const PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_dporosity_qp_dgradvar
protectedinherited

d(quadpoint porosity)/d(grad(PorousFlow variable))

Definition at line 53 of file PorousFlowPermeabilityKozenyCarmanBase.h.

◆ _dporosity_qp_dvar

template<bool is_ad>
const MaterialProperty<std::vector<Real> >* const PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_dporosity_qp_dvar
protectedinherited

d(quadpoint porosity)/d(PorousFlow variable)

Definition at line 50 of file PorousFlowPermeabilityKozenyCarmanBase.h.

◆ _k_anisotropy

template<bool is_ad>
const RealTensorValue PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_k_anisotropy
protectedinherited

Tensor multiplier k_ijk in k = k_ijk * A * phi^n / (1 - phi)^m.

Definition at line 44 of file PorousFlowPermeabilityKozenyCarmanBase.h.

◆ _m

template<bool is_ad>
const Real PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_m
protectedinherited

Exponent in k = k_ijk * A * phi^n / (1 - phi)^m.

Definition at line 38 of file PorousFlowPermeabilityKozenyCarmanBase.h.

Referenced by PorousFlowPermeabilityKozenyCarmanTempl< is_ad >::PorousFlowPermeabilityKozenyCarmanTempl().

◆ _n

template<bool is_ad>
const Real PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_n
protectedinherited

Exponent in k = k_ijk * A * phi^n / (1 - phi)^m.

Definition at line 41 of file PorousFlowPermeabilityKozenyCarmanBase.h.

Referenced by PorousFlowPermeabilityKozenyCarmanTempl< is_ad >::PorousFlowPermeabilityKozenyCarmanTempl().

◆ _num_components

const unsigned int PorousFlowMaterialVectorBase::_num_components
protectedinherited

◆ _num_phases

const unsigned int PorousFlowMaterialVectorBase::_num_phases
protectedinherited

◆ _num_var

const unsigned int PorousFlowMaterialVectorBase::_num_var
protectedinherited

◆ _permeability_qp

template<bool is_ad>
GenericMaterialProperty<RealTensorValue, is_ad>& PorousFlowPermeabilityBaseTempl< is_ad >::_permeability_qp
protectedinherited

Quadpoint permeability.

Definition at line 27 of file PorousFlowPermeabilityBase.h.

◆ _porosity_qp

template<bool is_ad>
const GenericMaterialProperty<Real, is_ad>& PorousFlowPermeabilityKozenyCarmanBaseTempl< is_ad >::_porosity_qp
protectedinherited

Quadpoint porosity.

Definition at line 47 of file PorousFlowPermeabilityKozenyCarmanBase.h.

◆ usingPorousFlowPermeabilityBaseMembers

template<bool is_ad>
PorousFlowPermeabilityKozenyCarmanFromVarTempl< is_ad >::usingPorousFlowPermeabilityBaseMembers
protected

Definition at line 39 of file PorousFlowPermeabilityKozenyCarmanFromVar.h.


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