https://mooseframework.inl.gov
Functions
small_elastic_tri.C File Reference

Go to the source code of this file.

Functions

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)
 

Function Documentation

◆ umat_()

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 
)

Definition at line 17 of file small_elastic_tri.C.

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 }