www.mooseframework.org
ComputeEigenstrainBase.h
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://www.mooseframework.org
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #pragma once
11 
12 #include "Material.h"
13 
14 template <typename>
17 
19 
20 template <>
21 InputParameters validParams<ComputeEigenstrainBase>();
22 
26 class ComputeEigenstrainBase : public Material
27 {
28 public:
29  static InputParameters validParams();
30 
31  ComputeEigenstrainBase(const InputParameters & parameters);
32 
33 protected:
34  virtual void initQpStatefulProperties();
35  virtual void computeQpProperties();
36 
38  virtual void computeQpEigenstrain() = 0;
39 
41  const std::string _base_name;
42 
44  std::string _eigenstrain_name;
45 
47  MaterialProperty<RankTwoTensor> & _eigenstrain;
48 
57  Real computeVolumetricStrainComponent(const Real volumetric_strain) const;
58 
60  bool & _step_zero;
61 };
RankTwoTensor
RankTwoTensorTempl< Real > RankTwoTensor
Definition: ComputeEigenstrainBase.h:15
ComputeEigenstrainBase::_base_name
const std::string _base_name
Base name prepended to material property name.
Definition: ComputeEigenstrainBase.h:41
ComputeEigenstrainBase::validParams
static InputParameters validParams()
Definition: ComputeEigenstrainBase.C:17
ComputeEigenstrainBase::ComputeEigenstrainBase
ComputeEigenstrainBase(const InputParameters &parameters)
Definition: ComputeEigenstrainBase.C:31
ComputeEigenstrainBase::_step_zero
bool & _step_zero
Restartable data to check for the zeroth and first time steps for thermal calculations.
Definition: ComputeEigenstrainBase.h:60
ComputeEigenstrainBase::computeQpEigenstrain
virtual void computeQpEigenstrain()=0
Compute the eigenstrain and store in _eigenstrain.
validParams< ComputeEigenstrainBase >
InputParameters validParams< ComputeEigenstrainBase >()
ComputeEigenstrainBase::computeQpProperties
virtual void computeQpProperties()
Definition: ComputeEigenstrainBase.C:49
ComputeEigenstrainBase::computeVolumetricStrainComponent
Real computeVolumetricStrainComponent(const Real volumetric_strain) const
Helper function for models that compute the eigenstrain based on a volumetric strain.
Definition: ComputeEigenstrainBase.C:62
ComputeEigenstrainBase::_eigenstrain_name
std::string _eigenstrain_name
Material property name for the eigenstrain tensor.
Definition: ComputeEigenstrainBase.h:44
ComputeEigenstrainBase::initQpStatefulProperties
virtual void initQpStatefulProperties()
Definition: ComputeEigenstrainBase.C:41
ComputeEigenstrainBase
ComputeEigenstrainBase is the base class for eigenstrain tensors.
Definition: ComputeEigenstrainBase.h:26
RankTwoTensorTempl
Definition: ACGrGrElasticDrivingForce.h:17
ComputeEigenstrainBase::_eigenstrain
MaterialProperty< RankTwoTensor > & _eigenstrain
Stores the current total eigenstrain.
Definition: ComputeEigenstrainBase.h:47