29 . X1, X2, X3, X4, X5, X6, X7, X8,
30 . Y1, Y2, Y3, Y4, Y5, Y6, Y7, Y8,
31 . Z1, Z2, Z3, Z4, Z5, Z6, Z7, Z8,
32 . VZ1, VZ2, VZ3, VZ4, VZ5, VZ6, VZ7, VZ8,
33 . F31,F32,F33,F35,F36,F37,
34 . NU ,FHOUR ,OFF,VOL0,EINT,NEL)
41#include "implicit_f.inc"
53 INTEGER ,
INTENT(IN) :: NEL
55 my_real,
DIMENSION(MVSIZ) ,
INTENT(IN) ::
56 . X1, X2, X3, X4, X5, X6, X7, X8,
57 . Y1, Y2, Y3, Y4, Y5, Y6, Y7, Y8,
58 . Z1, Z2, Z3, Z4, , Z6, Z7, Z8,
59 . vz1,vz2,vz3,vz4,vz5,vz6,vz7,vz8,
61 my_real,
DIMENSION(NEL) ,
INTENT(IN) :: vol0
62 my_real,
DIMENSION(NEL) ,
INTENT(INOUT) :: eint
63 my_real,
DIMENSION(MVSIZ) ,
INTENT(INOUT) ::
64 . f31,f32,f33,f35,f36,f37
65 my_real,
DIMENSION(NEL,2) ,
INTENT(INOUT) :: fhour
73 . jaci1, jaci2, jaci3,
74 . jaci4, jaci5, jaci6,
75 . jaci7, jaci8, jaci9,
76 . x17(mvsiz) , x28(mvsiz) , x35(mvsiz) , x46(mvsiz),
77 . y17(mvsiz) , y28(mvsiz) , y35(mvsiz) , y46(mvsiz),
78 . z17(mvsiz) , z28(mvsiz) , z35(mvsiz) , z46(mvsiz),
79 . jac_59_68(mvsiz), jac_67_49(mvsiz), jac_48_57(mvsiz),jac_19_37(mvsiz),
80 . jaci12, jaci45, jaci78,
84 . hx,hy,hz,h1x,h1y,h1z,h2x,h2y,h2z,h3y,h3z,h4x,h4y,h4z,
85 . px1(mvsiz), px2(mvsiz), px3(mvsiz), px4(mvsiz),
86 . py1(mvsiz), py2(mvsiz), py3(mvsiz), py4(mvsiz),
87 . pz1(mvsiz), pz2(mvsiz), pz3(mvsiz), pz4(mvsiz),
88 . px1h1(mvsiz),px2h1(mvsiz),px3h1(mvsiz),px4h1(mvsiz),
89 . px1h2(mvsiz),px2h2(mvsiz),px3h2(mvsiz),px4h2(mvsiz),
90 . jac1(mvsiz),jac2(mvsiz),jac3(mvsiz),
91 . jac4(mvsiz),jac5(mvsiz),jac6(mvsiz),
92 . jac7(mvsiz),jac8(mvsiz),jac9(mvsiz),det(mvsiz)
94 . g11(mvsiz),g21(mvsiz),g31(mvsiz),g41(mvsiz),
95 . g51(mvsiz),g61(mvsiz),g71(mvsiz),g81(mvsiz),
96 . g12(mvsiz),g22(mvsiz),g32(mvsiz),g42(mvsiz),
97 . g52(mvsiz),g62(mvsiz),g72(mvsiz),g82(mvsiz),
98 . fcl(mvsiz),nfhz1(mvsiz),nfhz2(mvsiz),vz17,vz28,vz35,vz46,
99 . h1vz,h2vz,hgz1(mvsiz),hgz2(mvsiz),cc,
100 . gg ,e_dt(mvsiz),thk,thk_1(mvsiz)
120 jac3(i)=x17(i)+x28(i)-x35(i)-x46(i)
121 jac1(i)=y17(i)+y28(i)-y35(i)-y46(i)
122 jac2(i)=z17(i)+z28(i)-z35(i)-z46(i)
124 x_17_46=x17(i)+x46(i)
125 x_28_35=x28(i)+x35(i)
126 y_17_46=y17(i)+y46(i)
127 y_28_35=y28(i)+y35(i)
128 z_17_46=z17(i)+z46(i)
129 z_28_35=z28(i)+z35(i)
131 jac6(i)=x_17_46+x_28_35
132 jac4(i)=y_17_46+y_28_35
133 jac5(i)=z_17_46+z_28_35
135 jac9(i)=x_17_46-x_28_35
136 jac7(i)=y_17_46-y_28_35
137 jac8(i)=z_17_46-z_28_35
138 jac_59_68(i)=jac5(i)*jac9(i)-jac6(i)*jac8(i)
139 jac_67_49(i)=jac6(i)*jac7(i)-jac4(i)*jac9(i)
140 jac_19_37(i)=jac1(i)*jac9(i)-jac3(i)*jac7(i)
141 jac_48_57(i)=jac4(i)*jac8(i)-jac5(i)*jac7(i)
142 det(i)=one_over_64*(jac1(i)*jac_59_68(i)+jac2(i)*jac_67_49(i)+jac3(i)*jac_48_57(i))
148 dett=one_over_64/det(i)
149 jaci1=dett*jac_59_68(i)
150 jaci4=dett*jac_67_49(i)
151 jaci7=dett*jac_48_57(i)
152 jaci2=dett*(-jac2(i)*jac9(i)+jac3(i)*jac8(i))
153 jaci5=dett*jac_19_37(i)
154 jaci8=dett*(-jac1(i)*jac8(i)+jac2(i)*jac7(i))
155 jaci3=dett*( jac2(i)*jac6(i)-jac3(i)*jac5(i))
156 jaci6=dett*(-jac1(i)*jac6(i)+jac3(i)*jac4(i))
157 jaci9=dett*( jac1(i)*jac5(i)-jac2(i)*jac4(i))
184 h1x=x1(i)+x2(i)-x3(i)-x4(i)-x5(i)-x6(i)+x7(i)+x8(i)
185 h1y=y1(i)+y2(i)-y3(i)-y4(i)-y5(i)-y6(i)+y7(i)+y8(i)
186 h1z=z1(i)+z2(i)-z3(i)-z4(i)-z5(i)-z6(i)+z7(i)+z8(i)
190 px1h1(i)=px1(i)*hx+ py1(i)*hy+pz1(i)*hz
191 px2h1(i)=px2(i)*hx+ py2(i)*hy+pz2(i)*hz
192 px3h1(i)=px3(i)*hx+ py3(i)*hy+pz3(i)*hz
193 px4h1(i)=px4(i)*hx+ py4(i)*hy+pz4(i)*hz
196 g11(i)= one_over_8-px1h1(i)
197 g21(i)= one_over_8-px2h1(i)
198 g31(i)=-one_over_8-px3h1(i)
199 g41(i)=-one_over_8-px4h1(i)
200 g51(i)=-one_over_8+px3h1(i)
201 g61(i)=-one_over_8+px4h1(i)
202 g71(i)= one_over_8+px1h1(i)
208 h2x=x1(i)-x2(i)-x3(i)+x4(i)-x5(i)+x6(i)+x7(i)-x8(i)
209 h2y=y1(i)-y2(i)-y3(i)+y4(i)-y5(i)+y6(i)+y7(i)-y8(i)
210 h2z=z1(i)-z2(i)-z3(i)+z4(i)-z5(i)+z6(i)+z7(i)-z8(i)
214 px1h2(i)=px1(i)*hx+ py1(i)*hy+pz1(i)*hz
215 px2h2(i)=px2(i)*hx+ py2(i)*hy+pz2(i)*hz
216 px3h2(i)=px3(i)*hx+ py3(i)*hy+pz3(i)*hz
220 g12(i)= one_over_8-px1h2(i)
221 g22(i)=-one_over_8-px2h2(i)
222 g32(i)=-one_over_8-px3h2(i)
223 g42(i)= one_over_8-px4h2(i)
224 g52(i)=-one_over_8+px3h2(i)
225 g62(i)= one_over_8+px4h2(i)
226 g72(i)= one_over_8+px1h2(i)
227 g82(i)=-one_over_8+px2h2(i)
234 h1vz=vz1(i)+vz2(i)-vz3(i)-vz4
235 . -vz5(i)-vz6(i)+vz7(i)+vz8(i)
237 . (px1h1(i)*vz17+px2h1(i)*vz28+
238 . px3h1(i)*vz35+px4h1(i)*vz46)
239 h2vz=vz1(i)-vz2(i)-vz3(i)+vz4(i)
240 . -vz5(i)+vz6(i)+vz7(i)-vz8(i)
241 hgz2(i)=one_over_8*h2vz-
242 . (px1h2(i)*vz17+px2h2(i)*vz28+
243 . px3h2(i)*vz35+px4h2(i)*vz46)
247 gg =rho(i)*ssp(i)*ssp(i)*(one-two*nu(i))/(one-nu(i))
248 e_dt(i)=gg*off(i)*dt1*(one +nu(i))
251 cc =zep1*e_dt(i)*thk_1(i)
252 fhour(i,1) = off(i)*fhour(i,1) + cc*hgz1(i)
253 fhour(i,2) = off(i)*fhour(i,2) + cc*hgz2(i)
257 fcl(i)=em02*rho(i)*off(i)*ssp(i)*vol
258 nfhz1(i) = cc*fhour(i,1) + fcl(i)*hgz1(i)
259 nfhz2(i) = cc*fhour(i,2) + fcl(i)*hgz2(i)
264 f31(i) =f31(i)-g11(i)*nfhz1(i)-g12(i)*nfhz2(i)
265 f32(i) =f32(i)-g21(i)*nfhz1(i)-g22(i)*nfhz2(i)
266 f33(i) =f33(i)-g31(i)*nfhz1(i)-g32(i)*nfhz2(i)
267 . -g41(i)*nfhz1(i)-g42(i)*nfhz2(i)
268 f35(i) =f35(i)-g51(i)*nfhz1(i)-g52(i)*nfhz2(i)
269 f36(i) =f36(i)-g61(i)*nfhz1(i)-g62(i)*nfhz2(i)
270 f37(i) =f37(i)-g71(i)*nfhz1(i)-g72(i)*nfhz2(i)
271 . -g81(i)*nfhz1(i)-g82(i)*nfhz2(i)
274 eint(i)= eint(i)+dt1*(
275 . nfhz1(i)*hgz1(i) + nfhz2(i)*hgz2(i) )
subroutine s6cforc3(timers, output, elbuf_tab, ng, pm, geo, ixs, x, a, v, ms, w, flux, flu1, veul, fv, ale_connect, iparg, tf, npf, bufmat, partsav, dt2t, neltst, ityptst, stifn, fsky, iads, offset, eani, iparts, f11, f21, f31, f12, f22, f32, f13, f23, f33, f14, f24, f34, f15, f25, f35, f16, f26, f36, nel, icp, icsig, nloc_dmg, ipm, istrain, igeo, gresav, grth, igrth, table, mssa, dmels, voln, itask, ioutprt, mat_elem, h3d_strain, temp, fthe, fthesky, condn, condnsky, iexpan, ifthe, icondn, dt, snpc, stf, sbufmat, svis, nsvois, idtmins, iresp, idel7ng, idel7nok, maxfunc, imon_mat, userl_avail, glob_therm, xdp, sensors)
subroutine s6chour3(rho, vol, ssp, x1, x2, x3, x4, x5, x6, x7, x8, y1, y2, y3, y4, y5, y6, y7, y8, z1, z2, z3, z4, z5, z6, z7, z8, vz1, vz2, vz3, vz4, vz5, vz6, vz7, vz8, f31, f32, f33, f35, f36, f37, nu, fhour, off, vol0, eint, nel)