Line data Source code
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 : #include "AnisotropicReturnPlasticityStressUpdateBase.h" 11 : 12 : template <bool is_ad> 13 : InputParameters 14 60 : AnisotropicReturnPlasticityStressUpdateBaseTempl<is_ad>::validParams() 15 : { 16 60 : InputParameters params = GeneralizedRadialReturnStressUpdateTempl<is_ad>::validParams(); 17 : 18 60 : params.set<std::string>("effective_inelastic_strain_name") = "effective_plastic_strain"; 19 60 : params.set<std::string>("inelastic_strain_rate_name") = "plastic_strain_rate"; 20 : 21 60 : return params; 22 0 : } 23 : 24 : template <bool is_ad> 25 45 : AnisotropicReturnPlasticityStressUpdateBaseTempl< 26 : is_ad>::AnisotropicReturnPlasticityStressUpdateBaseTempl(const InputParameters & parameters) 27 : : GeneralizedRadialReturnStressUpdateTempl<is_ad>(parameters), 28 45 : _plasticity_strain(this->template declareGenericProperty<RankTwoTensor, is_ad>( 29 45 : this->_base_name + "plastic_strain")), 30 45 : _plasticity_strain_old( 31 90 : this->template getMaterialPropertyOld<RankTwoTensor>(this->_base_name + "plastic_strain")) 32 : { 33 45 : } 34 : 35 : template <bool is_ad> 36 : void 37 3552 : AnisotropicReturnPlasticityStressUpdateBaseTempl<is_ad>::initQpStatefulProperties() 38 : { 39 3552 : _plasticity_strain[this->_qp].zero(); 40 : 41 3552 : GeneralizedRadialReturnStressUpdateTempl<is_ad>::initQpStatefulProperties(); 42 3552 : } 43 : 44 : template <bool is_ad> 45 : void 46 0 : AnisotropicReturnPlasticityStressUpdateBaseTempl<is_ad>::propagateQpStatefulProperties() 47 : { 48 0 : _plasticity_strain[this->_qp] = _plasticity_strain_old[this->_qp]; 49 : 50 0 : this->propagateQpStatefulPropertiesRadialReturn(); 51 0 : } 52 : 53 : template <bool is_ad> 54 : void 55 57624 : AnisotropicReturnPlasticityStressUpdateBaseTempl<is_ad>::computeStrainFinalize( 56 : GenericRankTwoTensor<is_ad> & inelasticStrainIncrement, 57 : const GenericRankTwoTensor<is_ad> & /*stress*/, 58 : const GenericDenseVector<is_ad> & /*stress_dev*/, 59 : const GenericReal<is_ad> & /*delta_gamma*/) 60 : { 61 57624 : _plasticity_strain[this->_qp] = _plasticity_strain_old[this->_qp] + inelasticStrainIncrement; 62 57624 : } 63 : 64 : template class AnisotropicReturnPlasticityStressUpdateBaseTempl<false>; 65 : template class AnisotropicReturnPlasticityStressUpdateBaseTempl<true>;