https://mooseframework.inl.gov
small_elastic_tri.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #pragma GCC diagnostic push
11 #pragma GCC diagnostic ignored "-Wunused-parameter"
12 
13 #include "MooseError.h"
14 #include <iomanip>
15 
16 extern "C" void
17 umat_(double * stress,
18  double * statev,
19  double * ddsdde,
20  double * sse,
21  double * spd,
22  double * scd,
23  double * rpl,
24  double * ddsddt,
25  double * drplde,
26  double * drpldt,
27  double * stran,
28  double * dstran,
29  double * time,
30  double * dtime,
31  double * temp,
32  double * dtemp,
33  double * predef,
34  double * dpred,
35  char * cmname,
36  int * ndi,
37  int * nshr,
38  int * ntens,
39  int * nstatv,
40  double * props,
41  int * nprops,
42  double * coords,
43  double * drot,
44  double * pnewdt,
45  double * celent,
46  double * dfgrd0,
47  double * dfgrd1,
48  int * noel,
49  int * npt,
50  int * layer,
51  int * kspt,
52  int * kstep,
53  int * kinc,
54  short cmname_len)
55 {
56  auto emod = props[0];
57  auto enu = props[1];
58  auto ebulk3 = emod / (1.0 - 2.0 * enu);
59  auto eg2 = emod / (1.0 + enu);
60  auto eg = eg2 / 2.0;
61  auto elam = (ebulk3 - eg2) / 3.0;
62 
63  // elastic stiffness
64  for (int k1 = 0; k1 < *ndi; ++k1)
65  {
66  for (int k2 = 0; k2 < *ndi; ++k2)
67  ddsdde[k1 * *ntens + k2] = elam;
68  ddsdde[k1 * *ntens + k1] += eg2;
69  }
70  for (int k1 = *ndi; k1 < *ntens; ++k1)
71  ddsdde[k1 * *ntens + k1] = eg;
72 
73  // calculate stress
74  for (int k1 = 0; k1 < *ntens; ++k1)
75  for (int k2 = 0; k2 < *ntens; ++k2)
76  stress[k1] += ddsdde[k1 * *ntens + k2] * dstran[k2];
77 }
void umat_(double *stress, double *statev, double *ddsdde, double *sse, double *spd, double *scd, double *rpl, double *ddsddt, double *drplde, double *drpldt, double *stran, double *dstran, double *time, double *dtime, double *temp, double *dtemp, double *predef, double *dpred, char *cmname, int *ndi, int *nshr, int *ntens, int *nstatv, double *props, int *nprops, double *coords, double *drot, double *pnewdt, double *celent, double *dfgrd0, double *dfgrd1, int *noel, int *npt, int *layer, int *kspt, int *kstep, int *kinc, short cmname_len)