www.mooseframework.org
ADComputeFiniteStrainElasticStress.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 "ADComputeStressBase.h"
13 #include "GuaranteeConsumer.h"
14 
15 #define usingComputeFiniteStrainElasticStressMembers \
16  usingComputeStressBaseMembers; \
17  using ADComputeFiniteStrainElasticStress<compute_stage>::_elasticity_tensor; \
18  using ADComputeFiniteStrainElasticStress<compute_stage>::_elasticity_tensor_name; \
19  using ADComputeFiniteStrainElasticStress<compute_stage>::_strain_increment; \
20  using ADComputeFiniteStrainElasticStress<compute_stage>::_rotation_increment; \
21  using ADComputeFiniteStrainElasticStress<compute_stage>::_stress_old; \
22  using ADComputeFiniteStrainElasticStress<compute_stage>::_elastic_strain_old
23 
24 template <ComputeStage>
26 
28 
33 template <ComputeStage compute_stage>
34 class ADComputeFiniteStrainElasticStress : public ADComputeStressBase<compute_stage>,
35  public GuaranteeConsumer
36 {
37 public:
38  static InputParameters validParams();
39 
40  ADComputeFiniteStrainElasticStress(const InputParameters & parameters);
41 
42  void initialSetup() override;
43 
44 protected:
45  virtual void computeQpStress() override;
46 
48  const std::string _elasticity_tensor_name;
50  const ADMaterialProperty(RankFourTensor) & _elasticity_tensor;
51  const ADMaterialProperty(RankTwoTensor) & _strain_increment;
52  const ADMaterialProperty(RankTwoTensor) & _rotation_increment;
53  const MaterialProperty<RankTwoTensor> & _stress_old;
54 
59  const MaterialProperty<RankTwoTensor> & _elastic_strain_old;
60 
62 };
ADComputeFiniteStrainElasticStress::ADComputeFiniteStrainElasticStress
ADComputeFiniteStrainElasticStress(const InputParameters &parameters)
Definition: ADComputeFiniteStrainElasticStress.C:26
ADComputeFiniteStrainElasticStress::_stress_old
const MaterialProperty< RankTwoTensor > & _stress_old
Definition: ADComputeFiniteStrainElasticStress.h:53
ADComputeFiniteStrainElasticStress::computeQpStress
virtual void computeQpStress() override
Definition: ADComputeFiniteStrainElasticStress.C:52
ADComputeFiniteStrainElasticStress::initialSetup
void initialSetup() override
Definition: ADComputeFiniteStrainElasticStress.C:42
declareADValidParams
declareADValidParams(ADComputeFiniteStrainElasticStress)
ADComputeFiniteStrainElasticStress::usingComputeStressBaseMembers
usingComputeStressBaseMembers
Definition: ADComputeFiniteStrainElasticStress.h:61
ADComputeFiniteStrainElasticStress
ADComputeFiniteStrainElasticStress computes the stress following elasticity theory for finite strains...
Definition: ADComputeFiniteStrainElasticStress.h:25
ADComputeFiniteStrainElasticStress::_elasticity_tensor_name
const std::string _elasticity_tensor_name
Name of the elasticity tensor material property.
Definition: ADComputeFiniteStrainElasticStress.h:48
ADComputeFiniteStrainElasticStress::_elastic_strain_old
const MaterialProperty< RankTwoTensor > & _elastic_strain_old
The old elastic strain is used to calculate the old stress in the case of variable elasticity tensors...
Definition: ADComputeFiniteStrainElasticStress.h:59
GuaranteeConsumer
Add-on class that provides the functionality to check if guarantees for material properties are provi...
Definition: GuaranteeConsumer.h:25
ADComputeStressBase
ADComputeStressBase is the base class for stress tensors.
Definition: ADComputeStressBase.h:25
GuaranteeConsumer.h
RankFourTensorTempl< Real >
ADComputeStressBase.h
RankTwoTensorTempl
Definition: ACGrGrElasticDrivingForce.h:17
ADComputeFiniteStrainElasticStress::validParams
static InputParameters validParams()
Definition: ADComputeFiniteStrainElasticStress.C:18
ADComputeFiniteStrainElasticStress::ADMaterialProperty
const ADMaterialProperty(RankFourTensor) &_elasticity_tensor
Elasticity tensor material property.