21 #include "libmesh/libmesh.h" 22 #include "libmesh/elem.h" 23 #include "libmesh/dof_map.h" 45 TEST_CASE(
"quad4_linear_extension_bending_structural",
46 "[quad],[quad4],[linear],[structural],[2D],[element]")
49 coords << -1.0, 1.0, 1.0, -1.0,
61 test_elem.
kappa = 0.0;
69 double val_margin = (test_elem.
jacobian0.array().abs()).mean() * 1.490116119384766e-08;
72 SECTION(
"Internal Jacobian (stiffness matrix) finite difference check")
77 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
84 SECTION(
"Internal Jacobian (stiffness matrix) should be symmetric")
91 SECTION(
"Determinant of undeformed internal Jacobian (stiffness matrix) should be zero")
93 REQUIRE(test_elem.
jacobian0.determinant() == Approx(0.0).margin(1e-06));
97 SECTION(
"Internal Jacobian (stiffness matrix) is invariant to displacement solution")
100 elem_sol << -0.04384355, 0.03969142, -0.09470648, -0.05011107,
101 -0.02989082, -0.01205296, 0.08846868, 0.04522207,
102 0.06435953, -0.07282706, 0.09307561, -0.06250143,
103 0.03332844, -0.00040089, -0.00423108, -0.07258241,
104 0.06636534, -0.08421098, -0.0705489 , -0.06004976,
105 0.03873095, -0.09194373, 0.00055061, 0.046831;
114 SECTION(
"Internal Jacobian (stiffness matrix) is invariant to element x-location")
117 1.0, 1.0, 0.0, 0.0, 0.0);
126 SECTION(
"Internal Jacobian (stiffness matrix) is invariant to element y-location")
129 1.0, 1.0, 0.0, 0.0, 0.0);
138 SECTION(
"Internal Jacobian (stiffness matrix) is invariant to element z-location")
141 1.0, 1.0, 0.0, 0.0, 0.0);
150 SECTION(
"Internal Jacobian (stiffness matrix) checks for element rotated about z-axis")
154 1.0, 1.0, 0.0, 0.0, 63.4);
160 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
169 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
173 SECTION(
"Internal Jacobian (stiffness matrix) checks for element rotated about y-axis")
177 1.0, 1.0, 0.0, 35.8, 0.0);
183 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
192 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
196 SECTION(
"Internal Jacobian (stiffness matrix) checks for element rotated about x-axis")
200 1.0, 1.0, 15.8, 0.0, 0.0);
206 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
215 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
219 SECTION(
"\"Internal Jacobian (stiffness matrix) checks for element sheared in x-direction\"")
223 1.0, 1.0, 0.0, 0.0, 0.0, 6.7, 0.0);
229 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
238 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
242 SECTION(
"\"Internal Jacobian (stiffness matrix) checks for element sheared in y-direction\"")
246 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, -11.2);
252 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
261 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
265 SECTION(
"Internal Jacobian (stiffness matrix) checks for element stretched in x-direction")
268 3.2, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0);
274 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
283 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
286 SECTION(
"Internal Jacobian (stiffness matrix) checks for element stretched in y-direction")
289 1.0, 0.64, 0.0, 0.0, 0.0, 0.0, 0.0);
295 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
304 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
308 SECTION(
"Internal Jacobian (stiffness matrix) checks for element arbitrarily scaled, stretched, rotated, and sheared")
312 2.7, 6.4, 20.0, 47.8, -70.1, 5.7, -6.3);
318 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
327 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
331 SECTION(
"Internal Jacobian (stiffness matrix) checks for element arbitrarily scaled, stretched, rotated, and displaced")
339 elem_sol << -0.04384355, 0.03969142, -0.09470648, -0.05011107,
340 -0.02989082, -0.01205296, 0.08846868, 0.04522207,
341 0.06435953, -0.07282706, 0.09307561, -0.06250143,
342 0.03332844, -0.00040089, -0.00423108, -0.07258241,
343 0.06636534, -0.08421098, -0.0705489 , -0.06004976,
344 0.03873095, -0.09194373, 0.00055061, 0.046831;
352 val_margin = (test_elem.
jacobian_fd.array().abs()).mean() * 1.490116119384766e-08;
361 REQUIRE(test_elem.
jacobian.determinant() == Approx(0.0).margin(1e-06));
MAST::Parameter offset
Section offset.
RealMatrixX jacobian
Matrix storage for Jacobian of the element in a perturbed/modified state.
libMesh::Elem * reference_elem
Pointer to the actual libMesh element object.
RealVectorX elem_solution
void update_residual_and_jacobian0()
void update_residual_and_jacobian()
Real get_shoelace_area(RealMatrixX X)
Calcualtes the area of a 2D polygon using the shoelace formula.
MAST::Solid2DSectionElementPropertyCard section
void set_strain(MAST::StrainType strain)
sets the type of strain to be used, which is LINEAR_STRAIN by default
void transform_element(libMesh::MeshBase &mesh, const RealMatrixX X0, Real shift_x, Real shift_y, Real shift_z, Real scale_x, Real scale_y, Real rotation_x, Real rotation_y, Real rotation_z, Real shear_x=0, Real shear_y=0)
Transform an element by applying any combination of: shifts, scales, rotations, and shears...
std::vector< double > eigen_matrix_to_std_vector(RealMatrixX M)
Converts an Eigen Matrix object to a std::vector.
void approximate_internal_jacobian_with_finite_difference(MAST::StructuralElementBase &elem, const RealVectorX &initial_elem_solution, RealMatrixX &jacobian)
Approximates the internal Jacobian of an element using a 6th order accurate central finite difference...
Matrix< Real, Dynamic, Dynamic > RealMatrixX
libMesh::LibMeshInit * p_global_init
virtual void set_solution(const RealVectorX &vec, bool if_sens=false)
stores vec as solution for element level calculations, or its sensitivity if if_sens is true...
RealMatrixX jacobian0
Matrix storage for Jacobian of baseline/undeformed element.
Matrix< Real, Dynamic, 1 > RealVectorX
MAST::StructuralElement2D * elem
MAST::Parameter kappa
Shear coefficient.
TEST_CASE("quad4_linear_extension_bending_structural", "[quad],[quad4],[linear],[structural],[2D],[element]")
libMesh::ReplicatedMesh mesh
The actual libMesh mesh object.
RealMatrixX jacobian_fd
Matrix storage for element Jacobian approximated by finite difference.