18 type(hecmwst_local_mesh),
intent(in) :: hecmesh
23 type(hecmwst_result_data) :: fstrRESULT
24 integer(kind=kint) :: i, j, ndof, maxstep, interval, fnum, is, iE, gid, istep
29 istep = fstrdynamic%i_step
31 if( fstrsolid%TEMP_ngrp_tot>0 .or. fstrsolid%TEMP_irres>0 )
then
33 allocate( fstrsolid%tnstrain(hecmesh%n_node*6) )
34 allocate( fstrsolid%testrain(hecmesh%n_elem*6) )
35 else if( ndof==2 )
then
36 allocate( fstrsolid%tnstrain(hecmesh%n_node*3) )
37 allocate( fstrsolid%testrain(hecmesh%n_elem*3) )
38 else if( ndof== 4)
then
39 write(*,*)
'Error: This routine is not implemented'
44 if( ndof==3 .or. ndof == 4 )
then
46 else if( ndof==2 )
then
48 else if( ndof==6 )
then
52 if(
associated( fstrsolid%contacts ) ) &
55 maxstep = fstrdynamic%n_step
57 if( (mod(istep,fstrsolid%output_ctrl(1)%frequency)==0 .or. istep==maxstep) )
then
58 fnum = fstrsolid%output_ctrl(1)%filenum
62 if( fstrsolid%output_ctrl(2)%outinfo%grp_id>0 .and. &
63 (mod(istep,fstrsolid%output_ctrl(2)%frequency)==0 .or. istep==maxstep) )
then
64 is = fstrsolid%output_ctrl(2)%outinfo%grp_id
65 fnum = fstrsolid%output_ctrl(2)%filenum
66 do i = hecmesh%node_group%grp_index(is-1)+1, hecmesh%node_group%grp_index(is)
67 ie = hecmesh%node_group%grp_item(i)
68 gid = hecmesh%global_node_ID(ie)
69 write(fnum,
'(2i10,1p6e15.7)') istep,gid,(fstrsolid%unode(ndof*(ie-1)+j),j=1,ndof)
74 (mod(istep,fstrsolid%output_ctrl(3)%frequency)==0 .or. istep==maxstep) )
then
75 if(
associated( fstrsolid%contacts ) ) &
77 call fstr_write_result( hecmesh, fstrsolid, fstrparam, istep, fstrdynamic%t_curr, 0, fstrdynamic )
81 (mod(istep,fstrsolid%output_ctrl(4)%frequency)==0 .or. istep==maxstep) )
then
83 if(
associated( fstrsolid%contacts ) ) &
85 call fstr_make_result( hecmesh, fstrsolid, fstrresult, istep, fstrdynamic%t_curr, fstrdynamic )
87 call hecmw_visualize_init
88 call hecmw_visualize( hecmesh, fstrresult, istep )
89 call hecmw_visualize_finalize
91 call hecmw_result_free( fstrresult )
101 integer,
intent(in) :: fnum
102 type(hecmwst_local_mesh),
intent(in) :: hecMESH
106 real(kind=kreal) :: umax(6), umin(6), vmax(6), vmin(6), amax(6), amin(6)
107 real(kind=kreal) :: emax(14), emin(14), smax(14), smin(14)
108 real(kind=kreal) :: mmax(1), mmin(1), emmax(1), emmin(1)
109 real(kind=kreal) :: eemax(14), eemin(14), esmax(14), esmin(14)
111 real(kind=kreal) :: gumax(6), gumin(6), gvmax(6), gvmin(6), gamax(6), gamin(6)
112 real(kind=kreal) :: gemax(14), gemin(14), gsmax(14), gsmin(14)
113 real(kind=kreal) :: gmmax(1), gmmin(1), gemmax(1), gemmin(1)
114 real(kind=kreal) :: geemax(14), geemin(14), gesmax(14), gesmin(14)
116 integer(kind=kint) :: IUmax(6), IUmin(6), IVmax(6), IVmin(6), IAmax(6), IAmin(6)
117 integer(kind=kint) :: IEmax(14), IEmin(14), ISmax(14), ISmin(14)
118 integer(kind=kint) :: IMmax(1), IMmin(1), IEMmax(1), IEMmin(1)
119 integer(kind=kint) :: IEEmax(14), IEEmin(14), IESmax(14), IESmin(14)
120 integer(kind=kint) :: i, j, k, ndof, mdof, ID_area, idx
121 integer(kind=kint) :: label(6)
123 if( fstrdynamic%i_step==0 )
return
124 if( fstrdynamic%idx_eqa==1 .and. fstrdynamic%i_step>0 )
then
131 write( fnum,
'(''#### Result step='',I6)') fstrdynamic%i_step
135 label(1)=11;label(2)=22
139 label(1)=11;label(2)=22;label(3)=33;
140 label(4)=12;label(5)=23;label(6)=31;
143 j = hecmesh%global_node_ID(1)
145 umax(k) = fstrdynamic%DISP(k,idx); umin(k) = fstrdynamic%DISP(k,idx)
146 vmax(k) = fstrdynamic%VEL(k,idx); vmin(k) = fstrdynamic%VEL(k,idx)
147 amax(k) = fstrdynamic%ACC(k,idx); amin(k) = fstrdynamic%ACC(k,idx)
148 iumax(k)= j; iumin(k)= j; ivmax(k)= j; ivmin(k)= j; iamax(k)= j; iamin(k)= j
151 emax(k) = fstrsolid%STRAIN(k); emin(k) = fstrsolid%STRAIN(k)
152 smax(k) = fstrsolid%STRESS(k); smin(k) = fstrsolid%STRESS(k)
153 eemax(k) = fstrsolid%ESTRAIN(k); eemin(k) = fstrsolid%ESTRAIN(k)
154 esmax(k) = fstrsolid%ESTRESS(k); esmin(k) = fstrsolid%ESTRESS(k)
155 iemax(k)= j; iemin(k)= j; ismax(k)= j; ismin(k)= j
156 ieemax(k)= j; ieemin(k)= j; iesmax(k)= j; iesmin(k)= j
158 mmax(1) = fstrsolid%MISES(1); mmin(1) = fstrsolid%MISES(1)
159 emmax(1) = fstrsolid%EMISES(1); emmin(1) = fstrsolid%EMISES(1)
160 immax(1)= j; immin(1)= j; iemmax(1)= j; iemmin(1)= j
163 do i = 1, hecmesh%nn_internal
164 if(fstrsolid%is_rot(i)==1)cycle
165 j = hecmesh%global_node_ID(i)
167 if ( fstrdynamic%DISP(ndof*(i-1)+k,idx) > umax(k) )
then
168 umax(k) = fstrdynamic%DISP(ndof*(i-1)+k,idx)
170 else if( fstrdynamic%DISP(ndof*(i-1)+k,idx) < umin(k) )
then
171 umin(k) = fstrdynamic%DISP(ndof*(i-1)+k,idx)
174 if ( fstrdynamic%VEL(ndof*(i-1)+k,idx) > vmax(k) )
then
175 vmax(k) = fstrdynamic%VEL(ndof*(i-1)+k,idx)
177 else if( fstrdynamic%VEL(ndof*(i-1)+k,idx) < vmin(k) )
then
178 vmin(k) = fstrdynamic%VEL(ndof*(i-1)+k,idx)
181 if ( fstrdynamic%ACC(ndof*(i-1)+k,idx) > amax(k) )
then
182 amax(k) = fstrdynamic%ACC(ndof*(i-1)+k,idx)
184 else if( fstrdynamic%ACC(ndof*(i-1)+k,idx) < amin(k) )
then
185 amin(k) = fstrdynamic%ACC(ndof*(i-1)+k,idx)
192 do i = 1, hecmesh%nn_internal
193 if(fstrsolid%is_rot(i)==1)cycle
194 j = hecmesh%global_node_ID(i)
196 if ( fstrsolid%STRAIN(mdof*(i-1)+k) > emax(k) )
then
197 emax(k) = fstrsolid%STRAIN(mdof*(i-1)+k)
199 else if( fstrsolid%STRAIN(mdof*(i-1)+k) < emin(k) )
then
200 emin(k) = fstrsolid%STRAIN(mdof*(i-1)+k)
203 if ( fstrsolid%STRESS(mdof*(i-1)+k) > smax(k) )
then
204 smax(k) = fstrsolid%STRESS(mdof*(i-1)+k)
206 else if( fstrsolid%STRESS(mdof*(i-1)+k) < smin(k) )
then
207 smin(k) = fstrsolid%STRESS(mdof*(i-1)+k)
211 if ( fstrsolid%MISES(i) > mmax(1) )
then
212 mmax(1) = fstrsolid%MISES(i)
214 else if( fstrsolid%MISES(i) < mmin(1) )
then
215 mmin(1) = fstrsolid%MISES(i)
220 do i = 1, hecmesh%n_elem
221 id_area = hecmesh%elem_ID(i*2)
222 if( id_area==hecmesh%my_rank )
then
223 j = hecmesh%global_elem_ID(i)
225 if( fstrsolid%ESTRAIN(mdof*(i-1)+k) > eemax(k) )
then
226 eemax(k) = fstrsolid%ESTRAIN(mdof*(i-1)+k)
228 else if( fstrsolid%ESTRAIN(mdof*(i-1)+k) < eemin(k) )
then
229 eemin(k) = fstrsolid%ESTRAIN(mdof*(i-1)+k)
232 if( fstrsolid%ESTRESS(mdof*(i-1)+k) > esmax(k) )
then
233 esmax(k) = fstrsolid%ESTRESS(mdof*(i-1)+k)
235 else if( fstrsolid%ESTRESS(mdof*(i-1)+k) < esmin(k) )
then
236 esmin(k) = fstrsolid%ESTRESS(mdof*(i-1)+k)
240 if( fstrsolid%EMISES(i) > emmax(1) )
then
241 emmax(1) = fstrsolid%EMISES(i)
243 else if( fstrsolid%EMISES(i) < emmin(1) )
then
244 emmin(1) = fstrsolid%EMISES(i)
251 write(
ilog,*)
'##### Local Summary @Node :Max/IdMax/Min/IdMin####'
252 do i = 1, ndof;
write(
ilog,1029)
' //U',i,
' ',umax(i),iumax(i),umin(i),iumin(i);
end do
253 if (ndof == 4)
write(
ilog,1009)
' //P ' , umax(4),iumax(4),umin(4),iumin(4)
254 do i = 1, ndof;
write(
ilog,1029)
' //V',i,
' ',vmax(i),ivmax(i),vmin(i),ivmin(i);
end do
255 do i = 1, ndof;
write(
ilog,1029)
' //A',i,
' ',amax(i),iamax(i),amin(i),iamin(i);
end do
256 do i = 1, mdof;
write(
ilog,1029)
' //E',label(i),
' ',emax(i),iemax(i),emin(i),iemin(i);
end do
257 do i = 1, mdof;
write(
ilog,1029)
' //S',label(i),
' ',smax(i),ismax(i),smin(i),ismin(i);
end do
258 write(
ilog,1009)
'//SMS ' ,mmax(1),immax(1),mmin(1),immin(1)
259 write(
ilog,*)
'##### Local Summary @Element :Max/IdMax/Min/IdMin####'
260 do i = 1, mdof;
write(
ilog,1029)
' //E',label(i),
' ',eemax(i),ieemax(i),eemin(i),ieemin(i);
end do
261 do i = 1, mdof;
write(
ilog,1029)
' //S',label(i),
' ',esmax(i),iesmax(i),esmin(i),iesmin(i);
end do
262 write(
ilog,1009)
'//SMS ' ,emmax(1),iemmax(1),emmin(1),iemmin(1)
265 gumax = umax; gumin = umin; gvmax = vmax; gvmin = vmin; gamax = amax; gamin = amin;
266 gemax = emax; gemin = emin; geemax = eemax; geemin = eemin;
267 gsmax = smax; gsmin = smin; gesmax = esmax; gesmin = esmin;
268 gmmax = mmax; gmmin = mmin; gemmax = emmax; gemmin = emmin;
270 call hecmw_allreduce_r(hecmesh,gumax,ndof,hecmw_max)
271 call hecmw_allreduce_r(hecmesh,gumin,ndof,hecmw_min)
272 call hecmw_allreduce_r(hecmesh,gvmax,ndof,hecmw_max)
273 call hecmw_allreduce_r(hecmesh,gvmin,ndof,hecmw_min)
274 call hecmw_allreduce_r(hecmesh,gamax,ndof,hecmw_max)
275 call hecmw_allreduce_r(hecmesh,gamin,ndof,hecmw_min)
276 call hecmw_allreduce_r(hecmesh,gemax,mdof,hecmw_max)
277 call hecmw_allreduce_r(hecmesh,gemin,mdof,hecmw_min)
278 call hecmw_allreduce_r(hecmesh,gsmax,mdof,hecmw_max)
279 call hecmw_allreduce_r(hecmesh,gsmin,mdof,hecmw_min)
280 call hecmw_allreduce_r(hecmesh,gmmax,1,hecmw_max)
281 call hecmw_allreduce_r(hecmesh,gmmin,1,hecmw_min)
282 call hecmw_allreduce_r(hecmesh,geemax,mdof,hecmw_max)
283 call hecmw_allreduce_r(hecmesh,geemin,mdof,hecmw_min)
284 call hecmw_allreduce_r(hecmesh,gesmax,mdof,hecmw_max)
285 call hecmw_allreduce_r(hecmesh,gesmin,mdof,hecmw_min)
286 call hecmw_allreduce_r(hecmesh,gemmax,1,hecmw_max)
287 call hecmw_allreduce_r(hecmesh,gemmin,1,hecmw_min)
290 if(gumax(i) > umax(i)) iumax(i) = 0
291 if(gvmax(i) > vmax(i)) ivmax(i) = 0
292 if(gamax(i) > amax(i)) iamax(i) = 0
293 if(gumin(i) < umin(i)) iumin(i) = 0
294 if(gvmin(i) < vmin(i)) ivmin(i) = 0
295 if(gamin(i) < amin(i)) iamin(i) = 0
298 if(gemax(i) > emax(i)) iemax(i) = 0
299 if(gsmax(i) > smax(i)) ismax(i) = 0
300 if(geemax(i) > eemax(i)) ieemax(i) = 0
301 if(gesmax(i) > esmax(i)) iesmax(i) = 0
302 if(gemin(i) < emin(i)) iemin(i) = 0
303 if(gsmin(i) < smin(i)) ismin(i) = 0
304 if(geemin(i) < eemin(i)) ieemin(i) = 0
305 if(gesmin(i) < esmin(i)) iesmin(i) = 0
308 if(gmmax(i) > mmax(i)) immax(i) = 0
309 if(gemmax(i) > emmax(i)) iemmax(i) = 0
310 if(gmmin(i) < mmin(i)) immin(i) = 0
311 if(gemmin(i) < emmin(i)) iemmin(i) = 0
314 call hecmw_allreduce_i(hecmesh,iumax,ndof,hecmw_max)
315 call hecmw_allreduce_i(hecmesh,iumin,ndof,hecmw_max)
316 call hecmw_allreduce_i(hecmesh,ivmax,ndof,hecmw_max)
317 call hecmw_allreduce_i(hecmesh,ivmin,ndof,hecmw_max)
318 call hecmw_allreduce_i(hecmesh,iamax,ndof,hecmw_max)
319 call hecmw_allreduce_i(hecmesh,iamin,ndof,hecmw_max)
320 call hecmw_allreduce_i(hecmesh,iemax,mdof,hecmw_max)
321 call hecmw_allreduce_i(hecmesh,iemin,mdof,hecmw_max)
322 call hecmw_allreduce_i(hecmesh,ismax,mdof,hecmw_max)
323 call hecmw_allreduce_i(hecmesh,ismin,mdof,hecmw_max)
324 call hecmw_allreduce_i(hecmesh,immax,1,hecmw_max)
325 call hecmw_allreduce_i(hecmesh,immin,1,hecmw_max)
326 call hecmw_allreduce_i(hecmesh,ieemax,mdof,hecmw_max)
327 call hecmw_allreduce_i(hecmesh,ieemin,mdof,hecmw_max)
328 call hecmw_allreduce_i(hecmesh,iesmax,mdof,hecmw_max)
329 call hecmw_allreduce_i(hecmesh,iesmin,mdof,hecmw_max)
330 call hecmw_allreduce_i(hecmesh,iemmax,1,hecmw_max)
331 call hecmw_allreduce_i(hecmesh,iemmin,1,hecmw_max)
333 if( hecmesh%my_rank==0 )
then
334 write(
ilog,*)
'##### Global Summary @Node :Max/IdMax/Min/IdMin####'
335 do i = 1, ndof;
write(
ilog,1029)
' //U',i,
' ',gumax(i),iumax(i),gumin(i),iumin(i);
end do
336 if (ndof == 4)
write(
ilog,1009)
' //P ' ,gumax(4),iumax(4),gumin(4),iumin(4)
337 do i = 1, ndof;
write(
ilog,1029)
' //V',i,
' ',gvmax(i),ivmax(i),gvmin(i),ivmin(i);
end do
338 do i = 1, ndof;
write(
ilog,1029)
' //A',i,
' ',gamax(i),iamax(i),gamin(i),iamin(i);
end do
339 do i = 1, mdof;
write(
ilog,1029)
' //E',label(i),
' ',gemax(i),iemax(i),gemin(i),iemin(i);
end do
340 do i = 1, mdof;
write(
ilog,1029)
' //S',label(i),
' ',gsmax(i),ismax(i),gsmin(i),ismin(i);
end do
341 write(
ilog,1009)
'//SMS ' ,gmmax(1),immax(1),gmmin(1),immin(1)
342 write(
ilog,*)
'##### Global Summary @Element :Max/IdMax/Min/IdMin####'
343 do i = 1, mdof;
write(
ilog,1029)
' //E',label(i),
' ',geemax(i),ieemax(i),geemin(i),ieemin(i);
end do
344 do i = 1, mdof;
write(
ilog,1029)
' //S',label(i),
' ',gesmax(i),iesmax(i),gesmin(i),iesmin(i);
end do
345 write(
ilog,1009)
'//SMS ' ,gemmax(1),iemmax(1),gemmin(1),iemmin(1)
348 1009
format(a7,1pe12.4,i10,1pe12.4,i10)
349 1029
format(a,i0,a,1pe12.4,i10,1pe12.4,i10)
357 type(hecmwst_local_mesh) :: hecMESH
363 integer(kind=kint) :: idx, ii, jj, ierr, ncmp
364 integer(kind=kint) :: num_monit, ig, is, iE, ik, iunitS, iunit
367 if( mod(fstrdynamic%i_step,fstrdynamic%nout_monit)/=0 )
return
369 if( fstrdynamic%idx_eqa==1 .and. fstrdynamic%i_step>0 )
then
376 ig = fstrdynamic%ngrp_monit
377 is = hecmesh%node_group%grp_index(ig-1)+1
378 ie = hecmesh%node_group%grp_index(ig)
380 ii = hecmesh%node_group%grp_item(ik)
381 if (ii > hecmesh%nn_internal) cycle
382 num_monit = num_monit+1
383 jj = hecmesh%global_node_id(ii)
384 iunits = 10*(num_monit-1)
387 if( fstrdynamic%iout_list(1)==1 )
then
388 iunit = iunits + fstrdynamic%dynamic_IW4
389 write( iunit,
'(i10,1pe13.4e3,i10,1p6e13.4e3)' ) &
390 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
391 fstrdynamic%DISP( hecmesh%n_dof*(ii-1)+1 : hecmesh%n_dof*ii , idx )
394 if( fstrdynamic%iout_list(2)==1 )
then
395 iunit = iunits + fstrdynamic%dynamic_IW5
396 write( iunit,
'(i10,1pe13.4e3,i10,1p6e13.4e3)' ) &
397 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
398 fstrdynamic%VEL( hecmesh%n_dof*(ii-1)+1 : hecmesh%n_dof*ii , idx )
401 if( fstrdynamic%iout_list(3)==1 )
then
402 iunit = iunits + fstrdynamic%dynamic_IW6
403 write( iunit,
'(i10,1pe13.4e3,i10,1p6e13.4e3)' ) &
404 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
405 fstrdynamic%ACC( hecmesh%n_dof*(ii-1)+1 : hecmesh%n_dof*ii , idx )
408 if( fstrdynamic%iout_list(4)==1 )
then
409 iunit = iunits + fstrdynamic%dynamic_IW7
410 write( iunit,
'(i10,1pe13.4e3,i10,1p6e13.4e3)' ) &
411 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
412 fstrsolid%QFORCE( hecmesh%n_dof*(ii-1)+1 : hecmesh%n_dof*ii )
415 if( fstrdynamic%iout_list(5) > 0 )
then
416 if (hecmesh%n_dof == 2 .or. hecmesh%n_dof == 3 .or. hecmesh%n_dof == 4)
then
421 iunit = iunits + fstrdynamic%dynamic_IW8
422 write( iunit,
'(i10,1pe13.4e3,i10,1p6e13.4e3)') &
423 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
424 fstrsolid%STRAIN( ncmp*(ii-1)+1 : ncmp*ii )
427 if( fstrdynamic%iout_list(6) > 0 )
then
428 if (hecmesh%n_dof == 2 .or. hecmesh%n_dof == 3 .or. hecmesh%n_dof == 4)
then
433 iunit = iunits + fstrdynamic%dynamic_IW9
434 write( iunit,
'(i10,1pe13.4e3,i10,1p7e13.4e3)') &
435 fstrdynamic%i_step, fstrdynamic%t_curr, jj, &
436 fstrsolid%STRESS( ncmp*(ii-1)+1 : ncmp*ii )
440 if( hecmesh%my_rank==0 )
then
441 if( any(fstrdynamic%iout_list(1:3)==1) )
then
442 inquire( file=
'dyna_energy.txt', opened=yes )
444 open( fstrdynamic%dynamic_IW10, file=
'dyna_energy.txt', status=
'replace', iostat=ierr )
446 write(*,*)
'stop due to file opening error <dyna_enrgy.txt>'
447 call hecmw_abort( hecmw_comm_get_comm() )
449 write( fstrdynamic%dynamic_IW10, * ) &
450 ' time step',
' time ',
' kinetic energy',
' strain energy',
' total energy'
452 if(fstrdynamic%i_step==0)
then
453 fstrdynamic%kineticEnergy = 0.0d0
454 do ii = 1, hecmesh%n_node*hecmesh%n_dof
455 fstrdynamic%kineticEnergy = fstrdynamic%kineticEnergy &
456 + 0.5d0 * fstreig%mass(ii) * fstrdynamic%VEL(ii,idx) * fstrdynamic%VEL(ii,idx)
459 fstrdynamic%totalEnergy = fstrdynamic%kineticEnergy + fstrdynamic%strainEnergy
460 write( fstrdynamic%dynamic_IW10,
'(i10,1pe13.4e3,1p3e16.4e3)' ) &
461 fstrdynamic%i_step, fstrdynamic%t_curr, &
462 fstrdynamic%kineticEnergy, fstrdynamic%strainEnergy, fstrdynamic%totalEnergy
464 if( fstrdynamic%i_step==fstrdynamic%n_step )
close(fstrdynamic%dynamic_IW10)
471 subroutine matvec(y,x,hecMAT,ndof,D,AU,AL)
473 type(hecmwst_matrix) :: hecMAT
475 integer(kind=kint) :: ndof, i, is, ie, j, icol, ki, kj, ix, iy, ip, nn
476 real(kind=kreal) :: d(ndof*ndof*hecmat%NP)
477 real(kind=kreal) :: au(ndof*ndof*hecmat%NPU)
478 real(kind=kreal) :: al(ndof*ndof*hecmat%NPL)
479 real(kind=kreal) :: x(ndof*hecmat%NP)
480 real(kind=kreal) :: y(ndof*hecmat%NP)
487 is=hecmat%indexU(i-1)+1
495 ip=nn*(j-1)+ndof*(ki-1)+kj
496 y(iy)=y(iy)+au(ip)*x(ix)
503 is=hecmat%indexL(i-1)+1
511 ip=nn*(j-1)+ndof*(ki-1)+kj
512 y(iy)=y(iy)+al(ip)*x(ix)
523 ip=nn*(i-1)+ndof*(ki-1)+kj
524 y(iy)=y(iy)+d(ip)*x(ix)