const std::vector< Real > _inelastic_weights
_inelastic_strain = sum_i (_inelastic_weights_i * inelastic_strain_from_model_i)
ADComputeMultipleInelasticStress(const InputParameters ¶meters)
virtual void updateQpStateSingleModel(unsigned model_number, ADRankTwoTensor &elastic_strain_increment, ADRankTwoTensor &combined_inelastic_strain_increment)
An optimised version of updateQpState that gets used when the number of plastic models is unity...
const Real _relative_tolerance
const MaterialProperty< RankTwoTensor > & _inelastic_strain_old
old value of inelastic strain
ADMaterialProperty< RankTwoTensor > & _inelastic_strain
The sum of the inelastic strains that come from the plastic models.
virtual void computeQpStressIntermediateConfiguration()
Compute the stress for the current QP, but do not rotate tensors from the intermediate configuration ...
ADComputeMultipleInelasticStress computes the stress and a decomposition of the strain into elastic a...
const bool _perform_finite_strain_rotations
after updateQpState, rotate the stress, elastic_strain, and inelastic_strain using _rotation_incremen...
const bool _internal_solve_full_iteration_history
virtual void updateQpState(ADRankTwoTensor &elastic_strain_increment, ADRankTwoTensor &combined_inelastic_strain_increment)
Given the _strain_increment[_qp], iterate over all of the user-specified recompute materials in order...
virtual void computeQpStress() override
const unsigned int _max_iterations
Input parameters associated with the recompute iteration to return the stress state to the yield surf...
ADComputeFiniteStrainElasticStress computes the stress following elasticity theory for finite strains...
RankTwoTensor _undamaged_stress_old
virtual void initQpStatefulProperties() override
std::vector< ADStressUpdateBase * > _models
The user supplied list of inelastic models to use in the simulation.
static InputParameters validParams()
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
bool _is_elasticity_tensor_guaranteed_isotropic
is the elasticity tensor guaranteed to be isotropic?
const unsigned _num_models
number of plastic models
DamageBaseTempl< true > * _damage_model
Pointer to the damage model.
const Real _absolute_tolerance
const InputParameters & parameters() const
const bool _cycle_models
whether to cycle through the models, using only one model per timestep
virtual void initialSetup() override
MaterialProperty< Real > & _material_timestep_limit
virtual void computeAdmissibleState(unsigned model_number, ADRankTwoTensor &elastic_strain_increment, ADRankTwoTensor &inelastic_strain_increment)
Given a trial stress (_stress[_qp]) and a strain increment (elastic_strain_increment) let the model_n...
virtual void finiteStrainRotation()
Rotate _elastic_strain, _stress, and _inelastic_strain to the new configuration.