80 SUBROUTINE s6cforc3(TIMERS, OUTPUT, ELBUF_TAB,NG ,
83 3 FLU1 ,VEUL ,FV ,ALE_CONNECT ,IPARG ,
84 4 TF ,NPF ,BUFMAT ,PARTSAV,
85 5 DT2T ,NELTST ,ITYPTST ,STIFN ,FSKY ,
86 6 IADS ,OFFSET ,EANI ,IPARTS ,
87 7 F11 ,F21 ,F31 ,F12 ,F22 ,
88 8 F32 ,F13 ,F23 ,F33 ,F14 ,
89 9 F24 ,F34 ,F15 ,F25 ,F35 ,
90 A F16 ,F26 ,F36 ,NEL ,
91 B ICP ,ICSIG ,NLOC_DMG,
92 C IPM ,ISTRAIN ,IGEO ,GRESAV ,GRTH ,
93 D IGRTH ,TABLE ,MSSA ,DMELS ,VOLN ,
94 E ITASK ,IOUTPRT ,MAT_ELEM,H3D_STRAIN ,
95 F TEMP ,FTHE ,FTHESKY ,CONDN ,CONDNSKY,
96 G IEXPAN ,IFTHE ,ICONDN ,DT ,SNPC,STF,
97 H SBUFMAT ,SVIS ,NSVOIS ,IDTMINS,IRESP,
98 I IDEL7NG ,IDEL7NOK,MAXFUNC, IMON_MAT, USERL_AVAIL,
99 J GLOB_THERM,XDP,SENSORS )
104 USE output_mod,
only : output_
112 USE sdistor_ini_mod,
ONLY : sdistor_ini
113 USE s6get_xv_mod,
ONLY : s6get_xv
114 USE s6for_distor_mod,
ONLY : s6for_distor
115 USE s6chour_ctl_mod ,
ONLY : s6chour_ctl
121#include "implicit_f.inc"
125#include "mvsiz_p.inc"
129#include "com01_c.inc"
130#include "com08_c.inc"
131#include "vect01_c.inc"
132#include "parit_c.inc"
133#include "param_c.inc"
134#include "com04_c.inc"
135#include
"com06_c.inc"
136#include "scr18_c.inc"
137#include "impl1_c.inc"
141 TYPE(timer_),
INTENT(inout) :: TIMERS
142 TYPE(OUTPUT_),
INTENT(inout) :: OUTPUT
143 INTEGER,
INTENT(IN):: SNPC
144 INTEGER,
INTENT(IN):: STF
145 INTEGER,
INTENT(IN) :: SBUFMAT
146 INTEGER,
INTENT(IN) :: NSVOIS
147 INTEGER,
INTENT(IN) :: IDTMINS
148 INTEGER ,
INTENT(IN) :: IRESP
149 INTEGER ,
INTENT(IN) :: IDEL7NG
150 INTEGER ,
INTENT(INOUT) :: IDEL7NOK
151 INTEGER ,
INTENT(IN) :: MAXFUNC
152 INTEGER,
INTENT(IN) :: USERL_AVAIL
153 INTEGER,
INTENT(IN) :: IMON_MAT
154 INTEGER IXS(NIXS,*),IPARG(NPARG,NGROUP),NPF(*),IADS(8,*),GRTH(*),
155 . IPARTS(*),IPM(NPROPMI,*),IGEO(NPROPGI,*),IGRTH(*), ITASK,IOUTPRT
156 INTEGER NELTST,ITYPTST,OFFSET,NG,NEL,ICP,ICSIG,ISTRAIN,H3D_STRAIN
157 INTEGER,
INTENT(IN) :: IEXPAN,IFTHE,ICONDN
161 . pm(npropm,*), x(*), a(*), v(*), ms(*), w(*),
162 . flux(6,*),geo(npropg,*),
163 . flu1(*), veul(*), fv(*), tf(*), bufmat(*),
164 . partsav(*),stifn(*), fsky(*),eani(*),
165 . f11(mvsiz),f21(mvsiz),f31(mvsiz),
166 . f12(mvsiz),f22(mvsiz),f32(mvsiz),
167 . f13(mvsiz),f23(mvsiz),f33(mvsiz),
168 . f14(mvsiz),f24(mvsiz),f34(mvsiz),
169 . f15(mvsiz),f25(mvsiz),f35(mvsiz),
170 . f16(mvsiz),f26(mvsiz),f36(mvsiz),gresav(*),
171 . mssa(*), dmels(*), voln(mvsiz)
172 my_real,
INTENT(INOUT) :: temp(numnod),fthe(ifthe),fthesky(lsky),
173 . condn(icondn),condnsky(lsky)
174 my_real,
DIMENSION(MVSIZ,6),
INTENT(INOUT) :: svis
175 DOUBLE PRECISION,
DIMENSION(3,NUMNOD),
INTENT(IN ) :: XDP
176 TYPE (TTABLE) TABLE(*)
177 TYPE (ELBUF_STRUCT_),
TARGET,
DIMENSION(NGROUP) :: ELBUF_TAB
178 TYPE (NLOCAL_STR_) ,
TARGET :: NLOC_DMG
180 TYPE (MAT_ELEM_) ,
INTENT(INOUT) :: MAT_ELEM
181 TYPE(DT_) ,
INTENT(INOUT) :: DT
182 type () ,
intent(inout) :: glob_therm
183 type (sensors_),
INTENT(INOUT) :: SENSORS
187 INTEGER I,J,LCO,NF1,IFLAG,NUVAR,CURRENT_LAYER,IMAT,
188 . ILAY,NLAY,IR,IS,IT,IP,IBID,MX,L_PLA,L_EPSD
189 INTEGER MXT(MVSIZ),NGL(MVSIZ),NGEO(MVSIZ),IBIDON(1)
191 INTEGER NC1(MVSIZ), NC2(MVSIZ), NC3(MVSIZ), NC4(MVSIZ),
192 . NC5(MVSIZ), NC6(MVSIZ), NC7(MVSIZ), NC8(MVSIZ)
197 . vd2(mvsiz) , dvol(mvsiz),deltax(mvsiz),
198 . vis(mvsiz) , qvis(mvsiz), cxx(mvsiz) ,
199 . s1(mvsiz) , s2(mvsiz) , s3(mvsiz) ,
200 . s4(mvsiz) , s5(mvsiz) , s6(mvsiz) ,
201 . dxx(mvsiz) , dyy(mvsiz
202 . d4(mvsiz) , d5(mvsiz) , d6(mvsiz) ,
203 . jac1(mvsiz), jac2(mvsiz), jac3(mvsiz),
204 . jac4(mvsiz), jac5(mvsiz), jac6(mvsiz),
205 . vdx(mvsiz) , vdy(mvsiz) , vdz(mvsiz),ssp_eq(mvsiz),aire(mvsiz)
208 . sti(mvsiz),wxx(mvsiz),wyy(mvsiz),wzz(mvsiz),conde(mvsiz)
213 . off(mvsiz) , rhoo(mvsiz), offg
214 . x1(mvsiz), x2(mvsiz), x3(mvsiz), x4(mvsiz),
215 . x5(mvsiz), x6(mvsiz),
216 . y1(mvsiz), y2(mvsiz), y3(mvsiz), y4(mvsiz),
217 . y5(mvsiz), y6(mvsiz),
218 . z1(mvsiz), z2(mvsiz), z3(mvsiz), z4(mvsiz),
219 . z5(mvsiz), z6(mvsiz),
220 . vx1(mvsiz),vx2(mvsiz),vx3(mvsiz),vx4(mvsiz
221 . vx5(mvsiz),vx6(mvsiz),
222 . vy1(mvsiz),vy2(mvsiz),vy3(mvsiz),vy4(mvsiz),
223 . vy5(mvsiz),vy6(mvsiz),
224 . vz1(mvsiz),vz2(mvsiz),vz3(mvsiz),vz4(mvsiz),
225 . vz5(mvsiz),vz6(mvsiz),
226 . px1(mvsiz),px2(mvsiz),px3(mvsiz),px4(mvsiz),
227 . px5(mvsiz),px6(mvsiz),
228 . py1(mvsiz),py2(mvsiz),py3(mvsiz),py4(mvsiz),
229 . py5(mvsiz),py6(mvsiz),
230 . pz1(mvsiz),pz2(mvsiz),pz3(mvsiz),pz4(mvsiz),
231 . pz5(mvsiz),pz6(mvsiz),
232 . px1h(mvsiz),px2h(mvsiz),px3h(mvsiz),
233 . py1h(mvsiz),py2h(mvsiz),py3h(mvsiz),
234 . pz1h(mvsiz),pz2h(mvsiz),pz3h(mvsiz),
235 . vgxa(mvsiz),vgya(mvsiz),vgza(mvsiz), vga2(mvsiz),
236 . xgxa(mvsiz),xgya(mvsiz),xgza(mvsiz),
237 . xgxya(mvsiz),xgyza(mvsiz),xgzxa(mvsiz),
238 . xgxa2(mvsiz),xgya2(mvsiz),xgza2(mvsiz)
240 . dxy(mvsiz),dyx(mvsiz),
241 . dyz(mvsiz),dzy(mvsiz),
242 . dzx(mvsiz),dxz(mvsiz),divde(mvsiz)
244 . r11(mvsiz),r12(mvsiz),r13(mvsiz),
245 . r21(mvsiz),r22(mvsiz),r23(mvsiz),
246 . r31(mvsiz),r32(mvsiz),r33(mvsiz),gama(mvsiz,6)
249 . sigym(mvsiz),g(mvsiz),nu(mvsiz),volg(mvsiz),sigy(mvsiz),
250 . b1122(mvsiz),b1221(mvsiz),b2212(mvsiz),b1121(mvsiz),
251 . b1122h(mvsiz),b1221h(mvsiz),b2212h(mvsiz),b1121h(mvsiz),
252 . b1x(mvsiz,2),b1y(mvsiz,2),b2x(mvsiz,2),b2y(mvsiz,2),
253 . b1xh(mvsiz,2),b1yh(mvsiz,2),b2xh(mvsiz,2),b2yh(mvsiz,2),
254 . dcxx(mvsiz),dcxy(mvsiz),dcxz(mvsiz),dcyx(mvsiz),dcyy(mvsiz),
255 . dcyz(mvsiz),dczx(mvsiz),dczy(mvsiz),dczz(mvsiz),dc4(mvsiz),
256 . dc5(mvsiz),dc6(mvsiz),vzl(mvsiz),jaci33(mvsiz),
257 . dhxx(mvsiz),dhxy(mvsiz),dhyx(mvsiz
258 . dhzx(mvsiz),dhzy(mvsiz),dhzz(mvsiz),dh4(mvsiz),dhxz(mvsiz),
259 . dh5(mvsiz),dh6(mvsiz),eintm(mvsiz),ddhv(mvsiz),dd(mvsiz,6),
260 . sigzm(mvsiz),volm(mvsiz),usb(mvsiz),et(mvsiz),
261 . r1_free(mvsiz),r3_free(mvsiz),r4_free(mvsiz),
262 . stin(mvsiz),bid(mvsiz),dsv(mvsiz),alpha_e(mvsiz),llsh(mvsiz)
264 INTEGER PID,MTN0,IPTHK,IPPOS,IPMAT
265INTEGER MXT0(MVSIZ),NN_DEL,IPRES,ISCTL,ISTAB(MVSIZ)
267 . dir(mvsiz,2),sign(nel,6),shf(mvsiz),zt,wt,offs(mvsiz),
268 . rx(mvsiz), ry(mvsiz), rz(mvsiz),nu1(mvsiz),fac(mvsiz),
269 . sx(mvsiz), sy(mvsiz), sz(mvsiz),
270 . tx(mvsiz), ty(mvsiz), tz(mvsiz),e0(mvsiz),
271 . n1x(mvsiz), n2x(mvsiz), n3x(mvsiz),
272 . n1y(mvsiz), n2y(mvsiz), n3y(mvsiz),
273 . n1z(mvsiz), n2z(mvsiz), n3z(mvsiz),
274 . n4x(mvsiz), n5x(mvsiz), n6x(mvsiz),
275 . n4y(mvsiz), n5y(mvsiz), n6y(mvsiz),
276 . n4z(mvsiz), n5z(mvsiz), n6z(mvsiz),amu(mvsiz),
area(mvsiz)
277 my_real them(mvsiz,6),tempel(mvsiz),die(mvsiz),conden(mvsiz)
278 my_real,
dimension(mvsiz) :: fheat
281 INTEGER INLOC,L_NLOC,IPOS(6),INOD(6)
282 iNTEGER SZ_R1_FREE,SZ_IX
283 my_real,
DIMENSION(:,:),
ALLOCATABLE :: var_reg
284 my_real,
DIMENSION(:),
POINTER :: dnl
285 my_real :: sti_c(mvsiz),ll(mvsiz),fld(mvsiz),
288 TYPE(g_bufel_) ,
POINTER :: GBUF
289 TYPE(L_BUFEL_) ,
POINTER :: LBUF
292 . W_GAUSS(9,9),A_GAUSS(9,9)
300 3 0.555555555555556,0.888888888888889,0.555555555555556,
303 4 0.347854845137454,0.652145154862546,0.652145154862546,
304 4 0.347854845137454,0. ,0. ,
306 5 0.236926885056189,0.478628670499366,0.568888888888889,
307 5 0.478628670499366,0.236926885056189,0. ,
309 6 0.171324492379170,0.360761573048139,0.467913934572691,
310 6 0.467913934572691,0.360761573048139,0.171324492379170,
312 7 0.129484966168870,0.279705391489277,0.381830050505119,
313 7 0.417959183673469,0.381830050505119,0.279705391489277,
314 7 0.129484966168870,0. ,0. ,
315 8 0.101228536290376,0.222381034453374,0.313706645877887,
316 8 0.362683783378362,0.362683783378362,0.313706645877887,
317 8 0.222381034453374,0.101228536290376,0. ,
318 9 0.081274388361574,0.180648160694857,0.260610696402935,
319 9 0.312347077040003,0.330239355001260,0.312347077040003,
320 9 0.260610696402935,0.180648160694857,0.081274388361574/
325 2 -.577350269189626,0.577350269189626,0. ,
328 3 -.774596669241483,0. ,0.774596669241483,
331 4 -.861136311594053,-.339981043584856,0.339981043584856,
332 4 0.861136311594053,0. ,0. ,
334 5 -.906179845938664,-.538469310105683,0. ,
335 5 0.538469310105683,0.906179845938664,0. ,
337 6 -.932469514203152,-.661209386466265,-.238619186083197,
338 6 0.238619186083197,0.661209386466265,0.932469514203152,
340 7 -.949107912342759,-.741531185599394,-.405845151377397,
341 7 0. ,0.405845151377397,0.741531185599394,
342 7 0.949107912342759,0. ,0. ,
343 8 -.960289856497536,-.796666477413627,-.525532409916329,
344 8 -.183434642495650,0.183434642495650,0.525532409916329,
345 8 0.796666477413627,0.960289856497536,0. ,
346 9 -.968160239507626,-.836031107326636,-.613371432700590,
347 9 -.324253423403809,0. ,0.324253423403809,
348 9 0.613371432700590,0.836031107326636,0.968160239507626/
359 gbuf => elbuf_tab(ng)%GBUF
360 nlay = elbuf_tab(ng)%NLAY
365 ALLOCATE(var_reg(nel,nlay))
367 sz_ix=numelq+numels+nsvois
371 IF (igtyp /= 22)
THEN
380 1 6, x, ixs(1,nf1),rx,
388 CALL s6rcoor3(x,ixs(1,nf1),v,w,gbuf%GAMA,gama,
389 . x1, x2, x3, x4, x5, x6,
390 . y1, y2, y3, y4, y5, y6,
391 . z1, z2, z3, z4, z5, z6,
392 . vx1, vx2, vx3, vx4, vx5, vx6,
393 . vy1, vy2, vy3, vy4, vy5, vy6,
394 . vz1, vz2, vz3, vz4, vz5, vz6,
395 . vd2,vis,gbuf%OFF,offg,gbuf%SMSTR,gbuf%RHO,rhoo,
396 . r11, r12, r13, r21, r22, r23, r31, r32, r33,
397 . nc1,nc2,nc3,nc4,nc5,nc6,ngl,mxt,ngeo,
398 . ioutprt, vgxa, vgya, vgza, vga2,dd,
399 . nel, xgxa, xgya, xgza,xgxa2,xgya2,xgza2,
400 . xgxya,xgyza,xgzxa,iparg(1,ng),gbuf%GAMA_R)
404 IF (geo(190,pid)+geo(191,pid)+geo(192,pid)+geo(192,pid)>zero)
406 IF (nn_del ==0 .AND. dt%IDEL_BRICK>0) nn_del=6
409 ipres = mat_elem%MAT_PARAM(mx)%IPRES
414 nu(i)=
min(half,pm(21,mx))
415 e0(i) =three*(one-two*nu(i))*c1
426 CALL s8csigp3(gbuf%SIG,e0 ,gbuf%PLA,fac,gbuf%G_PLA,nel)
428 nu1(i)=nu(i)+(half-nu(i))*fac(i)
437 1 offg, voln, ngl, x1,
443 7 px4, py1, py2, py3,
444 8 py4, pz1, pz2, pz3,
445 9 pz4, px1h, px2h, px3h,
446 a py1h, py2h, py3h, pz1h,
447 b pz2h, pz3h, jac1, jac2,
448 c jac3, jac4, jac5, jac6,
449 d jaci33, b1x, b1y, b2y,
450 e b2x, b1122, b1221, b2212,
451 f b1121, b1xh, b1yh, b2xh,
452 g b2yh, b1122h, b1221h, b2212h,
453 h b1121h, vzl, volg, gbuf%SMSTR,
454 i gbuf%OFF, nel, ismstr)
456 1 volg, deltax, x1, x2,
463 8 n3x, n4x, n5x, n6x,
464 9 n1y, n2y, n3y, n4y,
465 a n5y, n6y, n1z, n2z,
466 b n3z, n4z, n5z, n6z,
467 c nel, mtn, jale, jeul)
468 IF (ntsheg > 0.AND.isctl == 0)
THEN
470 . x1, x2, x3, x4, x5, x6,
471 . y1, y2, y3, y4, y5, y6,
472 . z1, z2, z3, z4, z5, z6,nel)
475 IF (gbuf%IDT_TSH(i)<=0) cycle
476 facdp = 1.343*llsh(i)/deltax(i)
477 alpha_e(i) = facdp*facdp
478 deltax(i)=
max(llsh(i),deltax(i))
482 1 px1, px2, px3, px4,
483 2 py1, py2, py3, py4,
484 3 pz1, pz2, pz3, pz4,
485 4 vx1, vx2, vx3, vx4,
486 5 vx5, vx6, vy1, vy2,
487 6 vy3, vy4, vy5, vy6,
488 7 vz1, vz2, vz3, vz4,
489 8 vz5, vz6, dcxx, dcxy,
490 9 dcxz, dcyx, dcyy, dcyz,
491 a dczx, dczy, dczz, dc4,
492 b dc5, dc6, wxx, wyy,
493 c wzz, dhxx, dhxy, dhxz,
494 d dhyx, dhyy, dhyz, dhzx,
495 e dhzy, dhzz, dh4, dh5,
496 f dh6, px1h, px2h, px3h,
497 g py1h, py2h, py3h, pz1h,
498 h pz2h, pz3h, jaci33, b1x,
499 i b1y, b2y, b2x, b1122,
500 j b1221, b2212, b1121, b1xh,
501 k b1yh, b2xh, b2yh, b1122h,
502 l b1221h, b2212h, b1121h, ddhv,
505 1 f11, f21, f31, f12,
506 2 f22, f32, f13, f23,
507 3 f33, f14, f24, f34,
508 4 f15, f25, f35, f16,
509 5 f26, f36, gbuf%SIG, gbuf%EINT,
510 6 gbuf%RHO, gbuf%QVIS, gbuf%PLA, gbuf%EPSD,
511 7 gbuf%G_PLA, gbuf%G_EPSD,nel)
515 IF (ismstr <= 3.OR.(ismstr==4.AND.jlag>0))
THEN
517 1 gbuf%OFF, gbuf%SMSTR,x1, x2,
527 IF (igtyp == 21)
THEN
528 CALL sgetdir3(nel,rx,ry,rz,tx,ty,tz,
529 . r11,r21,r31,r12,r22,r32,
530 . gbuf%GAMA,dir,irep)
532 IF (igtyp == 22)
THEN
541 shf(i)=geo(38,ngeo(i))
550 l_nloc = nloc_dmg%L_NLOC
551 dnl => nloc_dmg%DNL(1:l_nloc)
554 inod(1) = nloc_dmg%IDXI(nc1(i))
555 inod(2) = nloc_dmg%IDXI(nc2(i))
556 inod(3) = nloc_dmg%IDXI(nc3(i))
557 inod(4) = nloc_dmg%IDXI(nc4(i))
558 inod(5) = nloc_dmg%IDXI(nc5(i))
559 inod(6) = nloc_dmg%IDXI(nc6(i))
561 ipos(j) = nloc_dmg%POSI(inod(j))+ilay-1
563 var_reg(i,ilay) = dnl(ipos(1)) + dnl(ipos(2)) + dnl(ipos(3)) +
564 . dnl(ipos(4)) + dnl(ipos(5)) + dnl(ipos(6))
565 var_reg(i,ilay) = var_reg(i,ilay)*one_over_6
575 lbuf => elbuf_tab(ng)%BUFLY(ilay)%LBUF(ir,is,it)
576 IF (igtyp == 22)
THEN
577 mid=igeo(ipmat+ilay,pid)
581 sigzm(i) = sigzm(i)+lbuf%VOL(i)*lbuf%SIG(i+2*nel)
582 volm(i) = volm(i) +lbuf%VOL(i)
585 IF (dt1 == zero)
THEN
597 tempel(i) = one_over_6 *(temp(nc1(i)) + temp(nc2(i))
598 . + temp(nc3(i)) + temp(nc4(i))
599 . + temp(nc5(i)) + temp(nc6(i)))
600 gbuf%TEMP(i) = tempel(i)
607 IF (jthe < 0) them(1:nel,1:6) = zero
612 lbuf => elbuf_tab(ng)%BUFLY(ilay)%LBUF(ir,is,it)
613 IF (igtyp == 22)
THEN
614 zt = geo(ippos+ilay,pid)
615 wt = geo(ipthk+ilay,pid)
616 mid=igeo(ipmat+ilay,pid)
622 zt = a_gauss(ilay,nlay)
623 wt = w_gauss(ilay,nlay)
627 1 dxx, dxy, dxz, dyx,
628 2 dyy, dyz, dzx, dzy,
630 4 dcxx, dcxy, dcxz, dcyx,
631 5 dcyy, dcyz, dczx, dczy,
632 6 dczz, dc4, dc5, dc6,
633 7 dhxx, dhxy, dhxz, dhyx,
634 8 dhyy, dhyz, dhzx, dhzy,
635 9 dhzz, dh4, dh5, dh6,
637 b volg, lbuf%VOL, ddhv, lbuf%SIG,
638 c sigzm, volm, usb, lbuf%EINT,
639 d off, offg, dti, gbuf%OFF,
640 e dsv, lbuf%VOL0DP,voldp, ipres,
647 .
CALL sgetdir3(nel,rx,ry,rz,tx,ty,tz,
648 . r11,r21,r31,r12,r22,r32,
649 . lbuf%GAMA,dir,irep)
650 CALL scordef3(nel,dxx,dyy,dzz,d4,d5,d6,dir)
651 IF (igtyp == 22)
THEN
659 divde(1:nel) = dt1*(dxx(1:nel)+ dyy(1:nel)+ dzz(1:nel))+dsv(1:nel)
661 1 pm, lbuf%VOL, lbuf%RHO, lbuf%EINT,
662 2 divde, flux(1,nf1),flu1(nf1), voln,
663 3 dvol, ngl, mxt, off,
664 4 0, gbuf%TAG22, voldp, lbuf%VOL0DP,
665 5 amu, gbuf%OFF, nel, mtn,
666 6 jale, ismstr, jeul, jlag)
671 CALL csmall3(lbuf%SIG,s1,s2,s3,s4,s5,s6,
677 CALL mmain(timers, output,
678 1 elbuf_tab, ng, pm, geo,
679 2 ale_connect, ixs, iparg,
680 3 v, tf, npf, bufmat,
681 4 sti, x, dt2t, neltst,
682 5 ityptst, offset, nel, w,
683 6 off, ngeo, mxt, ngl,
684 7 voln, vd2, dvol, deltax,
685 8 vis, qvis, cxx, s1,
689 c wyy, wzz, jac1, jac2,
690 d jac3, jac4, jac5, jac6,
691 e vdx, vdy, vdz, muvoid,
692 f ssp_eq, aire, sigy, et,
693 g r1_free, lbuf%PLA, r3_free, amu,
694 h dxx, dxy, dxz, dyx,
695 i dyy, dyz, dzx, dzy,
696 j dzz, ipm, gama, bid,
697 k bid, bid, bid, bid,
698 l bid, bid, istrain, tempel,
699 m die, iexpan, current_layer,mssa,
701 o table, bid, bid, bid,
702 p bid, iparg(1,ng), igeo, conde,
703 q itask, nloc_dmg, var_reg(1,ilay),mat_elem,
704 r h3d_strain, jplasol, jsph, sz_r1_free,
705 * snpc, stf, sbufmat ,glob_therm,
706 * svis, sz_ix, iresp,
707 * n2d, th_strain, ngroup, tt,
708 . dt1, ntable, numelq, nummat,
709 . numgeo, numnod, numels,
710 . idel7nok, idtmin, maxfunc,
711 . imon_mat, userl_avail, impl_s,
712 . idyna, dt, fheat ,sensors, opt_mtn=mtn,opt_jcvt=jcvt,
713 . opt_isorth=isorth,opt_isorthg=isorthg)
716 stin(i) = stin(i)+sti(i)
719 IF(glob_therm%NODADT_THERM == 1)
THEN
721 conden(i)= conden(i)+ conde(i)
724 IF (istrain == 1)
THEN
727 2 d5, d6, lbuf%STRA,wxx,
728 3 wyy, wzz, off, nel,
734 l_pla = elbuf_tab(ng)%BUFLY(ilay)%L_PLA
735 l_epsd = elbuf_tab(ng)%BUFLY(ilay)%L_EPSD
741 1 sign, px1, px2, px3,
742 2 px4, py1, py2, py3,
743 3 py4, pz1, pz2, pz3,
744 4 pz4, px1h, px2h, px3h,
746 6 pz2h, pz3h, jaci33, b1x,
747 7 b1y, b2y, b2x, b1122,
748 8 b1221, b2212, b1121, b1xh
749 9 b1yh, b2xh, b2yh, b1122h,
750 a b1221h, b2212h, b1121h, f11,
751 b f21, f31, f12, f22,
752 c f32, f13, f23, f33,
755 f f36, voln, qvis, lbuf%EINT,
756 g lbuf%RHO, lbuf%QVIS, lbuf%PLA, lbuf%EPSD,
757 h gbuf%EPSD, gbuf%SIG, gbuf%EINT, gbuf%RHO,
758 i gbuf%QVIS, gbuf%PLA, zt, wt,
759 j volg, off, nu1, lbuf%VOL,
760 k gbuf%VOL, l_pla, l_epsd, nel,
761 l svis, gbuf%WPLA, lbuf%WPLA, gbuf%G_WPLA )
765 2 px4, py1, py2, py3,
766 3 py4, pz1, pz2, pz3,
767 4 pz4, px1h, px2h, px3h,
768 5 py1h, py2h, py3h, pz1h,
769 6 pz2h, pz3h, jaci33, b1x,
770 7 b1y, b2y, b2x, b1122,
771 8 b1221, b2212, b1121, b1xh,
772 9 b1yh, b2xh, b2yh, b1122h,
773 a b1221h, b2212h, b1121h, f11,
775 c f32, f13, f23, f33,
776 d f14, f24, f34, f15,
777 e f25, f35, f16, f26,
778 f f36, voln, qvis, lbuf%EINT,
779 g lbuf%RHO, lbuf%QVIS, lbuf%PLA, lbuf%EPSD,
780 h gbuf%EPSD, gbuf%SIG, gbuf%EINT, gbuf%RHO,
781 i gbuf%QVIS, gbuf%PLA, a_gauss(ilay,nlay),w_gauss(ilay,nlay),
782 j volg, off, nu1, lbuf%VOL,
783 k gbuf%VOL, l_pla, l_epsd, nel,
784 l svis, gbuf%WPLA, lbuf%WPLA, gbuf%G_WPLA )
791 IF (mat_elem%MAT_PARAM(imat)%HEAT_FLAG == 1)
THEN
793 1 pm ,imat ,voln ,nc1 ,
794 2 nc2 ,nc3 ,nc4 ,nc5 ,
795 3 nc6 ,px1 ,px2 ,px3 ,
796 4 px4 ,py1 ,py2 ,py3 ,
797 5 py4 ,pz1 ,pz2 ,pz3 ,
798 6 pz4 ,dt1 ,temp ,tempel ,
799 7 fheat ,them ,gbuf%OFF ,lbuf%OFF ,
800 8 nel ,glob_therm%THEACCFACT)
804 1 pm ,imat ,voln ,nc1 ,
805 2 nc2 ,nc3 ,nc4 ,nc5 ,
806 3 nc6 ,px1 ,px2 ,px3 ,
807 4 px4 ,py1 ,py2 ,py3 ,
808 5 py4 ,pz1 ,pz2 ,pz3 ,
809 6 pz4 ,dt1 ,temp ,tempel ,
810 7 die ,them ,gbuf%OFF ,lbuf%OFF ,
811 8 nel ,glob_therm%THEACCFACT)
814 offg(i)=
min(offg(i),off(i))
815 IF (lbuf%OFF(i) > one .AND. gbuf%OFF(i) == one)
THEN
816 offs(i) =
min(lbuf%OFF(i),offs(i))
830 . x1, x2, x3, x4, x5, x6,
831 . y1, y2, y3, y4, y5, y6,
832 . z1, z2, z3, z4, z5, z6,nel)
836 2 volg ,nc1 ,nc2 ,nc3 ,
837 3 nc4 ,nc5 ,nc6 ,px1 ,
838 4 px2 ,px3 ,px4 ,py1 ,
839 5 py2 ,py3 ,py4 ,pz1 ,
840 6 pz2 ,pz3 ,pz4 ,mxt(lft),
841 7 itask ,dt2t ,gbuf%VOL,nft ,
842 8 nlay ,w_gauss ,a_gauss ,
area ,
843 9 elbuf_tab(ng)%NLOCTS(1,1))
849 IF (offs(i)<=two)gbuf%OFF(i) = offs(i)
852 lbuf => elbuf_tab(ng)%BUFLY(ilay)%LBUF(ir,is,it)
853 IF (igtyp == 22)
THEN
854 mid=igeo(ipmat+ilay,pid)
858 IF (gbuf%OFF(i) > one) lbuf%OFF(i)=gbuf%OFF(i)
862 IF (igtyp == 22)
THEN
870 . x1, x2, x3, x4, x5, x6,
871 . y1, y2, y3, y4, y5, y6,
872 . z1, z2, z3, z4, z5, z6, nel)
879 IF ( impl_s == 0)
THEN
883 . x1, x2, x3, x4, x5, x6,
884 . y1, y2, y3, y4, y5, y6,
885 . z1, z2, z3, z4, z5, z6,
886 . vx1, vx2, vx3, vx4, vx5, vx6
888 . vz1, vz2, vz3, vz4, vz5, vz6,
889 . f11, f12, f13, f14, f15,
891 . f31, f32, f33, f34, f35, f36,
892 . pm,npropm, nummat,mtn,mxt,dn,
894 . off,gbuf%VOL,gbuf%EINT,dt1,stin,nel)
898 . x1, x2, x3, x3, x4, x5, x6, x6,
899 . y1, y2, y3, y3, y4, y5, y6, y6,
900 . z1, z2, z3, z3, z4, z5, z6, z6,
901 . vz1, vz2, vz3, vz3, vz4, vz5, vz6, vz6,
902 . f31,f32,f33,f34,f35,f36,
903 . nu,gbuf%HOURG,off,gbuf%VOL,gbuf%EINT,nel)
910 1 gbuf%OFF,offg, nel, ismstr)
914 iflag=mod(ncycle,ncpri)
916 CALL s6cbilan(partsav,gbuf%EINT,gbuf%RHO,gbuf%RK ,gbuf%VOL,
917 . vgxa, vgya, vgza, vga2, volg,iparts,
918 . gresav,grth,igrth,gbuf%OFF,iexpan,gbuf%EINTTH,
919 . gbuf%FILL, xgxa, xgya, xgza,xgxa2,xgya2,xgza2,
920 . xgxya,xgyza,xgzxa,itask,iparg(1,ng),gbuf%OFF,
921 . sensors,nel,gbuf%G_WPLA,gbuf%WPLA)
932 6 f13, f14, f15, f16,
933 7 f21, f22, f23, f24,
934 8 f25, f26, f31, f32,
935 9 f33, f34, f35, f36,
938 1 r11, r21, r31, r12,
939 2 r22, r32, r13, r23,
940 3 r33, f11, f21, f31,
943 1 r11, r21, r31, r12,
944 2 r22, r32, r13, r23,
945 3 r33, f12, f22, f32,
948 1 r11, r21, r31, r12,
949 2 r22, r32, r13, r23,
950 3 r33, f13, f23, f33,
953 1 r11, r21, r31, r12,
954 2 r22, r32, r13, r23,
955 3 r33, f14, f24, f34,
958 1 r11, r21, r31, r12,
959 2 r22, r32, r13, r23,
960 3 r33, f15, f25, f35,
963 1 r11, r21, r31, r12,
964 2 r22, r32, r13, r23,
965 3 r33, f16, f26, f36,
973 1 nel ,sti_c ,npropm ,nummat ,
974 2 ismstr ,mxt ,istab ,pm ,
975 3 gbuf%SIG ,gbuf%RHO ,cxx ,offg ,
976 4 gbuf%OFF ,ll ,voln ,fld ,
995 . numnod, ismstr, nel )
1017 . fqmax,gbuf%EINT_DISTOR,dt1,
1022 1 gbuf%FILL,sti, f11, f21,
1023 2 f31, f12, f22, f32,
1024 3 f13, f23, f33, f14,
1025 4 f24, f34, f15, f25
1026 5 f35, f16, f26, f36,
1031 IF (iparit == 0)
THEN
1033 1 gbuf%OFF,a, nc1, nc2,
1034 2 nc3, nc4, nc5, nc6,
1035 3 stifn, stin, f11, f21,
1036 4 f31, f12, f22, f32,
1037 5 f13, f23, f33, f14,
1038 6 f24, f34, f15, f25,
1039 7 f35, f16, f26, f36,
1040 8 nel, jthe, fthe, them,
1041 9 condn,conden, ifthe, icondn,
1042 . glob_therm%NODADT_THERM)
1045 1 gbuf%OFF,stin, fsky, fsky,
1046 2 iads, f11, f21, f31,
1047 3 f12, f22, f32, f13,
1048 4 f23, f33, f14, f24,
1049 5 f34, f15, f25, f35,
1050 6 f16, f26, f36, nel,
1051 7 nft, jthe, fthesky
1053 . glob_therm%NODADT_THERM)
1057 1 gbuf%OFF,alpha_e, nc1, nc2,