diff --git a/applications/ConstitutiveLawsApplication/constitutive_laws_application.cpp b/applications/ConstitutiveLawsApplication/constitutive_laws_application.cpp index d51f8fb9ebca..f872f72efa07 100644 --- a/applications/ConstitutiveLawsApplication/constitutive_laws_application.cpp +++ b/applications/ConstitutiveLawsApplication/constitutive_laws_application.cpp @@ -72,7 +72,9 @@ void KratosConstitutiveLawsApplication::Register() KRATOS_REGISTER_CONSTITUTIVE_LAW("SerialParallelRuleOfMixturesLaw", mSerialParallelRuleOfMixturesLaw); // Anisotropic law + KRATOS_REGISTER_CONSTITUTIVE_LAW("GenericAnisotropicPlaneStrain2DLaw", mGenericAnisotropicPlaneStrain2DLaw); KRATOS_REGISTER_CONSTITUTIVE_LAW("GenericAnisotropic3DLaw", mGenericAnisotropic3DLaw); + KRATOS_REGISTER_CONSTITUTIVE_LAW("GenericAnisotropicPlaneStress2DLaw", mGenericAnisotropicPlaneStress2DLaw); /// Plasticity diff --git a/applications/ConstitutiveLawsApplication/constitutive_laws_application.h b/applications/ConstitutiveLawsApplication/constitutive_laws_application.h index 8115fda211a6..6c1947ea8412 100644 --- a/applications/ConstitutiveLawsApplication/constitutive_laws_application.h +++ b/applications/ConstitutiveLawsApplication/constitutive_laws_application.h @@ -66,7 +66,8 @@ #include "custom_constitutive/small_strains/plastic_damage/generic_small_strain_plastic_damage_model.h" #include "custom_constitutive/small_strains/damage/generic_small_strain_orthotropic_damage.h" #include "custom_constitutive/composites/serial_parallel_rule_of_mixtures_law.h" -#include "custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.h" +#include "custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.h" +#include "custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.h" #include "custom_constitutive/small_strains/linear/multi_linear_elastic_1d_law.h" #include "custom_constitutive/small_strains/linear/multi_linear_isotropic_plane_stress_2d.h" #include "custom_constitutive/small_strains/damage/generic_small_strain_isotropic_damage_plane_stress.h" @@ -623,7 +624,9 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) KratosConstitutiveLawsApplicatio const ParallelRuleOfMixturesLaw<2> mParallelRuleOfMixturesLaw2D; // Anisotropic law - const GenericAnisotropic3DLaw mGenericAnisotropic3DLaw; + const GenericAnisotropicLaw<2> mGenericAnisotropicPlaneStrain2DLaw; + const GenericAnisotropicLaw<3> mGenericAnisotropic3DLaw; + const GenericAnisotropicPlaneStress2DLaw mGenericAnisotropicPlaneStress2DLaw; const AssociativePlasticDamageModel >> mAssociativePlasticDamageModel3DVonMises; const AssociativePlasticDamageModel >> mAssociativePlasticDamageModel3DDruckerPrager; diff --git a/applications/ConstitutiveLawsApplication/custom_constitutive/composites/rule_of_mixtures_law.cpp b/applications/ConstitutiveLawsApplication/custom_constitutive/composites/rule_of_mixtures_law.cpp index efa3383a6e63..67550ba6a43c 100644 --- a/applications/ConstitutiveLawsApplication/custom_constitutive/composites/rule_of_mixtures_law.cpp +++ b/applications/ConstitutiveLawsApplication/custom_constitutive/composites/rule_of_mixtures_law.cpp @@ -1505,7 +1505,7 @@ void ParallelRuleOfMixturesLaw::CalculateRotationMatrix( const double euler_angle_theta = layers_euler_angles[3*Layer + 1]; const double euler_angle_hi = layers_euler_angles[3*Layer + 2]; - BoundedMatrix rotation_matrix; + BoundedMatrix rotation_matrix; if (std::abs(euler_angle_phi) + std::abs(euler_angle_theta) + std::abs(euler_angle_hi) > machine_tolerance) { AdvancedConstitutiveLawUtilities::CalculateRotationOperator(euler_angle_phi, euler_angle_theta, euler_angle_hi, rotation_matrix); diff --git a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.cpp b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.cpp similarity index 66% rename from applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.cpp rename to applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.cpp index 9ad824a951c0..e37bfed64d67 100644 --- a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.cpp +++ b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.cpp @@ -9,7 +9,7 @@ // license: structural_mechanics_application/license.txt // // Main authors: Alejandro Cornejo -// Collaborator: Lucia Barbu +// // // System includes @@ -17,24 +17,29 @@ // External includes // Project includes -#include "utilities/math_utils.h" + #include "constitutive_laws_application_variables.h" -#include "generic_anisotropic_3d_law.h" +#include "generic_anisotropic_law.h" #include "custom_utilities/tangent_operator_calculator_utility.h" #include "custom_utilities/advanced_constitutive_law_utilities.h" #include "custom_utilities/constitutive_law_utilities.h" namespace Kratos { -ConstitutiveLaw::Pointer GenericAnisotropic3DLaw::Create(Kratos::Parameters NewParameters) const +/***********************************************************************************/ +/***********************************************************************************/ + +template +ConstitutiveLaw::Pointer GenericAnisotropicLaw::Create(Kratos::Parameters NewParameters) const { - return Kratos::make_shared(); + return Kratos::make_shared(); } /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateMaterialResponsePK1(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::CalculateMaterialResponsePK1(ConstitutiveLaw::Parameters& rValues) { this->CalculateMaterialResponsePK2(rValues); @@ -49,7 +54,8 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponsePK1(ConstitutiveLaw::Para /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Parameters& rValues) { this->CalculateMaterialResponsePK2(rValues); @@ -64,7 +70,8 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::P /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateMaterialResponseKirchhoff(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::CalculateMaterialResponseKirchhoff(ConstitutiveLaw::Parameters& rValues) { this->CalculateMaterialResponsePK2(rValues); @@ -79,7 +86,27 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponseKirchhoff(ConstitutiveLaw /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::CalculateRotationMatrixVoigt( + const Properties& rMaterialProperties, + BoundedMatrixVoigtType &rT +) +{ + if (rMaterialProperties.Has(EULER_ANGLES) && MathUtils::Norm3(rMaterialProperties[EULER_ANGLES]) > machine_tolerance) { + BoundedMatrixType rotation_matrix; + const Vector& r_euler_angles = rMaterialProperties[EULER_ANGLES]; + AdvancedConstitutiveLawUtilities::CalculateRotationOperator(r_euler_angles[0], r_euler_angles[1], r_euler_angles[2], rotation_matrix); + ConstitutiveLawUtilities::CalculateRotationOperatorVoigt(rotation_matrix, rT); + } else { + noalias(rT) = IdentityMatrix(VoigtSize, VoigtSize); + } +} + +/***********************************************************************************/ +/***********************************************************************************/ + +template +void GenericAnisotropicLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Parameters& rValues) { // Get Values to compute the constitutive law: Flags& r_flags = rValues.GetOptions(); @@ -91,7 +118,7 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Para if (!flag_strain) { Vector& r_strain_vector = rValues.GetStrainVector(); - this->CalculateCauchyGreenStrain(rValues, r_strain_vector); + ConstitutiveLawUtilities::CalculateCauchyGreenStrain(rValues, r_strain_vector); } // this strain in the real anisotropic space @@ -106,22 +133,8 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Para if (flag_stress) { // Here we compute the rotation tensors due to the angles of the local and global axes - BoundedMatrixType rotation_matrix; BoundedMatrixVoigtType voigt_rotation_matrix; - - if (r_material_properties.Has(EULER_ANGLES) && - MathUtils::Norm3(r_material_properties[EULER_ANGLES]) > machine_tolerance) { - const Vector& r_euler_angles = r_material_properties[EULER_ANGLES]; - AdvancedConstitutiveLawUtilities::CalculateRotationOperator( - r_euler_angles(0), r_euler_angles(1), - r_euler_angles(2), rotation_matrix); - ConstitutiveLawUtilities::CalculateRotationOperatorVoigt( - (rotation_matrix), - voigt_rotation_matrix); - } else { - noalias(rotation_matrix) = IdentityMatrix(Dimension, Dimension); - noalias(voigt_rotation_matrix) = IdentityMatrix(VoigtSize, VoigtSize); - } + CalculateRotationMatrixVoigt(r_material_properties, voigt_rotation_matrix); // We compute the mappers As and Ae BoundedMatrixVoigtType stress_mapper, strain_mapper; @@ -130,11 +143,10 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Para Matrix isotropic_elastic_matrix; this->CalculateAnisotropicStressMapperMatrix(r_material_properties, stress_mapper, stress_mapper_inv); - mpIsotropicCL->CalculateValue(rValues, CONSTITUTIVE_MATRIX, isotropic_elastic_matrix); // takes the props of the iso cl + mpIsotropicCL->CalculateValue(rValues, CONSTITUTIVE_MATRIX, isotropic_elastic_matrix); // Takes the props of the iso cl this->CalculateOrthotropicElasticMatrix(anisotropic_elastic_matrix, r_material_properties); - this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, - isotropic_elastic_matrix, stress_mapper, - strain_mapper); + this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, isotropic_elastic_matrix, stress_mapper, strain_mapper); + Vector &r_iso_strain_vector = rValues.GetStrainVector(); // Now we rotate the strain Eglob-> Eloc @@ -169,55 +181,23 @@ void GenericAnisotropic3DLaw::CalculateMaterialResponsePK2(ConstitutiveLaw::Para /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateOrthotropicElasticMatrix( +template +void GenericAnisotropicLaw::CalculateOrthotropicElasticMatrix( BoundedMatrixVoigtType& rElasticityTensor, const Properties& rMaterialProperties) { - KRATOS_TRY - - noalias(rElasticityTensor) = ZeroMatrix(VoigtSize, VoigtSize); - - const Vector& r_ortho_elastic_constants = rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS]; - const double Ex = r_ortho_elastic_constants(0); - const double Ey = r_ortho_elastic_constants(1); - const double Ez = r_ortho_elastic_constants(2); - const double vxy = r_ortho_elastic_constants(3); - const double vyz = r_ortho_elastic_constants(4); - const double vxz = r_ortho_elastic_constants(5); - - const double vyx = vxy * Ey / Ex; - const double vzx = vxz * Ez / Ex; - const double vzy = vyz * Ez / Ey; - - KRATOS_ERROR_IF(vyx > 0.5) << "The Poisson_yx is greater than 0.5." << std::endl; - KRATOS_ERROR_IF(vzx > 0.5) << "The Poisson_zx is greater than 0.5." << std::endl; - KRATOS_ERROR_IF(vzy > 0.5) << "The Poisson_zy is greater than 0.5." << std::endl; - - const double ctant = 1.0 / (1.0 - vxy * vyx - vzy * vyz - vzx * vxz - vxy * vyz * vzx - vxz * vyx * vzy); - - rElasticityTensor(0, 0) = Ex * (1.0 - vyz * vzy) * ctant; - rElasticityTensor(0, 1) = Ex * (vyx + vyz * vzx) * ctant; - rElasticityTensor(1, 0) = Ey * (vxy + vzy * vxz) * ctant; - - rElasticityTensor(0, 2) = Ex * (vzx + vyx * vzy) * ctant; - rElasticityTensor(2, 0) = Ez * (vxz + vxy * vyz) * ctant; - rElasticityTensor(1, 1) = Ey * (1.0 - vxz * vzx) * ctant; - - rElasticityTensor(1, 2) = Ey * (vzy + vxy * vzx) * ctant; - rElasticityTensor(2, 1) = Ez * (vyz + vyx * vxz) * ctant; - rElasticityTensor(2, 2) = Ez * (1.0 - vxy * vyx) * ctant; - - rElasticityTensor(3, 3) = (rMaterialProperties.Has(SHEAR_MODULUS_XY)) ? rMaterialProperties[SHEAR_MODULUS_XY] : 1.0 / ((1.0 + vyx) / Ex + (1.0 + vxy) / Ey); - rElasticityTensor(4, 4) = (rMaterialProperties.Has(SHEAR_MODULUS_YZ)) ? rMaterialProperties[SHEAR_MODULUS_YZ] : 1.0 / ((1.0 + vzy) / Ey + (1.0 + vyz) / Ez); - rElasticityTensor(5, 5) = (rMaterialProperties.Has(SHEAR_MODULUS_XZ)) ? rMaterialProperties[SHEAR_MODULUS_XZ] : 1.0 / ((1.0 + vzx) / Ex + (1.0 + vxz) / Ez); - - KRATOS_CATCH("") + if constexpr (Dimension == 3) { + AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrix(rElasticityTensor, rMaterialProperties); + } else { // The 2D is plane strain + AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrixPlaneStrain(rElasticityTensor, rMaterialProperties); + } } /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK1(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::FinalizeMaterialResponsePK1(ConstitutiveLaw::Parameters& rValues) { this->FinalizeMaterialResponsePK2(rValues); } @@ -225,7 +205,8 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK1(ConstitutiveLaw::Param /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::FinalizeMaterialResponseCauchy(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::FinalizeMaterialResponseCauchy(ConstitutiveLaw::Parameters& rValues) { this->FinalizeMaterialResponsePK2(rValues); } @@ -233,7 +214,8 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponseCauchy(ConstitutiveLaw::Pa /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::FinalizeMaterialResponseKirchhoff(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::FinalizeMaterialResponseKirchhoff(ConstitutiveLaw::Parameters& rValues) { this->FinalizeMaterialResponsePK2(rValues); } @@ -241,12 +223,13 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponseKirchhoff(ConstitutiveLaw: /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK2(ConstitutiveLaw::Parameters& rValues) +template +void GenericAnisotropicLaw::FinalizeMaterialResponsePK2(ConstitutiveLaw::Parameters& rValues) { Flags& r_flags = rValues.GetOptions(); if (r_flags.IsNot(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN)) { Vector& r_strain_vector = rValues.GetStrainVector(); - this->CalculateCauchyGreenStrain(rValues, r_strain_vector); + ConstitutiveLawUtilities::CalculateCauchyGreenStrain(rValues, r_strain_vector); } // this strain in the real anisotropic space @@ -258,22 +241,8 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK2(ConstitutiveLaw::Param rValues.SetMaterialProperties(r_props_iso_cl); // Here we compute the rotation tensors due to the angles of the local and global axes - BoundedMatrixType rotation_matrix; BoundedMatrixVoigtType voigt_rotation_matrix; - - if (r_material_properties.Has(EULER_ANGLES) && - MathUtils::Norm3(r_material_properties[EULER_ANGLES]) > machine_tolerance) { - const Vector& r_euler_angles = r_material_properties[EULER_ANGLES]; - AdvancedConstitutiveLawUtilities::CalculateRotationOperator( - r_euler_angles(0), r_euler_angles(1), - r_euler_angles(2), rotation_matrix); - ConstitutiveLawUtilities::CalculateRotationOperatorVoigt( - (rotation_matrix), - voigt_rotation_matrix); - } else { - noalias(rotation_matrix) = IdentityMatrix(Dimension, Dimension); - noalias(voigt_rotation_matrix) = IdentityMatrix(VoigtSize, VoigtSize); - } + CalculateRotationMatrixVoigt(r_material_properties, voigt_rotation_matrix); // We compute the mappers As and Ae BoundedMatrixVoigtType stress_mapper, strain_mapper; @@ -284,12 +253,10 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK2(ConstitutiveLaw::Param this->CalculateAnisotropicStressMapperMatrix(r_material_properties, stress_mapper, stress_mapper_inv); mpIsotropicCL->CalculateValue(rValues, CONSTITUTIVE_MATRIX, isotropic_elastic_matrix); // takes the props of the iso cl this->CalculateOrthotropicElasticMatrix(anisotropic_elastic_matrix, r_material_properties); - this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, - isotropic_elastic_matrix, stress_mapper, - strain_mapper); + this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, isotropic_elastic_matrix, stress_mapper, strain_mapper); Vector &r_iso_strain_vector = rValues.GetStrainVector(); // Now we rotate the strain Eglob-> Eloc - r_iso_strain_vector = prod((voigt_rotation_matrix), r_iso_strain_vector); + r_iso_strain_vector = prod(voigt_rotation_matrix, r_iso_strain_vector); // Now we map the strains to the isotropic fictitious space: Eiso = Ae*Ereal,loc r_iso_strain_vector = prod(strain_mapper, r_iso_strain_vector); // mapped @@ -303,7 +270,8 @@ void GenericAnisotropic3DLaw::FinalizeMaterialResponsePK2(ConstitutiveLaw::Param /***********************************************************************************/ /***********************************************************************************/ -double& GenericAnisotropic3DLaw::GetValue( +template +double& GenericAnisotropicLaw::GetValue( const Variable& rThisVariable, double& rValue ) @@ -314,7 +282,8 @@ double& GenericAnisotropic3DLaw::GetValue( /***********************************************************************************/ /***********************************************************************************/ -Vector& GenericAnisotropic3DLaw::GetValue( +template +Vector& GenericAnisotropicLaw::GetValue( const Variable& rThisVariable, Vector& rValue ) @@ -325,7 +294,8 @@ Vector& GenericAnisotropic3DLaw::GetValue( /***********************************************************************************/ /***********************************************************************************/ -Matrix& GenericAnisotropic3DLaw::GetValue( +template +Matrix& GenericAnisotropicLaw::GetValue( const Variable& rThisVariable, Matrix& rValue ) @@ -336,7 +306,8 @@ Matrix& GenericAnisotropic3DLaw::GetValue( /***********************************************************************************/ /***********************************************************************************/ -bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) +template +bool GenericAnisotropicLaw::Has(const Variable& rThisVariable) { return mpIsotropicCL->Has(rThisVariable); } @@ -344,7 +315,8 @@ bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) /***********************************************************************************/ /***********************************************************************************/ -bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) +template +bool GenericAnisotropicLaw::Has(const Variable& rThisVariable) { return mpIsotropicCL->Has(rThisVariable); } @@ -352,7 +324,8 @@ bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) /***********************************************************************************/ /***********************************************************************************/ -bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) +template +bool GenericAnisotropicLaw::Has(const Variable& rThisVariable) { return false; } @@ -360,7 +333,8 @@ bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) /***********************************************************************************/ /***********************************************************************************/ -bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) +template +bool GenericAnisotropicLaw::Has(const Variable& rThisVariable) { return mpIsotropicCL->Has(rThisVariable); } @@ -368,7 +342,8 @@ bool GenericAnisotropic3DLaw::Has(const Variable& rThisVariable) /***********************************************************************************/ /***********************************************************************************/ -double& GenericAnisotropic3DLaw::CalculateValue( +template +double& GenericAnisotropicLaw::CalculateValue( Parameters& rParameterValues, const Variable& rThisVariable, double& rValue) @@ -379,7 +354,8 @@ double& GenericAnisotropic3DLaw::CalculateValue( /***********************************************************************************/ /***********************************************************************************/ -Vector& GenericAnisotropic3DLaw::CalculateValue( +template +Vector& GenericAnisotropicLaw::CalculateValue( Parameters& rParameterValues, const Variable& rThisVariable, Vector& rValue) @@ -387,7 +363,7 @@ Vector& GenericAnisotropic3DLaw::CalculateValue( if (rThisVariable == GREEN_LAGRANGE_STRAIN_VECTOR) { Flags& r_flags = rParameterValues.GetOptions(); if (r_flags.IsNot(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN)) { - this->CalculateCauchyGreenStrain(rParameterValues, rValue); + ConstitutiveLawUtilities::CalculateCauchyGreenStrain(rParameterValues, rValue); } else { noalias(rValue) = rParameterValues.GetStrainVector(); } @@ -465,25 +441,10 @@ Vector& GenericAnisotropic3DLaw::CalculateValue( values_iso_cl.SetMaterialProperties(r_props_iso_cl); // Here we compute the rotation tensors due to the angles of the local and global axes - BoundedMatrixType rotation_matrix; BoundedMatrixVoigtType voigt_rotation_matrix, inv_voigt_rotation_matrix; - - if (r_material_properties.Has(EULER_ANGLES) && - MathUtils::Norm3(r_material_properties[EULER_ANGLES]) > machine_tolerance) { - const Vector& r_euler_angles = r_material_properties[EULER_ANGLES]; - AdvancedConstitutiveLawUtilities::CalculateRotationOperator( - r_euler_angles(0), r_euler_angles(1), - r_euler_angles(2), rotation_matrix); - ConstitutiveLawUtilities::CalculateRotationOperatorVoigt( - (rotation_matrix), - voigt_rotation_matrix); - double det = 0.0; - MathUtils::InvertMatrix(voigt_rotation_matrix, inv_voigt_rotation_matrix, det); - } else { - noalias(rotation_matrix) = IdentityMatrix(Dimension, Dimension); - noalias(voigt_rotation_matrix) = IdentityMatrix(VoigtSize, VoigtSize); - noalias(inv_voigt_rotation_matrix) = IdentityMatrix(VoigtSize, VoigtSize); - } + CalculateRotationMatrixVoigt(r_material_properties, voigt_rotation_matrix); + double det = 0.0; + MathUtils::InvertMatrix(voigt_rotation_matrix, inv_voigt_rotation_matrix, det); // We compute the mappers As and Ae BoundedMatrixVoigtType stress_mapper, strain_mapper; @@ -494,9 +455,7 @@ Vector& GenericAnisotropic3DLaw::CalculateValue( this->CalculateAnisotropicStressMapperMatrix(r_material_properties, stress_mapper, stress_mapper_inv); mpIsotropicCL->CalculateValue(values_iso_cl, CONSTITUTIVE_MATRIX, isotropic_elastic_matrix); this->CalculateOrthotropicElasticMatrix(anisotropic_elastic_matrix, r_material_properties); - this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, - isotropic_elastic_matrix, stress_mapper, - strain_mapper); + this->CalculateAnisotropicStrainMapperMatrix(anisotropic_elastic_matrix, isotropic_elastic_matrix, stress_mapper, strain_mapper); BoundedMatrixVoigtType invAe; double aux_det; MathUtils::InvertMatrix(strain_mapper, invAe, aux_det); @@ -516,47 +475,47 @@ Vector& GenericAnisotropic3DLaw::CalculateValue( /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateAnisotropicStressMapperMatrix( +template +void GenericAnisotropicLaw::CalculateAnisotropicStressMapperMatrix( const Properties& rProperties, BoundedMatrixVoigtType& rAs, BoundedMatrixVoigtType& rAsInv ) { - noalias(rAs) = ZeroMatrix(VoigtSize, VoigtSize); - noalias(rAsInv) = ZeroMatrix(VoigtSize, VoigtSize); + rAs.clear(); + rAsInv.clear(); + // We use the same input in 2D and in 3D const Vector &r_iso_aniso_yield_ratios = rProperties[ISOTROPIC_ANISOTROPIC_YIELD_RATIO]; - KRATOS_ERROR_IF_NOT(r_iso_aniso_yield_ratios.size() == VoigtSize) << "The length of the ISOTROPIC_ANISOTROPIC_YIELD_RATIO is not correct" << std::endl; - - if (VoigtSize == 6) { - rAs(0, 0) = r_iso_aniso_yield_ratios(0); - rAs(1, 1) = r_iso_aniso_yield_ratios(1); - rAs(2, 2) = r_iso_aniso_yield_ratios(2); - rAs(3, 3) = r_iso_aniso_yield_ratios(3); - rAs(4, 4) = r_iso_aniso_yield_ratios(4); - rAs(5, 5) = r_iso_aniso_yield_ratios(5); + if constexpr (VoigtSize == 6) { + rAs(0, 0) = r_iso_aniso_yield_ratios[0]; // xx + rAs(1, 1) = r_iso_aniso_yield_ratios[1]; // yy + rAs(2, 2) = r_iso_aniso_yield_ratios[2]; // zz + rAs(3, 3) = r_iso_aniso_yield_ratios[3]; // xy + rAs(4, 4) = r_iso_aniso_yield_ratios[4]; // yz + rAs(5, 5) = r_iso_aniso_yield_ratios[5]; // xz } else { - rAs(0, 0) = r_iso_aniso_yield_ratios(0); - rAs(1, 1) = r_iso_aniso_yield_ratios(1); - rAs(2, 2) = r_iso_aniso_yield_ratios(2); + rAs(0, 0) = r_iso_aniso_yield_ratios[0]; // xx + rAs(1, 1) = r_iso_aniso_yield_ratios[1]; // yy + rAs(2, 2) = r_iso_aniso_yield_ratios[3]; // xy } - for (IndexType i = 0; i < VoigtSize; ++i) + + for (IndexType i = 0; i < VoigtSize; ++i) { rAsInv(i, i) = 1.0 / rAs(i, i); + } } /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateAnisotropicStrainMapperMatrix( +template +void GenericAnisotropicLaw::CalculateAnisotropicStrainMapperMatrix( const BoundedMatrixVoigtType& rAnisotropicElasticMatrix, const BoundedMatrixVoigtType& rIsotropicElasticMatrix, const BoundedMatrixVoigtType &rAs, BoundedMatrixVoigtType& rAe ) { - noalias(rAe) = ZeroMatrix(VoigtSize, VoigtSize); - Matrix inv_isotropic_elastic_matrix(VoigtSize, VoigtSize); - noalias(inv_isotropic_elastic_matrix) = ZeroMatrix(VoigtSize, VoigtSize); double aux_det; MathUtils::InvertMatrix(rIsotropicElasticMatrix, inv_isotropic_elastic_matrix, aux_det); noalias(rAe) = prod(inv_isotropic_elastic_matrix, Matrix(prod(rAs, rAnisotropicElasticMatrix))); @@ -565,7 +524,8 @@ void GenericAnisotropic3DLaw::CalculateAnisotropicStrainMapperMatrix( /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::InitializeMaterial( +template +void GenericAnisotropicLaw::InitializeMaterial( const Properties& rMaterialProperties, const GeometryType& rElementGeometry, const Vector& rShapeFunctionsValues) @@ -575,21 +535,13 @@ void GenericAnisotropic3DLaw::InitializeMaterial( KRATOS_ERROR_IF_NOT(r_props_isotropic_cl.Has(CONSTITUTIVE_LAW)) << "No constitutive law set" << std::endl; mpIsotropicCL = r_props_isotropic_cl[CONSTITUTIVE_LAW]->Clone(); mpIsotropicCL->InitializeMaterial(r_props_isotropic_cl, rElementGeometry, rShapeFunctionsValues); - - // We check now the dimension of the CL pointer, must be 3D - KRATOS_ERROR_IF_NOT(mpIsotropicCL->GetStrainSize() == 6) << "The slave CL has a dimension lower than 3, not possible" << std::endl; - - // Let's check variables - KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(ISOTROPIC_ANISOTROPIC_YIELD_RATIO)) << "ISOTROPIC_ANISOTROPIC_YIELD_RATIO not defined in properties" << std::endl; - - KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(ORTHOTROPIC_ELASTIC_CONSTANTS)) << "The ORTHOTROPIC_ELASTIC_CONSTANTS are not defined" << std::endl; - KRATOS_ERROR_IF_NOT(rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS].size() == 6) << "The dimension of the ORTHOTROPIC_ELASTIC_CONSTANTS is incorrect" << std::endl; } /***********************************************************************************/ /***********************************************************************************/ -Matrix& GenericAnisotropic3DLaw::CalculateValue( +template +Matrix& GenericAnisotropicLaw::CalculateValue( ConstitutiveLaw::Parameters& rParameterValues, const Variable& rThisVariable, Matrix& rValue @@ -601,36 +553,17 @@ Matrix& GenericAnisotropic3DLaw::CalculateValue( /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::InitializeMaterialResponsePK2(Parameters& rValues) +template +void GenericAnisotropicLaw::InitializeMaterialResponsePK2(Parameters& rValues) { mpIsotropicCL->InitializeMaterialResponsePK2(rValues); } - /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateCauchyGreenStrain( - ConstitutiveLaw::Parameters& rValues, - Vector& rStrainVector - ) -{ - // Compute total deformation gradient - const BoundedMatrixType& F = rValues.GetDeformationGradientF(); - - BoundedMatrixType E_tensor = ZeroMatrix(F.size1()); - E_tensor = prod(trans(F), F); - for(unsigned int i = 0; i < Dimension; ++i) - E_tensor(i, i) -= 1.0; - E_tensor *= 0.5; - - noalias(rStrainVector) = MathUtils::StrainTensorToVector(E_tensor); -} - -/***********************************************************************************/ -/***********************************************************************************/ - -int GenericAnisotropic3DLaw::Check( +template +int GenericAnisotropicLaw::Check( const Properties& rMaterialProperties, const GeometryType& rElementGeometry, const ProcessInfo& rCurrentProcessInfo @@ -638,28 +571,21 @@ int GenericAnisotropic3DLaw::Check( { const auto it_cl_begin = rMaterialProperties.GetSubProperties().begin(); const auto& r_props_iso_cl = *(it_cl_begin); + + // We check now the dimension of the CL pointer and th dimension of the anisotropic one + KRATOS_ERROR_IF_NOT(mpIsotropicCL->GetStrainSize() == VoigtSize) << "The slave CL has a different dimension of the Generic Anisotropic CL..." << std::endl; + + // Let's check variables + KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(ISOTROPIC_ANISOTROPIC_YIELD_RATIO)) << "ISOTROPIC_ANISOTROPIC_YIELD_RATIO not defined in properties" << std::endl; + KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(ORTHOTROPIC_ELASTIC_CONSTANTS)) << "The ORTHOTROPIC_ELASTIC_CONSTANTS are not defined" << std::endl; + KRATOS_ERROR_IF_NOT(rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS].size() == 6) << "The dimension of the ORTHOTROPIC_ELASTIC_CONSTANTS is incorrect" << std::endl; return mpIsotropicCL->Check(r_props_iso_cl, rElementGeometry, rCurrentProcessInfo); } /***********************************************************************************/ /***********************************************************************************/ -void GenericAnisotropic3DLaw::CalculateTangentTensor(ConstitutiveLaw::Parameters& rValues) -{ - const Properties& r_material_properties = rValues.GetMaterialProperties(); - - const bool consider_perturbation_threshold = r_material_properties.Has(CONSIDER_PERTURBATION_THRESHOLD) ? r_material_properties[CONSIDER_PERTURBATION_THRESHOLD] : true; - const TangentOperatorEstimation tangent_operator_estimation = r_material_properties.Has(TANGENT_OPERATOR_ESTIMATION) ? static_cast(r_material_properties[TANGENT_OPERATOR_ESTIMATION]) : TangentOperatorEstimation::SecondOrderPerturbation; - - if (tangent_operator_estimation == TangentOperatorEstimation::Analytic) { - KRATOS_ERROR << "Analytic solution not available" << std::endl; - } else if (tangent_operator_estimation == TangentOperatorEstimation::FirstOrderPerturbation) { - // Calculates the Tangent Constitutive Tensor by perturbation (first order) - TangentOperatorCalculatorUtility::CalculateTangentTensor(rValues, this, ConstitutiveLaw::StressMeasure_PK2, consider_perturbation_threshold, 1); - } else if (tangent_operator_estimation == TangentOperatorEstimation::SecondOrderPerturbation) { - // Calculates the Tangent Constitutive Tensor by perturbation (second order) - TangentOperatorCalculatorUtility::CalculateTangentTensor(rValues, this, ConstitutiveLaw::StressMeasure_PK2, consider_perturbation_threshold, 2); - } -} +template class GenericAnisotropicLaw<2>; +template class GenericAnisotropicLaw<3>; } // namespace Kratos diff --git a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.h b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.h similarity index 86% rename from applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.h rename to applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.h index 6c05b60411b4..c799be9bbd3f 100644 --- a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_3d_law.h +++ b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.h @@ -9,7 +9,7 @@ // license: structural_mechanics_application/license.txt // // Main authors: Alejandro Cornejo -// Collaborator: Lucia Barbu +// // #pragma once @@ -30,6 +30,9 @@ namespace Kratos ///@name Type Definitions ///@{ + /// The size type definition +using SizeType = std::size_t; + ///@} ///@name Enum's ///@{ @@ -41,48 +44,45 @@ namespace Kratos ///@} ///@name Kratos Classes ///@{ -/** - * @class GenericAnisotropic3DLaw - * @ingroup StructuralMechanicsApplication - * @brief This CL takes into account the material anisotropy in terms of - * young modulus, poisson ratio, orientation and strengths. - * @details See "Comportamiento mecánico de los materiales compuestos" by S. Oller, - * Chapter "Anisotropía mecánica" + +/* + * @class GenericAnisotropicLaw + * @ingroup ConstitutiveLawsApplication + * @brief This CL takes into account the material anisotropy in terms of young modulus, poisson ratio, orientation and strengths. 3D CLs and plane strain. + * @details See "Nonlinear behavior of existing pre-tensioned concrete beams: Experimental study and finite element modeling with the constitutive Serial-Parallel rule of mixtures", DOI: https://doi.org/10.1016/j.istruc.2024.106990 * @author Alejandro Cornejo */ -class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw +template +class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropicLaw : public ConstitutiveLaw { - public: +public: ///@name Type Definitions ///@{ /// The node definition - typedef Node NodeType; + using NodeType = Node; /// The geometry definition - typedef Geometry GeometryType; + using GeometryType = Geometry; /// Definition of the machine precision tolerance static constexpr double machine_tolerance = std::numeric_limits::epsilon(); - /// The size type definition - typedef std::size_t SizeType; - /// Static definition of the dimension - static constexpr SizeType Dimension = 3; + static constexpr SizeType Dimension = TDim; /// Static definition of the VoigtSize - static constexpr SizeType VoigtSize = 6; + static constexpr SizeType VoigtSize = (Dimension == 3) ? 6 : 3; /// The definition of the bounded matrix type - typedef BoundedMatrix BoundedMatrixType; + using BoundedMatrixType = BoundedMatrix; /// The definition of the bounded matrix type - typedef BoundedMatrix BoundedMatrixVoigtType; + using BoundedMatrixVoigtType = BoundedMatrix; - /// Counted pointer of GenericAnisotropic3DLaw - KRATOS_CLASS_POINTER_DEFINITION(GenericAnisotropic3DLaw); + /// Counted pointer of GenericAnisotropicLaw + KRATOS_CLASS_POINTER_DEFINITION(GenericAnisotropicLaw); ///@} ///@name Life Cycle @@ -91,7 +91,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw /** * Constructor. */ - GenericAnisotropic3DLaw() + GenericAnisotropicLaw() { } @@ -100,11 +100,11 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw */ ConstitutiveLaw::Pointer Clone() const override { - return Kratos::make_shared(*this); + return Kratos::make_shared>(*this); } // Copy constructor - GenericAnisotropic3DLaw(GenericAnisotropic3DLaw const& rOther) + GenericAnisotropicLaw(GenericAnisotropicLaw const& rOther) : ConstitutiveLaw(rOther), mpIsotropicCL(rOther.mpIsotropicCL) { @@ -113,7 +113,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw /** * Destructor. */ - ~GenericAnisotropic3DLaw() override + ~GenericAnisotropicLaw() override { } @@ -137,7 +137,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw */ SizeType WorkingSpaceDimension() override { - return 3; + return Dimension; }; /** @@ -145,7 +145,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw */ SizeType GetStrainSize() const override { - return 6; + return VoigtSize; }; /** @@ -311,6 +311,13 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw BoundedMatrixVoigtType& rAsInv ); + /** + * @brief This computes the rotation matrix, from global to local + */ + void CalculateRotationMatrixVoigt( + const Properties& rProperties, + BoundedMatrixVoigtType &rT); + /** * @brief This computes the mapper operator between the strain in the isotropic * "ficticious" space and the real anisotropic space @@ -323,8 +330,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw const BoundedMatrixVoigtType& rAnisotropicElasticMatrix, const BoundedMatrixVoigtType& rIsotropicElasticMatrix, const BoundedMatrixVoigtType &rAs, - BoundedMatrixVoigtType& rAe - ); + BoundedMatrixVoigtType& rAe); /** * Initialize the material response in terms of 2nd Piola-Kirchhoff stresses @@ -348,15 +354,22 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw return mpIsotropicCL->RequiresFinalizeMaterialResponse(); } - void CalculateOrthotropicElasticMatrix( + /** + * @brief This method computes the orthotropic elastic constitutive matrix + * This method is overriden in the derived class for plane stress + */ + virtual void CalculateOrthotropicElasticMatrix( BoundedMatrixVoigtType &rElasticityTensor, const Properties &rMaterialProperties); - int Check(const Properties &rMaterialProperties, - const GeometryType &rElementGeometry, - const ProcessInfo &rCurrentProcessInfo) const override; + /** + * @brief This method checks the properties in the nested CL + */ + int Check( + const Properties &rMaterialProperties, + const GeometryType &rElementGeometry, + const ProcessInfo &rCurrentProcessInfo) const override; - void CalculateTangentTensor(ConstitutiveLaw::Parameters &rValues); ///@} ///@name Access ///@{ @@ -375,7 +388,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw ///@} - protected: +protected: ///@name Protected static Member Variables ///@{ @@ -403,7 +416,6 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw mpIsotropicCL = pIsotropicConstitutiveLaw; } - ///@} ///@name Protected Operations ///@{ @@ -421,7 +433,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw ///@{ ///@} - private: +private: ///@name Static Member Variables ///@{ @@ -439,10 +451,6 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw ///@name Private Operations ///@{ - void CalculateCauchyGreenStrain( - ConstitutiveLaw::Parameters &rValues, - Vector &rStrainVector); - ///@} ///@name Private Access ///@{ @@ -473,6 +481,6 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropic3DLaw ///@} -}; // Class GenericAnisotropic3DLaw +}; // Class GenericAnisotropicLaw } // namespace Kratos diff --git a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.cpp b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.cpp new file mode 100644 index 000000000000..d3168ad89f3a --- /dev/null +++ b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.cpp @@ -0,0 +1,48 @@ +// KRATOS ___ _ _ _ _ _ __ _ +// / __\___ _ __ ___| |_(_) |_ _ _| |_(_)_ _____ / / __ ___ _____ /_\ _ __ _ __ +// / / / _ \| '_ \/ __| __| | __| | | | __| \ \ / / _ \/ / / _` \ \ /\ / / __| //_\\| '_ \| '_ | +// / /__| (_) | | | \__ \ |_| | |_| |_| | |_| |\ V / __/ /__| (_| |\ V V /\__ \/ _ \ |_) | |_) | +// \____/\___/|_| |_|___/\__|_|\__|\__,_|\__|_| \_/ \___\____/\__,_| \_/\_/ |___/\_/ \_/ .__/| .__/ +// |_| |_| +// +// License: BSD License +// license: structural_mechanics_application/license.txt +// +// Main authors: Alejandro Cornejo +// +// + +// System includes + +// External includes + +// Project includes + +#include "generic_anisotropic_plane_stress_2d_law.h" +#include "custom_utilities/advanced_constitutive_law_utilities.h" + +namespace Kratos +{ + +/***********************************************************************************/ +/***********************************************************************************/ + +ConstitutiveLaw::Pointer GenericAnisotropicPlaneStress2DLaw::Create(Kratos::Parameters NewParameters) const +{ + return Kratos::make_shared(); +} + +/***********************************************************************************/ +/***********************************************************************************/ + +void GenericAnisotropicPlaneStress2DLaw::CalculateOrthotropicElasticMatrix( + BoundedMatrixVoigtType& rElasticityTensor, + const Properties& rMaterialProperties) +{ + AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrixPlaneStress(rElasticityTensor, rMaterialProperties); +} + +/***********************************************************************************/ +/***********************************************************************************/ + +} // namespace Kratos diff --git a/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.h b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.h new file mode 100644 index 000000000000..c41790211275 --- /dev/null +++ b/applications/ConstitutiveLawsApplication/custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.h @@ -0,0 +1,216 @@ +// KRATOS ___ _ _ _ _ _ __ _ +// / __\___ _ __ ___| |_(_) |_ _ _| |_(_)_ _____ / / __ ___ _____ /_\ _ __ _ __ +// / / / _ \| '_ \/ __| __| | __| | | | __| \ \ / / _ \/ / / _` \ \ /\ / / __| //_\\| '_ \| '_ | +// / /__| (_) | | | \__ \ |_| | |_| |_| | |_| |\ V / __/ /__| (_| |\ V V /\__ \/ _ \ |_) | |_) | +// \____/\___/|_| |_|___/\__|_|\__|\__,_|\__|_| \_/ \___\____/\__,_| \_/\_/ |___/\_/ \_/ .__/| .__/ +// |_| |_| +// +// License: BSD License +// license: structural_mechanics_application/license.txt +// +// Main authors: Alejandro Cornejo +// +// + +#pragma once + +// System includes + +// External includes + +// Project includes +#include "generic_anisotropic_law.h" + +namespace Kratos +{ +///@name Kratos Globals +///@{ + +///@} +///@name Type Definitions +///@{ + + /// The size type definition +using SizeType = std::size_t; + +///@} +///@name Enum's +///@{ + +///@} +///@name Functions +///@{ + +///@} +///@name Kratos Classes +///@{ + +/* + * @class GenericAnisotropicLaw + * @ingroup ConstitutiveLawsApplication + * @brief This CL takes into account the material anisotropy in terms of young modulus, poisson ratio, orientation and strengths. 3D CLs and plane strain. + * @details See "Nonlinear behavior of existing pre-tensioned concrete beams: Experimental study and finite element modeling with the constitutive Serial-Parallel rule of mixtures", DOI: https://doi.org/10.1016/j.istruc.2024.106990 + * @author Alejandro Cornejo + */ +class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) GenericAnisotropicPlaneStress2DLaw + : public GenericAnisotropicLaw<2> +{ +public: + ///@name Type Definitions + ///@{ + + using BaseType = GenericAnisotropicLaw<2>; + + /// Counted pointer of GenericAnisotropicLaw + KRATOS_CLASS_POINTER_DEFINITION(GenericAnisotropicPlaneStress2DLaw); + + ///@} + ///@name Life Cycle + ///@{ + + /** + * Constructor. + */ + GenericAnisotropicPlaneStress2DLaw() + { + } + + /** + * Clone. + */ + ConstitutiveLaw::Pointer Clone() const override + { + return Kratos::make_shared(*this); + } + + // Copy constructor + GenericAnisotropicPlaneStress2DLaw(GenericAnisotropicPlaneStress2DLaw const& rOther) + : BaseType(rOther) + { + } + + /** + * Destructor. + */ + ~GenericAnisotropicPlaneStress2DLaw() override + { + } + + /** + * creates a new constitutive law pointer + * @param NewParameters The configuration parameters of the new constitutive law + * @return a Pointer to the new constitutive law + */ + ConstitutiveLaw::Pointer Create(Kratos::Parameters NewParameters) const override; + + ///@} + ///@name Operators + ///@{ + + ///@} + ///@name Operations + ///@{ + + + /** + * @brief This method computes the orthotropic elastic constitutive matrix + * This method is overriden in the derived class for plane stress + */ + void CalculateOrthotropicElasticMatrix( + BoundedMatrixVoigtType &rElasticityTensor, + const Properties &rMaterialProperties) override; + + ///@} + ///@name Access + ///@{ + + ///@} + ///@name Inquiry + ///@{ + + ///@} + ///@name Input and output + ///@{ + + ///@} + ///@name Friends + ///@{ + + ///@} + +protected: + ///@name Protected static Member Variables + ///@{ + + ///@} + ///@name Protected member Variables + ///@{ + + ///@} + ///@name Protected Operators + ///@{ + + ///@} + ///@name Protected Operations + ///@{ + + ///@} + ///@name Protected Access + ///@{ + + ///@} + ///@name Protected Inquiry + ///@{ + + ///@} + ///@name Protected LifeCycle + ///@{ + + ///@} +private: + ///@name Static Member Variables + ///@{ + + ///@} + ///@name Member Variables + ///@{ + + ///@} + ///@name Private Operators + ///@{ + + ///@} + ///@name Private Operations + ///@{ + + ///@} + ///@name Private Access + ///@{ + + ///@} + ///@name Private Inquiry + ///@{ + + ///@} + ///@name Un accessible methods + ///@{ + + // Serialization + + friend class Serializer; + + void save(Serializer& rSerializer) const override + { + KRATOS_SERIALIZE_SAVE_BASE_CLASS(rSerializer, BaseType) + } + + void load(Serializer& rSerializer) override + { + KRATOS_SERIALIZE_LOAD_BASE_CLASS(rSerializer, BaseType) + } + + ///@} + +}; // Class GenericAnisotropicLaw + +} // namespace Kratos diff --git a/applications/ConstitutiveLawsApplication/custom_python/add_custom_constitutive_laws_to_python.cpp b/applications/ConstitutiveLawsApplication/custom_python/add_custom_constitutive_laws_to_python.cpp index efb2fbbd5db4..f0764e9d8133 100644 --- a/applications/ConstitutiveLawsApplication/custom_python/add_custom_constitutive_laws_to_python.cpp +++ b/applications/ConstitutiveLawsApplication/custom_python/add_custom_constitutive_laws_to_python.cpp @@ -103,6 +103,8 @@ // Rules of mixtures #include "custom_constitutive/composites/rule_of_mixtures_law.h" #include "custom_constitutive/composites/traction_separation_law.h" +#include "custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_law.h" +#include "custom_constitutive/small_strains/anisotropy_orthotropy/generic_anisotropic_plane_stress_2d_law.h" #include "custom_constitutive/small_strains/plastic_damage/associative_plastic_damage_model.h" @@ -1355,6 +1357,18 @@ void AddCustomConstitutiveLawsToPython(pybind11::module& m) (m,"SerialParallelRuleOfMixturesLaw").def(py::init<>()) ; + py::class_< GenericAnisotropicLaw<3>, typename GenericAnisotropicLaw<3>::Pointer, ConstitutiveLaw > + (m,"GenericAnisotropic3DLaw").def(py::init<>()) + ; + + py::class_< GenericAnisotropicLaw<2>, typename GenericAnisotropicLaw<2>::Pointer, ConstitutiveLaw > + (m,"GenericAnisotropicPlaneStrain2DLaw").def(py::init<>()) + ; + + py::class_< GenericAnisotropicPlaneStress2DLaw, typename GenericAnisotropicPlaneStress2DLaw::Pointer, ConstitutiveLaw > + (m,"GenericAnisotropicPlaneStress2DLaw").def(py::init<>()) + ; + py::class_< AssociativePlasticDamageModel >>, typename AssociativePlasticDamageModel >>::Pointer, ConstitutiveLaw > diff --git a/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.cpp b/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.cpp index 0781dee6d771..7f13d7309d54 100644 --- a/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.cpp +++ b/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.cpp @@ -19,6 +19,7 @@ #include "includes/global_variables.h" #include "utilities/math_utils.h" #include "custom_utilities/advanced_constitutive_law_utilities.h" +#include "constitutive_laws_application_variables.h" namespace Kratos { @@ -677,19 +678,23 @@ Matrix AdvancedConstitutiveLawUtilities::CalculateDirectPlasticDefor template void AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEuler1( const double EulerAngle1, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ) { - noalias(rRotationOperator) = ZeroMatrix(Dimension, Dimension); + rRotationOperator.clear(); - const double cos_angle = std::cos(EulerAngle1 * Globals::Pi / 180.0); - const double sin_angle = std::sin(EulerAngle1 * Globals::Pi / 180.0); + const double angle_radians = EulerAngle1 * Globals::Pi / 180.0; + const double cos_angle = std::cos(angle_radians); + const double sin_angle = std::sin(angle_radians); rRotationOperator(0, 0) = cos_angle; rRotationOperator(0, 1) = sin_angle; rRotationOperator(1, 0) = -sin_angle; rRotationOperator(1, 1) = cos_angle; - rRotationOperator(2, 2) = 1.0; + + if constexpr (Dimension == 3) { + rRotationOperator(2, 2) = 1.0; + } } /***********************************************************************************/ @@ -698,19 +703,24 @@ void AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEule template void AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEuler2( const double EulerAngle2, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ) { - noalias(rRotationOperator) = ZeroMatrix(Dimension, Dimension); + rRotationOperator.clear(); - const double cos_angle = std::cos(EulerAngle2 * Globals::Pi / 180.0); - const double sin_angle = std::sin(EulerAngle2 * Globals::Pi / 180.0); + if constexpr (Dimension == 3) { + const double cos_angle = std::cos(EulerAngle2 * Globals::Pi / 180.0); + const double sin_angle = std::sin(EulerAngle2 * Globals::Pi / 180.0); + + rRotationOperator(0, 0) = 1.0; + rRotationOperator(1, 1) = cos_angle; + rRotationOperator(1, 2) = sin_angle; + rRotationOperator(2, 1) = -sin_angle; + rRotationOperator(2, 2) = cos_angle; + } else { + KRATOS_ERROR << "This operation cannot be done in Dimension = 2 ..." << std::endl; + } - rRotationOperator(0, 0) = 1.0; - rRotationOperator(1, 1) = cos_angle; - rRotationOperator(1, 2) = sin_angle; - rRotationOperator(2, 1) = -sin_angle; - rRotationOperator(2, 2) = cos_angle; } /***********************************************************************************/ @@ -719,7 +729,7 @@ void AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEule template void AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEuler3( const double EulerAngle3, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ) { AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEuler1(EulerAngle3, rRotationOperator); @@ -733,26 +743,32 @@ void AdvancedConstitutiveLawUtilities::CalculateRotationOperator( const double EulerAngle1, // phi const double EulerAngle2, // theta const double EulerAngle3, // hi - BoundedMatrix& rRotationOperator // global to local coordinates + BoundedMatrix& rRotationOperator // global to local coordinates ) { + const double pi_over_180 = Globals::Pi / 180.0; - const double cos1 = std::cos(EulerAngle1 * pi_over_180); - const double sin1 = std::sin(EulerAngle1 * pi_over_180); - const double cos2 = std::cos(EulerAngle2 * pi_over_180); - const double sin2 = std::sin(EulerAngle2 * pi_over_180); - const double cos3 = std::cos(EulerAngle3 * pi_over_180); - const double sin3 = std::sin(EulerAngle3 * pi_over_180); - rRotationOperator(0, 0) = cos1 * cos3 - sin1 * cos2 * sin3; - rRotationOperator(0, 1) = sin1 * cos3 + cos1 * cos2 * sin3; - rRotationOperator(0, 2) = sin2 * sin3; - rRotationOperator(1, 0) = -cos1 * sin3 - sin1 * cos2 * cos3; - rRotationOperator(1, 1) = -sin1 * sin3 + cos1 * cos2 * cos3; - rRotationOperator(1, 2) = sin2 * cos3; - rRotationOperator(2, 0) = sin1 * sin2; - rRotationOperator(2, 1) = -cos1 * sin2; - rRotationOperator(2, 2) = cos2; + if constexpr (Dimension == 3) { + const double cos1 = std::cos(EulerAngle1 * pi_over_180); + const double sin1 = std::sin(EulerAngle1 * pi_over_180); + const double cos2 = std::cos(EulerAngle2 * pi_over_180); + const double sin2 = std::sin(EulerAngle2 * pi_over_180); + const double cos3 = std::cos(EulerAngle3 * pi_over_180); + const double sin3 = std::sin(EulerAngle3 * pi_over_180); + + rRotationOperator(0, 0) = cos1 * cos3 - sin1 * cos2 * sin3; + rRotationOperator(0, 1) = sin1 * cos3 + cos1 * cos2 * sin3; + rRotationOperator(0, 2) = sin2 * sin3; + rRotationOperator(1, 0) = -cos1 * sin3 - sin1 * cos2 * cos3; + rRotationOperator(1, 1) = -sin1 * sin3 + cos1 * cos2 * cos3; + rRotationOperator(1, 2) = sin2 * cos3; + rRotationOperator(2, 0) = sin1 * sin2; + rRotationOperator(2, 1) = -cos1 * sin2; + rRotationOperator(2, 2) = cos2; + } else { // In 2D + AdvancedConstitutiveLawUtilities::CalculateRotationOperatorEuler1(EulerAngle1, rRotationOperator); + } } /***********************************************************************************/ @@ -842,6 +858,140 @@ double AdvancedConstitutiveLawUtilities::GetPropertyFromTemperatureT /***********************************************************************************/ /***********************************************************************************/ +template +void AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrix( + BoundedMatrixVoigtType& rElasticityTensor, + const Properties& rMaterialProperties) +{ + KRATOS_TRY + + rElasticityTensor.clear(); + + const Vector& r_ortho_elastic_constants = rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS]; + const double Ex = r_ortho_elastic_constants[0]; + const double Ey = r_ortho_elastic_constants[1]; + const double Ez = r_ortho_elastic_constants[2]; + const double vxy = r_ortho_elastic_constants[3]; + const double vyz = r_ortho_elastic_constants[4]; + const double vxz = r_ortho_elastic_constants[5]; + + const double vyx = vxy * Ey / Ex; + const double vzx = vxz * Ez / Ex; + const double vzy = vyz * Ez / Ey; + + KRATOS_ERROR_IF(vyx > 0.5) << "The Poisson_yx is greater than 0.5." << std::endl; + KRATOS_ERROR_IF(vzx > 0.5) << "The Poisson_zx is greater than 0.5." << std::endl; + KRATOS_ERROR_IF(vzy > 0.5) << "The Poisson_zy is greater than 0.5." << std::endl; + + const double ctant = 1.0 / (1.0 - vxy * vyx - vzy * vyz - vzx * vxz - vxy * vyz * vzx - vxz * vyx * vzy); + + rElasticityTensor(0, 0) = Ex * (1.0 - vyz * vzy) * ctant; + rElasticityTensor(0, 1) = Ex * (vyx + vyz * vzx) * ctant; + rElasticityTensor(1, 0) = Ey * (vxy + vzy * vxz) * ctant; + + rElasticityTensor(0, 2) = Ex * (vzx + vyx * vzy) * ctant; + rElasticityTensor(2, 0) = Ez * (vxz + vxy * vyz) * ctant; + rElasticityTensor(1, 1) = Ey * (1.0 - vxz * vzx) * ctant; + + rElasticityTensor(1, 2) = Ey * (vzy + vxy * vzx) * ctant; + rElasticityTensor(2, 1) = Ez * (vyz + vyx * vxz) * ctant; + rElasticityTensor(2, 2) = Ez * (1.0 - vxy * vyx) * ctant; + + rElasticityTensor(3, 3) = (rMaterialProperties.Has(SHEAR_MODULUS_XY)) ? rMaterialProperties[SHEAR_MODULUS_XY] : 1.0 / ((1.0 + vyx) / Ex + (1.0 + vxy) / Ey); + rElasticityTensor(4, 4) = (rMaterialProperties.Has(SHEAR_MODULUS_YZ)) ? rMaterialProperties[SHEAR_MODULUS_YZ] : 1.0 / ((1.0 + vzy) / Ey + (1.0 + vyz) / Ez); + rElasticityTensor(5, 5) = (rMaterialProperties.Has(SHEAR_MODULUS_XZ)) ? rMaterialProperties[SHEAR_MODULUS_XZ] : 1.0 / ((1.0 + vzx) / Ex + (1.0 + vxz) / Ez); + + KRATOS_CATCH("") +} + +/***********************************************************************************/ +/***********************************************************************************/ + +template +void AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrixPlaneStrain( + BoundedMatrixVoigtType& rElasticityTensor, + const Properties& rMaterialProperties) +{ + KRATOS_TRY + + rElasticityTensor.clear(); + // The input vector is the same as in 3D. + const Vector& r_ortho_elastic_constants = rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS]; + const double E1 = r_ortho_elastic_constants[0]; + const double E2 = r_ortho_elastic_constants[1]; + const double E3 = r_ortho_elastic_constants[2]; + const double v12 = r_ortho_elastic_constants[3]; + const double v23 = r_ortho_elastic_constants[4]; + const double v13 = r_ortho_elastic_constants[5]; + + const double v21 = v12 * E2 / E1; + const double v31 = v13 * E3 / E1; + const double v32 = v23 * E3 / E2; + + KRATOS_ERROR_IF(v21 > 0.5) << "The Poisson_yx is greater than 0.5." << std::endl; + KRATOS_ERROR_IF(v31 > 0.5) << "The Poisson_zx is greater than 0.5." << std::endl; + KRATOS_ERROR_IF(v32 > 0.5) << "The Poisson_zy is greater than 0.5." << std::endl; + + const double a = 1.0 - v23 * v32; + const double b = v12 + v32 * v13; + const double c = v21 + v23 * v31; + const double d = 1.0 - v13 * v31; + + const double factor = a * d - b * c; + + const double G12 = (rMaterialProperties.Has(SHEAR_MODULUS_XY)) ? rMaterialProperties[SHEAR_MODULUS_XY] : 1.0 / ((1.0 + v21) / E1 + (1.0 + v12) / E2); + + rElasticityTensor(0, 0) = a * E1; + rElasticityTensor(0, 1) = b * E1; + rElasticityTensor(1, 0) = c * E2; + rElasticityTensor(1, 1) = d * E2; + rElasticityTensor(2, 2) = factor * G12; + + rElasticityTensor /= factor; + + KRATOS_CATCH("") +} + +/***********************************************************************************/ +/***********************************************************************************/ + +template +void AdvancedConstitutiveLawUtilities::CalculateOrthotropicElasticMatrixPlaneStress( + BoundedMatrixVoigtType& rElasticityTensor, + const Properties& rMaterialProperties) +{ + KRATOS_TRY + + rElasticityTensor.clear(); + // The input vector is the same as in 3D. + const Vector& r_ortho_elastic_constants = rMaterialProperties[ORTHOTROPIC_ELASTIC_CONSTANTS]; + const double E1 = r_ortho_elastic_constants[0]; + const double E2 = r_ortho_elastic_constants[1]; + const double v12 = r_ortho_elastic_constants[3]; + + const double v21 = v12 * E2 / E1; + + KRATOS_ERROR_IF(v21 > 0.5) << "The Poisson_yx is greater than 0.5." << std::endl; + + const double factor = 1.0 - v12 * v21; + + const double G12 = (rMaterialProperties.Has(SHEAR_MODULUS_XY)) ? rMaterialProperties[SHEAR_MODULUS_XY] : 1.0 / ((1.0 + v21) / E1 + (1.0 + v12) / E2); + + rElasticityTensor(0, 0) = E1; + rElasticityTensor(0, 1) = v21 * E1; + rElasticityTensor(1, 0) = v12 * E2; + rElasticityTensor(1, 1) = E2; + rElasticityTensor(2, 2) = factor * G12; + + rElasticityTensor /= factor; + + KRATOS_CATCH("") +} + +/***********************************************************************************/ +/***********************************************************************************/ + + template class AdvancedConstitutiveLawUtilities<3>; template class AdvancedConstitutiveLawUtilities<6>; diff --git a/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.h b/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.h index af35f45f2dad..265cbe7587fa 100644 --- a/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.h +++ b/applications/ConstitutiveLawsApplication/custom_utilities/advanced_constitutive_law_utilities.h @@ -433,7 +433,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) AdvancedConstitutiveLawUtilities */ static void CalculateRotationOperatorEuler1( const double EulerAngle1, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ); /** @@ -442,7 +442,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) AdvancedConstitutiveLawUtilities */ static void CalculateRotationOperatorEuler2( const double EulerAngle2, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ); /** @@ -451,7 +451,7 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) AdvancedConstitutiveLawUtilities */ static void CalculateRotationOperatorEuler3( const double EulerAngle3, - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ); /** @@ -468,10 +468,31 @@ class KRATOS_API(CONSTITUTIVE_LAWS_APPLICATION) AdvancedConstitutiveLawUtilities const double EulerAngle1, // phi const double EulerAngle2, // theta const double EulerAngle3, // hi - BoundedMatrix& rRotationOperator + BoundedMatrix& rRotationOperator ); - /** + /** + * @brief This computes the elastic constituive matrix for a 3D elastic CL + */ + static void CalculateOrthotropicElasticMatrix( + BoundedMatrixVoigtType &rElasticityTensor, + const Properties &rMaterialProperties); + + /** + * @brief This computes the elastic constituive matrix for a 3D elastic CL + */ + static void CalculateOrthotropicElasticMatrixPlaneStrain( + BoundedMatrixVoigtType &rElasticityTensor, + const Properties &rMaterialProperties); + + /** + * @brief This computes the elastic constituive matrix for a 3D elastic CL + */ + static void CalculateOrthotropicElasticMatrixPlaneStress( + BoundedMatrixVoigtType &rElasticityTensor, + const Properties &rMaterialProperties); + + /** * @brief This computes the MacaullyBrackets of a double */ static double MacaullyBrackets(const double Number); diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test.mdpa b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test.mdpa new file mode 100644 index 000000000000..71377086af28 --- /dev/null +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test.mdpa @@ -0,0 +1,65 @@ +Begin ModelPartData +// VARIABLE_NAME value +End ModelPartData + +Begin Properties 0 +End Properties +Begin Nodes + 1 0.6696930000 2.7809300000 0.0000000000 + 2 0.6696930000 0.5902400000 0.0000000000 + 3 -3.2463085000 2.7809300000 0.0000000000 + 4 0.6696930000 -1.6004500000 0.0000000000 + 5 -3.2463085000 0.5902400000 0.0000000000 + 6 -3.2463085000 -1.6004500000 0.0000000000 + 7 -7.1623100000 2.7809300000 0.0000000000 + 8 -7.1623100000 0.5902400000 0.0000000000 + 9 -7.1623100000 -1.6004500000 0.0000000000 +End Nodes + + +Begin Elements SmallDisplacementElement2D4N// GUI group identifier: Solid Auto1 + 1 0 3 5 2 1 + 2 0 7 8 5 3 + 3 0 5 6 4 2 + 4 0 8 9 6 5 +End Elements + +Begin SubModelPart Parts_Solid_Solid_Auto1 // Group Solid Auto1 // Subtree Parts_Solid + Begin SubModelPartNodes + 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 + End SubModelPartNodes + Begin SubModelPartElements + 1 + 2 + 3 + 4 + End SubModelPartElements +End SubModelPart +Begin SubModelPart DISPLACEMENT_Displacement_Auto1 // Group Displacement Auto1 // Subtree DISPLACEMENT + Begin SubModelPartNodes + 7 + 8 + 9 + End SubModelPartNodes +End SubModelPart +Begin SubModelPart SelfWeight2D_Self_weight_Auto1 // Group Self weight Auto1 // Subtree SelfWeight2D + Begin SubModelPartNodes + 1 + 2 + 3 + 4 + 5 + 6 + 7 + 8 + 9 + End SubModelPartNodes +End SubModelPart diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_materials.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_materials.json new file mode 100644 index 000000000000..b8d98434899b --- /dev/null +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_materials.json @@ -0,0 +1,32 @@ +{ + "properties" : [{ + "model_part_name" : "Structure.Parts_Solid_Solid_Auto1", + "properties_id" : 1, + "Material" : { + "constitutive_law" : { + "name" : "GenericAnisotropicPlaneStress2DLaw" + }, + "Variables" : { + "ORTHOTROPIC_ELASTIC_CONSTANTS" : [10e9, 2.1e9, 2.1e9, 0.29, 0.29, 0.29], + "EULER_ANGLES" : [32,0,0], + "ISOTROPIC_ANISOTROPIC_YIELD_RATIO" : [1,1,1,1,1,1], + "DENSITY" : 7850 + }, + "Tables" : {} + }, + "sub_properties" : [{ + "properties_id" : 10, + "Material" : { + "constitutive_law" : { + "name" : "LinearElasticPlaneStrain2DLaw" + }, + "Variables" : { + "DENSITY" : 2400.0, + "YOUNG_MODULUS" : 40E9, + "POISSON_RATIO" : 0.3 + }, + "Tables" : {} + } + }] + }] +} diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_parameters.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_parameters.json new file mode 100644 index 000000000000..092f40800d54 --- /dev/null +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_parameters.json @@ -0,0 +1,93 @@ +{ + "problem_data" : { + "problem_name" : "anisotropy_2d_test", + "parallel_type" : "OpenMP", + "echo_level" : 1, + "start_time" : 0.0, + "end_time" : 1.0 + }, + "solver_settings" : { + "time_stepping" : { + "time_step" : 1.0 + }, + "solver_type" : "Static", + "model_part_name" : "Structure", + "domain_size" : 2, + "echo_level" : 1, + "analysis_type" : "non_linear", + "model_import_settings" : { + "input_type" : "mdpa", + "input_filename" : "AnisotropyCube/anisotropy_2d_test" + }, + "material_import_settings" : { + "materials_filename" : "AnisotropyCube/anisotropy_2d_test_materials.json" + }, + "line_search" : false, + "convergence_criterion" : "residual_criterion", + "displacement_relative_tolerance" : 0.0001, + "displacement_absolute_tolerance" : 1e-9, + "residual_relative_tolerance" : 0.0001, + "residual_absolute_tolerance" : 1e-9, + "max_iteration" : 10, + "use_old_stiffness_in_first_iteration" : false, + "rotation_dofs" : false, + "volumetric_strain_dofs" : false + }, + "processes" : { + "constraints_process_list" : [{ + "python_module" : "assign_vector_variable_process", + "kratos_module" : "KratosMultiphysics", + "process_name" : "AssignVectorVariableProcess", + "Parameters" : { + "model_part_name" : "Structure.DISPLACEMENT_Displacement_Auto1", + "variable_name" : "DISPLACEMENT", + "interval" : [0.0,"End"], + "constrained" : [true,true,true], + "value" : [0.0,0.0,0.0] + } + }], + "loads_process_list" : [{ + "python_module" : "assign_vector_by_direction_process", + "kratos_module" : "KratosMultiphysics", + "check" : "DirectorVectorNonZero direction", + "process_name" : "AssignVectorByDirectionProcess", + "Parameters" : { + "model_part_name" : "Structure.SelfWeight2D_Self_weight_Auto1", + "variable_name" : "VOLUME_ACCELERATION", + "interval" : [0.0,"End"], + "constrained" : false, + "modulus" : 9.81, + "direction" : [1,0,0.0] + } + }], + "list_other_processes" : [], + "json_check_process" : [ + { + "python_module" : "from_json_check_result_process", + "kratos_module" : "KratosMultiphysics", + "help" : "", + "process_name" : "FromJsonCheckResultProcess", + "Parameters" : { + "check_variables" : ["DISPLACEMENT"], + "input_file_name" : "AnisotropyCube/anisotropy_2d_test_results.json", + "model_part_name" : "Structure.Parts_Solid_Solid_Auto1", + "time_frequency" : 0.1 + } + }] + //"_json_output_process" : [ + //{ + // "python_module" : "json_output_process", + // "kratos_module" : "KratosMultiphysics", + // "help" : "", + // "process_name" : "JsonOutputProcess", + // "Parameters" : { + // "output_variables" : ["DISPLACEMENT"], + // "output_file_name" : "AnisotropyCube/anisotropy_2d_test_results.json", + // "model_part_name" : "Structure.Parts_Solid_Solid_Auto1", + // "time_frequency" : 0.1 + // } + //}] + }, + "output_processes" : {}, + "analysis_stage" : "KratosMultiphysics.StructuralMechanicsApplication.structural_mechanics_analysis" +} diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_results.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_results.json new file mode 100644 index 000000000000..66ddf3968860 --- /dev/null +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_2d_test_results.json @@ -0,0 +1,104 @@ +{ + "TIME": [ + 1.0 + ], + "NODE_1": { + "DISPLACEMENT_X": [ + 0.0005237129686011353 + ], + "DISPLACEMENT_Y": [ + -0.0004905129181585165 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_2": { + "DISPLACEMENT_X": [ + 0.00052650436190964 + ], + "DISPLACEMENT_Y": [ + -0.0004821475041993483 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_3": { + "DISPLACEMENT_X": [ + 0.0004038998113975294 + ], + "DISPLACEMENT_Y": [ + -0.00039855850816312646 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_4": { + "DISPLACEMENT_X": [ + 0.0005139806181518545 + ], + "DISPLACEMENT_Y": [ + -0.00047272710313771304 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_5": { + "DISPLACEMENT_X": [ + 0.0003884411459232532 + ], + "DISPLACEMENT_Y": [ + -0.00036083936525943376 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_6": { + "DISPLACEMENT_X": [ + 0.00037635963836100077 + ], + "DISPLACEMENT_Y": [ + -0.00032342329242713354 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_7": { + "DISPLACEMENT_X": [ + 0.0 + ], + "DISPLACEMENT_Y": [ + 0.0 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_8": { + "DISPLACEMENT_X": [ + 0.0 + ], + "DISPLACEMENT_Y": [ + 0.0 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + }, + "NODE_9": { + "DISPLACEMENT_X": [ + 0.0 + ], + "DISPLACEMENT_Y": [ + 0.0 + ], + "DISPLACEMENT_Z": [ + 0.0 + ] + } +} \ No newline at end of file diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_materials.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_materials.json index d1a26c55af68..16b26e15bb5e 100644 --- a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_materials.json +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_materials.json @@ -24,7 +24,7 @@ "YOUNG_MODULUS" : 40E9, "POISSON_RATIO" : 0.3, "YIELD_STRESS" : 0.8e7, - "FRACTURE_ENERGY" : 100000, + "FRACTURE_ENERGY" : 10000, "SOFTENING_TYPE" : 1 }, "Tables" : {} diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_parameters.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_parameters.json index b7a61ce70719..f65d1aa0f825 100644 --- a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_parameters.json +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_parameters.json @@ -1,6 +1,6 @@ { "problem_data" : { - "problem_name" : "serial_parallel_test", + "problem_name" : "anisotropy_test", "parallel_type" : "OpenMP", "start_time" : 0.0, "end_time" : 30.0, @@ -14,13 +14,13 @@ "analysis_type" : "non_linear", "model_import_settings" : { "input_type" : "mdpa", - "input_filename" : "SerialParallelRuleOfMixturesCube/serial_parallel_damage_test" + "input_filename" : "AnisotropyCube/anisotropy_test" }, "material_import_settings" : { - "materials_filename" : "SerialParallelRuleOfMixturesCube/serial_parallel_damage_test_materials.json" + "materials_filename" : "AnisotropyCube/anisotropy_test_materials.json" }, "time_stepping" : { - "time_step" : 1.1 + "time_step" : 1.0 }, "line_search" : false, "convergence_criterion" : "residual_criterion", @@ -29,10 +29,7 @@ "residual_relative_tolerance" : 0.0001, "residual_absolute_tolerance" : 1e-9, "max_iteration" : 10, - "rotation_dofs" : false, - "linear_solver_settings":{ - "solver_type": "amgcl" - } + "rotation_dofs" : false }, "processes" : { "constraints_process_list" : [{ @@ -70,52 +67,19 @@ "model_part_name" : "Structure.Parts_Parts_Auto1", "time_frequency" : 0.2 } - } - ] - }, - "_json_output_process" : [ - { - "python_module" : "json_output_process", - "kratos_module" : "KratosMultiphysics", - "help" : "", - "process_name" : "JsonOutputProcess", - "Parameters" : { - "gauss_points_output_variables" : ["DAMAGE"], - "output_file_name" : "AnisotropyCube/anisotropy_test_results.json", - "model_part_name" : "Structure.Parts_Parts_Auto1", - "time_frequency" : 0.2 - } + }] } - ] - //"_output_processes" : { - // "gid_output" : [{ - // "python_module" : "gid_output_process", - // "kratos_module" : "KratosMultiphysics", - // "process_name" : "GiDOutputProcess", - // "help" : "This process writes postprocessing files for GiD", - // "Parameters" : { - // "model_part_name" : "Structure.computing_domain", - // "output_name" : "small_deformation_plasticity_test", - // "postprocess_parameters" : { - // "result_file_configuration" : { - // "gidpost_flags" : { - // "GiDPostMode" : "GiD_PostBinary", - // "WriteDeformedMeshFlag" : "WriteDeformed", - // "MultiFileFlag" : "SingleFile" - // }, - // "file_label" : "step", - // "output_control_type" : "step", - // "output_frequency" : 1, - // "body_output" : true, - // "node_output" : false, - // "skin_output" : false, - // "plane_output" : [], - // "nodal_results" : ["DISPLACEMENT"], - // "gauss_point_results" : ["GREEN_LAGRANGE_STRAIN_TENSOR","CAUCHY_STRESS_TENSOR","UNIAXIAL_STRESS","DAMAGE"] - // }, - // "point_data_configuration" : [] - // } - // } - // }] - //} + //"_json_output_process" : [ + //{ + // "python_module" : "json_output_process", + // "kratos_module" : "KratosMultiphysics", + // "help" : "", + // "process_name" : "JsonOutputProcess", + // "Parameters" : { + // "gauss_points_output_variables" : ["DAMAGE"], + // "output_file_name" : "AnisotropyCube/anisotropy_test_results.json", + // "model_part_name" : "Structure.Parts_Parts_Auto1", + // "time_frequency" : 0.2 + // } + //}] } diff --git a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_results.json b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_results.json index e15fe860461c..5e2822fc663f 100644 --- a/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_results.json +++ b/applications/ConstitutiveLawsApplication/tests/AnisotropyCube/anisotropy_test_results.json @@ -1,275 +1,293 @@ { "TIME": [ - 1.1, - 2.2, - 3.3000000000000003, - 4.4, - 5.5, - 6.6, - 7.699999999999999, - 8.799999999999999, - 9.899999999999999, - 10.999999999999998, - 12.099999999999998, - 13.199999999999998, - 14.299999999999997, - 15.399999999999997, - 16.499999999999996, - 17.599999999999998, - 18.7, - 19.8, - 20.900000000000002, - 22.000000000000004, - 23.100000000000005, - 24.200000000000006, - 25.300000000000008, - 26.40000000000001, - 27.50000000000001, - 28.600000000000012, - 29.700000000000014, - 30.800000000000015 + 1.0, + 2.0, + 3.0, + 4.0, + 5.0, + 6.0, + 7.0, + 8.0, + 9.0, + 10.0, + 11.0, + 12.0, + 13.0, + 14.0, + 15.0, + 16.0, + 17.0, + 18.0, + 19.0, + 20.0, + 21.0, + 22.0, + 23.0, + 24.0, + 25.0, + 26.0, + 27.0, + 28.0, + 29.0, + 30.0 ], "ELEMENT_1": { "DAMAGE": { "0": [ 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.08497382961154254, - 0.2003498542211647, - 0.3039640565567405, - 0.3976610905437068, - 0.48279089512707996, - 0.560235016951109, - 0.6304079380140246, - 0.6932616463370467, - 0.7483870552707599, - 0.7953157307175527, - 0.833959370553301, - 0.8649135422342809, - 0.8892892417657103 + 0.3703463501054223, + 0.5807013125792653, + 0.6858783470322534, + 0.7489842351424558, + 0.7910522188354059, + 0.8211039098387255, + 0.8436417399781939, + 0.8611707624620276, + 0.8751937499736083, + 0.8866669373576644, + 0.8962277903431974, + 0.9043176228821856, + 0.9112516560508597, + 0.9172610507226795, + 0.9225191770451143, + 0.9271586119806348, + 0.9312824708593755, + 0.9349721604881396, + 0.9382928063018301, + 0.9412971288891722, + 0.944028263279271, + 0.9465218427600096, + 0.9488075617409981, + 0.9509103635289516, + 0.9528513540010051, + 0.9546485122394448, + 0.9563172488876821, + 0.9578708489842317, + 0.9593208262300325 ], "1": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.16392470688197802, - 0.30788062941775296, - 0.4185605748734288, - 0.505759400044122, - 0.5758025924785972, - 0.6329739791868596, - 0.6802664627169739, - 0.7209233176829885, - 0.7559261956265719, - 0.785934950793872, - 0.8118733214707485, - 0.8344645616732929, - 0.8542769695014911, - 0.8717544903822655, - 0.8872335650067829, - 0.9009532051795921, - 0.9130713448318001, - 0.9236990068846305, - 0.9329465515256958, - 0.9409453295939485 + 0.28096466663773545, + 0.6461697955446122, + 0.7645833477467442, + 0.8237893638694037, + 0.8593124305315241, + 0.8829933101124907, + 0.8999087306387259, + 0.9125948376118134, + 0.9224614629709466, + 0.9303544740412512, + 0.9368121389761599, + 0.9421932989169386, + 0.9467463805154822, + 0.9506488305382936, + 0.9540307762018362, + 0.9569898127051153, + 0.9596005715553703, + 0.9619210994151607, + 0.9639972225589095, + 0.9658656019829832, + 0.9675559156224085, + 0.9690924454147459, + 0.9704952503457945, + 0.9717810462328633, + 0.9729638743596116, + 0.9740556158101339, + 0.9750663915063913, + 0.976004876523188, + 0.976878549372391, + 0.9776938914302293 ], "2": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.1639247068819779, - 0.30788062941775285, - 0.4185605748734288, - 0.505759400044122, - 0.5758025924785969, - 0.6329739791868598, - 0.6802664627169739, - 0.7209233176829885, - 0.7559261956265716, - 0.7859349507938717, - 0.8118733214707486, - 0.8344645616732929, - 0.8542769695014911, - 0.8717544903822655, - 0.8872335650067829, - 0.9009532051795919, - 0.9130713448318001, - 0.9236990068846305, - 0.9329465515256958, - 0.9409453295939486 + 0.28096466663765507, + 0.6461697955446102, + 0.7645833477467434, + 0.8237893638694036, + 0.8593124305315243, + 0.8829933101124925, + 0.8999087306387427, + 0.9125948376118451, + 0.9224614629709328, + 0.930354474041226, + 0.9368121389761346, + 0.9421932989169584, + 0.9467463805154325, + 0.9506488305382823, + 0.9540307762018411, + 0.9569898127051368, + 0.9596005715553669, + 0.9619210994151774, + 0.9639972225589133, + 0.9658656019829828, + 0.9675559156224057, + 0.9690924454147554, + 0.970495250345792, + 0.9717810462328581, + 0.9729638743596071, + 0.9740556158101321, + 0.9750663915063912, + 0.9760048765231919, + 0.9768785493723953, + 0.9776938914302269 ], "3": [ 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.08497382961154287, - 0.20034985422116391, - 0.3039640565567382, - 0.397661090543708, - 0.48279089512707996, - 0.560235016951109, - 0.6304079380140246, - 0.6932616463370462, - 0.74838705527076, - 0.7953157307175528, - 0.8339593705533013, - 0.8649135422342809, - 0.8892892417657103 + 0.3703463501054062, + 0.5807013125792628, + 0.6858783470322531, + 0.7489842351424568, + 0.7910522188353757, + 0.8211039098386895, + 0.8436417399781879, + 0.8611707624620546, + 0.8751937499736238, + 0.8866669373576412, + 0.8962277903431932, + 0.9043176228821873, + 0.9112516560508628, + 0.9172610507226696, + 0.9225191770451073, + 0.9271586119806452, + 0.9312824708593627, + 0.9349721604881244, + 0.9382928063018365, + 0.9412971288891819, + 0.944028263279261, + 0.9465218427600074, + 0.9488075617410008, + 0.9509103635289591, + 0.9528513540010007, + 0.9546485122394496, + 0.95631724888768, + 0.9578708489842344, + 0.9593208262300356 ], "4": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0849738296115422, - 0.20034985422115237, - 0.30396405655673353, - 0.397661090543707, - 0.48279089512708084, - 0.5602350169511087, - 0.630407938014024, - 0.6932616463370407, - 0.7483870552707579, - 0.7953157307175552, - 0.8339593705532944, - 0.864913542234285, - 0.8892892417657093 + 0.024054436534102108, + 0.5254973515759862, + 0.6841500630324189, + 0.7634756832675195, + 0.8110706404537296, + 0.8427984728191676, + 0.8654631718842709, + 0.8824611255220076, + 0.8956814065885437, + 0.9062573746898921, + 0.9149102299112031, + 0.9221207612732518, + 0.9282218180568983, + 0.9334511476249779, + 0.9379830970117622, + 0.9419484259627495, + 0.9454471269393688, + 0.9485569716960255, + 0.9513393588935537, + 0.9538434074047839, + 0.9561088800924714, + 0.9581683101861961, + 0.9600485729485582, + 0.9617720644222978, + 0.9633575972770746, + 0.9648210899213379, + 0.9661761024777809, + 0.967434257906534, + 0.9686055759992707, + 0.9696987405742831 ], "5": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.1639247068819787, - 0.3078806294177534, - 0.4185605748734288, - 0.505759400044122, - 0.5758025924785972, - 0.6329739791868598, - 0.6802664627169768, - 0.7209233176829886, - 0.7559261956265712, - 0.7859349507938715, - 0.8118733214707486, - 0.834464561673293, - 0.8542769695014911, - 0.8717544903822655, - 0.8872335650067824, - 0.9009532051795919, - 0.9130713448318004, - 0.9236990068846298, - 0.9329465515256964, - 0.9409453295939484 + 0.40477112944938876, + 0.7069329499470747, + 0.8050926270061836, + 0.8541715561565126, + 0.8836182669388262, + 0.9032485416166576, + 0.9172700017229616, + 0.9277857261256732, + 0.9359642611449026, + 0.9425067598534744, + 0.9478594155084898, + 0.9523196909167985, + 0.9560935216684462, + 0.959328004335143, + 0.9621310095210563, + 0.9645834400320652, + 0.9667471626229583, + 0.9686702958174428, + 0.9703908278823334, + 0.9719391494033877, + 0.973339862264779, + 0.9746130952680514, + 0.9757754765447438, + 0.9768408628647136, + 0.9778208939100611, + 0.978725418639132, + 0.9795628269027461, + 0.9803403099995769, + 0.9810640673234562, + 0.9817394716810717 ], "6": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.1639247068819787, - 0.3078806294177534, - 0.4185605748734288, - 0.505759400044122, - 0.5758025924785972, - 0.6329739791868598, - 0.6802664627169765, - 0.7209233176829886, - 0.7559261956265719, - 0.7859349507938715, - 0.8118733214707488, - 0.834464561673293, - 0.8542769695014912, - 0.8717544903822656, - 0.8872335650067824, - 0.9009532051795918, - 0.9130713448318004, - 0.9236990068846299, - 0.9329465515256963, - 0.9409453295939485 + 0.40477112944917737, + 0.7069329499470757, + 0.8050926270061831, + 0.8541715561565125, + 0.8836182669388264, + 0.9032485416166693, + 0.9172700017230032, + 0.9277857261257343, + 0.935964261144869, + 0.9425067598534228, + 0.9478594155084494, + 0.9523196909168363, + 0.9560935216683533, + 0.959328004335121, + 0.9621310095210682, + 0.9645834400321074, + 0.9667471626229492, + 0.9686702958174777, + 0.9703908278823449, + 0.9719391494033851, + 0.973339862264771, + 0.9746130952680718, + 0.9757754765447398, + 0.9768408628647031, + 0.9778208939100506, + 0.97872541863913, + 0.9795628269027443, + 0.9803403099995845, + 0.9810640673234634, + 0.9817394716810665 ], "7": [ - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.0, - 0.08497382961154343, - 0.2003498542211618, - 0.3039640565567351, - 0.39766109054370813, - 0.48279089512708095, - 0.5602350169511094, - 0.6304079380140242, - 0.6932616463370409, - 0.7483870552707579, - 0.7953157307175557, - 0.8339593705532946, - 0.8649135422342851, - 0.8892892417657094 + 0.024054436533822998, + 0.5254973515759825, + 0.6841500630324172, + 0.7634756832675194, + 0.8110706404537303, + 0.8427984728191757, + 0.8654631718843245, + 0.8824611255221018, + 0.8956814065885, + 0.906257374689816, + 0.914910229911131, + 0.92212076127331, + 0.9282218180567519, + 0.9334511476249442, + 0.9379830970117775, + 0.9419484259628138, + 0.9454471269393578, + 0.948556971696076, + 0.9513393588935665, + 0.953843407404782, + 0.9561088800924622, + 0.9581683101862247, + 0.9600485729485511, + 0.9617720644222821, + 0.9633575972770604, + 0.9648210899213332, + 0.9661761024777797, + 0.9674342579065456, + 0.968605575999283, + 0.9696987405742757 ] } } diff --git a/applications/ConstitutiveLawsApplication/tests/test_ConstitutiveLawsApplication.py b/applications/ConstitutiveLawsApplication/tests/test_ConstitutiveLawsApplication.py index b84370b5ab3b..50969e14a31f 100644 --- a/applications/ConstitutiveLawsApplication/tests/test_ConstitutiveLawsApplication.py +++ b/applications/ConstitutiveLawsApplication/tests/test_ConstitutiveLawsApplication.py @@ -17,6 +17,7 @@ from test_factory import SerialParallelRuleOfMixturesCubeDamageTest from test_factory import PlasticDamageTest from test_factory import AnisotropyTest +from test_factory import Anisotropy2DTest from test_factory import InitialStateInelasticityTest from test_factory import InitialStateInelasticity2Test from test_factory import SmallDeformationPlasticityTest @@ -55,6 +56,7 @@ def AssembleTestSuites(): smallSuite.addTest(BigCubeSmallDeformationPlasticityDPTest('test_execution')) smallSuite.addTest(BigCubeSmallDeformationPlasticityTTest('test_execution')) smallSuite.addTest(AnisotropyTest('test_execution')) + smallSuite.addTest(Anisotropy2DTest('test_execution')) smallSuite.addTest(InitialStateInelasticityTest('test_execution')) smallSuite.addTest(InitialStateInelasticity2Test('test_execution')) smallSuite.addTest(SimpleJ2PlasticityTest('test_execution')) diff --git a/applications/ConstitutiveLawsApplication/tests/test_factory.py b/applications/ConstitutiveLawsApplication/tests/test_factory.py index d447d240e952..ae586a68b9e7 100644 --- a/applications/ConstitutiveLawsApplication/tests/test_factory.py +++ b/applications/ConstitutiveLawsApplication/tests/test_factory.py @@ -103,6 +103,9 @@ class PlasticDamageTest(TestFactory): class AnisotropyTest(TestFactory): file_name = "AnisotropyCube/anisotropy_test" +class Anisotropy2DTest(TestFactory): + file_name = "AnisotropyCube/anisotropy_2d_test" + class InitialStateInelasticityTest(TestFactory): file_name = "InitialStateInelasticity/initial_state2_test" diff --git a/applications/GeoMechanicsApplication/custom_constitutive/linear_elastic_law.cpp b/applications/GeoMechanicsApplication/custom_constitutive/linear_elastic_law.cpp index cac5d93772a0..72eba7ee1e21 100644 --- a/applications/GeoMechanicsApplication/custom_constitutive/linear_elastic_law.cpp +++ b/applications/GeoMechanicsApplication/custom_constitutive/linear_elastic_law.cpp @@ -155,16 +155,20 @@ int GeoLinearElasticLaw::Check(const Properties& rMaterialProperties, const ProcessInfo& rCurrentProcessInfo) const { KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(YOUNG_MODULUS)) - << "YOUNG_MODULUS is not available in material parameters" << std::endl; + << "YOUNG_MODULUS is not available in the parameters of material " + << rMaterialProperties.Id() << "." << std::endl; KRATOS_ERROR_IF(rMaterialProperties[YOUNG_MODULUS] <= 0.0) - << "YOUNG_MODULUS is invalid value " << std::endl; + << "The value of YOUNG_MODULUS (" << rMaterialProperties[YOUNG_MODULUS] + << ") should be positive in material " << rMaterialProperties.Id() << "." << std::endl; KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(POISSON_RATIO)) - << "POISSON_RATIO is not available in material parameters" << std::endl; + << "POISSON_RATIO is not available in the parameters of material " + << rMaterialProperties.Id() << "." << std::endl; - const double& nu = rMaterialProperties[POISSON_RATIO]; - KRATOS_ERROR_IF((nu > 0.499 && nu < 0.501) || (nu < -0.999 && nu > -1.01)) - << "POISSON_RATIO has invalid value " << std::endl; + const auto nu = rMaterialProperties[POISSON_RATIO]; + KRATOS_ERROR_IF(nu < -1.0 || nu >= 0.5) << "The value of POISSON_RATIO (" << nu + << ") should be in the range [-1.0, 0.5> in material " + << rMaterialProperties.Id() << "." << std::endl; return 0; } diff --git a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.cpp b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.cpp index 38e09d251a75..0b6d0e06d84c 100644 --- a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.cpp +++ b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.cpp @@ -258,12 +258,12 @@ void SmallStrainUDSM3DLaw::ResetStateVariables(const Properties& rMaterialProper KRATOS_TRY // reset state variables - int nStateVariables = std::max(GetNumberOfStateVariablesFromUDSM(rMaterialProperties), 1); - mStateVariables.resize(nStateVariables); - noalias(mStateVariables) = ZeroVector(nStateVariables); + int n_state_variables = std::max(GetNumberOfStateVariablesFromUDSM(rMaterialProperties), 1); + mStateVariables.resize(n_state_variables); + noalias(mStateVariables) = ZeroVector(n_state_variables); - mStateVariablesFinalized.resize(nStateVariables); - noalias(mStateVariablesFinalized) = ZeroVector(nStateVariables); + mStateVariablesFinalized.resize(n_state_variables); + noalias(mStateVariablesFinalized) = ZeroVector(n_state_variables); KRATOS_CATCH("") } @@ -597,13 +597,13 @@ void SmallStrainUDSM3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Para if (rOptions.Is(ConstitutiveLaw::COMPUTE_CONSTITUTIVE_TENSOR)) { // Constitutive matrix (D matrix) - Matrix& rConstitutiveMatrix = rValues.GetConstitutiveMatrix(); - CalculateConstitutiveMatrix(rValues, rConstitutiveMatrix); + Matrix& r_constitutive_matrix = rValues.GetConstitutiveMatrix(); + CalculateConstitutiveMatrix(rValues, r_constitutive_matrix); } if (rOptions.Is(ConstitutiveLaw::COMPUTE_STRESS)) { - Vector& rStressVector = rValues.GetStressVector(); - CalculateStress(rValues, rStressVector); + Vector& r_stress_vector = rValues.GetStressVector(); + CalculateStress(rValues, r_stress_vector); } KRATOS_CATCH("") @@ -612,10 +612,10 @@ void SmallStrainUDSM3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Para void SmallStrainUDSM3DLaw::UpdateInternalDeltaStrainVector(ConstitutiveLaw::Parameters& rValues) { KRATOS_TRY - const Vector& rStrainVector = rValues.GetStrainVector(); + const Vector& r_strain_vector = rValues.GetStrainVector(); for (unsigned int i = 0; i < mDeltaStrainVector.size(); ++i) { - mDeltaStrainVector[i] = rStrainVector(i) - mStrainVectorFinalized[i]; + mDeltaStrainVector[i] = r_strain_vector(i) - mStrainVectorFinalized[i]; } KRATOS_CATCH("") } @@ -806,7 +806,7 @@ void SmallStrainUDSM3DLaw::FinalizeMaterialResponseCauchy(ConstitutiveLaw::Param void SmallStrainUDSM3DLaw::SetInternalStrainVector(const Vector& rStrainVector) { KRATOS_TRY - std::copy_n(rStrainVector.begin(), mStrainVectorFinalized.size(), mStrainVectorFinalized.begin()); + std::copy(rStrainVector.begin(), rStrainVector.end(), mStrainVectorFinalized.begin()); KRATOS_CATCH("") } @@ -821,11 +821,11 @@ double& SmallStrainUDSM3DLaw::CalculateValue(ConstitutiveLaw::Parameters& rParam double& rValue) { if (rThisVariable == STRAIN_ENERGY) { - Vector& rStrainVector = rParameterValues.GetStrainVector(); - Vector& rStressVector = rParameterValues.GetStressVector(); - this->CalculateStress(rParameterValues, rStressVector); + const Vector& r_strain_vector = rParameterValues.GetStrainVector(); + Vector& r_stress_vector = rParameterValues.GetStressVector(); + this->CalculateStress(rParameterValues, r_stress_vector); - rValue = 0.5 * inner_prod(rStrainVector, rStressVector); // Strain energy = 0.5*E:C:E + rValue = 0.5 * inner_prod(r_strain_vector, r_stress_vector); // Strain energy = 0.5*E:C:E } return rValue; } @@ -898,13 +898,6 @@ double& SmallStrainUDSM3DLaw::GetValue(const Variable& rThisVariable, do return rValue; } -int& SmallStrainUDSM3DLaw::GetValue(const Variable& rThisVariable, int& rValue) -{ - if (rThisVariable == NUMBER_OF_UMAT_STATE_VARIABLES) - rValue = static_cast(mStateVariablesFinalized.size()); - return rValue; -} - void SmallStrainUDSM3DLaw::SetValue(const Variable& rThisVariable, const double& rValue, const ProcessInfo& rCurrentProcessInfo) diff --git a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.hpp b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.hpp index 0496a48c8d12..a9862d413f5c 100644 --- a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.hpp +++ b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_udsm_3D_law.hpp @@ -133,7 +133,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti /** * @brief Clone method */ - ConstitutiveLaw::Pointer Clone() const override; + [[nodiscard]] ConstitutiveLaw::Pointer Clone() const override; /** * Copy constructor. @@ -162,7 +162,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti /** * @brief Voigt tensor size: */ - SizeType GetStrainSize() const override { return VoigtSize; } + [[nodiscard]] SizeType GetStrainSize() const override { return VoigtSize; } /** * @brief Returns the expected strain measure of this constitutive law (by default Green-Lagrange) @@ -258,9 +258,9 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti // @details It is designed to be called only once (or anyway, not often) typically at the beginning // of the calculations, so to verify that nothing is missing from the input or that // no common error is found. - int Check(const Properties& rMaterialProperties, - const GeometryType& rElementGeometry, - const ProcessInfo& rCurrentProcessInfo) const override; + [[nodiscard]] int Check(const Properties& rMaterialProperties, + const GeometryType& rElementGeometry, + const ProcessInfo& rCurrentProcessInfo) const override; /** * This is to be called at the very beginning of the calculation @@ -289,14 +289,12 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti * @param rMaterialProperties the Properties instance of the current element * @param rElementGeometry the geometry of the current element * @param rShapeFunctionsValues the shape functions values in the current integration point - * @param the current ProcessInfo instance */ void ResetMaterial(const Properties& rMaterialProperties, const GeometryType& rElementGeometry, const Vector& rShapeFunctionsValues) override; double& GetValue(const Variable& rThisVariable, double& rValue) override; - int& GetValue(const Variable& rThisVariable, int& rValue) override; Vector& GetValue(const Variable& rThisVariable, Vector& rValue) override; using ConstitutiveLaw::GetValue; @@ -313,7 +311,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti ///@{ /// Turn back information as a string. - std::string Info() const override { return "SmallStrainUDSM3DLaw"; } + [[nodiscard]] std::string Info() const override { return "SmallStrainUDSM3DLaw"; } /// Print information about this object. void PrintInfo(std::ostream& rOStream) const override { rOStream << Info(); } @@ -455,8 +453,8 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUDSM3DLaw : public Consti int GetNumberOfStateVariablesFromUDSM(const Properties& rMaterialProperties); // get number of MaterialParameters - SizeType GetNumberOfMaterialParametersFromUDSM(const Properties& rMaterialProperties); - int GetStateVariableIndex(const Variable& rThisVariable) const; + SizeType GetNumberOfMaterialParametersFromUDSM(const Properties& rMaterialProperties); + [[nodiscard]] int GetStateVariableIndex(const Variable& rThisVariable) const; ///@} ///@name Serialization diff --git a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.cpp b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.cpp index 8b791764af2c..ee73b69b1472 100644 --- a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.cpp +++ b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.cpp @@ -216,14 +216,14 @@ void SmallStrainUMAT3DLaw::ResetStateVariables(const Properties& rMaterialProper KRATOS_TRY // reset state variables - const auto& StateVariables = rMaterialProperties[STATE_VARIABLES]; - const auto nStateVariables = StateVariables.size(); + const auto& state_variables = rMaterialProperties[STATE_VARIABLES]; + const auto n_state_variables = state_variables.size(); - mStateVariables.resize(nStateVariables); - mStateVariablesFinalized.resize(nStateVariables); + mStateVariables.resize(n_state_variables); + mStateVariablesFinalized.resize(n_state_variables); - noalias(mStateVariables) = StateVariables; - noalias(mStateVariablesFinalized) = StateVariables; + noalias(mStateVariables) = state_variables; + noalias(mStateVariablesFinalized) = state_variables; KRATOS_CATCH("") } @@ -382,24 +382,24 @@ void SmallStrainUMAT3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Para KRATOS_TRY // Get Values to compute the constitutive law: - const Flags& rOptions = rValues.GetOptions(); + const Flags& r_options = rValues.GetOptions(); - KRATOS_DEBUG_ERROR_IF(rOptions.IsDefined(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN) && - rOptions.IsNot(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN)) + KRATOS_DEBUG_ERROR_IF(r_options.IsDefined(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN) && + r_options.IsNot(ConstitutiveLaw::USE_ELEMENT_PROVIDED_STRAIN)) << "The SmallStrainUMAT3DLaw needs an element provided strain" << std::endl; KRATOS_ERROR_IF(!rValues.IsSetStrainVector() || rValues.GetStrainVector().size() != GetStrainSize()) << "Constitutive laws in the geomechanics application need a valid provided strain" << std::endl; - if (rOptions.Is(ConstitutiveLaw::COMPUTE_STRESS)) { - Vector& rStressVector = rValues.GetStressVector(); - CalculateStress(rValues, rStressVector); + if (r_options.Is(ConstitutiveLaw::COMPUTE_STRESS)) { + Vector& r_stress_vector = rValues.GetStressVector(); + CalculateStress(rValues, r_stress_vector); } - if (rOptions.Is(ConstitutiveLaw::COMPUTE_CONSTITUTIVE_TENSOR)) { + if (r_options.Is(ConstitutiveLaw::COMPUTE_CONSTITUTIVE_TENSOR)) { // Constitutive matrix (D matrix) - Matrix& rConstitutiveMatrix = rValues.GetConstitutiveMatrix(); - CalculateConstitutiveMatrix(rValues, rConstitutiveMatrix); + Matrix& r_constitutive_matrix = rValues.GetConstitutiveMatrix(); + CalculateConstitutiveMatrix(rValues, r_constitutive_matrix); } KRATOS_CATCH("") @@ -407,32 +407,26 @@ void SmallStrainUMAT3DLaw::CalculateMaterialResponseCauchy(ConstitutiveLaw::Para void SmallStrainUMAT3DLaw::UpdateInternalDeltaStrainVector(ConstitutiveLaw::Parameters& rValues) { - const Vector& rStrainVector = rValues.GetStrainVector(); + const Vector& r_strain_vector = rValues.GetStrainVector(); for (unsigned int i = 0; i < mDeltaStrainVector.size(); ++i) { - mDeltaStrainVector[i] = rStrainVector(i) - mStrainVectorFinalized[i]; + mDeltaStrainVector[i] = r_strain_vector(i) - mStrainVectorFinalized[i]; } } void SmallStrainUMAT3DLaw::SetExternalStressVector(Vector& rStressVector) { - for (unsigned int i = 0; i < rStressVector.size(); ++i) { - rStressVector(i) = mStressVector[i]; - } + std::copy(mStressVector.begin(), mStressVector.end(), rStressVector.begin()); } void SmallStrainUMAT3DLaw::SetInternalStressVector(const Vector& rStressVector) { - for (unsigned int i = 0; i < mStressVectorFinalized.size(); ++i) { - mStressVectorFinalized[i] = rStressVector(i); - } + std::copy(rStressVector.begin(), rStressVector.end(), mStressVectorFinalized.begin()); } void SmallStrainUMAT3DLaw::SetInternalStrainVector(const Vector& rStrainVector) { - for (unsigned int i = 0; i < mStrainVectorFinalized.size(); ++i) { - mStrainVectorFinalized[i] = rStrainVector(i); - } + std::copy(rStrainVector.begin(), rStrainVector.end(), mStrainVectorFinalized.begin()); } void SmallStrainUMAT3DLaw::CopyConstitutiveMatrix(ConstitutiveLaw::Parameters& rValues, Matrix& rConstitutiveMatrix) @@ -549,12 +543,12 @@ void SmallStrainUMAT3DLaw::InitializeMaterialResponseCauchy(ConstitutiveLaw::Par if (!mIsModelInitialized) { // stress and strain vectors must be initialized: - const Vector& rStressVector = rValues.GetStressVector(); - const Vector& rStrainVector = rValues.GetStrainVector(); + const Vector& r_stress_vector = rValues.GetStressVector(); + const Vector& r_strain_vector = rValues.GetStrainVector(); - SetInternalStressVector(rStressVector); + SetInternalStressVector(r_stress_vector); - SetInternalStrainVector(rStrainVector); + SetInternalStrainVector(r_strain_vector); CallUMAT(rValues); mIsModelInitialized = true; @@ -598,13 +592,12 @@ double& SmallStrainUMAT3DLaw::CalculateValue(ConstitutiveLaw::Parameters& rParam const Variable& rThisVariable, double& rValue) { - Vector& rStrainVector = rParameterValues.GetStrainVector(); - Vector& rStressVector = rParameterValues.GetStressVector(); - if (rThisVariable == STRAIN_ENERGY) { - this->CalculateStress(rParameterValues, rStressVector); + const Vector& r_strain_vector = rParameterValues.GetStrainVector(); + Vector& r_stress_vector = rParameterValues.GetStressVector(); + this->CalculateStress(rParameterValues, r_stress_vector); - rValue = 0.5 * inner_prod(rStrainVector, rStressVector); // Strain energy = 0.5*E:C:E + rValue = 0.5 * inner_prod(r_strain_vector, r_stress_vector); // Strain energy = 0.5*E:C:E } return rValue; @@ -679,14 +672,6 @@ double& SmallStrainUMAT3DLaw::GetValue(const Variable& rThisVariable, do return rValue; } -int& SmallStrainUMAT3DLaw::GetValue(const Variable& rThisVariable, int& rValue) -{ - if (rThisVariable == NUMBER_OF_UMAT_STATE_VARIABLES) - rValue = static_cast(mStateVariablesFinalized.size()); - - return rValue; -} - void SmallStrainUMAT3DLaw::SetValue(const Variable& rThisVariable, const double& rValue, const ProcessInfo& rCurrentProcessInfo) diff --git a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.hpp b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.hpp index 5f8fb4024dc3..eec5918742ea 100644 --- a/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.hpp +++ b/applications/GeoMechanicsApplication/custom_constitutive/small_strain_umat_3D_law.hpp @@ -138,7 +138,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti /** * @brief Clone method */ - ConstitutiveLaw::Pointer Clone() const override; + [[nodiscard]] ConstitutiveLaw::Pointer Clone() const override; /** * @brief This function is designed to be called once to check compatibility with element @@ -154,7 +154,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti /** * @brief Voigt tensor size: */ - SizeType GetStrainSize() const override { return VoigtSize; } + [[nodiscard]] SizeType GetStrainSize() const override { return VoigtSize; } /** * @brief Returns the expected strain measure of this constitutive law (by default Green-Lagrange) @@ -250,9 +250,9 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti // @details It is designed to be called only once (or anyway, not often) typically at the beginning // of the calculations, so to verify that nothing is missing from the input or that // no common error is found. - int Check(const Properties& rMaterialProperties, - const GeometryType& rElementGeometry, - const ProcessInfo& rCurrentProcessInfo) const override; + [[nodiscard]] int Check(const Properties& rMaterialProperties, + const GeometryType& rElementGeometry, + const ProcessInfo& rCurrentProcessInfo) const override; /** * This is to be called at the very beginning of the calculation @@ -281,7 +281,6 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti * @param rMaterialProperties the Properties instance of the current element * @param rElementGeometry the geometry of the current element * @param rShapeFunctionsValues the shape functions values in the current integration point - * @param the current ProcessInfo instance */ void ResetMaterial(const Properties& rMaterialProperties, const GeometryType& rElementGeometry, @@ -289,7 +288,6 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti using ConstitutiveLaw::GetValue; double& GetValue(const Variable& rThisVariable, double& rValue) override; - int& GetValue(const Variable& rThisVariable, int& rValue) override; Vector& GetValue(const Variable& rThisVariable, Vector& rValue) override; using ConstitutiveLaw::SetValue; @@ -306,7 +304,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SmallStrainUMAT3DLaw : public Consti ///@{ /// Turn back information as a string. - std::string Info() const override { return "SmallStrainUMAT3DLaw"; } + [[nodiscard]] std::string Info() const override { return "SmallStrainUMAT3DLaw"; } /// Print information about this object. void PrintInfo(std::ostream& rOStream) const override { rOStream << Info(); } diff --git a/applications/GeoMechanicsApplication/custom_elements/U_Pw_base_element.cpp b/applications/GeoMechanicsApplication/custom_elements/U_Pw_base_element.cpp index f27964482d6d..a409bdb59605 100644 --- a/applications/GeoMechanicsApplication/custom_elements/U_Pw_base_element.cpp +++ b/applications/GeoMechanicsApplication/custom_elements/U_Pw_base_element.cpp @@ -148,9 +148,8 @@ void UPwBaseElement::Initialize(const ProcessInfo& rCurrentProcessInfo) } mStateVariablesFinalized.resize(number_of_integration_points); - for (unsigned int i = 0; i < mConstitutiveLawVector.size(); ++i) { - if (auto nStateVariables = 0; - mConstitutiveLawVector[i]->GetValue(NUMBER_OF_UMAT_STATE_VARIABLES, nStateVariables) > 0) { + if (r_properties[CONSTITUTIVE_LAW]->Has(STATE_VARIABLES)) { + for (unsigned int i = 0; i < mConstitutiveLawVector.size(); ++i) { mConstitutiveLawVector[i]->SetValue(STATE_VARIABLES, mStateVariablesFinalized[i], rCurrentProcessInfo); } } diff --git a/applications/GeoMechanicsApplication/custom_retention/retention_law.cpp b/applications/GeoMechanicsApplication/custom_retention/retention_law.cpp index 06bd9ef2aeb4..463851238432 100644 --- a/applications/GeoMechanicsApplication/custom_retention/retention_law.cpp +++ b/applications/GeoMechanicsApplication/custom_retention/retention_law.cpp @@ -12,10 +12,28 @@ /* Project includes */ #include "custom_retention/retention_law.h" +#include "geo_mechanics_application_variables.h" namespace Kratos { +double& RetentionLaw::CalculateValue(Parameters& rParameters, const Variable& rThisVariable, double& rValue) const +{ + if (rThisVariable == DEGREE_OF_SATURATION) { + rValue = CalculateSaturation(rParameters); + } else if (rThisVariable == EFFECTIVE_SATURATION) { + rValue = CalculateEffectiveSaturation(rParameters); + } else if (rThisVariable == BISHOP_COEFFICIENT) { + rValue = CalculateBishopCoefficient(rParameters); + } else if (rThisVariable == DERIVATIVE_OF_SATURATION) { + rValue = CalculateDerivativeOfSaturation(rParameters); + } else if (rThisVariable == RELATIVE_PERMEABILITY) { + rValue = CalculateRelativePermeability(rParameters); + } + + return rValue; +} + void RetentionLaw::save(Serializer& rSerializer) const { // there is no member variables to be saved diff --git a/applications/GeoMechanicsApplication/custom_retention/retention_law.h b/applications/GeoMechanicsApplication/custom_retention/retention_law.h index 73a6bd1f67f9..d7f796f27c51 100644 --- a/applications/GeoMechanicsApplication/custom_retention/retention_law.h +++ b/applications/GeoMechanicsApplication/custom_retention/retention_law.h @@ -87,7 +87,7 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) RetentionLaw * @param rValue a reference to the returned value * @param rValue output: the value of the specified variable */ - virtual double& CalculateValue(Parameters& rParameters, const Variable& rThisVariable, double& rValue) = 0; + double& CalculateValue(Parameters& rParameters, const Variable& rThisVariable, double& rValue) const; virtual double CalculateSaturation(Parameters& rParameters) const = 0; diff --git a/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.cpp b/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.cpp index e659f732bd98..f5d7366b2ef8 100644 --- a/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.cpp +++ b/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.cpp @@ -54,24 +54,6 @@ double SaturatedBelowPhreaticLevelLaw::CalculateBishopCoefficient(Parameters& rP return CalculateEffectiveSaturation(rParameters); } -double& SaturatedBelowPhreaticLevelLaw::CalculateValue(Parameters& rParameterValues, - const Variable& rThisVariable, - double& rValue) -{ - if (rThisVariable == DEGREE_OF_SATURATION) { - rValue = this->CalculateSaturation(rParameterValues); - } else if (rThisVariable == EFFECTIVE_SATURATION) { - rValue = this->CalculateEffectiveSaturation(rParameterValues); - } else if (rThisVariable == BISHOP_COEFFICIENT) { - rValue = this->CalculateBishopCoefficient(rParameterValues); - } else if (rThisVariable == DERIVATIVE_OF_SATURATION) { - rValue = this->CalculateDerivativeOfSaturation(rParameterValues); - } else if (rThisVariable == RELATIVE_PERMEABILITY) { - rValue = this->CalculateRelativePermeability(rParameterValues); - } - return rValue; -} - int SaturatedBelowPhreaticLevelLaw::Check(const Properties& rMaterialProperties, const ProcessInfo&) { KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(SATURATED_SATURATION)) diff --git a/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.h b/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.h index ef9bb4349229..685aac29ba6c 100644 --- a/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.h +++ b/applications/GeoMechanicsApplication/custom_retention/saturated_below_phreatic_level_law.h @@ -45,17 +45,6 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SaturatedBelowPhreaticLevelLaw : pub double CalculateBishopCoefficient(Parameters& rParameters) const override; - /** - * @brief It calculates the value of a specified variable (double case) - * @param rParameterValues the needed parameters for the CL calculation - * @param rThisVariable the variable to be returned - * @param rValue a reference to the returned value - * @return rValue output: the value of the specified variable - */ - double& CalculateValue(RetentionLaw::Parameters& rParameterValues, - const Variable& rThisVariable, - double& rValue) override; - /** * @brief This function provides the place to perform checks on the completeness of the input. * @details It is designed to be called only once (or anyway, not often) typically at the beginning of the calculations, so to verify that nothing is missing from the input or that no common error is found. diff --git a/applications/GeoMechanicsApplication/custom_retention/saturated_law.cpp b/applications/GeoMechanicsApplication/custom_retention/saturated_law.cpp index fc2a01b3670b..da79930a8fc3 100644 --- a/applications/GeoMechanicsApplication/custom_retention/saturated_law.cpp +++ b/applications/GeoMechanicsApplication/custom_retention/saturated_law.cpp @@ -39,24 +39,6 @@ double SaturatedLaw::CalculateBishopCoefficient(Parameters& rParameters) const return CalculateEffectiveSaturation(rParameters); } -double& SaturatedLaw::CalculateValue(RetentionLaw::Parameters& rParameterValues, - const Variable& rThisVariable, - double& rValue) -{ - if (rThisVariable == DEGREE_OF_SATURATION) { - rValue = this->CalculateSaturation(rParameterValues); - } else if (rThisVariable == EFFECTIVE_SATURATION) { - rValue = this->CalculateEffectiveSaturation(rParameterValues); - } else if (rThisVariable == BISHOP_COEFFICIENT) { - rValue = this->CalculateBishopCoefficient(rParameterValues); - } else if (rThisVariable == DERIVATIVE_OF_SATURATION) { - rValue = this->CalculateDerivativeOfSaturation(rParameterValues); - } else if (rThisVariable == RELATIVE_PERMEABILITY) { - rValue = this->CalculateRelativePermeability(rParameterValues); - } - return rValue; -} - int SaturatedLaw::Check(const Properties& rMaterialProperties, const ProcessInfo& rCurrentProcessInfo) { if (rMaterialProperties.Has(SATURATED_SATURATION)) { diff --git a/applications/GeoMechanicsApplication/custom_retention/saturated_law.h b/applications/GeoMechanicsApplication/custom_retention/saturated_law.h index 611e926341db..25c37436100a 100644 --- a/applications/GeoMechanicsApplication/custom_retention/saturated_law.h +++ b/applications/GeoMechanicsApplication/custom_retention/saturated_law.h @@ -45,15 +45,6 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) SaturatedLaw : public RetentionLaw double CalculateBishopCoefficient(Parameters& rParameters) const override; - /** - * @brief It calculates the value of a specified variable (double case) - * @param rParameterValues the needed parameters for the CL calculation - * @param rThisVariable the variable to be returned - * @param rValue a reference to the returned value - * @return rValue output: the value of the specified variable - */ - double& CalculateValue(Parameters& rParameterValues, const Variable& rThisVariable, double& rValue) override; - /** * @brief This function provides the place to perform checks on the completeness of the input. * @details It is designed to be called only once (or anyway, not often) typically at the beginning of the calculations, so to verify that nothing is missing from the input or that no common error is found. diff --git a/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.cpp b/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.cpp index 95a910c70de3..020465ce13f0 100644 --- a/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.cpp +++ b/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.cpp @@ -103,23 +103,6 @@ double VanGenuchtenLaw::CalculateBishopCoefficient(Parameters& rParameters) cons return CalculateEffectiveSaturation(rParameters); } -double& VanGenuchtenLaw::CalculateValue(Parameters& rParameterValues, const Variable& rThisVariable, double& rValue) -{ - if (rThisVariable == DEGREE_OF_SATURATION) { - rValue = this->CalculateSaturation(rParameterValues); - } else if (rThisVariable == EFFECTIVE_SATURATION) { - rValue = this->CalculateEffectiveSaturation(rParameterValues); - } else if (rThisVariable == BISHOP_COEFFICIENT) { - rValue = this->CalculateBishopCoefficient(rParameterValues); - } else if (rThisVariable == DERIVATIVE_OF_SATURATION) { - rValue = this->CalculateDerivativeOfSaturation(rParameterValues); - } else if (rThisVariable == RELATIVE_PERMEABILITY) { - rValue = this->CalculateRelativePermeability(rParameterValues); - } - - return rValue; -} - int VanGenuchtenLaw::Check(const Properties& rMaterialProperties, const ProcessInfo& rCurrentProcessInfo) { KRATOS_ERROR_IF_NOT(rMaterialProperties.Has(SATURATED_SATURATION)) diff --git a/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.h b/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.h index ca008a74c8e9..a2a0719e722f 100644 --- a/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.h +++ b/applications/GeoMechanicsApplication/custom_retention/van_genuchten_law.h @@ -44,15 +44,6 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) VanGenuchtenLaw : public RetentionLa double CalculateBishopCoefficient(Parameters& rParameters) const override; - /** - * @brief It calculates the value of a specified variable (double case) - * @param rParameterValues the needed parameters for the CL calculation - * @param rThisVariable the variable to be returned - * @param rValue a reference to the returned value - * @return rValue output: the value of the specified variable - */ - double& CalculateValue(Parameters& rParameterValues, const Variable& rThisVariable, double& rValue) override; - /** * @brief This function provides the place to perform checks on the completeness of the input. * @details It is designed to be called only once (or anyway, not often) typically at the beginning of the calculations, so to verify that nothing is missing from the input or that no common error is found. diff --git a/applications/GeoMechanicsApplication/geo_mechanics_application.cpp b/applications/GeoMechanicsApplication/geo_mechanics_application.cpp index 4ff26bf0d520..7084b19dde8e 100644 --- a/applications/GeoMechanicsApplication/geo_mechanics_application.cpp +++ b/applications/GeoMechanicsApplication/geo_mechanics_application.cpp @@ -534,8 +534,6 @@ void KratosGeoMechanicsApplication::Register() KRATOS_REGISTER_VARIABLE(IS_FORTRAN_UDSM) // Also for UMAT KRATOS_REGISTER_VARIABLE(UMAT_PARAMETERS) - - KRATOS_REGISTER_VARIABLE(NUMBER_OF_UMAT_STATE_VARIABLES) KRATOS_REGISTER_VARIABLE(INDEX_OF_UMAT_C_PARAMETER) KRATOS_REGISTER_VARIABLE(INDEX_OF_UMAT_PHI_PARAMETER) diff --git a/applications/GeoMechanicsApplication/geo_mechanics_application.h b/applications/GeoMechanicsApplication/geo_mechanics_application.h index d1b832956538..833cfe42a60e 100644 --- a/applications/GeoMechanicsApplication/geo_mechanics_application.h +++ b/applications/GeoMechanicsApplication/geo_mechanics_application.h @@ -959,8 +959,8 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) KratosGeoMechanicsApplication : publ 0, Kratos::make_shared>(Condition::GeometryType::PointsArrayType(9))}; // constitutive models - const BilinearCohesive3DLaw mBilinearCohesive3DLaw; - const BilinearCohesive2DLaw mBilinearCohesive2DLaw; + const BilinearCohesive3DLaw mBilinearCohesive3DLaw; + const BilinearCohesive2DLaw mBilinearCohesive2DLaw; const GeoIncrementalLinearElasticLaw mLinearElasticPlaneStrain2DLaw{std::make_unique()}; const GeoIncrementalLinearElasticLaw mLinearElastic3DLaw{std::make_unique()}; const GeoLinearElasticPlaneStress2DLaw mLinearElasticPlaneStress2DLaw; diff --git a/applications/GeoMechanicsApplication/geo_mechanics_application_variables.cpp b/applications/GeoMechanicsApplication/geo_mechanics_application_variables.cpp index bd0e49daab8a..84f4b8a3d6ec 100644 --- a/applications/GeoMechanicsApplication/geo_mechanics_application_variables.cpp +++ b/applications/GeoMechanicsApplication/geo_mechanics_application_variables.cpp @@ -179,11 +179,8 @@ KRATOS_CREATE_VARIABLE(int, UDSM_NUMBER) KRATOS_CREATE_VARIABLE(bool, IS_FORTRAN_UDSM) // Also for UMAT KRATOS_CREATE_VARIABLE(Vector, UMAT_PARAMETERS) - -KRATOS_CREATE_VARIABLE(int, NUMBER_OF_UMAT_STATE_VARIABLES) KRATOS_CREATE_VARIABLE(int, INDEX_OF_UMAT_C_PARAMETER) KRATOS_CREATE_VARIABLE(int, INDEX_OF_UMAT_PHI_PARAMETER) - KRATOS_CREATE_VARIABLE(Vector, STATE_VARIABLES) KRATOS_CREATE_VARIABLE(double, STATE_VARIABLE_1) diff --git a/applications/GeoMechanicsApplication/geo_mechanics_application_variables.h b/applications/GeoMechanicsApplication/geo_mechanics_application_variables.h index 8ff81f77c09c..40fb6e463308 100644 --- a/applications/GeoMechanicsApplication/geo_mechanics_application_variables.h +++ b/applications/GeoMechanicsApplication/geo_mechanics_application_variables.h @@ -196,11 +196,8 @@ KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, int, UDSM_NUMBER) KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, bool, IS_FORTRAN_UDSM) // also for umat KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, Vector, UMAT_PARAMETERS) - -KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, int, NUMBER_OF_UMAT_STATE_VARIABLES) KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, int, INDEX_OF_UMAT_C_PARAMETER) KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, int, INDEX_OF_UMAT_PHI_PARAMETER) - KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, Vector, STATE_VARIABLES) KRATOS_DEFINE_APPLICATION_VARIABLE(GEO_MECHANICS_APPLICATION, double, STATE_VARIABLE_1) diff --git a/applications/GeoMechanicsApplication/tests/Simple_Dike_Gravity_Loading/simple_dike_test_with_gravity_umat.gid/MaterialParameters.json b/applications/GeoMechanicsApplication/tests/Simple_Dike_Gravity_Loading/simple_dike_test_with_gravity_umat.gid/MaterialParameters.json index 9381bcc86193..85a233216dc0 100644 --- a/applications/GeoMechanicsApplication/tests/Simple_Dike_Gravity_Loading/simple_dike_test_with_gravity_umat.gid/MaterialParameters.json +++ b/applications/GeoMechanicsApplication/tests/Simple_Dike_Gravity_Loading/simple_dike_test_with_gravity_umat.gid/MaterialParameters.json @@ -25,7 +25,6 @@ 30, 0.0, 1000], - "NUMBER_OF_UMAT_STATE_VARIABLES": 1, "STATE_VARIABLES" : [0.0] }, "Tables": {} @@ -56,7 +55,6 @@ 20, 0.0, 1000], - "NUMBER_OF_UMAT_STATE_VARIABLES": 1, "STATE_VARIABLES" : [0.0] }, "Tables": {} diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_Pw_normal_flux_condition.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_Pw_normal_flux_condition.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_Pw_normal_flux_condition.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_Pw_normal_flux_condition.cpp index a41080e1da5a..fddaf65afc79 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_Pw_normal_flux_condition.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_Pw_normal_flux_condition.cpp @@ -16,7 +16,7 @@ #include "containers/model.h" #include "custom_conditions/Pw_normal_flux_condition.hpp" #include "custom_constitutive/linear_elastic_2D_interface_law.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_T_micro_climate_flux_condition.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_T_micro_climate_flux_condition.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_T_micro_climate_flux_condition.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_T_micro_climate_flux_condition.cpp index 0458510bc45f..ffaef6938006 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_T_micro_climate_flux_condition.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_T_micro_climate_flux_condition.cpp @@ -12,9 +12,9 @@ #include "containers/model.h" #include "custom_conditions/T_microclimate_flux_condition.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/line_2d_4.h" #include "geometries/line_2d_5.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_condition.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_condition.cpp similarity index 95% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_condition.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_condition.cpp index a1c1b3bcf794..51188f5d788a 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_condition.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_condition.cpp @@ -13,7 +13,7 @@ // Project includes #include "custom_conditions/U_Pw_condition.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_normal_lysmer_absorbing_condition.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_normal_lysmer_absorbing_condition.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_normal_lysmer_absorbing_condition.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_normal_lysmer_absorbing_condition.cpp index 9425b0f77f7d..930f646521e4 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_U_Pw_normal_lysmer_absorbing_condition.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_U_Pw_normal_lysmer_absorbing_condition.cpp @@ -16,7 +16,7 @@ #include "custom_elements/U_Pw_small_strain_element.hpp" #include "custom_elements/plane_strain_stress_state.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_t_normal_flux_condition.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_t_normal_flux_condition.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_t_normal_flux_condition.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_t_normal_flux_condition.cpp index be5a9f051f84..f038051d1f3f 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_t_normal_flux_condition.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_conditions/test_t_normal_flux_condition.cpp @@ -13,10 +13,10 @@ #include "containers/model.h" #include "custom_conditions/T_normal_flux_condition.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/line_2d_4.h" #include "geometries/line_2d_5.h" #include "includes/condition.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_linear_elastic_plane_strain_2D_law.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_linear_elastic_plane_strain_2D_law.cpp index 6b1d44887efa..0e669489d057 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_linear_elastic_plane_strain_2D_law.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_linear_elastic_plane_strain_2D_law.cpp @@ -199,4 +199,32 @@ KRATOS_TEST_CASE_IN_SUITE(GeoLinearElasticPlaneStrain2DLawThrows_WhenElementProv } #endif +KRATOS_TEST_CASE_IN_SUITE(GeoLinearElasticPlaneStrain2DLawChecksYoungModulusAndPoissonRatio, + KratosGeoMechanicsFastSuiteWithoutKernel) +{ + auto law = CreateLinearElasticPlaneStrainLaw(); + ConstitutiveLaw::Parameters parameters; + Properties properties(3); + parameters.SetMaterialProperties(properties); + const auto element_geometry = Geometry{}; + const auto process_info = ProcessInfo{}; + KRATOS_EXPECT_EXCEPTION_IS_THROWN( + law.Check(properties, element_geometry, process_info), + "Error: YOUNG_MODULUS is not available in the parameters of material 3.") + properties.SetValue(YOUNG_MODULUS, -1.0e7); + KRATOS_EXPECT_EXCEPTION_IS_THROWN( + law.Check(properties, element_geometry, process_info), + "Error: The value of YOUNG_MODULUS (-1e+07) should be positive in material 3.") + properties.SetValue(YOUNG_MODULUS, 1.0e7); + KRATOS_EXPECT_EXCEPTION_IS_THROWN( + law.Check(properties, element_geometry, process_info), + "Error: POISSON_RATIO is not available in the parameters of material 3.") + properties.SetValue(POISSON_RATIO, 0.7); + KRATOS_EXPECT_EXCEPTION_IS_THROWN( + law.Check(properties, element_geometry, process_info), + "Error: The value of POISSON_RATIO (0.7) should be in the range [-1.0, 0.5> in material 3.") + properties.SetValue(POISSON_RATIO, 0.25); + KRATOS_EXPECT_EQ(law.Check(properties, element_geometry, process_info), 0); +} + } // namespace Kratos::Testing \ No newline at end of file diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_dispersion_law.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_dispersion_law.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_dispersion_law.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_dispersion_law.cpp index 16f7a4884939..1ff27ed193fd 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_dispersion_law.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_dispersion_law.cpp @@ -12,8 +12,8 @@ #include "custom_constitutive/thermal_dispersion_law.h" #include "geo_mechanics_application.h" -#include "geo_mechanics_fast_suite.h" #include "includes/ublas_interface.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_filter_law.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_filter_law.cpp similarity index 95% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_filter_law.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_filter_law.cpp index 7063466f4853..1a469891befc 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_thermal_filter_law.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_thermal_filter_law.cpp @@ -12,8 +12,8 @@ #include "custom_constitutive/thermal_filter_law.h" #include "geo_mechanics_application.h" -#include "geo_mechanics_fast_suite.h" #include "includes/ublas_interface.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_truss_backbone_constitutive_law.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_truss_backbone_constitutive_law.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_truss_backbone_constitutive_law.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_truss_backbone_constitutive_law.cpp index a280bf25d803..58ef83fc0295 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_truss_backbone_constitutive_law.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_constitutive/test_truss_backbone_constitutive_law.cpp @@ -14,7 +14,7 @@ #include "custom_constitutive/truss_backbone_constitutive_law.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_axisymmetric_stress_state.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_axisymmetric_stress_state.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_axisymmetric_stress_state.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_axisymmetric_stress_state.cpp index b005f9e2484a..e255f8b0cd04 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_axisymmetric_stress_state.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_axisymmetric_stress_state.cpp @@ -14,9 +14,9 @@ #include "containers/model.h" #include "custom_elements/axisymmetric_stress_state.h" #include "custom_elements/stress_state_policy.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/geometry.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "tests/cpp_tests/test_utilities/model_setup_utilities.h" #include diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_plane_strain_stress_state.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_plane_strain_stress_state.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_plane_strain_stress_state.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_plane_strain_stress_state.cpp index e20668342cb9..0907ccc303cc 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_plane_strain_stress_state.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_plane_strain_stress_state.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_elements/plane_strain_stress_state.h" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "tests/cpp_tests/test_utilities/model_setup_utilities.h" #include @@ -120,4 +120,4 @@ KRATOS_TEST_CASE_IN_SUITE(PlaneStrainStressState_GivesCorrectStressTensorSize, K KRATOS_EXPECT_EQ(p_stress_state_policy->GetStressTensorSize(), STRESS_TENSOR_SIZE_2D); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_steady_state_Pw_piping_element.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_steady_state_Pw_piping_element.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_steady_state_Pw_piping_element.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_steady_state_Pw_piping_element.cpp index 5303b7c648cc..b541f7828943 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_steady_state_Pw_piping_element.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_steady_state_Pw_piping_element.cpp @@ -17,7 +17,7 @@ #include "custom_constitutive/linear_elastic_2D_interface_law.h" #include "custom_elements/plane_strain_stress_state.h" #include "custom_elements/steady_state_Pw_piping_element.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { @@ -167,4 +167,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculateHeadGradient, KratosGeoMechanicsFastSuiteWith // expected gradient should be 2. Test is failing on purpose to check CI KRATOS_EXPECT_NEAR(expected_gradient, 2, 1.0e-10); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_three_dimensional_stress_state.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_three_dimensional_stress_state.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_three_dimensional_stress_state.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_three_dimensional_stress_state.cpp index 5b98b723fcfa..2932a0278718 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_three_dimensional_stress_state.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_three_dimensional_stress_state.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_elements/three_dimensional_stress_state.h" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "tests/cpp_tests/test_utilities/model_setup_utilities.h" #include @@ -133,4 +133,4 @@ KRATOS_TEST_CASE_IN_SUITE(ThreeDimensionalStressState_GivesCorrectStressTensorSi KRATOS_EXPECT_EQ(p_stress_state_policy->GetStressTensorSize(), STRESS_TENSOR_SIZE_3D); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_transient_thermal_element.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_transient_thermal_element.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_transient_thermal_element.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_transient_thermal_element.cpp index 593898af0697..3495df05f19b 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_transient_thermal_element.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_elements/test_transient_thermal_element.cpp @@ -13,9 +13,9 @@ #include "containers/model.h" #include "custom_elements/transient_thermal_element.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/triangle_2d_10.h" #include "geometries/triangle_2d_15.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_activate_model_part_operation.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_activate_model_part_operation.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_activate_model_part_operation.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_activate_model_part_operation.cpp index f28f09f4ed40..ecc91bac9c31 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_activate_model_part_operation.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_activate_model_part_operation.cpp @@ -12,10 +12,10 @@ // Project includes #include "containers/model.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" #include "includes/expect.h" #include "processes/structured_mesh_generator_process.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" // Application includes #include "custom_operations/activate_model_part_operation.h" diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_deactivate_model_part_operation.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_deactivate_model_part_operation.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_deactivate_model_part_operation.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_deactivate_model_part_operation.cpp index 2d1f56b905b2..ec2f72517b3e 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_deactivate_model_part_operation.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_operations/test_deactivate_model_part_operation.cpp @@ -12,10 +12,10 @@ // Project includes #include "containers/model.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" #include "includes/expect.h" #include "processes/structured_mesh_generator_process.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" // Application includes #include "custom_operations/deactivate_model_part_operation.h" diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_c_phi_reduction_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_c_phi_reduction_process.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_c_phi_reduction_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_c_phi_reduction_process.cpp index 6e893f0c12f4..d4cd526bd6b1 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_c_phi_reduction_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_c_phi_reduction_process.cpp @@ -12,10 +12,10 @@ // #include "containers/model.h" #include "custom_processes/apply_c_phi_reduction_process.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" #include "processes/structured_mesh_generator_process.h" -#include "stub_linear_elastic_law.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/stub_linear_elastic_law.h" #include using namespace Kratos; @@ -200,4 +200,4 @@ KRATOS_TEST_CASE_IN_SUITE(CheckFailureNegativeReductionFactorApplyCPhiReductionP "Reduction factor should not drop below 0.01, calculation stopped."); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_constant_phreatic_multi_line_pressure_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_constant_phreatic_multi_line_pressure_process.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_constant_phreatic_multi_line_pressure_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_constant_phreatic_multi_line_pressure_process.cpp index 7a449c9d65b7..9cc58d522c47 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_constant_phreatic_multi_line_pressure_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_constant_phreatic_multi_line_pressure_process.cpp @@ -11,10 +11,10 @@ // #include "containers/model.h" #include "custom_processes/apply_constant_phreatic_multi_line_pressure_process.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" #include "includes/checks.h" #include "processes/structured_mesh_generator_process.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -186,4 +186,4 @@ KRATOS_TEST_CASE_IN_SUITE(ApplyConstantPhreaticMultilinePressureProcess_AppliesC }); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_k0_procedure_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_k0_procedure_process.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_k0_procedure_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_k0_procedure_process.cpp index a38e9d932d50..e1bebae8f6e4 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_k0_procedure_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_k0_procedure_process.cpp @@ -12,10 +12,10 @@ #include "containers/model.h" #include "custom_processes/apply_k0_procedure_process.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "includes/element.h" -#include "stub_linear_elastic_law.h" -#include "test_utilities.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/stub_linear_elastic_law.h" +#include "tests/cpp_tests/test_utilities.h" #include #include @@ -32,10 +32,10 @@ class MockConstitutiveLaw : public GeoIncrementalLinearElasticLaw MOCK_METHOD(std::size_t, WorkingSpaceDimension, (), (override)); }; -class StubElement : public Element +class StubElementForK0ProcedureTest : public Element { public: - KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElement); + KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElementForK0ProcedureTest); void CalculateOnIntegrationPoints(const Variable& rVariable, std::vector& rOutput, @@ -63,7 +63,7 @@ Vector ApplyK0ProcedureOnStubElement(const Properties::Pointer& rProperties, con { Model model; auto& r_model_part = model.CreateModelPart("main"); - auto p_element = make_intrusive(); + auto p_element = make_intrusive(); p_element->SetProperties(rProperties); r_model_part.AddElement(p_element); @@ -98,7 +98,7 @@ ModelPart& PrepareTestModelPart(Model& rModel) auto p_model_part_properties = result.pGetProperties(0); p_model_part_properties->SetValue(CONSTITUTIVE_LAW, p_dummy_law); - auto p_element = make_intrusive(); + auto p_element = make_intrusive(); p_element->SetProperties(p_model_part_properties); result.AddElement(p_element); @@ -415,7 +415,7 @@ KRATOS_TEST_CASE_IN_SUITE(K0ProcedureChecksIfProcessHasCorrectMaterialData, Krat // Arrange Model model; auto& r_model_part = model.CreateModelPart("main"); - auto p_element = make_intrusive(); + auto p_element = make_intrusive(); p_element->SetId(1); p_element->SetProperties(std::make_shared()); r_model_part.AddElement(p_element); diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_phreatic_multi_line_pressure_table_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_phreatic_multi_line_pressure_table_process.cpp similarity index 96% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_phreatic_multi_line_pressure_table_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_phreatic_multi_line_pressure_table_process.cpp index 0bf75282f452..04681140a0ce 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_apply_phreatic_multi_line_pressure_table_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_apply_phreatic_multi_line_pressure_table_process.cpp @@ -11,8 +11,8 @@ // #include "containers/model.h" #include "custom_processes/apply_phreatic_multi_line_pressure_table_process.h" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -77,4 +77,4 @@ KRATOS_TEST_CASE_IN_SUITE(ApplyPhreaticMultiLinePressureTableProcessDoesNotThrow r_model_part, test_parameters)) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_calculate_incremental_displacement_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_calculate_incremental_displacement_process.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_calculate_incremental_displacement_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_calculate_incremental_displacement_process.cpp index 2f238333a4d0..fa955b0fc4e7 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_calculate_incremental_displacement_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_calculate_incremental_displacement_process.cpp @@ -12,7 +12,7 @@ #include "custom_processes/calculate_incremental_displacement_process.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp similarity index 86% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp index da0036718a23..e3a965df896a 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_geo_extrapolate_integration_point_values_to_nodes_process.cpp @@ -13,18 +13,21 @@ #include "containers/model.h" #include "custom_processes/geo_extrapolate_integration_point_values_to_nodes_process.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { -class StubElement : public Element +class StubElementForNodalExtrapolationTest : public Element { public: - KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElement); + KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElementForNodalExtrapolationTest); - StubElement(IndexType NewId, GeometryType::Pointer pGeometry) : Element(NewId, pGeometry) {} + StubElementForNodalExtrapolationTest(IndexType NewId, GeometryType::Pointer pGeometry) + : Element(NewId, pGeometry) + { + } void CalculateOnIntegrationPoints(const Variable& rVariable, std::vector& rOutput, @@ -83,11 +86,11 @@ ModelPart& CreateModelPartWithTwoStubElements(Model& model) auto node_6 = model_part.CreateNewNode(6, 2.0, 1.0, 0.0); auto geometry_1 = std::make_shared>(node_1, node_2, node_3, node_4); - auto element_1 = Kratos::make_intrusive(1, geometry_1); + auto element_1 = Kratos::make_intrusive(1, geometry_1); model_part.AddElement(element_1); auto geometry_2 = std::make_shared>(node_2, node_5, node_6, node_3); - auto element_2 = Kratos::make_intrusive(2, geometry_2); + auto element_2 = Kratos::make_intrusive(2, geometry_2); model_part.AddElement(element_2); return model_part; @@ -134,8 +137,10 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesCorrectlyForConst Model model; auto& model_part = CreateModelPartWithTwoStubElements(model); - dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = {1.0, 1.0, 1.0, 1.0}; - dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = {1.0, 1.0, 1.0, 1.0}; + dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = { + 1.0, 1.0, 1.0, 1.0}; + dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = { + 1.0, 1.0, 1.0, 1.0}; auto parameters = Parameters(R"( { @@ -163,8 +168,10 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesCorrectlyForTwoCo Model model; auto& model_part = CreateModelPartWithTwoStubElements(model); - dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = {1.0, 1.0, 1.0, 1.0}; - dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = {2.0, 2.0, 2.0, 2.0}; + dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = { + 1.0, 1.0, 1.0, 1.0}; + dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = { + 2.0, 2.0, 2.0, 2.0}; auto parameters = Parameters(R"( { @@ -196,11 +203,11 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesCorrectlyForLinea auto& model_part = CreateModelPartWithTwoStubElements(model); // Linear field in x between -1 and 1 - dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = { + dynamic_cast(model_part.Elements()[1]).mIntegrationDoubleValues = { -0.57735, 0.57735, 0.57735, -0.57735}; // Linear field in y between -1 and 1 - dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = { + dynamic_cast(model_part.Elements()[2]).mIntegrationDoubleValues = { -0.57735, -0.57735, 0.57735, 0.57735}; auto parameters = Parameters(R"( @@ -232,12 +239,12 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesMatrixCorrectlyFo auto& model_part = CreateModelPartWithTwoStubElements(model); // Linear field in x between -1 and 1 - dynamic_cast(model_part.Elements()[1]).mIntegrationMatrixValues = { + dynamic_cast(model_part.Elements()[1]).mIntegrationMatrixValues = { ScalarMatrix(3, 3, -0.57735), ScalarMatrix(3, 3, 0.57735), ScalarMatrix(3, 3, 0.57735), ScalarMatrix(3, 3, -0.57735)}; // Linear field in y between -1 and 1 - dynamic_cast(model_part.Elements()[2]).mIntegrationMatrixValues = { + dynamic_cast(model_part.Elements()[2]).mIntegrationMatrixValues = { ScalarMatrix(3, 3, -0.57735), ScalarMatrix(3, 3, -0.57735), ScalarMatrix(3, 3, 0.57735), ScalarMatrix(3, 3, 0.57735)}; @@ -276,12 +283,12 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesVectorCorrectlyFo auto& model_part = CreateModelPartWithTwoStubElements(model); // Linear field in x between -1 and 1 - dynamic_cast(model_part.Elements()[1]).mIntegrationVectorValues = { + dynamic_cast(model_part.Elements()[1]).mIntegrationVectorValues = { ScalarVector(6, -0.57735), ScalarVector(6, 0.57735), ScalarVector(6, 0.57735), ScalarVector(6, -0.57735)}; // Linear field in y between -1 and 1 - dynamic_cast(model_part.Elements()[2]).mIntegrationVectorValues = { + dynamic_cast(model_part.Elements()[2]).mIntegrationVectorValues = { ScalarVector(6, -0.57735), ScalarVector(6, -0.57735), ScalarVector(6, 0.57735), ScalarVector(6, 0.57735)}; auto parameters = Parameters(R"( @@ -319,12 +326,12 @@ KRATOS_TEST_CASE_IN_SUITE(TestExtrapolationProcess_ExtrapolatesArrayCorrectlyFor auto& model_part = CreateModelPartWithTwoStubElements(model); // Linear field in x between -1 and 1 - dynamic_cast(model_part.Elements()[1]).mIntegrationArrayValues = { + dynamic_cast(model_part.Elements()[1]).mIntegrationArrayValues = { ScalarVector(3, -0.57735), ScalarVector(3, 0.57735), ScalarVector(3, 0.57735), ScalarVector(3, -0.57735)}; // Linear field in y between -1 and 1 - dynamic_cast(model_part.Elements()[2]).mIntegrationArrayValues = { + dynamic_cast(model_part.Elements()[2]).mIntegrationArrayValues = { ScalarVector(3, -0.57735), ScalarVector(3, -0.57735), ScalarVector(3, 0.57735), ScalarVector(3, 0.57735)}; auto parameters = Parameters(R"( diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_reset_displacement_process.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_reset_displacement_process.cpp index bf1db91bdd6d..f669ccf05439 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_reset_displacement_process.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_processes/test_reset_displacement_process.cpp @@ -37,12 +37,13 @@ class StubConstitutiveLaw : public ConstitutiveLaw SizeType GetStrainSize() const override { return 4; } }; -class StubElement : public Element +class StubElementForResetDisplacementTest : public Element { public: - KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElement); + KRATOS_CLASS_INTRUSIVE_POINTER_DEFINITION(StubElementForResetDisplacementTest); - StubElement(IndexType NewId, const GeometryType::Pointer& pGeometry) : Element(NewId, pGeometry) + StubElementForResetDisplacementTest(IndexType NewId, const GeometryType::Pointer& pGeometry) + : Element(NewId, pGeometry) { mConstitutiveLaws = std::vector(3, make_shared()); } @@ -92,7 +93,7 @@ ModelPart& CreateModelPartWithAStubElement(Model& rModel) auto node_3 = model_part.CreateNewNode(3, 1.0, 1.0, 0.0); auto geometry = std::make_shared>(node_1, node_2, node_3); - model_part.AddElement(make_intrusive(1, geometry)); + model_part.AddElement(make_intrusive(1, geometry)); return model_part; } diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_Pw_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_Pw_scheme.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_Pw_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_Pw_scheme.cpp index 273a9bc670db..263e0483e90c 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_Pw_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_Pw_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/backward_euler_quasistatic_Pw_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_T_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_T_scheme.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_T_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_T_scheme.cpp index 3c4f9397105e..1374af3093e6 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_T_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_T_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/backward_euler_T_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { @@ -124,4 +124,4 @@ KRATOS_TEST_CASE_IN_SUITE(ForMissingTemperatureSolutionStepVariable_CheckBackwar "TEMPERATURE variable is not allocated for node 0") } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_UPw_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_UPw_scheme.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_UPw_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_UPw_scheme.cpp index d01f58659b23..5be0dc61e5eb 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_backward_euler_UPw_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_backward_euler_UPw_scheme.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_strategies/schemes/backward_euler_quasistatic_U_Pw_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_T_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_T_scheme.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_T_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_T_scheme.cpp index f9f2948017fb..da601592d4c6 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_T_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_T_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/generalized_newmark_T_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; @@ -145,4 +145,4 @@ KRATOS_TEST_CASE_IN_SUITE(InitializeNewmarkTScheme_SetsTimeFactors, KratosGeoMec KRATOS_EXPECT_DOUBLE_EQ(model_part.GetProcessInfo()[DT_TEMPERATURE_COEFFICIENT], 1.0 / (theta * delta_time)); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_scheme.cpp similarity index 96% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_scheme.cpp index 88a9b3d54501..8ef9b941a254 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_generalized_newmark_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_generalized_newmark_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/generalized_newmark_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp index bbe6e65e0697..16f3505e2543 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geo_mechanics_newton_rapson_erosion_processs_strategy.cpp @@ -12,8 +12,8 @@ // Project includes #include "custom_strategies/strategies/geo_mechanics_newton_raphson_erosion_process_strategy.hpp" -#include "geo_mechanics_fast_suite.h" -#include "test_utilities.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/test_utilities.h" #include #include @@ -213,4 +213,4 @@ KRATOS_TEST_CASE_IN_SUITE(CheckFinalizeSolutionStep, KratosGeoMechanicsFastSuite KRATOS_EXPECT_NEAR(elements[2].GetValue(PIPE_HEIGHT), expected_inactive_pipe_height, Defaults::relative_tolerance); KRATOS_EXPECT_NEAR(elements[3].GetValue(PIPE_HEIGHT), expected_inactive_pipe_height, Defaults::relative_tolerance); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geomechanics_time_integration_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geomechanics_time_integration_scheme.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_geomechanics_time_integration_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geomechanics_time_integration_scheme.cpp index b824ddc98338..238393b65c24 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_geomechanics_time_integration_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_geomechanics_time_integration_scheme.cpp @@ -10,13 +10,13 @@ // Main authors: Richard Faasse // -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "containers/model.h" #include "custom_strategies/schemes/geomechanics_time_integration_scheme.hpp" #include "spaces/ublas_space.h" -#include "test_utilities/spy_condition.h" -#include "test_utilities/spy_element.h" +#include "tests/cpp_tests/test_utilities/spy_condition.h" +#include "tests/cpp_tests/test_utilities/spy_element.h" using namespace Kratos; using SparseSpaceType = UblasSpace; @@ -264,4 +264,4 @@ KRATOS_TEST_CASE_IN_SUITE(GeoMechanicsTimeIntegrationScheme_GivesCorrectDofs_Whe TestUpdateForNumberOfThreads(2); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_Pw_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_Pw_scheme.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_Pw_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_Pw_scheme.cpp index 1434e432eed1..893d8ea0d7d9 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_Pw_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_Pw_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/newmark_quasistatic_Pw_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; @@ -149,4 +149,4 @@ KRATOS_TEST_CASE_IN_SUITE(InitializeNewmarkPwScheme_SetsTimeFactors, KratosGeoMe KRATOS_EXPECT_DOUBLE_EQ(model_part.GetProcessInfo()[DT_PRESSURE_COEFFICIENT], 1.0 / (theta * delta_time)); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_dynamic_U_Pw_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_dynamic_U_Pw_scheme.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_dynamic_U_Pw_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_dynamic_U_Pw_scheme.cpp index 9114bda561ee..75f40eb0ee58 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_dynamic_U_Pw_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_dynamic_U_Pw_scheme.cpp @@ -11,8 +11,8 @@ // #include "custom_strategies/schemes/newmark_dynamic_U_Pw_scheme.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { @@ -296,4 +296,4 @@ KRATOS_TEST_CASE_IN_SUITE(NewmarkDynamicUPwSchemeUpdate_DoesNotUpdateFixedScalar KRATOS_EXPECT_DOUBLE_EQ(actual_dt_water_pressure, expected_dt_water_pressure); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_quasistatic_U_Pw_scheme.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_quasistatic_U_Pw_scheme.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_quasistatic_U_Pw_scheme.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_quasistatic_U_Pw_scheme.cpp index a91f1b59487a..64356296b7c8 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_newmark_quasistatic_U_Pw_scheme.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_strategies/test_newmark_quasistatic_U_Pw_scheme.cpp @@ -10,12 +10,12 @@ // Main authors: Richard Faasse // -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "custom_strategies/schemes/newmark_quasistatic_U_Pw_scheme.hpp" #include "spaces/ublas_space.h" -#include "test_utilities/spy_condition.h" -#include "test_utilities/spy_element.h" +#include "tests/cpp_tests/test_utilities/spy_condition.h" +#include "tests/cpp_tests/test_utilities/spy_element.h" namespace Kratos::Testing { @@ -170,4 +170,4 @@ KRATOS_TEST_CASE_IN_SUITE(ForInvalidGamma_CheckNewmarkUPwScheme_Throws, KratosGe "Gamma must be larger than zero, but got -2.5") } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_Hencky_strain.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_Hencky_strain.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_Hencky_strain.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_Hencky_strain.cpp index b0198f86ba1e..613aa50291dc 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_Hencky_strain.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_Hencky_strain.cpp @@ -12,7 +12,7 @@ #include "custom_utilities/math_utilities.h" #include "custom_utilities/stress_strain_utilities.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -97,4 +97,4 @@ KRATOS_TEST_CASE_IN_SUITE(CheckHenckyStrainPureShear, KratosGeoMechanicsFastSuit KRATOS_EXPECT_DOUBLE_EQ(2.0 * EHenckyAnalytical(1, 0), Evector(3)); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_builder_and_solver_factory.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_builder_and_solver_factory.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_builder_and_solver_factory.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_builder_and_solver_factory.cpp index 4083caaab2f1..c40b2f292392 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_builder_and_solver_factory.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_builder_and_solver_factory.cpp @@ -11,9 +11,9 @@ // #include "custom_utilities/builder_and_solver_factory.hpp" -#include "geo_mechanics_fast_suite.h" #include "linear_solvers/linear_solver.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_compressibility_matrix.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_compressibility_matrix.cpp similarity index 96% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_compressibility_matrix.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_compressibility_matrix.cpp index fbdeca13738d..54aec220935f 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_compressibility_matrix.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_compressibility_matrix.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include using namespace Kratos; @@ -66,4 +66,4 @@ KRATOS_TEST_CASE_IN_SUITE(Calculatecompressibility_matrix3D4NGivesCorrectResults KRATOS_CHECK_MATRIX_NEAR(compressibility_matrix, expected_compressibility_matrix, 1e-12) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_constitutive_law_set6.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_constitutive_law_utilities.cpp similarity index 95% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_constitutive_law_set6.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_constitutive_law_utilities.cpp index aadeddbeb89e..dfbda408a4e2 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_constitutive_law_set6.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_constitutive_law_utilities.cpp @@ -11,8 +11,8 @@ // #include "custom_utilities/constitutive_law_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include using namespace Kratos; @@ -50,4 +50,4 @@ KRATOS_TEST_CASE_IN_SUITE(SetSixConstitutiveParametersCorrectResults, KratosGeoM KRATOS_CHECK_NEAR(ConstitutiveParameters.GetDeterminantF(), determinant_of_F, 1e-12); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_convergence_criteria_factory.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_convergence_criteria_factory.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_convergence_criteria_factory.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_convergence_criteria_factory.cpp index a08c1e3260c1..861d917a25fb 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_convergence_criteria_factory.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_convergence_criteria_factory.cpp @@ -11,8 +11,8 @@ // #include "custom_utilities/convergence_criteria_factory.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; using SparseSpaceType = UblasSpace; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_coupling_matrix.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_coupling_matrix.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_coupling_matrix.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_coupling_matrix.cpp index f838f0f9c39c..5affff6d0fc9 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_coupling_matrix.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_coupling_matrix.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include using namespace Kratos; @@ -109,4 +109,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculateCouplingMatrix3D4NGivesCorrectResults, Kratos KRATOS_CHECK_MATRIX_NEAR(coupling_matrix, expected_coupling_matrix, 1e-12) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_dof_utilities.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_dof_utilities.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_dof_utilities.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_dof_utilities.cpp index b40e621ed223..0ebd50864c97 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_dof_utilities.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_dof_utilities.cpp @@ -20,9 +20,9 @@ #include "custom_utilities/dof_utilities.h" #include "geo_aliases.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "includes/element.h" -#include "test_utilities/model_setup_utilities.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/test_utilities/model_setup_utilities.h" namespace { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_equation_of_motion.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_equation_of_motion.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_equation_of_motion.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_equation_of_motion.cpp index 30d8d07adb07..a2f3eb3251ab 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_equation_of_motion.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_equation_of_motion.cpp @@ -13,7 +13,7 @@ #include "custom_constitutive/linear_elastic_2D_interface_law.h" #include "custom_utilities/equation_of_motion_utilities.h" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "tests/cpp_tests/test_utilities.h" #include "tests/cpp_tests/test_utilities/model_setup_utilities.h" @@ -270,4 +270,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculatingTheInternalForceVectorFailsWhenTheMatrixVec #endif -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_fluid_pressure.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_fluid_pressure.cpp similarity index 91% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_fluid_pressure.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_fluid_pressure.cpp index dc3a284ce19a..94bd36fcca40 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_fluid_pressure.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_fluid_pressure.cpp @@ -12,8 +12,8 @@ #include "boost/numeric/ublas/assignment.hpp" #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -33,4 +33,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculateFluidPressureGivesCorrectResults, KratosGeoMe KRATOS_CHECK_NEAR(fluid_pressure, expected_value, 1e-12); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_linear_nodal_extrapolator.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_linear_nodal_extrapolator.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_linear_nodal_extrapolator.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_linear_nodal_extrapolator.cpp index a9fb6a5a55af..bb437732375b 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_linear_nodal_extrapolator.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_linear_nodal_extrapolator.cpp @@ -11,11 +11,11 @@ // #include "custom_utilities/linear_nodal_extrapolator.h" -#include "geo_mechanics_fast_suite.h" #include "geometries/quadrilateral_2d_4.h" #include "geometries/quadrilateral_2d_8.h" #include "geometries/triangle_2d_3.h" #include "geometries/triangle_2d_6.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include namespace Kratos::Testing @@ -125,4 +125,4 @@ KRATOS_TEST_CASE_IN_SUITE(NodalExtrapolator_GivesCorrectExtrapolationMatrix_For2 KRATOS_EXPECT_MATRIX_NEAR(extrapolation_matrix, expected_extrapolation_matrix, 1e-6) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_node_utilities.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_node_utilities.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_node_utilities.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_node_utilities.cpp index 986706cc704d..67fcc129bc0b 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_node_utilities.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_node_utilities.cpp @@ -10,9 +10,9 @@ // Main authors: Richard Faasse // #include "custom_utilities/node_utilities.h" -#include "geo_mechanics_fast_suite.h" #include "includes/node.h" #include "includes/variables.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_permeability_matrix.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_permeability_matrix.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_permeability_matrix.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_permeability_matrix.cpp index b7152efb65c2..669c6393e4c3 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_permeability_matrix.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_permeability_matrix.cpp @@ -12,8 +12,8 @@ #include "containers/model.h" #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include using namespace Kratos; @@ -90,4 +90,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculatePermeabilityMatrix3D4NGivesCorrectResults, Kr KRATOS_CHECK_MATRIX_NEAR(PermeabilityMatrix, PMatrix, 1e-12) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_process_factory.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_factory.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_process_factory.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_factory.cpp index 65f73caf6e99..d720d8077263 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_process_factory.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_factory.cpp @@ -12,7 +12,7 @@ // #include "custom_utilities/process_factory.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_process_info_parser.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_info_parser.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_process_info_parser.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_info_parser.cpp index 672e290c5ac8..cbdad872d792 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_process_info_parser.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_process_info_parser.cpp @@ -11,7 +11,7 @@ // #include "custom_utilities/json_process_info_parser.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -145,4 +145,4 @@ KRATOS_TEST_CASE_IN_SUITE(GetProcessList_ReturnsEmptyList_WhenNoProcessesAreDefi KRATOS_EXPECT_TRUE(parser.GetProcessList(Parameters{}).empty()) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_scheme_factory.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_scheme_factory.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_scheme_factory.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_scheme_factory.cpp index 808dc5b922ad..b1794b007f05 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_scheme_factory.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_scheme_factory.cpp @@ -11,8 +11,8 @@ // #include "custom_utilities/scheme_factory.hpp" -#include "geo_mechanics_fast_suite.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_soil_density.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_soil_density.cpp similarity index 93% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_soil_density.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_soil_density.cpp index 74faa6ef3ce3..e610d539c437 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_soil_density.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_soil_density.cpp @@ -11,8 +11,8 @@ // #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/checks.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; @@ -38,4 +38,4 @@ KRATOS_TEST_CASE_IN_SUITE(CalculateSoilDensityGivesCorrectResults, KratosGeoMech KRATOS_CHECK_NEAR(soil_density, expected_value, 1e-12); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_factory.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_solving_strategy_factory.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_factory.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_solving_strategy_factory.cpp index 08d5695b4f46..ea0cc755a8fd 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_factory.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_solving_strategy_factory.cpp @@ -12,7 +12,7 @@ #include "containers/model.h" #include "custom_utilities/solving_strategy_factory.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_stress_strain_utitlities.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_stress_strain_utitlities.cpp similarity index 98% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_stress_strain_utitlities.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_stress_strain_utitlities.cpp index 6587da6c7069..8b45edc8850d 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_stress_strain_utitlities.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_stress_strain_utitlities.cpp @@ -13,7 +13,7 @@ #include "custom_utilities/math_utilities.h" #include "custom_utilities/stress_strain_utilities.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include "utilities/math_utils.h" #include @@ -190,4 +190,4 @@ KRATOS_TEST_CASE_IN_SUITE(CheckCalculateStrains, KratosGeoMechanicsFastSuiteWith KRATOS_EXPECT_VECTOR_NEAR(strains[i], expected_strains[i], 1.E-6) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_transport_equation_utilities.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_transport_equation_utilities.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_transport_equation_utilities.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_transport_equation_utilities.cpp index 5654072b439c..9933d44ad88d 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_transport_equation_utilities.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_transport_equation_utilities.cpp @@ -11,7 +11,7 @@ // #include "custom_utilities/transport_equation_utilities.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include namespace @@ -212,4 +212,4 @@ KRATOS_TEST_CASE_IN_SUITE(PermeabilityUpdateFactorIsComputedFromStrainsAndProper expected_factors, 1e-5) } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_variables_utilities.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_variables_utilities.cpp similarity index 92% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_variables_utilities.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_variables_utilities.cpp index 9c9b3064d6df..cd9755b96edb 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_variables_utilities.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_utilities/test_variables_utilities.cpp @@ -10,8 +10,8 @@ // Main authors: Richard Faasse // #include "custom_utilities/variables_utilities.hpp" -#include "geo_mechanics_fast_suite.h" #include "includes/variables.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { @@ -30,4 +30,4 @@ KRATOS_TEST_CASE_IN_SUITE(TestVariablesUtilitiesThrowsWhenComponentDoesNotExist, "Error: The component \"ACCELERATION_?\" is not registered!") } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp similarity index 97% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp index 91f34993d3d7..5bf740423fde 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_GeoMechanicsNewtonRaphsonErosionProcessStrategy.cpp @@ -15,8 +15,8 @@ /* Project includes */ #include "custom_workflows/dgeoflow.h" -#include "flow_stubs.h" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/flow_stubs.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace Kratos::Testing { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_dgeosettlement.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_dgeosettlement.cpp similarity index 96% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_dgeosettlement.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_dgeosettlement.cpp index 5e1c9a5c74e1..c20dbad79504 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_dgeosettlement.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_dgeosettlement.cpp @@ -11,10 +11,10 @@ // #include "custom_workflows/dgeosettlement.h" -#include "geo_mechanics_fast_suite.h" -#include "stub_input_utility.h" -#include "stub_process_info_parser.h" -#include "stub_time_loop_executor.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/stub_input_utility.h" +#include "tests/cpp_tests/stub_process_info_parser.h" +#include "tests/cpp_tests/stub_time_loop_executor.h" using namespace Kratos; @@ -168,4 +168,4 @@ KRATOS_TEST_CASE_IN_SUITE(RunStage_PassesTheCorrectProcessReferences, KratosGeoM RunStage(settlement); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_head_extrapolation_flow_workflow.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_head_extrapolation_flow_workflow.cpp similarity index 95% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_head_extrapolation_flow_workflow.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_head_extrapolation_flow_workflow.cpp index 642f6bec6602..ea138e05a95d 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_head_extrapolation_flow_workflow.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_head_extrapolation_flow_workflow.cpp @@ -15,9 +15,9 @@ // Project includes #include "custom_workflows/dgeoflow.h" -#include "flow_stubs.h" -#include "geo_mechanics_fast_suite.h" -#include "test_utilities.h" +#include "tests/cpp_tests/flow_stubs.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/test_utilities.h" namespace { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_prescribed_time_incrementor.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_prescribed_time_incrementor.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_prescribed_time_incrementor.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_prescribed_time_incrementor.cpp index 9b88bb05a1f7..a5f223c9e701 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_prescribed_time_incrementor.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_prescribed_time_incrementor.cpp @@ -13,7 +13,7 @@ #include "custom_workflows/prescribed_time_incrementor.h" #include "custom_workflows/time_step_end_state.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_wrapper.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_solving_strategy_wrapper.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_wrapper.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_solving_strategy_wrapper.cpp index 01d6a5391c8f..1bf8d56008da 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_solving_strategy_wrapper.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_solving_strategy_wrapper.cpp @@ -14,9 +14,9 @@ #include "custom_utilities/solving_strategy_factory.hpp" #include "custom_workflows/solving_strategy_wrapper.hpp" #include "geo_mechanics_application_variables.h" -#include "geo_mechanics_fast_suite.h" #include "linear_solvers/linear_solver.h" #include "spaces/ublas_space.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" namespace { diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_incrementor.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_incrementor.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_time_incrementor.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_incrementor.cpp index 45693bf8bdfc..4cae98e80a2d 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_incrementor.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_incrementor.cpp @@ -13,7 +13,7 @@ #include "custom_workflows/adaptive_time_incrementor.h" #include "custom_workflows/time_step_end_state.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" using namespace Kratos; diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_loop_executor.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_loop_executor.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_time_loop_executor.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_loop_executor.cpp index e2b69e6ff6e8..53dd7b7b54a7 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_loop_executor.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_loop_executor.cpp @@ -15,7 +15,7 @@ #include "custom_workflows/prescribed_time_incrementor.h" #include "custom_workflows/time_loop_executor.hpp" #include "custom_workflows/time_step_end_state.hpp" -#include "geo_mechanics_fast_suite.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include @@ -389,4 +389,4 @@ KRATOS_TEST_CASE_IN_SUITE(ExpectOutputIsInitializedAndFinalizedWhenRunThrows, Kr KRATOS_EXPECT_EQ(solver_strategy->GetCountFinalizeOutputCalled(), 1); } -} // namespace Kratos::Testing \ No newline at end of file +} // namespace Kratos::Testing diff --git a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_stepping.cpp b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_stepping.cpp similarity index 99% rename from applications/GeoMechanicsApplication/tests/cpp_tests/test_time_stepping.cpp rename to applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_stepping.cpp index 3447e8918f1f..71cd2bdd759b 100644 --- a/applications/GeoMechanicsApplication/tests/cpp_tests/test_time_stepping.cpp +++ b/applications/GeoMechanicsApplication/tests/cpp_tests/custom_workflows/test_time_stepping.cpp @@ -13,8 +13,8 @@ #include "custom_workflows/strategy_wrapper.hpp" #include "custom_workflows/time_step_executor.h" -#include "geo_mechanics_fast_suite.h" #include "solving_strategies/strategies/solving_strategy.h" +#include "tests/cpp_tests/geo_mechanics_fast_suite.h" #include diff --git a/applications/GeoMechanicsApplication/tests/test_benchmark_set_2.py b/applications/GeoMechanicsApplication/tests/test_benchmark_set_2.py index f67a2e892b34..5a9560fb1daa 100644 --- a/applications/GeoMechanicsApplication/tests/test_benchmark_set_2.py +++ b/applications/GeoMechanicsApplication/tests/test_benchmark_set_2.py @@ -92,38 +92,5 @@ def test_benchmark2_2(self): self.assertAlmostEqual(max_y_total_stress_plaxis, max_y_cauchy_stress_kratos, delta=max(max_y_total_stress_plaxis*relative_precision_stress,absolute_precision_stress)) self.assertAlmostEqual(min_y_total_stress_plaxis, min_y_cauchy_stress_kratos, delta=max(abs(min_x_total_stress_plaxis*relative_precision_stress),absolute_precision_stress)) - @KratosUnittest.skip("unit test skipped as it is not ready") - def test_benchmark2_3(self): - """ - In this benchmark a four stage model is tested. - Stage 1: initialisation sand layer - Stage 2: addition of sheetpile - Stage 3: addition of dike - Stage 4: addition of water - - The test is calculated using gravity loading. - - This test compares minimum, maximum stress and displacement in the third and fourth stage. - - :return: - """ - - test_name = r'dike_with_sheetpile_all_stage' - project_path = test_helper.get_file_path(os.path.join('.', test_name)) - n_stages = 3 - test_helper.run_stages(project_path, n_stages) - - # max_x_disp_plaxis = 0.01279 - # min_x_disp_plaxis = -0.012234 - # - # max_y_disp_plaxis = 0.0 - # min_y_disp_plaxis = -0.21458 - # - # max_x_total_stress_plaxis = -311 - # min_x_total_stress_plaxis = -146256 - # - # max_y_total_stress_plaxis = -674 - # min_y_total_stress_plaxis = -432068 - if __name__ == '__main__': KratosUnittest.main() diff --git a/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_k0_umat/MaterialParameters1.json b/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_k0_umat/MaterialParameters1.json index e736f4d25a5d..420219c09a1d 100644 --- a/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_k0_umat/MaterialParameters1.json +++ b/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_k0_umat/MaterialParameters1.json @@ -29,7 +29,6 @@ 30, 0.0, 1000], - "NUMBER_OF_UMAT_STATE_VARIABLES": 1, "RETENTION_LAW": "SaturatedLaw", "SATURATED_SATURATION": 1.0 } diff --git a/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_simple_dike/MaterialParameters.json b/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_simple_dike/MaterialParameters.json index d44e0675e354..6272d694886d 100644 --- a/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_simple_dike/MaterialParameters.json +++ b/applications/GeoMechanicsApplication/tests/test_k0_procedure_process/test_k0_procedure_simple_dike/MaterialParameters.json @@ -27,7 +27,6 @@ 30, 0.0, 1000], - "NUMBER_OF_UMAT_STATE_VARIABLES": 1, "STATE_VARIABLES" : [0.0] }, "Tables": {} @@ -58,7 +57,6 @@ 20, 0.0, 1000], - "NUMBER_OF_UMAT_STATE_VARIABLES": 1, "STATE_VARIABLES" : [0.0] }, "Tables": {} diff --git a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_beam_element_2D2N.cpp b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_beam_element_2D2N.cpp index d419c8ff615a..f1d8e7e90adc 100644 --- a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_beam_element_2D2N.cpp +++ b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_beam_element_2D2N.cpp @@ -954,15 +954,12 @@ void LinearTimoshenkoBeamElement2D2N::CalculateOnIntegrationPoints( const SizeType strain_size = mConstitutiveLawVector[0]->GetStrainSize(); const SizeType mat_size = GetDoFsPerNode() * GetGeometry().size(); rOutput.resize(integration_points.size()); - const auto &r_props = GetProperties(); if (rVariable == PK2_STRESS_VECTOR) { - - const auto &r_geometry = GetGeometry(); - - ConstitutiveLaw::Parameters cl_values(r_geometry, r_props, rProcessInfo); + const auto &r_props = GetProperties(); + ConstitutiveLaw::Parameters cl_values(GetGeometry(), r_props, rProcessInfo); const double length = CalculateLength(); - const double Phi = StructuralMechanicsElementUtilities::CalculatePhi(r_props, length); + const double phi = StructuralMechanicsElementUtilities::CalculatePhi(r_props, length); VectorType strain_vector(strain_size), stress_vector(strain_size); StructuralMechanicsElementUtilities::InitializeConstitutiveLawValuesForStressCalculation(cl_values, strain_vector, stress_vector); @@ -972,13 +969,12 @@ void LinearTimoshenkoBeamElement2D2N::CalculateOnIntegrationPoints( // Loop over the integration points for (SizeType integration_point = 0; integration_point < integration_points.size(); ++integration_point) { - CalculateGeneralizedStrainsVector(strain_vector, length, Phi, integration_points[integration_point].X(), nodal_values); + CalculateGeneralizedStrainsVector(strain_vector, length, phi, integration_points[integration_point].X(), nodal_values); mConstitutiveLawVector[integration_point]->CalculateMaterialResponsePK2(cl_values); - auto stress_vector = cl_values.GetStressVector(); - if ( this->GetProperties().Has(TIMOSHENKO_BEAM_PRESTRESS_PK2)) { - stress_vector += this->GetProperties()[TIMOSHENKO_BEAM_PRESTRESS_PK2]; + rOutput[integration_point] = cl_values.GetStressVector(); + if ( this->GetProperties().Has(BEAM_PRESTRESS_PK2)) { + rOutput[integration_point] += this->GetProperties()[BEAM_PRESTRESS_PK2]; } - rOutput[integration_point] = stress_vector; } } } diff --git a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.cpp b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.cpp index 6ba7bea908d5..91a4d0288636 100644 --- a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.cpp +++ b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.cpp @@ -672,119 +672,101 @@ void LinearTimoshenkoCurvedBeamElement2D3N::CalculateOnIntegrationPoints( { const auto& r_integration_points = IntegrationPoints(GetIntegrationMethod()); rOutput.resize(r_integration_points.size()); - const auto &r_props = GetProperties(); if (rVariable == AXIAL_FORCE || rVariable == BENDING_MOMENT || rVariable == SHEAR_FORCE) { - const auto &r_geometry = GetGeometry(); - - ConstitutiveLaw::Parameters cl_values(r_geometry, r_props, rProcessInfo); - auto &r_cl_options = cl_values.GetOptions(); - r_cl_options.Set(ConstitutiveLaw::COMPUTE_STRESS , true); - r_cl_options.Set(ConstitutiveLaw::COMPUTE_CONSTITUTIVE_TENSOR, false); - - // Let's initialize the cl values + ConstitutiveLaw::Parameters cl_values(GetGeometry(), GetProperties(), rProcessInfo); VectorType strain_vector(StrainSize), stress_vector(StrainSize); - strain_vector.clear(); - cl_values.SetStrainVector(strain_vector); - cl_values.SetStressVector(stress_vector); - - GlobalSizeVector nodal_values, B_b, dNu, dN_theta, N_shape, Nu, N_theta, dN_shape; - BoundedMatrix frenet_serret; - BoundedVector N_forces, Gamma; // axial and shear forces, strains - BoundedMatrix B_s, aux_B_s; - - // Loop over the integration points - for (SizeType IP = 0; IP < r_integration_points.size(); ++IP) { - const double xi = r_integration_points[IP].X(); - const double J = GetJacobian(xi); - - GetNodalValuesVector(nodal_values); + StructuralMechanicsElementUtilities::InitializeConstitutiveLawValuesForStressCalculation(cl_values, strain_vector, stress_vector); - const array_3 shape_functions = GetShapeFunctionsValues(xi); - const array_3 d_shape_functions = GetFirstDerivativesShapeFunctionsValues(xi, J); - - GetShapeFunctionsValuesGlobalVectors(shape_functions, N_shape, Nu, N_theta); - GetShapeFunctionsValuesGlobalVectors(d_shape_functions, dN_shape, dNu, dN_theta); - - array_3 t, n; - GetTangentandTransverseUnitVectors(xi, t, n); - noalias(frenet_serret) = GetFrenetSerretMatrix(xi, t, n); - noalias(B_b) = dN_theta; - - // we fill aux_B_s - for (IndexType i = 0; i < SystemSize; ++i) { - aux_B_s(0, i) = dNu[i] + t[1] * N_theta[i]; - aux_B_s(1, i) = dN_shape[i] - t[0] * N_theta[i]; - } - noalias(B_s) = prod(frenet_serret, aux_B_s); + for (SizeType integration_point = 0; integration_point < r_integration_points.size(); ++integration_point) { - noalias(Gamma) = prod(B_s, nodal_values); - strain_vector[0] = Gamma[0]; // axial strain - strain_vector[2] = Gamma[1]; // shear strain - strain_vector[1] = inner_prod(B_b, nodal_values); // curvature + noalias(strain_vector) = CalculateStrainVector(r_integration_points[integration_point].X()); - mConstitutiveLawVector[IP]->CalculateMaterialResponseCauchy(cl_values); + mConstitutiveLawVector[integration_point]->CalculateMaterialResponseCauchy(cl_values); const Vector &r_generalized_stresses = cl_values.GetStressVector(); if (rVariable == AXIAL_FORCE) { - rOutput[IP] = r_generalized_stresses[0]; + rOutput[integration_point] = r_generalized_stresses[0]; } else if (rVariable == BENDING_MOMENT) { - rOutput[IP] = r_generalized_stresses[1]; + rOutput[integration_point] = r_generalized_stresses[1]; } else if (rVariable == SHEAR_FORCE) { - rOutput[IP] = r_generalized_stresses[2]; + rOutput[integration_point] = r_generalized_stresses[2]; } } } else if (rVariable == AXIAL_STRAIN || rVariable == BENDING_STRAIN || rVariable == SHEAR_STRAIN) { - // Let's initialize the cl values VectorType strain_vector(StrainSize); - GlobalSizeVector nodal_values, B_b, dNu, dN_theta, N_shape, Nu, N_theta, dN_shape; - BoundedMatrix frenet_serret; - BoundedVector N_forces, Gamma; // axial and shear forces, strains - BoundedMatrix B_s, aux_B_s; + for (SizeType integration_point = 0; integration_point < r_integration_points.size(); ++integration_point) { - // Loop over the integration points - for (SizeType IP = 0; IP < r_integration_points.size(); ++IP) { - const double xi = r_integration_points[IP].X(); - const double J = GetJacobian(xi); + noalias(strain_vector) = CalculateStrainVector(r_integration_points[integration_point].X()); - GetNodalValuesVector(nodal_values); + if (rVariable == AXIAL_STRAIN) { + rOutput[integration_point] = strain_vector[0]; + } else if (rVariable == BENDING_STRAIN) { + rOutput[integration_point] = strain_vector[1]; + } else if (rVariable == SHEAR_STRAIN) { + rOutput[integration_point] = strain_vector[2]; + } + } + } +} - const array_3 shape_functions = GetShapeFunctionsValues(xi); - const array_3 d_shape_functions = GetFirstDerivativesShapeFunctionsValues(xi, J); +void LinearTimoshenkoCurvedBeamElement2D3N::CalculateOnIntegrationPoints( + const Variable& rVariable, + std::vector& rOutput, + const ProcessInfo& rProcessInfo + ) +{ + const auto& r_integration_points = IntegrationPoints(GetIntegrationMethod()); + rOutput.resize(r_integration_points.size()); - GetShapeFunctionsValuesGlobalVectors(shape_functions, N_shape, Nu, N_theta); - GetShapeFunctionsValuesGlobalVectors(d_shape_functions, dN_shape, dNu, dN_theta); + if (rVariable == PK2_STRESS_VECTOR) { + ConstitutiveLaw::Parameters cl_values(GetGeometry(), GetProperties(), rProcessInfo); + VectorType strain_vector(StrainSize), stress_vector(StrainSize); + StructuralMechanicsElementUtilities::InitializeConstitutiveLawValuesForStressCalculation(cl_values, strain_vector, stress_vector); - array_3 t, n; - GetTangentandTransverseUnitVectors(xi, t, n); - noalias(frenet_serret) = GetFrenetSerretMatrix(xi, t, n); - noalias(B_b) = dN_theta; + for (SizeType integration_point = 0; integration_point < r_integration_points.size(); ++integration_point) { - // we fill aux_B_s - for (IndexType i = 0; i < SystemSize; ++i) { - aux_B_s(0, i) = dNu[i] + t[1] * N_theta[i]; - aux_B_s(1, i) = dN_shape[i] - t[0] * N_theta[i]; - } - noalias(B_s) = prod(frenet_serret, aux_B_s); + noalias(strain_vector) = CalculateStrainVector(r_integration_points[integration_point].X()); - noalias(Gamma) = prod(B_s, nodal_values); - strain_vector[0] = Gamma[0]; // axial strain - strain_vector[2] = Gamma[1]; // shear strain - strain_vector[1] = inner_prod(B_b, nodal_values); // curvature + mConstitutiveLawVector[integration_point]->CalculateMaterialResponsePK2(cl_values); - if (rVariable == AXIAL_STRAIN) { - rOutput[IP] = strain_vector[0]; - } else if (rVariable == BENDING_STRAIN) { - rOutput[IP] = strain_vector[1]; - } else if (rVariable == SHEAR_STRAIN) { - rOutput[IP] = strain_vector[2]; + rOutput[integration_point] = cl_values.GetStressVector(); + if ( this->GetProperties().Has(BEAM_PRESTRESS_PK2)) { + rOutput[integration_point] += this->GetProperties()[BEAM_PRESTRESS_PK2]; } } } } +Vector LinearTimoshenkoCurvedBeamElement2D3N::CalculateStrainVector(double Xi) +{ + GlobalSizeVector nodal_values, dNu, dN_theta, n_shape, nu, n_theta, dN_shape; + + GetNodalValuesVector(nodal_values); + GetShapeFunctionsValuesGlobalVectors(GetShapeFunctionsValues(Xi), n_shape, nu, n_theta); + GetShapeFunctionsValuesGlobalVectors(GetFirstDerivativesShapeFunctionsValues(Xi, GetJacobian(Xi)), dN_shape, dNu, dN_theta); + + array_3 t, n; + GetTangentandTransverseUnitVectors(Xi, t, n); + BoundedMatrix aux_B_s; + for (IndexType i = 0; i < SystemSize; ++i) { + aux_B_s(0, i) = dNu[i] + t[1] * n_theta[i]; + aux_B_s(1, i) = dN_shape[i] - t[0] * n_theta[i]; + } + + BoundedMatrix frenet_serret = GetFrenetSerretMatrix(Xi, t, n); + BoundedVector gamma = prod(prod(frenet_serret, aux_B_s), nodal_values); + + Vector strain_vector(3); + strain_vector[0] = gamma[0]; // axial strain + strain_vector[2] = gamma[1]; // shear strain + strain_vector[1] = inner_prod(dN_theta, nodal_values); // curvature + + return strain_vector; +} + /***********************************************************************************/ /***********************************************************************************/ diff --git a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.h b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.h index ad1080bace02..b36f91622ca1 100644 --- a/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.h +++ b/applications/StructuralMechanicsApplication/custom_elements/beam_elements/timoshenko_curved_beam_element_2D3N.h @@ -333,6 +333,18 @@ class KRATOS_API(STRUCTURAL_MECHANICS_APPLICATION) LinearTimoshenkoCurvedBeamEle const ProcessInfo& rCurrentProcessInfo ) override; + /** + * @brief Calculate a double Variable on the Element Constitutive Law + * @param rVariable The variable we want to get + * @param rOutput The values obtained in the integration points + * @param rCurrentProcessInfo the current process info instance + */ + void CalculateOnIntegrationPoints( + const Variable& rVariable, + std::vector& rOutput, + const ProcessInfo& rCurrentProcessInfo + ) override; + /** * @brief Get on rVariable Constitutive Law from the element * @param rVariable The variable we want to get @@ -457,7 +469,7 @@ class KRATOS_API(STRUCTURAL_MECHANICS_APPLICATION) LinearTimoshenkoCurvedBeamEle ///@name Private Operations ///@{ - + Vector CalculateStrainVector(double Xi); ///@} ///@name Private Access ///@{ diff --git a/applications/StructuralMechanicsApplication/custom_python/structural_mechanics_python_application.cpp b/applications/StructuralMechanicsApplication/custom_python/structural_mechanics_python_application.cpp index 3fa928e6767a..cc5fa9eb9658 100644 --- a/applications/StructuralMechanicsApplication/custom_python/structural_mechanics_python_application.cpp +++ b/applications/StructuralMechanicsApplication/custom_python/structural_mechanics_python_application.cpp @@ -91,7 +91,7 @@ PYBIND11_MODULE(KratosStructuralMechanicsApplication,m) KRATOS_REGISTER_IN_PYTHON_VARIABLE(m,I33) KRATOS_REGISTER_IN_PYTHON_VARIABLE(m,IZ) KRATOS_REGISTER_IN_PYTHON_VARIABLE(m,BEAM_INITIAL_STRAIN_VECTOR) - KRATOS_REGISTER_IN_PYTHON_VARIABLE(m,TIMOSHENKO_BEAM_PRESTRESS_PK2) + KRATOS_REGISTER_IN_PYTHON_VARIABLE(m,BEAM_PRESTRESS_PK2) // semi rigid beam variables KRATOS_REGISTER_IN_PYTHON_VARIABLE(m, ROTATIONAL_STIFFNESS_AXIS_2) diff --git a/applications/StructuralMechanicsApplication/custom_utilities/constitutive_law_utilities.cpp b/applications/StructuralMechanicsApplication/custom_utilities/constitutive_law_utilities.cpp index 0d7a81861316..abe5ba8336cc 100644 --- a/applications/StructuralMechanicsApplication/custom_utilities/constitutive_law_utilities.cpp +++ b/applications/StructuralMechanicsApplication/custom_utilities/constitutive_law_utilities.cpp @@ -218,17 +218,21 @@ void ConstitutiveLawUtilities::CalculateRotationOperatorVoigt( const double c = rEulerOperator(0, 0); const double s = rEulerOperator(0, 1); - rVoigtOperator(0, 0) = std::pow(c, 2); - rVoigtOperator(0, 1) = std::pow(s, 2); - rVoigtOperator(0, 2) = c * s; + const double c_square = c * c; + const double s_square = s * s; + const double c_times_s = c * s; - rVoigtOperator(1, 0) = std::pow(s, 2); - rVoigtOperator(1, 1) = std::pow(c, 2); - rVoigtOperator(1, 2) = -c * s; + rVoigtOperator(0, 0) = c_square; + rVoigtOperator(0, 1) = s_square; + rVoigtOperator(0, 2) = c_times_s; + + rVoigtOperator(1, 0) = s_square; + rVoigtOperator(1, 1) = c_square; + rVoigtOperator(1, 2) = -c_times_s; rVoigtOperator(2, 0) = -2.0 * c * s; rVoigtOperator(2, 1) = 2.0 * c * s; - rVoigtOperator(2, 2) = std::pow(c, 2) - std::pow(s, 2); + rVoigtOperator(2, 2) = c_square - s_square; } else { const double l1 = rEulerOperator(0, 0); const double l2 = rEulerOperator(1, 0); @@ -240,23 +244,23 @@ void ConstitutiveLawUtilities::CalculateRotationOperatorVoigt( const double n2 = rEulerOperator(1, 2); const double n3 = rEulerOperator(2, 2); - rVoigtOperator(0, 0) = std::pow(l1, 2); - rVoigtOperator(0, 1) = std::pow(m1, 2); - rVoigtOperator(0, 2) = std::pow(n1, 2); + rVoigtOperator(0, 0) = l1 * l1; + rVoigtOperator(0, 1) = m1 * m1; + rVoigtOperator(0, 2) = n1 * n1; rVoigtOperator(0, 3) = l1 * m1; rVoigtOperator(0, 4) = m1 * n1; rVoigtOperator(0, 5) = n1 * l1; - rVoigtOperator(1, 0) = std::pow(l2, 2); - rVoigtOperator(1, 1) = std::pow(m2, 2); - rVoigtOperator(1, 2) = std::pow(n2, 2); + rVoigtOperator(1, 0) = l2 * l2; + rVoigtOperator(1, 1) = m2 * m2; + rVoigtOperator(1, 2) = n2 * n2; rVoigtOperator(1, 3) = l2 * m2; rVoigtOperator(1, 4) = m2 * n2; rVoigtOperator(1, 5) = n2 * l2; - rVoigtOperator(2, 0) = std::pow(l3, 2); - rVoigtOperator(2, 1) = std::pow(m3, 2); - rVoigtOperator(2, 2) = std::pow(n3, 2); + rVoigtOperator(2, 0) = l3 * l3; + rVoigtOperator(2, 1) = m3 * m3; + rVoigtOperator(2, 2) = n3 * n3; rVoigtOperator(2, 3) = l3 * m3; rVoigtOperator(2, 4) = m3 * n3; rVoigtOperator(2, 5) = n3 * l3; diff --git a/applications/StructuralMechanicsApplication/structural_mechanics_application.cpp b/applications/StructuralMechanicsApplication/structural_mechanics_application.cpp index f6c7b197259d..6fb1eb10b751 100644 --- a/applications/StructuralMechanicsApplication/structural_mechanics_application.cpp +++ b/applications/StructuralMechanicsApplication/structural_mechanics_application.cpp @@ -347,7 +347,7 @@ void KratosStructuralMechanicsApplication::Register() { KRATOS_REGISTER_VARIABLE(I33) KRATOS_REGISTER_VARIABLE(LUMPED_MASS_ROTATION_COEFFICIENT) KRATOS_REGISTER_VARIABLE(BEAM_INITIAL_STRAIN_VECTOR) - KRATOS_REGISTER_VARIABLE(TIMOSHENKO_BEAM_PRESTRESS_PK2) + KRATOS_REGISTER_VARIABLE(BEAM_PRESTRESS_PK2) // semi rigid beam variables diff --git a/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.cpp b/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.cpp index fc67e0d8b434..e2785045d012 100644 --- a/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.cpp +++ b/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.cpp @@ -71,7 +71,7 @@ KRATOS_CREATE_VARIABLE(double, I22) KRATOS_CREATE_VARIABLE(double, I33) KRATOS_CREATE_VARIABLE(double, LUMPED_MASS_ROTATION_COEFFICIENT) KRATOS_CREATE_VARIABLE(Vector, BEAM_INITIAL_STRAIN_VECTOR) -KRATOS_CREATE_VARIABLE(Vector, TIMOSHENKO_BEAM_PRESTRESS_PK2) +KRATOS_CREATE_VARIABLE(Vector, BEAM_PRESTRESS_PK2) // semi rigid beam variables diff --git a/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.h b/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.h index ed0ab5cfb803..ef3a86bd5432 100644 --- a/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.h +++ b/applications/StructuralMechanicsApplication/structural_mechanics_application_variables.h @@ -92,8 +92,7 @@ namespace Kratos KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION,double, I33) KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION,double, LUMPED_MASS_ROTATION_COEFFICIENT) KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION,Vector, BEAM_INITIAL_STRAIN_VECTOR) - KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION,Vector, TIMOSHENKO_BEAM_PRESTRESS_PK2) - + KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION,Vector, BEAM_PRESTRESS_PK2) // Semi rigid beam variables KRATOS_DEFINE_APPLICATION_VARIABLE( STRUCTURAL_MECHANICS_APPLICATION, double, ROTATIONAL_STIFFNESS_AXIS_2) diff --git a/applications/StructuralMechanicsApplication/tests/cpp_tests/test_timoshenko_beams.cpp b/applications/StructuralMechanicsApplication/tests/cpp_tests/test_timoshenko_beams.cpp index 83dc5e317124..27375096c4d2 100644 --- a/applications/StructuralMechanicsApplication/tests/cpp_tests/test_timoshenko_beams.cpp +++ b/applications/StructuralMechanicsApplication/tests/cpp_tests/test_timoshenko_beams.cpp @@ -20,7 +20,8 @@ namespace Kratos::Testing { -void CreateBeamModel2N(std::string TimoshenkoBeamElementName) +template +void Create2DBeamModel_and_CheckPK2Stress(const std::string & TimoshenkoBeamElementName, const std::vector& rExpectedShearStress, const std::vector& rExpectedBendingMoment) { Model current_model; auto &r_model_part = current_model.CreateModelPart("ModelPart",1); @@ -32,29 +33,29 @@ void CreateBeamModel2N(std::string TimoshenkoBeamElementName) auto p_elem_prop = r_model_part.CreateNewProperties(0); constexpr auto youngs_modulus = 2.0e+06; p_elem_prop->SetValue(YOUNG_MODULUS, youngs_modulus); - constexpr auto cross_area = 1.0; - p_elem_prop->SetValue(CROSS_AREA, cross_area); - constexpr auto i33 = 1.0; - p_elem_prop->SetValue(I33, i33); - constexpr auto area_effective_y = 1.0; - p_elem_prop->SetValue(AREA_EFFECTIVE_Y, area_effective_y); + p_elem_prop->SetValue(CROSS_AREA, 1.0); + p_elem_prop->SetValue(I33, 1.0); + p_elem_prop->SetValue(AREA_EFFECTIVE_Y, 5.0/6.0); const auto &r_clone_cl = KratosComponents::Get("TimoshenkoBeamElasticConstitutiveLaw"); p_elem_prop->SetValue(CONSTITUTIVE_LAW, r_clone_cl.Clone()); // Create the test element constexpr double directional_length = 2.0; - auto p_node_1 = r_model_part.CreateNewNode(1, 0.0, 0.0, 0.0); - auto p_node_2 = r_model_part.CreateNewNode(2, directional_length, directional_length, directional_length); + r_model_part.CreateNewNode(1, 0.0, 0.0, 0.0); + r_model_part.CreateNewNode(2, directional_length, directional_length, 0.0); + std::vector element_nodes{1,2}; + if constexpr (TNNodes==3) { + r_model_part.CreateNewNode(3, directional_length/2, directional_length/2, 0.0); + element_nodes.push_back(3); + } for (auto& r_node : r_model_part.Nodes()){ r_node.AddDof(DISPLACEMENT_X); r_node.AddDof(DISPLACEMENT_Y); - r_node.AddDof(DISPLACEMENT_Z); r_node.AddDof(ROTATION_Z); } - std::vector element_nodes {1,2}; auto p_element = r_model_part.CreateNewElement(std::move(TimoshenkoBeamElementName), 1, element_nodes, p_elem_prop); const auto& r_process_info = r_model_part.GetProcessInfo(); p_element->Initialize(r_process_info); // Initialize the element to initialize the constitutive law @@ -62,32 +63,54 @@ void CreateBeamModel2N(std::string TimoshenkoBeamElementName) constexpr auto induced_strain = 0.1; p_element->GetGeometry()[1].FastGetSolutionStepValue(DISPLACEMENT) += ScalarVector(3, induced_strain * directional_length); p_element->GetGeometry()[1].FastGetSolutionStepValue(ROTATION_Z) += 0.1; + if constexpr(TNNodes==3) { + p_element->GetGeometry()[2].FastGetSolutionStepValue(DISPLACEMENT) += ScalarVector(3, induced_strain * directional_length/2.0); + p_element->GetGeometry()[2].FastGetSolutionStepValue(ROTATION_Z) += 0.1/2.0; + } std::vector stress_vectors; p_element->CalculateOnIntegrationPoints(PK2_STRESS_VECTOR, stress_vectors, r_process_info); constexpr auto expected_stress = induced_strain * youngs_modulus; - constexpr auto expected_shear_stress = -37500.0; - constexpr auto tolerance = 1.0e-5; Vector expected_stress_vector(3); - expected_stress_vector <<= expected_stress, 29631.5,expected_shear_stress; + expected_stress_vector <<= expected_stress, rExpectedBendingMoment[0],rExpectedShearStress[0]; KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[0], tolerance); - expected_stress_vector <<= expected_stress, 70710.7,expected_shear_stress; + expected_stress_vector <<= expected_stress, rExpectedBendingMoment[1],rExpectedShearStress[1]; KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[1], tolerance); - expected_stress_vector <<= expected_stress, 111790,expected_shear_stress; - KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[2], tolerance); + if(stress_vectors.size()>2) { + expected_stress_vector <<= expected_stress, rExpectedBendingMoment[2],rExpectedShearStress[2]; + KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[2], tolerance); + } + expected_stress_vector <<= expected_stress, rExpectedBendingMoment[0],rExpectedShearStress[0]; Vector pre_stress(3); pre_stress <<= 1.0e5, 1.0e4, 1.0e3; - p_element->GetProperties().SetValue(TIMOSHENKO_BEAM_PRESTRESS_PK2, pre_stress); + p_element->GetProperties().SetValue(BEAM_PRESTRESS_PK2, pre_stress); p_element->CalculateOnIntegrationPoints(PK2_STRESS_VECTOR, stress_vectors, r_process_info); expected_stress_vector += pre_stress; - KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[2], tolerance); + KRATOS_EXPECT_VECTOR_RELATIVE_NEAR(expected_stress_vector, stress_vectors[0], tolerance); } KRATOS_TEST_CASE_IN_SUITE(LinearTimoshenkoBeam2D2N_CalculatesPK2Stress, KratosStructuralMechanicsFastSuite) { - CreateBeamModel2N("LinearTimoshenkoBeamElement2D2N"); + const std::vector expected_shear_stress {-32608.7, -32608.7, -32608.7}; + const std::vector expected_bending_moment {34989.6, 70710.7, 106432.0}; + + Create2DBeamModel_and_CheckPK2Stress<2>("LinearTimoshenkoBeamElement2D2N", expected_shear_stress, expected_bending_moment); + } + + KRATOS_TEST_CASE_IN_SUITE(LinearTimoshenkodBeam2D3N_CalculatesPK2Stress, KratosStructuralMechanicsFastSuite) + { + const std::vector expected_shear_stress {2604.74, -21673.6, -48084.9}; + const std::vector expected_bending_moment {86720.4, 68516.6, 61527.5}; + Create2DBeamModel_and_CheckPK2Stress<3>("LinearTimoshenkoBeamElement2D3N", expected_shear_stress, expected_bending_moment); + } + + KRATOS_TEST_CASE_IN_SUITE(LinearTimoshenkodCurvedBeam2D3N_CalculatesPK2Stress, KratosStructuralMechanicsFastSuite) + { + const std::vector expected_shear_stress {17610.4, 65722.9}; + const std::vector expected_bending_moment {70710.7, 70710.7}; + Create2DBeamModel_and_CheckPK2Stress<3>("LinearTimoshenkoCurvedBeamElement2D3N", expected_shear_stress, expected_bending_moment); } } diff --git a/kratos/geometries/geometry_data.h b/kratos/geometries/geometry_data.h index dd0b57827421..6624d7103b2a 100644 --- a/kratos/geometries/geometry_data.h +++ b/kratos/geometries/geometry_data.h @@ -83,6 +83,7 @@ class GeometryData GI_EXTENDED_GAUSS_3, GI_EXTENDED_GAUSS_4, GI_EXTENDED_GAUSS_5, + GI_LOBATTO_1, NumberOfIntegrationMethods // Note that this entry needs to be always the last to be used as integration methods counter }; diff --git a/kratos/geometries/hexahedra_3d_8.h b/kratos/geometries/hexahedra_3d_8.h index edc8c86391b2..cbd3505c8091 100644 --- a/kratos/geometries/hexahedra_3d_8.h +++ b/kratos/geometries/hexahedra_3d_8.h @@ -1449,8 +1449,7 @@ template class Hexahedra3D8 : public Geometry Quadrature < HexahedronGaussLegendreIntegrationPoints3, 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), Quadrature < HexahedronGaussLegendreIntegrationPoints4, 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), Quadrature < HexahedronGaussLegendreIntegrationPoints5, 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), - Quadrature < HexahedronGaussLobattoIntegrationPoints1, 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), - Quadrature < HexahedronGaussLobattoIntegrationPoints2, 3, IntegrationPoint<3> >::GenerateIntegrationPoints() + Quadrature < HexahedronGaussLobattoIntegrationPoints1, 3, IntegrationPoint<3> >::GenerateIntegrationPoints() } }; return integration_points; @@ -1466,8 +1465,7 @@ template class Hexahedra3D8 : public Geometry Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_GAUSS_3 ), Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_GAUSS_4 ), Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_GAUSS_5 ), - Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_1 ), - Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_2 ) + Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_values; @@ -1488,7 +1486,8 @@ template class Hexahedra3D8 : public Geometry Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_GAUSS_4 ), Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_GAUSS_5 ), Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_1 ), - Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_2 ) + Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_2 ), + Hexahedra3D8::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_local_gradients; diff --git a/kratos/geometries/hexahedra_interface_3d_8.h b/kratos/geometries/hexahedra_interface_3d_8.h index aaadab166fca..1bbb84a0a03c 100644 --- a/kratos/geometries/hexahedra_interface_3d_8.h +++ b/kratos/geometries/hexahedra_interface_3d_8.h @@ -1766,9 +1766,9 @@ template class HexahedraInterface3D8 : public Geometry >::GenerateIntegrationPoints(), - Quadrature < HexahedronGaussLobattoIntegrationPoints2, + Quadrature < HexahedronGaussLobattoIntegrationPoints1, 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), IntegrationPointsArrayType(), IntegrationPointsArrayType() diff --git a/kratos/geometries/quadrilateral_2d_4.h b/kratos/geometries/quadrilateral_2d_4.h index cfd9a1ba4d7b..5fc08b3ccd5c 100644 --- a/kratos/geometries/quadrilateral_2d_4.h +++ b/kratos/geometries/quadrilateral_2d_4.h @@ -4,8 +4,8 @@ // _|\_\_| \__,_|\__|\___/ ____/ // Multi-Physics // -// License: BSD License -// Kratos default license: kratos/license.txt +// License: BSD License +// Kratos default license: kratos/license.txt // // Main authors: Riccardo Rossi // Janosch Stascheit @@ -26,6 +26,7 @@ #include "utilities/integration_utilities.h" #include "integration/quadrilateral_gauss_legendre_integration_points.h" #include "integration/quadrilateral_collocation_integration_points.h" +#include "integration/quadrilateral_gauss_lobatto_integration_points.h" namespace Kratos { @@ -1053,6 +1054,8 @@ template class Quadrilateral2D4 Quadrature < QuadrilateralCollocationIntegrationPoints4, 2, IntegrationPoint<3> >::GenerateIntegrationPoints(), Quadrature < QuadrilateralCollocationIntegrationPoints5, + 2, IntegrationPoint<3> >::GenerateIntegrationPoints(), + Quadrature < QuadrilateralGaussLobattoIntegrationPoints1, 2, IntegrationPoint<3> >::GenerateIntegrationPoints() } }; @@ -1086,7 +1089,9 @@ template class Quadrilateral2D4 Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_4 ), Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsValues( - GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 ) + GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 ), + Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsValues( + GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_values; @@ -1111,6 +1116,7 @@ template class Quadrilateral2D4 Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_3 ), Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_4 ), Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 ), + Quadrilateral2D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_local_gradients; diff --git a/kratos/geometries/quadrilateral_interface_2d_4.h b/kratos/geometries/quadrilateral_interface_2d_4.h index 9817956e923d..06abfcbd6cbd 100644 --- a/kratos/geometries/quadrilateral_interface_2d_4.h +++ b/kratos/geometries/quadrilateral_interface_2d_4.h @@ -1301,9 +1301,9 @@ template class QuadrilateralInterface2D4 IntegrationPointsContainerType integration_points = { { - Quadrature < QuadrilateralGaussLobattoIntegrationPoints1, + Quadrature < QuadrilateralGaussLobattoIntegrationPoints0, 2, IntegrationPoint<3> >::GenerateIntegrationPoints(), - Quadrature < QuadrilateralGaussLobattoIntegrationPoints2, + Quadrature < QuadrilateralGaussLobattoIntegrationPoints1, 2, IntegrationPoint<3> >::GenerateIntegrationPoints(), IntegrationPointsArrayType(), IntegrationPointsArrayType() diff --git a/kratos/geometries/tetrahedra_3d_4.h b/kratos/geometries/tetrahedra_3d_4.h index dcad8408b4e6..f779c64ea7e9 100644 --- a/kratos/geometries/tetrahedra_3d_4.h +++ b/kratos/geometries/tetrahedra_3d_4.h @@ -4,8 +4,8 @@ // _|\_\_| \__,_|\__|\___/ ____/ // Multi-Physics // -// License: BSD License -// Kratos default license: kratos/license.txt +// License: BSD License +// Kratos default license: kratos/license.txt // // Main authors: Riccardo Rossi // Janosch Stascheit @@ -23,6 +23,7 @@ // Project includes #include "geometries/triangle_3d_3.h" #include "integration/tetrahedron_gauss_legendre_integration_points.h" +#include "integration/tetrahedron_gauss_lobatto_integration_points.h" #include "geometries/plane.h" #include "utilities/geometry_utilities.h" @@ -1857,6 +1858,8 @@ template class Tetrahedra3D4 : public Geometry 3, IntegrationPoint<3> >::GenerateIntegrationPoints(), Quadrature >::GenerateIntegrationPoints(), + Quadrature >::GenerateIntegrationPoints() } }; return integration_points; @@ -1876,7 +1879,9 @@ template class Tetrahedra3D4 : public Geometry Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_GAUSS_4), Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsValues( - GeometryData::IntegrationMethod::GI_GAUSS_5) + GeometryData::IntegrationMethod::GI_GAUSS_5), + Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsValues( + GeometryData::IntegrationMethod::GI_LOBATTO_1) } }; return shape_functions_values; @@ -1897,7 +1902,9 @@ template class Tetrahedra3D4 : public Geometry Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_GAUSS_4), Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( - GeometryData::IntegrationMethod::GI_GAUSS_5) + GeometryData::IntegrationMethod::GI_GAUSS_5), + Tetrahedra3D4::CalculateShapeFunctionsIntegrationPointsLocalGradients( + GeometryData::IntegrationMethod::GI_LOBATTO_1) } }; return shape_functions_local_gradients; diff --git a/kratos/geometries/triangle_2d_3.h b/kratos/geometries/triangle_2d_3.h index e4841163c16d..0b18ab82aebe 100644 --- a/kratos/geometries/triangle_2d_3.h +++ b/kratos/geometries/triangle_2d_3.h @@ -4,8 +4,8 @@ // _|\_\_| \__,_|\__|\___/ ____/ // Multi-Physics // -// License: BSD License -// Kratos default license: kratos/license.txt +// License: BSD License +// Kratos default license: kratos/license.txt // // Main authors: Riccardo Rossi // Janosch Stascheit @@ -14,8 +14,7 @@ // Josep Maria Carbonell // -#if !defined(KRATOS_TRIANGLE_2D_3_H_INCLUDED ) -#define KRATOS_TRIANGLE_2D_3_H_INCLUDED +#pragma once // System includes @@ -26,6 +25,7 @@ #include "geometries/line_2d_2.h" #include "integration/triangle_gauss_legendre_integration_points.h" #include "integration/triangle_collocation_integration_points.h" +#include "integration/triangle_gauss_lobatto_integration_points.h" #include "utilities/intersection_utilities.h" namespace Kratos @@ -1549,7 +1549,8 @@ template class Triangle2D3 Quadrature >::GenerateIntegrationPoints(), Quadrature >::GenerateIntegrationPoints(), Quadrature >::GenerateIntegrationPoints(), - Quadrature >::GenerateIntegrationPoints() + Quadrature >::GenerateIntegrationPoints(), + Quadrature >::GenerateIntegrationPoints() } }; return integration_points; @@ -1583,6 +1584,8 @@ template class Triangle2D3 GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_4 ), Triangle2D3::CalculateShapeFunctionsIntegrationPointsValues( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 ), + Triangle2D3::CalculateShapeFunctionsIntegrationPointsValues( + GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_values; @@ -1607,6 +1610,7 @@ template class Triangle2D3 Triangle2D3::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_3 ), Triangle2D3::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_4 ), Triangle2D3::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 ), + Triangle2D3::CalculateShapeFunctionsIntegrationPointsLocalGradients( GeometryData::IntegrationMethod::GI_LOBATTO_1 ) } }; return shape_functions_local_gradients; @@ -2267,5 +2271,3 @@ template const GeometryDimension Triangle2D3::msGeometryDimension(2, 2); }// namespace Kratos. - -#endif // KRATOS_TRIANGLE_2D_3_H_INCLUDED defined diff --git a/kratos/includes/condition.h b/kratos/includes/condition.h index 404f4c42f6dd..8c7726fce677 100644 --- a/kratos/includes/condition.h +++ b/kratos/includes/condition.h @@ -669,6 +669,11 @@ class Condition : public GeometricalObject * the Output is given on integration points and characterizes the condition * Calculate(..) methods are: OPTIONAL */ + virtual void Calculate(const Variable& rVariable, + int& Output, + const ProcessInfo& rCurrentProcessInfo) + { + } virtual void Calculate(const Variable& rVariable, double& Output, @@ -682,6 +687,12 @@ class Condition : public GeometricalObject { } + virtual void Calculate(const Variable< array_1d >& rVariable, + array_1d& Output, + const ProcessInfo& rCurrentProcessInfo) + { + } + virtual void Calculate(const Variable& rVariable, Vector& Output, const ProcessInfo& rCurrentProcessInfo) diff --git a/kratos/includes/element.h b/kratos/includes/element.h index 563a5e76bfd3..98e27fa44c00 100644 --- a/kratos/includes/element.h +++ b/kratos/includes/element.h @@ -682,6 +682,11 @@ class Element : public GeometricalObject * the Output is given on integration points and characterizes the element * Calculate(..) methods are: OPTIONAL */ + virtual void Calculate(const Variable& rVariable, + int& Output, + const ProcessInfo& rCurrentProcessInfo) + { + } virtual void Calculate(const Variable& rVariable, double& Output, @@ -695,6 +700,12 @@ class Element : public GeometricalObject { } + virtual void Calculate(const Variable >& rVariable, + array_1d & Output, + const ProcessInfo& rCurrentProcessInfo) + { + } + virtual void Calculate(const Variable& rVariable, Vector& Output, const ProcessInfo& rCurrentProcessInfo) diff --git a/kratos/integration/hexahedron_gauss_lobatto_integration_points.h b/kratos/integration/hexahedron_gauss_lobatto_integration_points.h index b9a11431cb5a..7b4e59e42682 100644 --- a/kratos/integration/hexahedron_gauss_lobatto_integration_points.h +++ b/kratos/integration/hexahedron_gauss_lobatto_integration_points.h @@ -28,10 +28,10 @@ namespace Kratos { //TODO -class HexahedronGaussLobattoIntegrationPoints1 +class HexahedronGaussLobattoIntegrationPoints0 { public: - KRATOS_CLASS_POINTER_DEFINITION(HexahedronGaussLobattoIntegrationPoints1); + KRATOS_CLASS_POINTER_DEFINITION(HexahedronGaussLobattoIntegrationPoints0); typedef std::size_t SizeType; static const unsigned int Dimension = 3; @@ -61,17 +61,15 @@ class HexahedronGaussLobattoIntegrationPoints1 std::string Info() const { std::stringstream buffer; - buffer << "Hexahedron Gauss-Lobatto quadrature 1 "; + buffer << "Hexahedron Gauss-Lobatto quadrature 0 "; return buffer.str(); } +}; // Class HexahedronGaussLobattoIntegrationPoints0 - -}; // Class HexahedronGaussLobattoIntegrationPoints1 - -class HexahedronGaussLobattoIntegrationPoints2 +class HexahedronGaussLobattoIntegrationPoints1 { public: - KRATOS_CLASS_POINTER_DEFINITION(HexahedronGaussLobattoIntegrationPoints2); + KRATOS_CLASS_POINTER_DEFINITION(HexahedronGaussLobattoIntegrationPoints1); typedef std::size_t SizeType; static const unsigned int Dimension = 3; @@ -105,12 +103,10 @@ class HexahedronGaussLobattoIntegrationPoints2 std::string Info() const { std::stringstream buffer; - buffer << "Hexahedron Gauss-Lobatto quadrature 2 "; + buffer << "Hexahedron Gauss-Lobatto quadrature 1 "; return buffer.str(); } - - -}; // Class HexahedronGaussLobattoIntegrationPoints2 +}; // Class HexahedronGaussLobattoIntegrationPoints1 diff --git a/kratos/integration/integration_info.cpp b/kratos/integration/integration_info.cpp index 833ab5ccd720..ab962b766376 100644 --- a/kratos/integration/integration_info.cpp +++ b/kratos/integration/integration_info.cpp @@ -110,6 +110,10 @@ namespace Kratos mNumberOfIntegrationPointsPerSpanVector[DimensionIndex] = 5; mQuadratureMethodVector[DimensionIndex] = QuadratureMethod::EXTENDED_GAUSS; break; + case IntegrationMethod::GI_LOBATTO_1: + mNumberOfIntegrationPointsPerSpanVector[DimensionIndex] = 2; + mQuadratureMethodVector[DimensionIndex] = QuadratureMethod::LOBATTO; + break; case IntegrationMethod::NumberOfIntegrationMethods: mNumberOfIntegrationPointsPerSpanVector[DimensionIndex] = 0; mQuadratureMethodVector[DimensionIndex] = QuadratureMethod::Default; diff --git a/kratos/integration/integration_info.h b/kratos/integration/integration_info.h index 0b93d113573e..acc9a883ec82 100644 --- a/kratos/integration/integration_info.h +++ b/kratos/integration/integration_info.h @@ -61,6 +61,7 @@ class KRATOS_API(KRATOS_CORE) IntegrationInfo : public Flags Default, GAUSS, EXTENDED_GAUSS, + LOBATTO, GRID }; @@ -127,9 +128,12 @@ class KRATOS_API(KRATOS_CORE) IntegrationInfo : public Flags if (ThisQuadratureMethod == QuadratureMethod::GAUSS) { return IntegrationMethod::GI_GAUSS_1; } - else { + else if (ThisQuadratureMethod == QuadratureMethod::EXTENDED_GAUSS) { return IntegrationMethod::GI_EXTENDED_GAUSS_1; } + else { + return IntegrationMethod::GI_LOBATTO_1; + } break; case 2: if (ThisQuadratureMethod == QuadratureMethod::GAUSS) { diff --git a/kratos/integration/quadrilateral_gauss_lobatto_integration_points.h b/kratos/integration/quadrilateral_gauss_lobatto_integration_points.h index 96e038d06816..526b10ab5c6d 100644 --- a/kratos/integration/quadrilateral_gauss_lobatto_integration_points.h +++ b/kratos/integration/quadrilateral_gauss_lobatto_integration_points.h @@ -21,15 +21,13 @@ // Project includes #include "integration/quadrature.h" -// TO BE COMPLETED: Only the needed ones have been implemented - namespace Kratos { - class QuadrilateralGaussLobattoIntegrationPoints1 + class QuadrilateralGaussLobattoIntegrationPoints0 { public: - KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints1); + KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints0); typedef std::size_t SizeType; static const unsigned int Dimension = 2; @@ -56,16 +54,16 @@ namespace Kratos std::string Info() const { std::stringstream buffer; - buffer << "Quadrilateral Gauss-Lobatto integration 1 "; + buffer << "Quadrilateral Gauss-Lobatto integration 0 "; return buffer.str(); } - }; // Class QuadrilateralGaussLobattoIntegrationPoints1 + }; // Class QuadrilateralGaussLobattoIntegrationPoints0 - class QuadrilateralGaussLobattoIntegrationPoints2 + class QuadrilateralGaussLobattoIntegrationPoints1 { public: - KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints2); + KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints1); typedef std::size_t SizeType; static const unsigned int Dimension = 2; @@ -94,16 +92,16 @@ namespace Kratos std::string Info() const { std::stringstream buffer; - buffer << "Quadrilateral Gauss-Lobatto integration 2 "; + buffer << "Quadrilateral Gauss-Lobatto integration 1 "; return buffer.str(); } - }; // Class QuadrilateralGaussLobattoIntegrationPoints2 + }; // Class QuadrilateralGaussLobattoIntegrationPoints1 - class QuadrilateralGaussLobattoIntegrationPoints3 + class QuadrilateralGaussLobattoIntegrationPoints2 { public: - KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints3); + KRATOS_CLASS_POINTER_DEFINITION(QuadrilateralGaussLobattoIntegrationPoints2); typedef std::size_t SizeType; static const unsigned int Dimension = 2; @@ -146,10 +144,10 @@ namespace Kratos std::string Info() const { std::stringstream buffer; - buffer << "Quadrilateral Gauss-Lobatto integration 3 "; + buffer << "Quadrilateral Gauss-Lobatto integration 2 "; return buffer.str(); } - }; // Class QuadrilateralGaussLobattoIntegrationPoints3 + }; // Class QuadrilateralGaussLobattoIntegrationPoints2 } diff --git a/kratos/integration/tetrahedron_gauss_lobatto_integration_points.h b/kratos/integration/tetrahedron_gauss_lobatto_integration_points.h new file mode 100644 index 000000000000..dd88beaa3c71 --- /dev/null +++ b/kratos/integration/tetrahedron_gauss_lobatto_integration_points.h @@ -0,0 +1,77 @@ +// | / | +// ' / __| _` | __| _ \ __| +// . \ | ( | | ( |\__ ` +// _|\_\_| \__,_|\__|\___/ ____/ +// Multi-Physics +// +// License: BSD License +// Kratos default license: kratos/license.txt +// +// Main authors: Alejandro Cornejo +// +// + +#pragma once + +// System includes + +// External includes + +// Project includes +#include "integration/quadrature.h" + +namespace Kratos +{ + +class TetrahedronGaussLobattoIntegrationPoints1 +{ +public: + KRATOS_CLASS_POINTER_DEFINITION(TetrahedronGaussLobattoIntegrationPoints1); + typedef std::size_t SizeType; + + static const unsigned int Dimension = 3; + + typedef IntegrationPoint<2> IntegrationPointType; + + typedef std::array IntegrationPointsArrayType; + + typedef IntegrationPointType::PointType PointType; + + static SizeType IntegrationPointsNumber() + { + return 4; + } + + static const IntegrationPointsArrayType& IntegrationPoints() + { + const double one_over_twenty_four = 1.0 / 24.0; + static const IntegrationPointsArrayType s_integration_points{{ + IntegrationPointType( 0.0, 0.0 , 0.0, one_over_twenty_four ), + IntegrationPointType( 1.0, 0.0 , 0.0, one_over_twenty_four ), + IntegrationPointType( 0.0, 1.0 , 0.0, one_over_twenty_four ), + IntegrationPointType( 0.0, 0.0 , 1.0, one_over_twenty_four ) + }}; + return s_integration_points; + } + + std::string Info() const + { + std::stringstream buffer; + buffer << "Tetrahedron Gauss-Lobatto quadrature 1 (4 points, degree of precision = 1)"; + return buffer.str(); + } +}; // Class TetrahedronGaussLobattoIntegrationPoints1 + +///@name Type Definitions +///@{ + + +///@} +///@name Input and output +///@{ + + +///@} + + +} // namespace Kratos. diff --git a/kratos/python/add_mesh_to_python.cpp b/kratos/python/add_mesh_to_python.cpp index 77e69a3d43db..c19a2a68c827 100644 --- a/kratos/python/add_mesh_to_python.cpp +++ b/kratos/python/add_mesh_to_python.cpp @@ -483,8 +483,10 @@ void AddMeshToPython(pybind11::module& m) .def("SetValuesOnIntegrationPoints", SetValuesOnIntegrationPointsArray1d) .def("SetValuesOnIntegrationPoints", SetValuesOnIntegrationPointsArray1d) .def("ResetConstitutiveLaw", &Element::ResetConstitutiveLaw) + .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface >) + .def("Calculate", &EntityCalculateInterface >) .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface) .def("CalculateLumpedMassVector", &ElementCalculateLumpedMassVector) @@ -639,8 +641,10 @@ void AddMeshToPython(pybind11::module& m) // .def(SolutionStepVariableIndexingPython > >()) // .def(SolutionStepVariableIndexingPython > >()) // .def(SolutionStepVariableIndexingPython > >()) + .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface >) + .def("Calculate", &EntityCalculateInterface >) .def("Calculate", &EntityCalculateInterface) .def("Calculate", &EntityCalculateInterface) diff --git a/kratos/tests/cpp_tests/geometries/test_geometry.cpp b/kratos/tests/cpp_tests/geometries/test_geometry.cpp index 53024231df37..750591c5195a 100644 --- a/kratos/tests/cpp_tests/geometries/test_geometry.cpp +++ b/kratos/tests/cpp_tests/geometries/test_geometry.cpp @@ -4,8 +4,8 @@ // _|\_\_| \__,_|\__|\___/ ____/ // Multi-Physics // -// License: BSD License -// Kratos default license: kratos/license.txt +// License: BSD License +// Kratos default license: kratos/license.txt // // Main authors: Carlos A. Roig // Vicente Mataix Ferrandiz @@ -60,6 +60,8 @@ namespace Testing { return "GI_EXTENDED_GAUSS_4"; case GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 : return "GI_EXTENDED_GAUSS_5"; + case GeometryData::IntegrationMethod::GI_LOBATTO_1 : + return "GI_LOBATTO_1"; case GeometryData::IntegrationMethod::NumberOfIntegrationMethods : return "NumberOfIntegrationMethods"; }; diff --git a/kratos/tests/cpp_tests/geometries/test_geometry.h b/kratos/tests/cpp_tests/geometries/test_geometry.h index 6b52278ba8f0..009d3f94a223 100644 --- a/kratos/tests/cpp_tests/geometries/test_geometry.h +++ b/kratos/tests/cpp_tests/geometries/test_geometry.h @@ -4,8 +4,8 @@ // _|\_\_| \__,_|\__|\___/ ____/ // Multi-Physics // -// License: BSD License -// Kratos default license: kratos/license.txt +// License: BSD License +// Kratos default license: kratos/license.txt // // Main authors: Carlos A. Roig // Vicente Mataix Ferrandiz diff --git a/kratos/tests/cpp_tests/integration/test_integration_quadratures.cpp b/kratos/tests/cpp_tests/integration/test_integration_quadratures.cpp index 55aee9545e7c..af7e87b0d18d 100644 --- a/kratos/tests/cpp_tests/integration/test_integration_quadratures.cpp +++ b/kratos/tests/cpp_tests/integration/test_integration_quadratures.cpp @@ -19,6 +19,7 @@ #include "integration/quadrilateral_gauss_lobatto_integration_points.h" #include "integration/hexahedron_gauss_lobatto_integration_points.h" #include "integration/triangle_gauss_lobatto_integration_points.h" +#include "integration/tetrahedron_gauss_lobatto_integration_points.h" namespace Kratos::Testing { @@ -29,9 +30,9 @@ KRATOS_TEST_CASE_IN_SUITE(GaussLobattoQuadrilateralQuadraturesTest, KratosCoreFa // In This test we evaluate the Gauss-Lobatto quadratures for integrating // f = (x+y) and g = (x+y)^2 over a [-1, 1] quadrilateral - const auto& r_lobatto_1 = QuadrilateralGaussLobattoIntegrationPoints1(); - const auto& r_lobatto_2 = QuadrilateralGaussLobattoIntegrationPoints2(); - const auto& r_lobatto_3 = QuadrilateralGaussLobattoIntegrationPoints3(); + const auto& r_lobatto_1 = QuadrilateralGaussLobattoIntegrationPoints0(); + const auto& r_lobatto_2 = QuadrilateralGaussLobattoIntegrationPoints1(); + const auto& r_lobatto_3 = QuadrilateralGaussLobattoIntegrationPoints2(); // Analytical results, reference const double integral_f = 0.0; @@ -83,7 +84,7 @@ KRATOS_TEST_CASE_IN_SUITE(GaussLobattoHexaQuadraturesTest, KratosCoreFastSuite) // In This test we evaluate the Gauss-Lobatto quadratures for integrating // f = (x+y+z+5) over a [-1, 1] hexa - const auto& r_lobatto = HexahedronGaussLobattoIntegrationPoints2(); + const auto& r_lobatto = HexahedronGaussLobattoIntegrationPoints1(); // Analytical results, reference const double integral_f = 40.0; @@ -130,4 +131,26 @@ KRATOS_TEST_CASE_IN_SUITE(GaussLobattoTriangleQuadraturesTest, KratosCoreFastSui KRATOS_CHECK_NEAR(quadrature_integral_f, integral_f, 1.0E-6); } +KRATOS_TEST_CASE_IN_SUITE(GaussLobattoTetrahedronQuadraturesTest, KratosCoreFastSuite) +{ + + // In This test we evaluate the Gauss-Lobatto quadrature for integrating + // f = 1.0 over an isoparametric tetrahedron + + const auto& r_lobatto_1 = TetrahedronGaussLobattoIntegrationPoints1(); + + // Analytical result, reference + const double integral_f = 1.0 / 6.0; + + double quadrature_integral_f = 0.0; + + // Integral for f with Lobatto 1 + for (IndexType IP = 0; IP < r_lobatto_1.IntegrationPoints().size(); ++IP) { + const double w = r_lobatto_1.IntegrationPoints()[IP].Weight(); + quadrature_integral_f += w; + } + + KRATOS_CHECK_NEAR(quadrature_integral_f, integral_f, 1.0E-6); +} + } // namespace Kratos::Testing \ No newline at end of file diff --git a/kratos/utilities/geometry_tester.cpp b/kratos/utilities/geometry_tester.cpp index ea0eaa2d51cc..97c13b152644 100644 --- a/kratos/utilities/geometry_tester.cpp +++ b/kratos/utilities/geometry_tester.cpp @@ -1144,6 +1144,8 @@ std::string GeometryTesterUtility::GetIntegrationName( return std::string("GI_EXTENDED_GAUSS_4"); case GeometryData::IntegrationMethod::GI_EXTENDED_GAUSS_5 : return std::string("GI_EXTENDED_GAUSS_5"); + case GeometryData::IntegrationMethod::GI_LOBATTO_1 : + return std::string("GI_LOBATTO_1"); case GeometryData::IntegrationMethod::NumberOfIntegrationMethods : return std::string("NumberOfIntegrationMethods"); };