diff --git a/ProcessLib/SmallDeformation/SmallDeformationFEM.h b/ProcessLib/SmallDeformation/SmallDeformationFEM.h index df83712777f8a8c8ed2e184028d3332e9ce9ec1a..7283a44683c5333a9fbcb2209de9ee35894891f4 100644 --- a/ProcessLib/SmallDeformation/SmallDeformationFEM.h +++ b/ProcessLib/SmallDeformation/SmallDeformationFEM.h @@ -164,12 +164,10 @@ public: typename ConstitutiveRelations::ConstitutiveData<DisplacementDim> updateConstitutiveRelations( - Eigen::Ref<Eigen::VectorXd const> const& u, + BMatrixType const& B, Eigen::Ref<Eigen::VectorXd const> const& u, Eigen::Ref<Eigen::VectorXd const> const& u_prev, ParameterLib::SpatialPosition const& x_position, double const t, double const dt, - IntegrationPointData<BMatricesType, ShapeMatricesType, DisplacementDim>& - ip_data, typename ConstitutiveRelations::ConstitutiveSetting<DisplacementDim>& CS, MaterialPropertyLib::Medium const& medium, @@ -179,21 +177,8 @@ public: prev_state, MaterialStateData<DisplacementDim>& material_state, typename ConstitutiveRelations::OutputData<DisplacementDim>& - output_data, - BBarMatrixType const& B_dil_bar) const + output_data) const { - auto const& N = ip_data.N_u; - auto const& dNdx = ip_data.dNdx_u; - auto const x_coord = - NumLib::interpolateXCoordinate<ShapeFunction, ShapeMatricesType>( - this->element_, N); - - auto const B = LinearBMatrix::computeBMatrixPossiblyWithBbar< - DisplacementDim, ShapeFunction::NPOINTS, BBarMatrixType, - typename BMatricesType::BMatrixType>(dNdx, N, B_dil_bar, x_coord, - this->is_axially_symmetric_, - true /*use B bar*/); - double const T_ref = this->process_data_.reference_temperature ? (*this->process_data_.reference_temperature)(t, x_position)[0] @@ -287,13 +272,12 @@ public: DisplacementDim, ShapeFunction::NPOINTS, BBarMatrixType, typename BMatricesType::BMatrixType>( dNdx, N, B_dil_bar, x_coord, this->is_axially_symmetric_, - true /*use B bar*/); + this->process_data_.use_b_bar); auto const CD = updateConstitutiveRelations( - u, u_prev, x_position, t, dt, _ip_data[ip], - constitutive_setting, medium, this->current_states_[ip], - this->prev_states_[ip], this->material_states_[ip], - this->output_data_[ip], B_dil_bar); + B, u, u_prev, x_position, t, dt, constitutive_setting, medium, + this->current_states_[ip], this->prev_states_[ip], + this->material_states_[ip], this->output_data_[ip]); auto const& sigma = this->current_states_[ip].stress_data.sigma; auto const& b = *CD.volumetric_body_force; @@ -327,12 +311,24 @@ public: for (unsigned ip = 0; ip < n_integration_points; ip++) { x_position.setIntegrationPoint(ip); + auto const& N = _ip_data[ip].N_u; + auto const& dNdx = _ip_data[ip].dNdx_u; + + auto const x_coord = + NumLib::interpolateXCoordinate<ShapeFunction, + ShapeMatricesType>( + this->element_, N); + auto const B = LinearBMatrix::computeBMatrixPossiblyWithBbar< + DisplacementDim, ShapeFunction::NPOINTS, BBarMatrixType, + typename BMatricesType::BMatrixType>( + dNdx, N, B_dil_bar, x_coord, this->is_axially_symmetric_, + this->process_data_.use_b_bar); updateConstitutiveRelations( - local_x, local_x_prev, x_position, t, dt, _ip_data[ip], + B, local_x, local_x_prev, x_position, t, dt, constitutive_setting, medium, this->current_states_[ip], this->prev_states_[ip], this->material_states_[ip], - this->output_data_[ip], B_dil_bar); + this->output_data_[ip]); this->material_states_[ip].pushBackState(); }