55 const double r = rst[0];
56 const double s = rst[1];
57 const double t = rst[2];
59 N[0] = ShapeFunctionHexHQ_Corner(r, s, t);
60 N[1] = ShapeFunctionHexHQ_Corner(-r, s, t);
61 N[2] = ShapeFunctionHexHQ_Corner(-r, -s, t);
62 N[3] = ShapeFunctionHexHQ_Corner(r, -s, t);
63 N[4] = ShapeFunctionHexHQ_Corner(r, s, -t);
64 N[5] = ShapeFunctionHexHQ_Corner(-r, s, -t);
65 N[6] = ShapeFunctionHexHQ_Corner(-r, -s, -t);
66 N[7] = ShapeFunctionHexHQ_Corner(r, -s, -t);
68 N[8] = ShapeFunctionHexHQ_Middle(r, s, t);
69 N[10] = ShapeFunctionHexHQ_Middle(r, -s, t);
70 N[14] = ShapeFunctionHexHQ_Middle(r, -s, -t);
71 N[12] = ShapeFunctionHexHQ_Middle(r, s, -t);
73 N[11] = ShapeFunctionHexHQ_Middle(s, t, r);
74 N[15] = ShapeFunctionHexHQ_Middle(s, -t, r);
75 N[13] = ShapeFunctionHexHQ_Middle(s, -t, -r);
76 N[9] = ShapeFunctionHexHQ_Middle(s, t, -r);
78 N[16] = ShapeFunctionHexHQ_Middle(t, r, s);
79 N[17] = ShapeFunctionHexHQ_Middle(t, -r, s);
80 N[18] = ShapeFunctionHexHQ_Middle(t, -r, -s);
81 N[19] = ShapeFunctionHexHQ_Middle(t, r, -s);
87 const double r = rst[0];
88 const double s = rst[1];
89 const double t = rst[2];
90 const static double sign1[] = {-1.0, 1.0, 1.0};
91 const static double sign2[] = {1.0, -1.0, 1.0};
92 const static double sign3[] = {1.0, 1.0, -1.0};
93 for (
int i = 0; i < 3; i++)
95 dN[20 * i + 0] = dShapeFunctionHexHQ_Corner(r, s, t, i);
96 dN[20 * i + 1] = sign1[i] * dShapeFunctionHexHQ_Corner(-r, s, t, i);
98 sign1[i] * sign2[i] * dShapeFunctionHexHQ_Corner(-r, -s, t, i);
99 dN[20 * i + 3] = sign2[i] * dShapeFunctionHexHQ_Corner(r, -s, t, i);
100 dN[20 * i + 4] = sign3[i] * dShapeFunctionHexHQ_Corner(r, s, -t, i);
102 sign1[i] * sign3[i] * dShapeFunctionHexHQ_Corner(-r, s, -t, i);
103 dN[20 * i + 6] = sign1[i] * sign2[i] * sign3[i] *
104 dShapeFunctionHexHQ_Corner(-r, -s, -t, i);
106 sign2[i] * sign3[i] * dShapeFunctionHexHQ_Corner(r, -s, -t, i);
108 dN[20 * i + 8] = dShapeFunctionHexHQ_Middle(r, s, t, i);
109 dN[20 * i + 10] = sign2[i] * dShapeFunctionHexHQ_Middle(r, -s, t, i);
111 sign2[i] * sign3[i] * dShapeFunctionHexHQ_Middle(r, -s, -t, i);
112 dN[20 * i + 12] = sign3[i] * dShapeFunctionHexHQ_Middle(r, s, -t, i);
115 int const co = (i + 2) % 3;
116 dN[20 * i + 11] = dShapeFunctionHexHQ_Middle(s, t, r, co);
118 sign3[i] * dShapeFunctionHexHQ_Middle(s, -t, r, co);
120 sign1[i] * sign3[i] * dShapeFunctionHexHQ_Middle(s, -t, -r, co);
122 sign1[i] * dShapeFunctionHexHQ_Middle(s, t, -r, co);
126 int const co = (i + 1) % 3;
127 dN[20 * i + 16] = dShapeFunctionHexHQ_Middle(t, r, s, co);
129 sign1[i] * dShapeFunctionHexHQ_Middle(t, -r, s, co);
131 sign1[i] * sign2[i] * dShapeFunctionHexHQ_Middle(t, -r, -s, co);
133 sign2[i] * dShapeFunctionHexHQ_Middle(t, r, -s, co);