www.mooseframework.org
ADComputeStressBase.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 "ADMaterial.h"
13 #include "Function.h"
14 
15 #define usingComputeStressBaseMembers \
16  usingMaterialMembers; \
17  using ADComputeStressBase<compute_stage>::_stress; \
18  using ADComputeStressBase<compute_stage>::_mechanical_strain; \
19  using ADComputeStressBase<compute_stage>::_elastic_strain; \
20  using ADComputeStressBase<compute_stage>::_base_name; \
21  using ADComputeStressBase<compute_stage>::_initial_stress_fcn
22 
23 // Forward Declarations
24 template <ComputeStage>
26 template <typename>
30 template <typename>
34 
36 
40 template <ComputeStage compute_stage>
41 class ADComputeStressBase : public ADMaterial<compute_stage>
42 {
43 public:
44  static InputParameters validParams();
45 
46  ADComputeStressBase(const InputParameters & parameters);
47 
48 protected:
49  virtual void initQpStatefulProperties() override;
50  virtual void computeQpProperties() override;
51  virtual void computeQpStress() = 0;
52 
53  const std::string _base_name;
54 
55  const ADMaterialProperty(RankTwoTensor) & _mechanical_strain;
57  ADMaterialProperty(RankTwoTensor) & _elastic_strain;
58 
60  std::vector<const MaterialProperty<RankTwoTensor> *> _extra_stresses;
61 
63  std::vector<const Function *> _initial_stress_fcn;
64 
66 };
declareADValidParams
declareADValidParams(ADComputeStressBase)
ADComputeStressBase::ADMaterialProperty
const ADMaterialProperty(RankTwoTensor) &_mechanical_strain
ADComputeStressBase::usingMaterialMembers
usingMaterialMembers
Definition: ADComputeStressBase.h:65
DualRankFourTensor
RankFourTensorTempl< DualReal > DualRankFourTensor
Definition: ADComputeStressBase.h:33
ADComputeStressBase::_base_name
const std::string _base_name
Definition: ADComputeStressBase.h:53
ADComputeStressBase::initQpStatefulProperties
virtual void initQpStatefulProperties() override
Definition: ADComputeStressBase.C:53
ADComputeStressBase::computeQpProperties
virtual void computeQpProperties() override
Definition: ADComputeStressBase.C:61
RankFourTensor
RankFourTensorTempl< Real > RankFourTensor
Definition: ADComputeStressBase.h:31
RankTwoTensor
RankTwoTensorTempl< Real > RankTwoTensor
Definition: ADComputeStressBase.h:27
ADComputeStressBase::ADComputeStressBase
ADComputeStressBase(const InputParameters &parameters)
Definition: ADComputeStressBase.C:34
ADComputeStressBase
ADComputeStressBase is the base class for stress tensors.
Definition: ADComputeStressBase.h:25
ADComputeStressBase::_extra_stresses
std::vector< const MaterialProperty< RankTwoTensor > * > _extra_stresses
Extra stress tensors.
Definition: ADComputeStressBase.h:60
RankFourTensorTempl
Definition: ACGrGrElasticDrivingForce.h:20
ADComputeStressBase::validParams
static InputParameters validParams()
Definition: ADComputeStressBase.C:18
ADComputeStressBase::computeQpStress
virtual void computeQpStress()=0
DualRankTwoTensor
RankTwoTensorTempl< DualReal > DualRankTwoTensor
Definition: ADComputeStressBase.h:29
RankTwoTensorTempl
Definition: ACGrGrElasticDrivingForce.h:17
ADComputeStressBase::_initial_stress_fcn
std::vector< const Function * > _initial_stress_fcn
initial stress components
Definition: ADComputeStressBase.h:63