ComputeMultipleInelasticStress computes the stress, the consistent tangent operator (or an approximat...
const std::vector< Real > _inelastic_weights
_inelastic_strain = sum_i (_inelastic_weights_i * inelastic_strain_from_model_i)
const bool _cycle_models
whether to cycle through the models, using only one model per timestep
bool _all_models_isotropic
are all inelastic models inherently isotropic? (not the case for e.g. weak plane plasticity models)
ComputeFiniteStrainElasticStress computes the stress following elasticity theory for finite strains.
static InputParameters validParams()
virtual void initialSetup() override
const unsigned _num_models
number of plastic models
InputParameters validParams< ComputeMultipleInelasticStress >()
virtual void computeQpStress() override
Compute the stress and store it in the _stress material property for the current quadrature point.
virtual void updateQpStateSingleModel(unsigned model_number, RankTwoTensor &elastic_strain_increment, RankTwoTensor &combined_inelastic_strain_increment)
An optimised version of updateQpState that gets used when the number of plastic models is unity,...
const MaterialProperty< RankTwoTensor > & _inelastic_strain_old
old value of inelastic strain
bool _is_elasticity_tensor_guaranteed_isotropic
is the elasticity tensor guaranteed to be isotropic?
std::vector< bool > _tangent_computation_flag
Flags to compute tangent during updateState call.
std::vector< StressUpdateBase * > _models
The user supplied list of inelastic models to use in the simulation.
const bool _perform_finite_strain_rotations
after updateQpState, rotate the stress, elastic_strain, inelastic_strain and Jacobian_mult using _rot...
const MaterialProperty< RankTwoTensor > & _elastic_strain_old
Strain tensors.
RankTwoTensor _undamaged_stress_old
const bool _internal_solve_full_iteration_history
std::vector< RankFourTensor > _consistent_tangent_operator
the consistent tangent operators computed by each plastic model
MaterialProperty< RankTwoTensor > & _inelastic_strain
The sum of the inelastic strains that come from the plastic models.
const RankFourTensor _identity_symmetric_four
Rank four symmetric identity tensor.
const MaterialProperty< RankTwoTensor > & _strain_increment
DamageBase is a base class for damage models, which modify the stress tensor computed by another mode...
DamageBase * _damage_model
Pointer to the damage model.
const Real _absolute_tolerance
virtual void finiteStrainRotation(const bool force_elasticity_rotation=false)
Rotate _elastic_strain, _stress, _inelastic_strain, and _Jacobian_mult to the new configuration.
virtual void computeQpStressIntermediateConfiguration()
Compute the stress for the current QP, but do not rotate tensors from the intermediate configuration ...
virtual void updateQpState(RankTwoTensor &elastic_strain_increment, RankTwoTensor &combined_inelastic_strain_increment)
Given the _strain_increment[_qp], iterate over all of the user-specified recompute materials in order...
virtual void initQpStatefulProperties() override
virtual void computeAdmissibleState(unsigned model_number, RankTwoTensor &elastic_strain_increment, RankTwoTensor &inelastic_strain_increment, RankFourTensor &consistent_tangent_operator)
Given a trial stress (_stress[_qp]) and a strain increment (elastic_strain_increment) let the model_n...
MaterialProperty< Real > & _matl_timestep_limit
virtual void computeQpJacobianMult()
Using _elasticity_tensor[_qp] and the consistent tangent operators, _consistent_tangent_operator[....
TangentCalculationMethod _tangent_calculation_method
Calculation method for the tangent modulus.
TangentCalculationMethod
TangentCalculationMethod is an enum that determines the calculation method for the tangent operator.
enum ComputeMultipleInelasticStress::TangentOperatorEnum _tangent_operator_type
const unsigned int _max_iterations
Input parameters associated with the recompute iteration to return the stress state to the yield surf...
TangentOperatorEnum
what sort of Tangent operator to calculate
ComputeMultipleInelasticStress(const InputParameters ¶meters)
const Real _relative_tolerance