20 #include "libmesh/libmesh.h" 21 #include "libmesh/tuple_of.h" 22 #include "libmesh/int_range.h" 24 #include "metaphysicl/raw_type.h" 30 #include <Eigen/Dense> 71 static constexpr
unsigned int Ndim = LIBMESH_DIM;
73 static constexpr
unsigned int N2 =
N *
N;
78 {{0, 0, 0, 0}, {0, 0, 1, 1}, {0, 0, 2, 2}, {0, 0, 1, 2}, {0, 0, 0, 2}, {0, 0, 0, 1}},
79 {{1, 1, 0, 0}, {1, 1, 1, 1}, {1, 1, 2, 2}, {1, 1, 1, 2}, {1, 1, 0, 2}, {1, 1, 0, 1}},
80 {{2, 2, 0, 0}, {2, 2, 1, 1}, {2, 2, 2, 2}, {2, 2, 1, 2}, {2, 2, 0, 2}, {2, 2, 0, 1}},
81 {{1, 2, 0, 0}, {1, 2, 1, 1}, {1, 2, 2, 2}, {1, 2, 1, 2}, {1, 2, 0, 2}, {1, 2, 0, 1}},
82 {{0, 2, 0, 0}, {0, 2, 1, 1}, {0, 2, 2, 2}, {0, 2, 1, 2}, {0, 2, 0, 2}, {0, 2, 0, 1}},
83 {{0, 1, 0, 0}, {0, 1, 1, 1}, {0, 1, 2, 2}, {0, 1, 1, 2}, {0, 1, 0, 2}, {0, 1, 0, 1}}};
116 template <
template <
typename>
class Tensor,
typename Scalar>
121 template <
typename Scalar>
126 template <
typename Scalar>
131 template <
typename Scalar>
152 template <
typename T2>
178 inline const T &
operator()(
unsigned int i,
unsigned int j)
const {
return _vals[i *
N + j]; }
184 void print(std::ostream & stm = Moose::out)
const;
187 void printReal(std::ostream & stm = Moose::out)
const;
189 friend std::ostream & operator<<(std::ostream & os, const SymmetricRankFourTensorTempl<T> & t)
203 template <
typename Scalar>
204 typename std::enable_if<libMesh::ScalarTraits<Scalar>::value,
208 libmesh_assert_equal_to(p, Scalar(0));
214 template <
typename T2>
219 template <
typename T2>
221 typename std::enable_if<libMesh::ScalarTraits<T2>::value,
228 template <
typename T2>
230 typename std::enable_if<libMesh::ScalarTraits<T2>::value,
240 template <
typename T2>
248 template <
typename T2>
256 template <
typename T2>
281 void rotate(
const TypeTensor<T> & R);
321 template <
typename T2>
332 template <
typename T2>
410 template <
typename T2>
412 template <
typename T2>
414 template <
typename T2>
420 template <
typename T>
437 template <
typename T1,
typename T2>
440 typename std::enable_if<libMesh::ScalarTraits<T1>::value,
446 template <
typename T>
447 template <
typename T2>
452 _vals[i] = copy.
_vals[i];
455 template <
typename T>
456 template <
typename T2>
459 typename std::enable_if<libMesh::ScalarTraits<T2>::value,
462 typedef decltype(T() * T2()) ValueType;
466 result.
_vals[i] = _vals[i] * b;
471 template <
typename T>
472 template <
typename T2>
477 typedef decltype(T() * T2()) ValueType;
480 std::size_t index = 0;
485 tmp += _vals[index++] * b.
_vals[j];
486 result.
_vals[i] = tmp;
492 template <
typename T>
493 template <
typename T2>
496 typename std::enable_if<libMesh::ScalarTraits<T2>::value,
501 result.
_vals[i] = _vals[i] / b;
505 template <
typename T>
506 template <
typename T2>
510 mooseAssert(LIBMESH_DIM == 3,
"This method assumes LIBMESH_DIM == 3");
511 mooseAssert(input.size() == 9,
512 "To use fillSymmetric9FromInputVector, your input must have size 9.");
517 _vals[14] = input[5];
519 _vals[1] = _vals[6] = input[1];
520 _vals[2] = _vals[12] = input[2];
521 _vals[8] = _vals[13] = input[4];
523 static constexpr std::size_t C2323 = 21;
524 static constexpr std::size_t C1313 = 28;
525 static constexpr std::size_t C1212 = 35;
527 _vals[C2323] = 2.0 * input[6];
528 _vals[C1313] = 2.0 * input[7];
529 _vals[C1212] = 2.0 * input[8];
532 template <
typename T>
533 template <
typename T2>
544 mooseAssert(LIBMESH_DIM == 3,
"This method assumes LIBMESH_DIM == 3");
545 mooseAssert(input.size() == 21,
546 "To use fillSymmetric21FromInputVector, your input must have size 21.");
547 std::size_t index = 0;
551 _vals[i +
N * j] = mandelFactor(i, j) * input[index];
552 _vals[j +
N * i] = mandelFactor(j, i) * input[index];
557 template <
typename T>
565 Eigen::Matrix<T, Eigen::Dynamic, Eigen::Dynamic> mat(
N,
N);
568 mat(i, j) = (*this)(i, j);
572 result(i, j) = mat(i, j);
576 const Eigen::Map<const Eigen::Matrix<T, N, N, Eigen::RowMajor>> mat(&_vals[0]);
577 Eigen::Map<Eigen::Matrix<T, N, N, Eigen::RowMajor>> res(&result.
_vals[0]);
void fillAxisymmetricRZFromInputVector(const std::vector< T > &input)
fillAxisymmetricRZFromInputVector takes 5 inputs to fill the axisymmetric Rank-4 tensor with the appr...
RankFourTensorTempl is designed to handle any N-dimensional fourth order tensor, C.
std::array< T, N2 > _vals
The values of the rank-four tensor.
libMesh::VectorValue< T > sum3x1() const
Calculates the vector a[i] = sum over j Ciijj for i and j varying from 0 to 2.
void fillSymmetricIsotropicEandNu(const T &E, const T &nu)
const T & operator()(unsigned int i, unsigned int j) const
Gets the value for the indices specified.
static MooseEnum fillMethodEnum()
Static method for use in validParams for getting the "fill_method".
T & operator()(unsigned int i, unsigned int j)
Gets the value for the indices specified. Takes indices ranging from 0-5 for i and j...
bool isIsotropic() const
checks if the tensor is isotropic
auto operator+(const SymmetricRankFourTensorTempl< T2 > &a) const -> SymmetricRankFourTensorTempl< decltype(T()+T2())>
C_ijkl + a_ijkl.
FillMethod
To fill up the 36 entries in the 4th-order tensor, fillFromInputVector is called with one of the foll...
void fillSymmetricIsotropic(const T &i0, const T &i1)
Vector-less fill API functions. See docs of the corresponding ...FromInputVector methods.
SymmetricRankFourTensorTempl< T > & operator-=(const SymmetricRankFourTensorTempl< T > &a)
C_ijkl -= a_ijkl.
void mooseSetToZero< SymmetricRankFourTensor >(SymmetricRankFourTensor &v)
Helper function template specialization to set an object to zero.
auto operator*(const SymmetricRankTwoTensorTempl< T2 > &b) const -> SymmetricRankTwoTensorTempl< decltype(T() *T2())>
C_ijkl*a_kl.
void fillSymmetric21FromInputVector(const T2 &input)
fillSymmetric21FromInputVector takes 21 inputs to fill in the Rank-4 tensor with the appropriate crys...
static constexpr Real mandelFactor(unsigned int i, unsigned int j)
returns the 1, sqrt(2), or 2 prefactor in the Mandel notation for the indices i,j ranging from 0-5...
The following methods are specializations for using the libMesh::Parallel::packed_range_* routines fo...
std::basic_ostream< charT, traits > * os
static constexpr unsigned int N
T sum3x3() const
Calculates the sum of Ciijj for i and j varying from 0 to 2.
T L2norm() const
sqrt(C_ijkl*C_ijkl)
static SymmetricRankFourTensorTempl< T > rotationMatrix(const TypeTensor< T > &R)
Build a 6x6 rotation matrix MEHRABADI, MORTEZA M.
RankThreeTensor is designed to handle any N-dimensional third order tensor, r.
auto operator/(const T2 &a) const -> typename std::enable_if< libMesh::ScalarTraits< T2 >::value, SymmetricRankFourTensorTempl< decltype(T()/T2())>>::type
C_ijkl/a.
typename tuple_n< Index, T >::template type<> tuple_of
SymmetricRankFourTensorTempl< T > & operator+=(const SymmetricRankFourTensorTempl< T > &a)
C_ijkl += a_ijkl for all i, j, k, l.
SymmetricRankTwoTensorTempl is designed to handle the Stress or Strain Tensor for an anisotropic mate...
void fillSymmetricIsotropicEandNuFromInputVector(const std::vector< T > &input)
fillSymmetricIsotropicEandNuFromInputVector is a variation of the fillSymmetricIsotropicFromInputVect...
InitMethod
Initialization method.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
void rotate(const TypeTensor< T > &R)
Rotate the tensor using C_ijkl = R_im R_jn R_ko R_lp C_mnop.
SymmetricRankFourTensorTempl< T > & operator*=(const T &a)
C_ijkl *= a.
static SymmetricRankFourTensorTempl< T > identitySymmetricFour()
void fillPrincipalFromInputVector(const std::vector< T > &input)
fillPrincipalFromInputVector takes 9 inputs to fill a Rank-4 tensor C1111 = input0 C1122 = input1 C11...
void printReal(std::ostream &stm=Moose::out) const
Print the values of the rank four tensor.
void fillSymmetricIsotropicFromInputVector(const std::vector< T > &input)
fillSymmetricIsotropicFromInputVector takes 2 inputs to fill the the symmetric Rank-4 tensor with the...
friend void dataStore(std::ostream &, SymmetricRankFourTensorTempl< T2 > &, void *)
void mooseSetToZero< ADSymmetricRankFourTensor >(ADSymmetricRankFourTensor &v)
SymmetricRankFourTensorTempl< T > transposeMajor() const
Transpose the tensor by swapping the first pair with the second pair of indices This amounts to a reg...
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
SymmetricRankFourTensorTempl< T > & operator=(const SymmetricRankFourTensorTempl< T > &a)=default
copies values from a into this tensor
void print(std::ostream &stm=Moose::out) const
Print the rank four tensor.
void fillFromInputVector(const std::vector< T > &input, FillMethod fill_method)
fillFromInputVector takes some number of inputs to fill the Rank-4 tensor.
SymmetricRankFourTensorTempl< T > operator-() const
-C_ijkl
friend void dataLoad(std::istream &, SymmetricRankFourTensorTempl< T2 > &, void *)
void fillGeneralOrthotropicFromInputVector(const std::vector< T > &input)
fillGeneralOrhotropicFromInputVector takes 10 inputs to fill the Rank-4 tensor It defines a general o...
std::enable_if< libMesh::ScalarTraits< Scalar >::value, SymmetricRankFourTensorTempl & >::type operator=(const Scalar &libmesh_dbg_var(p))
Assignment-from-scalar operator.
static constexpr unsigned int full_index[6][6][4]
void zero()
Zeros out the tensor.
SymmetricRankFourTensorTempl is designed to handle an N-dimensional fourth order tensor with minor sy...
IntRange< T > make_range(T beg, T end)
SymmetricRankFourTensorTempl< T > invSymm() const
This returns A_ijkl such that C_ijkl*A_klmn = 0.5*(de_im de_jn + de_in de_jm) This routine assumes th...
static SymmetricRankFourTensorTempl< T > identity()
bool isSymmetric() const
checks if the tensor is symmetric
static constexpr Real mandelFactor(unsigned int i)
returns the 1 or sqrt(2) prefactor in the Mandel notation for the index i ranging from 0-5...
static constexpr unsigned int Ndim
tensor dimension, Mandel matrix dimension, and Mandel matrix size
SymmetricRankFourTensorTempl< T > & operator/=(const T &a)
C_ijkl /= a for all i, j, k, l.
SymmetricRankFourTensorTempl()
Default constructor; fills to zero.
void fillSymmetric9FromInputVector(const T2 &input)
fillSymmetric9FromInputVector takes 9 inputs to fill in the Rank-4 tensor with the appropriate crysta...
auto operator*(const T1 &a, const SymmetricRankFourTensorTempl< T2 > &b) -> typename std::enable_if< libMesh::ScalarTraits< T1 >::value, SymmetricRankFourTensorTempl< decltype(T1() *T2())>>::type
SymmetricRankFourTensorTempl< T > transposeIj() const
Transpose the tensor by swapping the first two indices - a no-op.
static constexpr unsigned int N2