Reference documentation for deal.II version 9.1.0-pre
standard_tensors.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2016 by the deal.II authors
4 //
5 // This file is part of the deal.II library.
6 //
7 // The deal.II library is free software; you can use it, redistribute
8 // it, and/or modify it under the terms of the GNU Lesser General
9 // Public License as published by the Free Software Foundation; either
10 // version 2.1 of the License, or (at your option) any later version.
11 // The full text of the license can be found in the file LICENSE.md at
12 // the top level directory of deal.II.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii_elasticity_standard_tensors_h
17 #define dealii_elasticity_standard_tensors_h
18 
19 
20 #include <deal.II/base/numbers.h>
22 #include <deal.II/base/tensor.h>
23 
24 DEAL_II_NAMESPACE_OPEN
25 
26 namespace Physics
27 {
28  namespace Elasticity
29  {
44  template <int dim>
46  {
47  public:
52 
70  static const SymmetricTensor<2, dim> I;
71 
98  static const SymmetricTensor<4, dim> S;
99 
111 
113 
118 
155 
214  template <typename Number>
216  Dev_P(const Tensor<2, dim, Number> &F);
217 
229  template <typename Number>
232 
234 
256  template <typename Number>
259 
261 
266 
281  template <typename Number>
284 
286  };
287 
288  } // namespace Elasticity
289 } // namespace Physics
290 
291 
292 
293 #ifndef DOXYGEN
294 
295 // ------------------------- inline functions ------------------------
296 
297 
298 template <int dim>
299 template <typename Number>
302  const Tensor<2, dim, Number> &F)
303 {
304  const Number det_F = determinant(F);
306  ExcMessage("Deformation gradient has a negative determinant."));
307  const Tensor<2, dim, Number> C_ns = transpose(F) * F;
310 
311  // See Wriggers p46 equ 3.125 (but transpose indices)
313  outer_product(C, C_inv); // Dev_P = C_x_C_inv
314  Dev_P /= -dim; // Dev_P = -[1/dim]C_x_C_inv
315  Dev_P += SymmetricTensor<4, dim, Number>(S); // Dev_P = S - [1/dim]C_x_C_inv
316  Dev_P *=
317  std::pow(det_F, -2.0 / dim); // Dev_P = J^{-2/dim} [S - [1/dim]C_x_C_inv]
318 
319  return Dev_P;
320 }
321 
322 
323 
324 template <int dim>
325 template <typename Number>
328  const Tensor<2, dim, Number> &F)
329 {
330  const Number det_F = determinant(F);
332  ExcMessage("Deformation gradient has a negative determinant."));
333  const Tensor<2, dim, Number> C_ns = transpose(F) * F;
336 
337  // See Wriggers p46 equ 3.125 (not transposed)
339  outer_product(C_inv, C); // Dev_P = C_inv_x_C
340  Dev_P_T /= -dim; // Dev_P = -[1/dim]C_inv_x_C
341  Dev_P_T += SymmetricTensor<4, dim, Number>(S); // Dev_P = S - [1/dim]C_inv_x_C
342  Dev_P_T *=
343  std::pow(det_F, -2.0 / dim); // Dev_P = J^{-2/dim} [S - [1/dim]C_inv_x_C]
344 
345  return Dev_P_T;
346 }
347 
348 
349 
350 template <int dim>
351 template <typename Number>
354  const Tensor<2, dim, Number> &F)
355 {
356  return Number(0.5) * determinant(F) * symmetrize(invert(transpose(F) * F));
357 }
358 
359 
360 
361 template <int dim>
362 template <typename Number>
365  const Tensor<2, dim, Number> &F)
366 {
367  const SymmetricTensor<2, dim, Number> C_inv =
368  symmetrize(invert(transpose(F) * F));
369 
371  for (unsigned int A = 0; A < dim; ++A)
372  for (unsigned int B = A; B < dim; ++B)
373  for (unsigned int C = 0; C < dim; ++C)
374  for (unsigned int D = C; D < dim; ++D)
375  dC_inv_dC[A][B][C][D] -=
376  0.5 * (C_inv[A][C] * C_inv[B][D] + C_inv[A][D] * C_inv[B][C]);
377 
378  return dC_inv_dC;
379 }
380 
381 #endif // DOXYGEN
382 
383 DEAL_II_NAMESPACE_CLOSE
384 
385 #endif
Number determinant(const SymmetricTensor< 2, dim, Number > &)
SymmetricTensor< 4, dim, Number > outer_product(const SymmetricTensor< 2, dim, Number > &t1, const SymmetricTensor< 2, dim, Number > &t2)
SymmetricTensor< 2, dim, Number > invert(const SymmetricTensor< 2, dim, Number > &)
static::ExceptionBase & ExcMessage(std::string arg1)
static const SymmetricTensor< 4, dim > S
#define Assert(cond, exc)
Definition: exceptions.h:1227
static SymmetricTensor< 2, dim, Number > ddet_F_dC(const Tensor< 2, dim, Number > &F)
static const SymmetricTensor< 2, dim > I
static const SymmetricTensor< 4, dim > dev_P
SymmetricTensor< 2, dim, Number > symmetrize(const Tensor< 2, dim, Number > &t)
SymmetricTensor< rank_, dim, Number > transpose(const SymmetricTensor< rank_, dim, Number > &t)
static const SymmetricTensor< 4, dim > IxI
bool value_is_greater_than(const Number1 &value_1, const Number2 &value_2)
Definition: numbers.h:827
Definition: mpi.h:55
static SymmetricTensor< 4, dim, Number > Dev_P(const Tensor< 2, dim, Number > &F)
static SymmetricTensor< 4, dim, Number > dC_inv_dC(const Tensor< 2, dim, Number > &F)
static SymmetricTensor< 4, dim, Number > Dev_P_T(const Tensor< 2, dim, Number > &F)