FrontISTR  5.9.0
Large-scale structural analysis program with finit element method
m_fstr.F90
Go to the documentation of this file.
1 !-------------------------------------------------------------------------------
2 ! Copyright (c) 2019 FrontISTR Commons
3 ! This software is released under the MIT License, see LICENSE.txt
4 !-------------------------------------------------------------------------------
5 ! If new header is supported, change according to following method. !
6 ! 1) Increase FSTR_CTRL_HEADER_NUMBER !
7 ! 2) Add new header name to fstr_ctrl_header_names !
8 ! 3) Describe new function to get parameters from control file !
9 ! in fstr_ctrl.f90 !
10 ! 4) Describe new subroutine to set values of the parameter !
11 ! in fstr_setup.f90 !
12 ! 5) If initial values are necessary, set the value !
13 ! in subroutine fstr_setup_init in fstr_setup.f90 !
15 module m_fstr
16  use hecmw
17  use m_common_struct
18  use m_step
19  use m_out
20  use m_timepoint
21  use m_elemact
22  use mmechgauss
23  use mcontactdef
25 
26  implicit none
27 
28  public
29 
32  integer(kind=kint), parameter :: kyes = 1
33  integer(kind=kint), parameter :: kno = 0
34  integer(kind=kint), parameter :: kon = 1
35  integer(kind=kint), parameter :: koff = 0
36 
38  integer(kind=kint), parameter :: kstprecheck = 0
39  integer(kind=kint), parameter :: kststatic = 1
40  integer(kind=kint), parameter :: ksteigen = 2
41  integer(kind=kint), parameter :: kstheat = 3
42  integer(kind=kint), parameter :: kstdynamic = 4
43  !integer(kind=kint), parameter :: kstNLSTATIC = 5
44  integer(kind=kint), parameter :: kststaticeigen = 6
45  integer(kind=kint), parameter :: kstnzprof = 7
46 
48  integer(kind=kint), parameter :: ksmcg = 1
49  integer(kind=kint), parameter :: ksmbicgstab = 2
50  integer(kind=kint), parameter :: ksmgmres = 3
51  integer(kind=kint), parameter :: ksmgpbicg = 4
52  integer(kind=kint), parameter :: ksmgmresr = 5
53  integer(kind=kint), parameter :: ksmgmresren = 6
54  integer(kind=kint), parameter :: ksmdirect = 101
55 
57  integer(kind=kint), parameter :: knsmnewton = 1
58  integer(kind=kint), parameter :: knsmquasinewton = 2
59 
61  integer(kind=kint), parameter :: kcaslagrange = 1
62  integer(kind=kint), parameter :: kcaalagrange = 2
63 
65  integer(kind=kint), parameter :: kbcffstr = 0 ! BC described in fstr control file (default)
66  integer(kind=kint), parameter :: kbcfnastran = 1 ! nastran file
67 
68  integer(kind=kint), parameter :: kbcinitial = 1
69  integer(kind=kint), parameter :: kbctransit = 2
70 
72  integer(kind=kint), parameter :: restart_outlast = 1
73  integer(kind=kint), parameter :: restart_outall = 2
74 
76  integer(kind=kint), parameter :: kel341fi = 1
77  integer(kind=kint), parameter :: kel341sesns = 2
78 
79  integer(kind=kint), parameter :: kel361fi = 1
80  integer(kind=kint), parameter :: kel361bbar = 2
81  integer(kind=kint), parameter :: kel361ic = 3
82  integer(kind=kint), parameter :: kel361fbar = 4
83 
84  integer(kind=kint), parameter :: kfloadtype_node = 1
85  integer(kind=kint), parameter :: kfloadtype_surf = 2
86 
87  integer(kind=kint), parameter :: kfloadcase_re = 1
88  integer(kind=kint), parameter :: kfloadcase_im = 2
89 
91  integer(kind=kint), parameter :: kitrcontinue = 0
92  integer(kind=kint), parameter :: kitrconverged = 1
93  integer(kind=kint), parameter :: kitrdiverged = 2
94  integer(kind=kint), parameter :: kitrfloatingerror = 3
95 
96 
98  integer(kind = kint) :: myrank
99  integer(kind = kint) :: nprocs
100 
102  logical :: paracontactflag = .false.
103 
105  character(len=HECMW_FILENAME_LEN) :: cntfilname
106  character(len=HECMW_FILENAME_LEN) :: restartfilname
107 
109  integer(kind=kint), parameter :: ilog = 16 ! log
110  integer(kind=kint), parameter :: ista = 17 ! status
111  integer(kind=kint), parameter :: iutb = 18 ! utable
112  integer(kind=kint), parameter :: imsg = 51 ! message (myrank == 0 only)
113  integer(kind=kint), parameter :: idbg = 52 ! debug
114  integer(kind=kint), parameter :: ifvs = 53 ! visual.ini file
115  integer(kind=kint), parameter :: ineu = 54 ! neutral file (heat)
116  integer(kind=kint), parameter :: iresout = 100 ! ~110, keeping for result output file
117 
119  integer(kind=kint) :: sviarray(100)
120  real(kind=kreal) :: svrarray(100)
121 
123  integer(kind=kint), pointer :: iecho
124  integer(kind=kint), pointer :: iresult
125  integer(kind=kint), pointer :: ivisual
126  integer(kind=kint), pointer :: ineutral ! flag for femap neutral file
127  integer(kind=kint), pointer :: irres ! flag for restart, read
128  integer(kind=kint), pointer :: iwres ! flag for restart, write
129  integer(kind=kint), pointer :: nrres ! position of restart read
130  integer(kind=kint), pointer :: nprint ! interval of write
131 
132  integer(kind=kint), parameter :: kopss_solution = 1
133  integer(kind=kint), parameter :: kopss_material = 2
134  integer(kind=kint) :: opsstype = kopss_solution ! output stress/strain type
135 
136 
138  real(kind=kreal), pointer :: ref_temp
139 
141  real(kind=kreal) :: dt ! /=fstr_param%dtime
142  real(kind=kreal) :: etime ! /=fstr_param%etime
143  integer(kind=kint) :: itmax
144  real(kind=kreal) :: eps ! /=fstr_param%eps
145 
147  character(len=HECMW_FILENAME_LEN) :: cond_name
148  integer :: node_elem
149  integer :: grpid
150  integer, pointer :: intval(:) => null()
151  real(kind=kreal), pointer :: realval(:) => null()
152  end type
153  type( tinitialcondition ), pointer, save :: g_initialcnd(:) => null()
154 
157  integer(kind=kint) :: solution_type
158  integer(kind=kint) :: solver_method
159  integer(kind=kint) :: nlsolver_method
160  logical :: nlgeom
161 
163  integer(kind=kint) :: analysis_n
164  real(kind=kreal), pointer :: dtime(:)
165  real(kind=kreal), pointer :: etime(:)
166  real(kind=kreal), pointer :: dtmin(:)
167  real(kind=kreal), pointer :: delmax(:)
168  integer(kind=kint), pointer:: itmax(:)
169  real(kind=kreal), pointer :: eps(:)
170  real(kind=kreal) :: ref_temp
171  integer(kind=kint) :: timepoint_id
172 
174  integer(kind=kint) :: fg_echo
175  integer(kind=kint) :: fg_result
176  integer(kind=kint) :: fg_visual
177 
179  integer(kind=kint) :: fg_neutral
180  integer(kind=kint) :: fg_irres
181  integer(kind=kint) :: fg_iwres
182  integer(kind=kint) :: nrres
183  integer(kind=kint) :: nprint
184 
186  integer(kind=kint) :: n_node
187  integer(kind=kint) :: nn_internal
188  integer(kind=kint), pointer :: global_local_id(:,:)
189 
191  integer( kind=kint ) :: fg_couple
192  integer( kind=kint ) :: fg_couple_type
193  integer( kind=kint ) :: fg_couple_first
194  integer( kind=kint ) :: fg_couple_window
195 
197  integer( kind=kint ) :: restart_out_type
198  integer( kind=kint ) :: restart_version
199 
201  integer( kind=kint ) :: contact_algo
202  integer( kind=kint ) :: augiter
203  type(tcontactparam), pointer :: contactparam(:)
204  type(tcontactinterference), pointer :: contact_if(:)
205 
207  type(tparamautoinc), pointer :: ainc(:)
208  type(time_points), pointer :: timepoints(:)
209  end type fstr_param
210 
212  type( fstr_param ),target :: fstrpr
213 
216  real(kind=kreal), pointer :: stress(:) => null()
217  real(kind=kreal), pointer :: strain(:) => null()
218  real(kind=kreal), pointer :: mises(:) => null()
219 
220  real(kind=kreal), pointer :: pstress(:) => null()
221  real(kind=kreal), pointer :: pstrain(:) => null()
222  real(kind=kreal), pointer :: pstress_vect(:,:) => null()
223  real(kind=kreal), pointer :: pstrain_vect(:,:) => null()
224 
225  real(kind=kreal), pointer :: estress(:) => null()
226  real(kind=kreal), pointer :: estrain(:) => null()
227  real(kind=kreal), pointer :: emises(:) => null()
228  real(kind=kreal), pointer :: eplstrain(:) => null()
229 
230  real(kind=kreal), pointer :: epstress(:) => null()
231  real(kind=kreal), pointer :: epstrain(:) => null()
232  real(kind=kreal), pointer :: epstress_vect(:,:) => null()
233  real(kind=kreal), pointer :: epstrain_vect(:,:) => null()
234  real(kind=kreal), pointer :: enqm(:) => null()
235 
236 
237  type(fstr_solid_physic_val), pointer :: layer(:) => null()
238  type(fstr_solid_physic_val), pointer :: plus => null()
239  type(fstr_solid_physic_val), pointer :: minus => null()
240  end type fstr_solid_physic_val
241 
243  integer(kind=kint) :: file_type ! kbcfFSTR or kbcfNASTRAN
244  integer(kind=kint) :: statictype ! 1:Total, 2:Updated, 3:Infinitesimal
245  integer(kind=kint) :: nstep_tot
246 
247  type(step_info), pointer :: step_ctrl(:) =>null()
248  type(t_output_ctrl), pointer :: output_ctrl(:)=>null()
249 
251  integer(kind=kint) :: boundary_ngrp_tot
252  integer(kind=kint), pointer :: boundary_ngrp_grpid (:) =>null()
253  integer(kind=kint), pointer :: boundary_ngrp_id (:) =>null()
254  integer(kind=kint), pointer :: boundary_ngrp_type (:) =>null()
255  integer(kind=kint), pointer :: boundary_ngrp_amp (:) =>null()
256  real(kind=kreal), pointer :: boundary_ngrp_val(:) =>null()
257  integer(kind=kint), pointer :: boundary_ngrp_istot (:) =>null()
258  integer(kind=kint) :: boundary_ngrp_rot
259  integer(kind=kint), pointer :: boundary_ngrp_rotid (:) =>null()
260  integer(kind=kint), pointer :: boundary_ngrp_centerid (:) =>null()
261 
263  integer(kind=kint) :: velocity_type
264  integer(kind=kint) :: velocity_ngrp_tot
265  integer(kind=kint), pointer :: velocity_ngrp_grpid (:) =>null()
266  integer(kind=kint), pointer :: velocity_ngrp_id (:) =>null()
267  integer(kind=kint), pointer :: velocity_ngrp_type (:) =>null()
268  integer(kind=kint), pointer :: velocity_ngrp_amp (:) =>null()
269  real(kind=kreal), pointer :: velocity_ngrp_val(:) =>null()
270 
272  integer(kind=kint) :: acceleration_type
273  integer(kind=kint) :: acceleration_ngrp_tot
274  integer(kind=kint), pointer :: acceleration_ngrp_grpid (:) =>null()
275  integer(kind=kint), pointer :: acceleration_ngrp_id (:) =>null()
276  integer(kind=kint), pointer :: acceleration_ngrp_type (:) =>null()
277  integer(kind=kint), pointer :: acceleration_ngrp_amp (:) =>null()
278  real(kind=kreal), pointer :: acceleration_ngrp_val(:) =>null()
279 
281  integer(kind=kint) :: cload_ngrp_tot
282  integer(kind=kint), pointer :: cload_ngrp_grpid (:) =>null()
283  integer(kind=kint), pointer :: cload_ngrp_id (:)
284  integer(kind=kint), pointer :: cload_ngrp_dof (:)
285  integer(kind=kint), pointer :: cload_ngrp_amp (:)
286  real(kind=kreal), pointer :: cload_ngrp_val(:)
287  integer(kind=kint) :: cload_ngrp_rot
288  integer(kind=kint), pointer :: cload_ngrp_rotid (:) =>null()
289  integer(kind=kint), pointer :: cload_ngrp_centerid (:) =>null()
290 
292  integer(kind=kint) :: dload_ngrp_tot
293  integer(kind=kint) :: dload_follow
294  integer(kind=kint), pointer :: dload_ngrp_grpid (:) =>null()
295  integer(kind=kint), pointer :: dload_ngrp_id (:)
296  integer(kind=kint), pointer :: dload_ngrp_lid (:)
297  integer(kind=kint), pointer :: dload_ngrp_amp (:)
298  real(kind=kreal), pointer :: dload_ngrp_params(:,:)
299 
301  integer(kind=kint) :: temp_ngrp_tot
302  integer(kind=kint) :: temp_irres
303  integer(kind=kint) :: temp_tstep
304  integer(kind=kint) :: temp_interval
305  integer(kind=kint) :: temp_rtype ! type of reading result; 1: step-based; 2: time-based
306  real(kind=kreal) :: temp_factor
307  integer(kind=kint), pointer :: temp_ngrp_grpid (:) =>null()
308  integer(kind=kint), pointer :: temp_ngrp_id (:)
309  real(kind=kreal), pointer :: temp_ngrp_val(:)
310 
312  integer(kind=kint) :: spring_ngrp_tot
313  integer(kind=kint), pointer :: spring_ngrp_grpid (:) =>null()
314  integer(kind=kint), pointer :: spring_ngrp_id (:)
315  integer(kind=kint), pointer :: spring_ngrp_dof (:)
316  integer(kind=kint), pointer :: spring_ngrp_amp (:)
317  real(kind=kreal), pointer :: spring_ngrp_val(:)
318 
320  type(telemact) :: elemact
321 
323  integer( kind=kint ) :: couple_ngrp_tot
324  integer( kind=kint ),pointer :: couple_ngrp_id(:)
325 
327  integer(kind=kint) :: maxn_gauss
328 
329  real(kind=kreal), pointer :: stress(:)
330  real(kind=kreal), pointer :: strain(:)
331  real(kind=kreal), pointer :: mises(:)
332 
333  real(kind=kreal), pointer :: pstress(:)
334  real(kind=kreal), pointer :: pstrain(:)
335  real(kind=kreal), pointer :: pstress_vect(:,:)
336  real(kind=kreal), pointer :: pstrain_vect(:,:)
337 
338  real(kind=kreal), pointer :: estress(:)
339  real(kind=kreal), pointer :: estrain(:)
340  real(kind=kreal), pointer :: emises(:)
341  real(kind=kreal), pointer :: eplstrain(:)
342 
343  real(kind=kreal), pointer :: epstress(:)
344  real(kind=kreal), pointer :: epstrain(:)
345  real(kind=kreal), pointer :: epstress_vect(:,:)
346  real(kind=kreal), pointer :: epstrain_vect(:,:)
347 
348  real(kind=kreal), pointer :: tnstrain(:)
349  real(kind=kreal), pointer :: testrain(:)
350 
351  real(kind=kreal), pointer :: yield_ratio(:)
352 
353  real(kind=kreal), pointer :: enqm(:)
354  real(kind=kreal), pointer :: reaction(:)
355 
356  real(kind=kreal), pointer :: cont_nforce(:)
357  real(kind=kreal), pointer :: cont_fric(:)
358  real(kind=kreal), pointer :: cont_relvel(:)
359  real(kind=kreal), pointer :: cont_state(:)
360  integer(kind=kint), pointer :: cont_sgrp_id(:)
361  real(kind=kreal), pointer :: cont_area(:)
362  real(kind=kreal), pointer :: cont_ntrac(:)
363  real(kind=kreal), pointer :: cont_ftrac(:)
364  real(kind=kreal), pointer :: embed_nforce(:)
365 
366  type(fstr_solid_physic_val), pointer :: solid=>null()
367  type(fstr_solid_physic_val), pointer :: shell=>null()
368  type(fstr_solid_physic_val), pointer :: beam =>null()
369 
371  integer(kind=kint) :: restart_nout
374  integer(kind=kint) :: restart_nin
375  type(step_info) :: step_ctrl_restart
376 
377  integer(kind=kint) :: max_lyr
378  integer(kind=kint) :: is_33shell
379  integer(kind=kint) :: is_33beam
380  integer(kind=kint) :: is_heat
381  integer(kind=kint) :: max_ncon_stf
382  integer(kind=kint) :: max_ncon
383  integer(kind=kint), pointer :: is_rot(:) => null()
384  integer(kind=kint) :: elemopt361
385  logical :: is_smoothing_active
386  real(kind=kreal) :: factor(2)
389  integer(kind=kint) :: nrstat_i(10)
390  real(kind=kreal) :: nrstat_r(10)
391  integer(kind=kint) :: autoinc_stat
392  integer(kind=kint) :: cutback_stat
393 
394  real(kind=kreal), pointer :: gl(:)
395  real(kind=kreal), pointer :: gl0(:)
396  real(kind=kreal), pointer :: eforce(:)
397  real(kind=kreal), pointer :: qforce(:)
398  real(kind=kreal), pointer :: qforce_bak(:)
399  real(kind=kreal), pointer :: dforce(:)
400  real(kind=kreal), pointer :: unode(:) => null()
401  real(kind=kreal), pointer :: unode_bak(:) => null()
402  real(kind=kreal), pointer :: dunode(:) => null()
403  real(kind=kreal), pointer :: ddunode(:) => null()
404  logical :: has_finite_rotation_kinematics
405  logical :: finite_rotation_state_ready
406  integer(kind=kint), pointer :: shell_node_mode(:) => null()
407  integer(kind=kint), pointer :: shell_rot_state(:) => null()
408  real(kind=kreal), pointer :: shell_ref_triad(:) => null()
409  real(kind=kreal), pointer :: shell_triad(:) => null()
410  real(kind=kreal), pointer :: shell_triad_bak(:) => null()
411  real(kind=kreal), pointer :: shell_dtriad(:) => null()
412  real(kind=kreal), pointer :: shell_drill(:) => null()
413  real(kind=kreal), pointer :: shell_drill_bak(:) => null()
414  real(kind=kreal), pointer :: shell_ddrill(:) => null()
415  real(kind=kreal), pointer :: temperature(:)=> null()
416  real(kind=kreal), pointer :: temp_bak(:) => null()
417  real(kind=kreal), pointer :: last_temp(:) => null()
418 
419  type( telement ), pointer :: elements(:) =>null()
420  type( tmaterial ),pointer :: materials(:) =>null()
421  integer :: n_contacts
422  type( tcontact ), pointer :: contacts(:) =>null()
423  integer :: n_embeds
424  type( tcontact ), pointer :: embeds(:) =>null()
425  integer :: n_fix_mpc
426  real(kind=kreal), pointer :: mpc_const(:) =>null()
427  type(tsection), pointer :: sections(:) =>null()
428 
429  ! for cutback
430  ! ####################### Notice #######################
431  ! # If you add new variables to store analysis status, #
432  ! # - backup variables with postfix "_bkup" here #
433  ! # - backup process to module m_fstr_Cutback #
434  ! # must be added if necessary. #
435  ! ######################################################
436  real(kind=kreal), pointer :: unode_bkup(:) => null()
437  real(kind=kreal), pointer :: qforce_bkup(:) => null()
438  real(kind=kreal), pointer :: dforce_bkup(:) => null()
439  real(kind=kreal), pointer :: last_temp_bkup(:) => null()
440  real(kind=kreal), pointer :: shell_triad_bkup(:) => null()
441  real(kind=kreal), pointer :: shell_drill_bkup(:) => null()
442  type( telement ), pointer :: elements_bkup(:) =>null()
443  type( tcontact ), pointer :: contacts_bkup(:) =>null()
444  type( tcontact ), pointer :: embeds_bkup(:) =>null()
445  end type fstr_solid
446 
450  integer(kind=kint) :: is_steady
451  real(kind=kreal) :: beta
452  logical :: is_iter_max_limit
453 
455  integer(kind=kint) :: steptot
456  integer(kind=kint) :: restart_nout
457  real(kind=kreal), pointer :: step_dltime(:), step_eetime(:)
458  real(kind=kreal), pointer :: step_delmin(:), step_delmax(:)
459  integer(kind=kint) :: timepoint_id
460 
462  integer(kind=kint) :: materialtot
463  integer(kind=kint), pointer :: rhotab(:), cptab(:), condtab(:)
464  real(kind=kreal), pointer :: rho(:,:), rhotemp(:,:)
465  real(kind=kreal), pointer :: cp(:,:), cptemp(:,:)
466  real(kind=kreal), pointer :: cond(:,:),condtemp(:,:)
467 
468  real(kind=kreal), pointer :: rhofunca(:,:), rhofuncb(:,:)
469  real(kind=kreal), pointer :: cpfunca(:,:), cpfuncb(:,:)
470  real(kind=kreal), pointer :: condfunca(:,:),condfuncb(:,:)
471 
473  integer(kind=kint) :: amplitudetot
474  integer(kind=kint), pointer :: ampltab(:)
475  real(kind=kreal), pointer :: ampl(:,:), ampltime(:,:)
476  real(kind=kreal), pointer :: amplfunca(:,:), amplfuncb(:,:)
477 
479  real(kind=kreal), pointer :: temp0(:)
480  real(kind=kreal), pointer :: tempc(:)
481  real(kind=kreal), pointer :: temp(:)
482 
484  integer(kind=kint) :: t_fix_tot
485  integer(kind=kint), pointer :: t_fix_node(:)
486  integer(kind=kint), pointer :: t_fix_ampl(:)
487  real(kind=kreal), pointer :: t_fix_val(:)
488 
490  integer(kind=kint) :: q_nod_tot
491  integer(kind=kint), pointer :: q_nod_node(:)
492  integer(kind=kint), pointer :: q_nod_ampl(:)
493  real(kind=kreal), pointer :: q_nod_val(:)
494 
496  integer(kind=kint) :: q_vol_tot
497  integer(kind=kint), pointer :: q_vol_elem(:)
498  integer(kind=kint), pointer :: q_vol_ampl(:)
499  real(kind=kreal), pointer :: q_vol_val(:)
500 
502  integer(kind=kint) :: q_suf_tot
503  integer(kind=kint), pointer :: q_suf_elem(:)
504  integer(kind=kint), pointer :: q_suf_ampl(:)
505  integer(kind=kint), pointer :: q_suf_surf(:)
506  real(kind=kreal), pointer :: q_suf_val(:)
507 
509  integer(kind=kint) :: r_suf_tot
510  integer(kind=kint), pointer :: r_suf_elem(:)
511  integer(kind=kint), pointer :: r_suf_ampl(:,:)
512  integer(kind=kint), pointer :: r_suf_surf(:)
513  real(kind=kreal), pointer :: r_suf_val(:,:)
514 
516  integer(kind=kint) :: h_suf_tot
517  integer(kind=kint), pointer :: h_suf_elem(:)
518  integer(kind=kint), pointer :: h_suf_ampl(:,:)
519  integer(kind=kint), pointer :: h_suf_surf(:)
520  real(kind=kreal), pointer :: h_suf_val(:,:)
521 
522  integer(kind=kint) :: wl_tot
523  type(tweldline), pointer :: weldline(:) => null()
524 
526  type(telemact) :: elemact
527  end type fstr_heat
528 
532  integer(kind=kint) :: idx_eqa ! implicit or explicit
533  integer(kind=kint) :: idx_resp ! time history or steady-state harmonic response analysis
534 
536  integer(kind=kint) :: n_step ! total step number of analysis
537  real(kind=kreal) :: t_start ! start time of analysis
538  real(kind=kreal) :: t_curr ! current time of analysis
539  real(kind=kreal) :: t_end ! end time of analysis
540  real(kind=kreal) :: t_delta ! time increment
541  integer(kind=kint) :: restart_nout ! output interval of restart file
542  ! (if .gt.0) restart file write
543  ! (if .lt.0) restart file read and write
544  integer(kind=kint) :: restart_nin !input number of restart file
545 
547  real(kind=kreal) :: gamma ! Newmark-beta parameter gamma
548  real(kind=kreal) :: beta ! Newmark-beta parameter beta
549 
551  integer(kind=kint) :: idx_mas ! mass matrix type
552 
554  integer(kind=kint) :: idx_dmp ! damping type
555  real(kind=kreal) :: ray_m ! Rayleigh damping parameter Rm
556  real(kind=kreal) :: ray_k ! Rayleigh damping parameter Rk
557 
559  logical :: varinitialize ! initialization flag
560 
562  integer(kind=kint) :: nout ! output interval of result
563  integer(kind=kint) :: ngrp_monit ! node of monitoring result
564  integer(kind=kint) :: nout_monit ! output interval of result monitoring
565  integer(kind=kint) :: iout_list(6) ! 0:not output 1:output
566  ! iout_list(1): displacement
567  ! iout_list(2): velocity
568  ! iout_list(3): acceleration
569  ! iout_list(4): reaction force
570  ! iout_list(5): strain
571  ! iout_list(6): stress
572 
574  real(kind=kreal), pointer :: disp(:,:)
575  real(kind=kreal), pointer :: vel(:,:)
576  real(kind=kreal), pointer :: acc(:,:)
577 
578  real(kind=kreal) :: kineticenergy
579  real(kind=kreal) :: strainenergy
580  real(kind=kreal) :: totalenergy
581 
583  real(kind=kreal), pointer :: vec1(:)
584  real(kind=kreal), pointer :: vec2(:)
585  real(kind=kreal), pointer :: vec3(:)
586 
587  integer(kind=kint) :: dynamic_iw4 = 204
588  integer(kind=kint) :: dynamic_iw5 = 205
589  integer(kind=kint) :: dynamic_iw6 = 206
590  integer(kind=kint) :: dynamic_iw7 = 207
591  integer(kind=kint) :: dynamic_iw8 = 208
592  integer(kind=kint) :: dynamic_iw9 = 209
593  integer(kind=kint) :: dynamic_iw10 = 210
594  end type fstr_dynamic
595 
597  integer(kind=kint) :: fload_ngrp_tot
598  integer(kind=kint), pointer :: fload_ngrp_grpid(:) => null()
599  integer(kind=kint), pointer :: fload_ngrp_id(:) => null()
600  integer(kind=kint), pointer :: fload_ngrp_type(:) => null()
601  integer(kind=kint), pointer :: fload_ngrp_dof(:) => null()
602  real(kind=kreal), pointer :: fload_ngrp_valre(:) => null()
603  real(kind=kreal), pointer :: fload_ngrp_valim(:) => null()
604  character(len=HECMW_FILENAME_LEN) :: eigenlog_filename
605  integer(kind=kint) :: start_mode
606  integer(kind=kint) :: end_mode
607  end type fstr_freqanalysis
608 
610  integer(kind=kint) :: nummode
611  integer(kind=kint) :: numnodedof
612  real(kind=kreal), pointer :: eigomega(:) => null()
613  real(kind=kreal), pointer :: eigvector(:,:) => null()
614  real(kind=kreal) :: rayalpha, raybeta
615  end type fstr_freqanalysis_data
616 
620  integer(kind=kint) :: nget ! Solved eigen value number (default:5)
621  integer(kind=kint) :: maxiter ! Max. Lcz iterations (default:60)
622  integer(kind=kint) :: iter ! Max. Lcz iterations (default:60)
623  real (kind=kreal) :: sigma ! 0.0
624  real (kind=kreal) :: tolerance ! Lcz tolerance (default:1.0e-8)
625  real (kind=kreal) :: totalmass
626  real (kind=kreal), pointer :: eigval(:)
627  real (kind=kreal), pointer :: eigvec(:,:)
628  real (kind=kreal), pointer :: filter(:)
629  real (kind=kreal), pointer :: mass(:)
630  real (kind=kreal), pointer :: effmass(:)
631  real (kind=kreal), pointer :: partfactor(:)
632  logical :: is_free = .false.
633  end type fstr_eigen
634 
638  integer( kind=kint ) :: dof ! == 3
639  integer( kind=kint ) :: ndof ! total dof (coupled_node_n*dof)
640  integer( kind=kint ) :: coupled_node_n
642  integer, pointer :: coupled_node(:) ! local node id sent from revocap
643  real( kind=8 ),pointer :: trac(:) ! input (x,y,z,x,y,z ... )
644  real( kind=8 ),pointer :: disp(:) ! output (x,y,z,x,y,z ... )
645  real( kind=8 ),pointer :: velo(:) ! output (x,y,z,x,y,z ... )
646  real( kind=8 ),pointer :: accel(:) ! output (x,y,z,x,y,z ... )
648  integer( kind=kint ),pointer :: index(:) ! size:total node num.
650  end type fstr_couple
651 
654  integer(kind=kint) :: egrpid
655  real( kind=kreal ) :: i
656  real( kind=kreal ) :: u
657  real( kind=kreal ) :: coe
658  real( kind=kreal ) :: v
659  integer(kind=kint) :: xyz
660  real(kind=kreal) :: n1, n2
661  real(kind=kreal) :: distol
662  real(kind=kreal) :: tstart
663  end type tweldline
664 
666  type tsection
667  !integer :: mat_ID
668  !integer :: iset
669  !integer :: orien_ID
670  !real(kind=kreal) :: thickness
671  integer :: elemopt341
672  !integer :: elemopt342
673  !integer :: elemopt351
674  !integer :: elemopt352
675  integer :: elemopt361
676  !integer :: elemopt362
677  end type tsection
678 
679 contains
680 
682  subroutine fstr_nullify_fstr_param( P )
683  implicit none
684  type( fstr_param ) :: P
685 
686  nullify( p%dtime )
687  nullify( p%etime )
688  nullify( p%dtmin )
689  nullify( p%delmax )
690  nullify( p%itmax )
691  nullify( p%eps )
692  nullify( p%global_local_ID)
693  nullify( p%timepoints )
694  end subroutine fstr_nullify_fstr_param
695 
696  subroutine fstr_nullify_fstr_solid( S )
697  implicit none
698  type( fstr_solid ) :: S
699 
700  nullify( s%BOUNDARY_ngrp_ID )
701  nullify( s%BOUNDARY_ngrp_type )
702  nullify( s%BOUNDARY_ngrp_amp )
703  nullify( s%BOUNDARY_ngrp_val)
704  nullify( s%BOUNDARY_ngrp_rotID )
705  nullify( s%BOUNDARY_ngrp_centerID )
706  nullify( s%CLOAD_ngrp_ID )
707  nullify( s%CLOAD_ngrp_DOF )
708  nullify( s%CLOAD_ngrp_amp )
709  nullify( s%CLOAD_ngrp_rotID )
710  nullify( s%CLOAD_ngrp_centerID )
711  nullify( s%CLOAD_ngrp_val )
712  nullify( s%DLOAD_ngrp_ID )
713  nullify( s%DLOAD_ngrp_LID )
714  nullify( s%DLOAD_ngrp_amp )
715  nullify( s%DLOAD_ngrp_params )
716  nullify( s%TEMP_ngrp_ID )
717  nullify( s%TEMP_ngrp_val )
718  nullify( s%SPRING_ngrp_ID )
719  nullify( s%SPRING_ngrp_DOF )
720  nullify( s%SPRING_ngrp_amp )
721  nullify( s%SPRING_ngrp_val )
722  nullify( s%STRESS )
723  nullify( s%STRAIN )
724  nullify( s%MISES )
725  nullify( s%PSTRESS )
726  nullify( s%PSTRAIN )
727  nullify( s%PSTRESS_VECT )
728  nullify( s%PSTRAIN_VECT )
729  nullify( s%REACTION )
730  nullify( s%ESTRESS )
731  nullify( s%ESTRAIN )
732  nullify( s%EMISES )
733  nullify( s%EPLSTRAIN )
734  nullify( s%EPSTRESS )
735  nullify( s%EPSTRAIN )
736  nullify( s%EPSTRESS_VECT )
737  nullify( s%EPSTRAIN_VECT )
738  nullify( s%ENQM )
739  nullify( s%GL )
740  nullify( s%GL0 )
741  nullify( s%QFORCE )
742  nullify( s%DFORCE )
743  nullify( s%VELOCITY_ngrp_GRPID )
744  nullify( s%VELOCITY_ngrp_ID )
745  nullify( s%VELOCITY_ngrp_type )
746  nullify( s%VELOCITY_ngrp_amp )
747  nullify( s%VELOCITY_ngrp_val )
748  nullify( s%ACCELERATION_ngrp_GRPID )
749  nullify( s%ACCELERATION_ngrp_ID )
750  nullify( s%ACCELERATION_ngrp_type )
751  nullify( s%ACCELERATION_ngrp_amp )
752  nullify( s%ACCELERATION_ngrp_val )
753  nullify( s%COUPLE_ngrp_ID )
754  end subroutine fstr_nullify_fstr_solid
755 
756  subroutine fstr_nullify_fstr_heat( H )
757  implicit none
758  type( fstr_heat ) :: H
759 
760  nullify( h%STEP_DLTIME )
761  nullify( h%STEP_EETIME )
762  nullify( h%STEP_DELMIN )
763  nullify( h%STEP_DELMAX )
764  nullify( h%RHO )
765  nullify( h%RHOtemp )
766  nullify( h%CP )
767  nullify( h%CPtemp )
768  nullify( h%COND )
769  nullify( h%CONDtemp )
770  nullify( h%RHOtab )
771  nullify( h%CPtab )
772  nullify( h%CONDtab )
773  nullify( h%RHOfuncA )
774  nullify( h%RHOfuncB )
775  nullify( h%CPfuncA )
776  nullify( h%CPfuncB )
777  nullify( h%CONDfuncA )
778  nullify( h%CONDfuncB )
779  nullify( h%AMPL )
780  nullify( h%AMPLtime )
781  nullify( h%AMPLtab )
782  nullify( h%AMPLfuncA )
783  nullify( h%AMPLfuncB )
784  nullify( h%TEMP0 )
785  nullify( h%TEMPC )
786  nullify( h%TEMP )
787  nullify( h%T_FIX_node )
788  nullify( h%T_FIX_ampl )
789  nullify( h%T_FIX_val )
790  nullify( h%Q_NOD_node )
791  nullify( h%Q_NOD_ampl )
792  nullify( h%Q_NOD_val )
793  nullify( h%Q_VOL_elem )
794  nullify( h%Q_VOL_ampl )
795  nullify( h%Q_VOL_val )
796  nullify( h%Q_SUF_elem )
797  nullify( h%Q_SUF_ampl )
798  nullify( h%Q_SUF_surf )
799  nullify( h%Q_SUF_val )
800  nullify( h%R_SUF_elem )
801  nullify( h%R_SUF_ampl )
802  nullify( h%R_SUF_surf )
803  nullify( h%R_SUF_val )
804  nullify( h%H_SUF_elem )
805  nullify( h%H_SUF_ampl )
806  nullify( h%H_SUF_surf )
807  nullify( h%H_SUF_val )
808  end subroutine fstr_nullify_fstr_heat
809 
810  subroutine fstr_nullify_fstr_dynamic( DY )
811  implicit none
812  type( fstr_dynamic ) :: DY
813 
814  nullify( dy%DISP )
815  nullify( dy%VEL )
816  nullify( dy%ACC )
817  nullify( dy%VEC1 )
818  nullify( dy%VEC2 )
819  nullify( dy%VEC3 )
820  end subroutine fstr_nullify_fstr_dynamic
821 
823  implicit none
824  type( fstr_freqanalysis ), intent(inout) :: f
825 
826  f%FLOAD_ngrp_tot = 0
827  nullify( f%FLOAD_ngrp_GRPID )
828  nullify( f%FLOAD_ngrp_ID )
829  nullify( f%FLOAD_ngrp_TYPE )
830  nullify( f%FLOAD_ngrp_DOF )
831  nullify( f%FLOAD_ngrp_valre )
832  nullify( f%FLOAD_ngrp_valim )
833  end subroutine fstr_nullify_fstr_freqanalysis
834 
835  subroutine fstr_nullify_fstr_eigen( E )
836  implicit none
837  type( fstr_eigen ) :: E
838 
839  nullify( e%mass )
840  end subroutine fstr_nullify_fstr_eigen
841 
842  subroutine fstr_nullify_fstr_couple( C )
843  implicit none
844  type( fstr_couple ) :: C
845 
846  nullify( c%coupled_node )
847  nullify( c%trac )
848  nullify( c%velo )
849  nullify( c%index )
850  end subroutine fstr_nullify_fstr_couple
851 
853  subroutine fstr_mat_init( hecMAT )
854  implicit none
855  type(hecmwst_matrix) :: hecMAT
856 
857  hecmat%Iarray(1) = 100 ! = nier
858  hecmat%Iarray(2) = 1 ! = method
859  hecmat%Iarray(3) = 1 ! = precond
860  hecmat%Iarray(4) = 0 ! = nset
861  hecmat%Iarray(5) = 1 ! = iterpremax
862  hecmat%Iarray(6) = 10 ! = nrest
863  hecmat%Iarray(7) = 0 ! = scaling
864  hecmat%Iarray(21)= kno ! = iterlog
865  hecmat%Iarray(22)= kno ! = timelog
866  hecmat%Iarray(31)= 0 ! = dumptype
867  hecmat%Iarray(32)= 0 ! = dumpexit
868  hecmat%Iarray(33)= 0 ! = usejad
869  hecmat%Iarray(34)= 10 ! = ncolor_in
870  hecmat%Iarray(13)= 0 ! = mpc_method
871  hecmat%Iarray(14)= 0 ! = estcond
872  hecmat%Iarray(35)= 3 ! = maxrecycle_precond
873  hecmat%Iarray(41)= 0 ! = solver_opt1
874  hecmat%Iarray(42)= 0 ! = solver_opt2
875  hecmat%Iarray(43)= 0 ! = solver_opt3
876  hecmat%Iarray(44)= 0 ! = solver_opt4
877  hecmat%Iarray(45)= 0 ! = solver_opt5
878  hecmat%Iarray(46)= 0 ! = solver_opt6
879 
880  hecmat%Rarray(1) = 1.0e-8 ! = resid
881  hecmat%Rarray(2) = 1.0 ! = sigma_diag
882  hecmat%Rarray(3) = 0.0 ! = sigma
883  hecmat%Rarray(4) = 0.1 ! = thresh
884  hecmat%Rarray(5) = 0.1 ! = filter
885  hecmat%Rarray(11)= 1.0e+4 ! = penalty
886 
887  hecmat%Iarray(96) = 0 ! nrecycle_precond
888  hecmat%Iarray(97) = kyes ! flag_numfact
889  hecmat%Iarray(98) = kyes ! flag_symbfact
890  hecmat%Iarray(99) = kyes ! indirect method
891  end subroutine fstr_mat_init
892 
893  subroutine hecmat_init( hecMAT )
894  implicit none
895  type( hecmwst_matrix ) :: hecMAT
896  integer :: ndof, nn, ierror
897  ndof = hecmat%NDOF
898  nn = ndof*ndof
899  allocate (hecmat%AL(nn*hecmat%NPL) ,stat=ierror )
900  if( ierror /= 0 ) then
901  write(*,*) "##ERROR : not enough memory"
902  write(idbg,*) 'stop due to allocation error'
903  call flush(idbg)
904  call hecmw_abort( hecmw_comm_get_comm() )
905  end if
906  allocate (hecmat%AU(nn*hecmat%NPU) ,stat=ierror )
907  if( ierror /= 0 ) then
908  write(*,*) "##ERROR : not enough memory"
909  write(idbg,*) 'stop due to allocation error'
910  call flush(idbg)
911  call hecmw_abort( hecmw_comm_get_comm() )
912  end if
913  allocate (hecmat%B(ndof*hecmat%NP) ,stat=ierror )
914  if( ierror /= 0 ) then
915  write(*,*) "##ERROR : not enough memory"
916  write(idbg,*) 'stop due to allocation error'
917  call flush(idbg)
918  call hecmw_abort( hecmw_comm_get_comm() )
919  end if
920  hecmat%B(:)=0.d0
921  allocate (hecmat%D(nn*hecmat%NP) ,stat=ierror )
922  if( ierror /= 0 ) then
923  write(*,*) "##ERROR : not enough memory"
924  write(idbg,*) 'stop due to allocation error'
925  call flush(idbg)
926  call hecmw_abort( hecmw_comm_get_comm() )
927  end if
928  allocate (hecmat%X(ndof*hecmat%NP) ,stat=ierror )
929  if( ierror /= 0 ) then
930  write(*,*) "##ERROR : not enough memory"
931  write(idbg,*) 'stop due to allocation error'
932  call flush(idbg)
933  call hecmw_abort( hecmw_comm_get_comm() )
934  end if
935  hecmat%D = 0.0d0
936  hecmat%AL = 0.0d0
937  hecmat%AU = 0.0d0
938  hecmat%B = 0.0d0
939  hecmat%X = 0.0d0
940  end subroutine hecmat_init
941 
942  subroutine hecmat_finalize( hecMAT )
943  implicit none
944  type( hecmwst_matrix ) :: hecMAT
945  integer :: ndof, nn, ierror
946  ndof = hecmat%NDOF
947  nn = ndof*ndof
948  if( associated(hecmat%AL) ) then
949  deallocate(hecmat%AL ,stat=ierror)
950  if( ierror /= 0 ) then
951  write(idbg,*) 'stop due to deallocation error'
952  call flush(idbg)
953  call hecmw_abort( hecmw_comm_get_comm())
954  end if
955  endif
956  if( associated(hecmat%AU) ) then
957  deallocate(hecmat%AU ,stat=ierror)
958  if( ierror /= 0 ) then
959  write(idbg,*) 'stop due to deallocation error'
960  call flush(idbg)
961  call hecmw_abort( hecmw_comm_get_comm())
962  end if
963  endif
964  if( associated(hecmat%B) ) then
965  deallocate(hecmat%B ,stat=ierror)
966  if( ierror /= 0 ) then
967  write(idbg,*) 'stop due to deallocation error'
968  call flush(idbg)
969  call hecmw_abort( hecmw_comm_get_comm())
970  end if
971  endif
972  if( associated(hecmat%D) ) then
973  deallocate(hecmat%D ,stat=ierror)
974  if( ierror /= 0 ) then
975  write(idbg,*) 'stop due to deallocation error'
976  call flush(idbg)
977  call hecmw_abort( hecmw_comm_get_comm())
978  end if
979  endif
980  if( associated(hecmat%X) ) then
981  deallocate(hecmat%X ,stat=ierror)
982  if( ierror /= 0 ) then
983  write(idbg,*) 'stop due to deallocation error'
984  call flush(idbg)
985  call hecmw_abort( hecmw_comm_get_comm())
986  end if
987  endif
988  if( associated(hecmat%A) ) then
989  deallocate(hecmat%A ,stat=ierror)
990  if( ierror /= 0 ) then
991  write(idbg,*) 'stop due to deallocation error'
992  call flush(idbg)
993  call hecmw_abort( hecmw_comm_get_comm())
994  end if
995  endif
996  end subroutine hecmat_finalize
997 
999  subroutine fstr_param_init( fstrPARAM, hecMESH )
1000  implicit none
1001  type(fstr_param) :: fstrPARAM
1002  type(hecmwst_local_mesh) :: hecMESH
1003  integer(kind=kint) :: i
1004  external fstr_sort_index
1005 
1006  fstrparam%solution_type = kststatic
1007  fstrparam%nlgeom = .false.
1008  fstrparam%solver_method = ksmcg
1009  fstrparam%nlsolver_method = knsmnewton
1010 
1011  !!STATIC !HEAT
1012  fstrparam%analysis_n = 0
1013  fstrparam%ref_temp = 0
1014 
1015  ! output control
1016  fstrparam%fg_echo = koff
1017  fstrparam%fg_result = koff
1018  fstrparam%fg_visual = koff
1019 
1020  ! for heat ...
1021  fstrparam%fg_neutral = koff
1022  fstrparam%fg_irres = kno
1023  fstrparam%fg_iwres = kno
1024  fstrparam%nrres = 1
1025  fstrparam%nprint = 1
1026 
1027  ! for couple
1028  fstrparam%fg_couple = 0
1029  fstrparam%fg_couple_type = 0
1030  fstrparam%fg_couple_first= 0
1031  fstrparam%fg_couple_window= 0
1032 
1033  ! for restart control
1034  fstrparam%restart_version = 5
1035 
1036  ! for contact analysis
1037  fstrparam%contact_algo = kcaslagrange ! default: Standard Lagrange
1038  fstrparam%augiter = 2 ! default augmentation iteration for ALagrange
1039 
1040  ! index table for global node ID sorting
1041 
1042  fstrparam%n_node = hecmesh%n_node;
1043  fstrparam%nn_internal = hecmesh%nn_internal;
1044  allocate( fstrparam%global_local_ID(2,hecmesh%nn_internal))
1045  do i = 1, hecmesh%nn_internal
1046  fstrparam%global_local_ID(1,i) = hecmesh%global_node_ID(i)
1047  fstrparam%global_local_ID(2,i) = i
1048  end do
1049  call fstr_sort_index( fstrparam%global_local_ID, hecmesh%nn_internal )
1050  end subroutine fstr_param_init
1051 
1052  logical function fstr_isboundaryactive( fstrSOLID, nbc, cstep )
1053  type(fstr_solid) :: fstrsolid
1054  integer, intent(in) :: nbc
1055  integer, intent(in) :: cstep
1056  fstr_isboundaryactive = .true.
1057  if( .not. associated(fstrsolid%step_ctrl) ) return
1058  if( cstep>fstrsolid%nstep_tot ) return
1059  fstr_isboundaryactive = isboundaryactive( nbc, fstrsolid%step_ctrl(cstep) )
1060  end function
1061 
1062  logical function fstr_isloadactive( fstrSOLID, nbc, cstep )
1063  type(fstr_solid) :: fstrsolid
1064  integer, intent(in) :: nbc
1065  integer, intent(in) :: cstep
1066  fstr_isloadactive = .true.
1067  if( cstep > 0 ) then
1068  if( .not. associated(fstrsolid%step_ctrl) ) return
1069  if( cstep>fstrsolid%nstep_tot ) return
1070  fstr_isloadactive = isloadactive( nbc, fstrsolid%step_ctrl(cstep) )
1071  else
1072  fstr_isloadactive = isloadactive( nbc, fstrsolid%step_ctrl_restart )
1073  endif
1074  end function
1075 
1076  logical function fstr_iscontactactive( fstrSOLID, nbc, cstep )
1077  type(fstr_solid) :: fstrsolid
1078  integer, intent(in) :: nbc
1079  integer, intent(in) :: cstep
1080  fstr_iscontactactive = .true.
1081  if( .not. associated(fstrsolid%step_ctrl) ) return
1082  if( cstep>fstrsolid%nstep_tot ) return
1083  fstr_iscontactactive = iscontactactive( nbc, fstrsolid%step_ctrl(cstep) )
1084  end function
1085 
1086  logical function fstr_isembedactive( fstrSOLID, nbc, cstep )
1087  type(fstr_solid) :: fstrsolid
1088  integer, intent(in) :: nbc
1089  integer, intent(in) :: cstep
1090  fstr_isembedactive = .true.
1091  if( .not. associated(fstrsolid%step_ctrl) ) return
1092  if( cstep>fstrsolid%nstep_tot ) return
1093  fstr_isembedactive = iscontactactive( nbc, fstrsolid%step_ctrl(cstep) )
1094  end function
1095 
1096  logical function fstr_iselemactivationactive( fstrSOLID, nbc, cstep )
1097  type(fstr_solid) :: fstrsolid
1098  integer, intent(in) :: nbc
1099  integer, intent(in) :: cstep
1101  if( .not. associated(fstrsolid%step_ctrl) ) return
1102  if( cstep>fstrsolid%nstep_tot ) return
1103  fstr_iselemactivationactive = iselemactivationactive( nbc, fstrsolid%step_ctrl(cstep) )
1104  end function
1105 
1107  subroutine get_coordsys( cdsys_ID, hecMESH, fstrSOLID, coords )
1108  integer, intent(in) :: cdsys_ID
1109  type(hecmwst_local_mesh) :: hecMESH
1110  type(fstr_solid), intent(inout) :: fstrSOLID
1111  real(kind=kreal), intent(out) :: coords(3,3)
1112  integer :: ik
1113 
1114  coords = 0.d0
1115  if( cdsys_id>0 ) then
1116  if( iscoordneeds(g_localcoordsys(cdsys_id)) ) then
1117  coords=g_localcoordsys(cdsys_id)%CoordSys
1118  else
1119  ik=g_localcoordsys(cdsys_id)%node_ID(1)
1120  coords(1,:)= hecmesh%node(3*ik-2:3*ik)+fstrsolid%unode(3*ik-2:3*ik) &
1121  + fstrsolid%dunode(3*ik-2:3*ik)
1122  ik=g_localcoordsys(cdsys_id)%node_ID(2)
1123  coords(2,:)= hecmesh%node(3*ik-2:3*ik)+fstrsolid%unode(3*ik-2:3*ik) &
1124  + fstrsolid%dunode(3*ik-2:3*ik)
1125  ik=g_localcoordsys(cdsys_id)%node_ID(3)
1126  if(ik>0) coords(3,:)= hecmesh%node(3*ik-2:3*ik)+fstrsolid%unode(3*ik-2:3*ik) &
1127  + fstrsolid%dunode(3*ik-2:3*ik)
1128  endif
1129  endif
1130  end subroutine get_coordsys
1131 
1132  subroutine fstr_set_current_config_to_mesh(hecMESH,fstrSOLID,coord)
1133  implicit none
1134  type(hecmwst_local_mesh), intent(inout) :: hecMESH
1135  type (fstr_solid), intent(in) :: fstrSOLID
1136  real(kind=kreal), intent(out) :: coord(:)
1137  integer(kind=kint) :: i
1138  if(hecmesh%n_dof == 4) return
1139  do i = 1, hecmesh%nn_internal*min(hecmesh%n_dof,3)
1140  coord(i) = hecmesh%node(i)
1141  hecmesh%node(i) = coord(i)+fstrsolid%unode(i)+fstrsolid%dunode(i)
1142  enddo
1143  end subroutine fstr_set_current_config_to_mesh
1144 
1145  subroutine fstr_recover_initial_config_to_mesh(hecMESH,fstrSOLID,coord)
1146  implicit none
1147  type(hecmwst_local_mesh), intent(inout) :: hecMESH
1148  type (fstr_solid), intent(in) :: fstrSOLID
1149  real(kind=kreal), intent(in) :: coord(:)
1150  integer(kind=kint) :: i
1151  if(hecmesh%n_dof == 4) return
1152  do i = 1, hecmesh%nn_internal*min(hecmesh%n_dof,3)
1153  hecmesh%node(i) = coord(i)
1154  enddo
1156 
1157  subroutine fstr_solid_phys_zero(phys)
1158  implicit none
1159  type(fstr_solid_physic_val), pointer :: phys
1160  phys%STRAIN = 0.0d0
1161  phys%STRESS = 0.0d0
1162  phys%MISES = 0.0d0
1163  phys%ESTRAIN = 0.0d0
1164  phys%ESTRESS = 0.0d0
1165  phys%EMISES = 0.0d0
1166  phys%EPLSTRAIN = 0.0d0
1167  phys%ENQM = 0.0d0
1168  end subroutine fstr_solid_phys_zero
1169 
1170  subroutine fstr_solid_phys_clear(fstrSOLID)
1171  implicit none
1172  type (fstr_solid) :: fstrSOLID
1173  integer(kind=kint) :: i
1174 
1175  if (associated(fstrsolid%SOLID)) then
1176  call fstr_solid_phys_zero(fstrsolid%SOLID)
1177  end if
1178  if (associated(fstrsolid%SHELL)) then
1179  call fstr_solid_phys_zero(fstrsolid%SHELL)
1180  do i=1,fstrsolid%max_lyr
1181  call fstr_solid_phys_zero(fstrsolid%SHELL%LAYER(i)%PLUS)
1182  call fstr_solid_phys_zero(fstrsolid%SHELL%LAYER(i)%MINUS)
1183  end do
1184  end if
1185  if (associated(fstrsolid%BEAM)) then
1186  call fstr_solid_phys_zero(fstrsolid%BEAM)
1187  end if
1188  end subroutine fstr_solid_phys_clear
1189 
1190  subroutine table_amp(hecMESH, fstrSOLID, cstep, jj_n_amp, time, f_t)
1191  type ( hecmwST_local_mesh ), intent(in) :: hecMESH
1192  type ( fstr_solid ), intent(in) :: fstrSOLID
1193  integer(kind=kint), intent(in) :: cstep
1194  integer(kind=kint), intent(in) :: jj_n_amp
1195  real(kind=kreal), intent(in) :: time
1196  real(kind=kreal), intent(out) :: f_t
1197 
1198  integer(kind=kint) :: i
1199  integer(kind=kint) :: jj1, jj2
1200  integer(kind=kint) :: s1, s2, flag
1201  real(kind=kreal) :: t_1, t_2, t_t, f_1, f_2, tincre
1202 
1203  s1 = 0; s2 = 0
1204 
1205  if( jj_n_amp <= 0 ) then ! Amplitude not defined
1206  if(myrank == 0) then
1207  write(imsg,*) 'internal error: amplitude table not defined'
1208  endif
1209  call hecmw_abort( hecmw_comm_get_comm() )
1210  endif
1211 
1212  tincre = fstrsolid%step_ctrl( cstep )%initdt
1213  jj1 = hecmesh%amp%amp_index(jj_n_amp - 1)
1214  jj2 = hecmesh%amp%amp_index(jj_n_amp)
1215 
1216  jj1 = jj1 + 2
1217  t_t = time-fstrsolid%step_ctrl(cstep)%starttime
1218 
1219  ! if(jj2 .eq. 0) then
1220  ! f_t = 1.0
1221  if(t_t .gt. hecmesh%amp%amp_table(jj2)) then
1222  f_t = hecmesh%amp%amp_val(jj2)
1223  else if(t_t .le. hecmesh%amp%amp_table(jj2)) then
1224  flag=0
1225  do i = jj1, jj2
1226  if(t_t .le. hecmesh%amp%amp_table(i)) then
1227  s2 = i
1228  s1 = i - 1
1229  flag = 1
1230  endif
1231  if( flag == 1 ) exit
1232  end do
1233 
1234  t_2 = hecmesh%amp%amp_table(s2)
1235  t_1 = hecmesh%amp%amp_table(s1)
1236  f_2 = hecmesh%amp%amp_val(s2)
1237  f_1 = hecmesh%amp%amp_val(s1)
1238  if( t_2-t_1 .lt. 1.0e-20) then
1239  if(myrank == 0) then
1240  write(imsg,*) 'stop due to t_2-t_1 <= 0'
1241  endif
1242  call hecmw_abort( hecmw_comm_get_comm())
1243  endif
1244  f_t = ((t_2*f_1 - t_1*f_2) + (f_2 - f_1)*t_t) / (t_2 - t_1)
1245  endif
1246 
1247  end subroutine table_amp
1248 
1249 end module m_fstr
void fstr_sort_index(int *index_data, int *n)
Definition: hecmw.f90:6
This modules defines common structures for fem analysis.
logical function iscoordneeds(coordsys)
if need to fetch global nodes' coordinate
type(tlocalcoordsys), dimension(:), pointer, save g_localcoordsys
This module defined elemact data and function.
Contact surface smoothing using Nagata patch interpolation.
This module defines common data and basic structures for analysis.
Definition: m_fstr.F90:15
integer(kind=kint), parameter kel361bbar
Definition: m_fstr.F90:80
integer(kind=kint), parameter iutb
Definition: m_fstr.F90:111
integer(kind=kint), pointer iresult
Definition: m_fstr.F90:124
subroutine fstr_solid_phys_zero(phys)
Definition: m_fstr.F90:1158
subroutine hecmat_finalize(hecMAT)
Definition: m_fstr.F90:943
subroutine get_coordsys(cdsys_ID, hecMESH, fstrSOLID, coords)
This subroutine fetch coords defined by local coordinate system.
Definition: m_fstr.F90:1108
subroutine fstr_nullify_fstr_couple(C)
Definition: m_fstr.F90:843
integer(kind=kint), parameter restart_outall
Definition: m_fstr.F90:73
integer(kind=kint), parameter ineu
Definition: m_fstr.F90:115
real(kind=kreal) eps
Definition: m_fstr.F90:144
integer(kind=kint) myrank
PARALLEL EXECUTION.
Definition: m_fstr.F90:98
integer(kind=kint), parameter kel341sesns
Definition: m_fstr.F90:77
integer(kind=kint), parameter kbcffstr
boundary condition file type (bcf)
Definition: m_fstr.F90:65
subroutine fstr_recover_initial_config_to_mesh(hecMESH, fstrSOLID, coord)
Definition: m_fstr.F90:1146
subroutine fstr_param_init(fstrPARAM, hecMESH)
Initializer of structure fstr_param.
Definition: m_fstr.F90:1000
integer(kind=kint), parameter imsg
Definition: m_fstr.F90:112
integer(kind=kint), parameter kopss_material
Definition: m_fstr.F90:133
integer(kind=kint), parameter kitrfloatingerror
Definition: m_fstr.F90:94
logical function fstr_isembedactive(fstrSOLID, nbc, cstep)
Definition: m_fstr.F90:1087
integer(kind=kint), parameter ksmcg
solver method (sm) !CAUTION : (<=100):indirect, (>100):direct
Definition: m_fstr.F90:48
real(kind=kreal), dimension(100) svrarray
Definition: m_fstr.F90:120
integer(kind=kint), parameter kstdynamic
Definition: m_fstr.F90:42
integer(kind=kint), parameter ksmgmresren
Definition: m_fstr.F90:53
integer(kind=kint), pointer ineutral
Definition: m_fstr.F90:126
subroutine fstr_nullify_fstr_heat(H)
Definition: m_fstr.F90:757
real(kind=kreal) etime
Definition: m_fstr.F90:142
logical function fstr_isloadactive(fstrSOLID, nbc, cstep)
Definition: m_fstr.F90:1063
integer(kind=kint), parameter kel341fi
section control
Definition: m_fstr.F90:76
integer(kind=kint), parameter idbg
Definition: m_fstr.F90:113
integer(kind=kint), parameter kfloadtype_surf
Definition: m_fstr.F90:85
integer(kind=kint), parameter ksmgmres
Definition: m_fstr.F90:50
integer(kind=kint), parameter kopss_solution
Definition: m_fstr.F90:132
integer(kind=kint), parameter kel361fi
Definition: m_fstr.F90:79
integer(kind=kint) opsstype
Definition: m_fstr.F90:134
integer(kind=kint), dimension(100) sviarray
SOLVER CONTROL.
Definition: m_fstr.F90:119
integer(kind=kint), parameter kon
Definition: m_fstr.F90:34
character(len=hecmw_filename_len) restartfilname
Definition: m_fstr.F90:106
integer(kind=kint), parameter kfloadcase_im
Definition: m_fstr.F90:88
subroutine fstr_mat_init(hecMAT)
Initializer of structure hecmwST_matrix.
Definition: m_fstr.F90:854
integer(kind=kint) itmax
Definition: m_fstr.F90:143
subroutine fstr_nullify_fstr_eigen(E)
Definition: m_fstr.F90:836
integer(kind=kint) nprocs
Definition: m_fstr.F90:99
integer(kind=kint), parameter ifvs
Definition: m_fstr.F90:114
logical function fstr_iscontactactive(fstrSOLID, nbc, cstep)
Definition: m_fstr.F90:1077
integer(kind=kint), pointer iwres
Definition: m_fstr.F90:128
logical function fstr_iselemactivationactive(fstrSOLID, nbc, cstep)
Definition: m_fstr.F90:1097
integer(kind=kint), parameter kitrconverged
Definition: m_fstr.F90:92
integer(kind=kint), parameter kyes
CONSTANTS general.
Definition: m_fstr.F90:32
integer(kind=kint), parameter kbcfnastran
Definition: m_fstr.F90:66
integer(kind=kint), parameter kel361ic
Definition: m_fstr.F90:81
integer(kind=kint), parameter kcaslagrange
contact analysis algorithm
Definition: m_fstr.F90:61
integer(kind=kint), parameter ilog
FILE HANDLER.
Definition: m_fstr.F90:109
integer(kind=kint), parameter ksmgpbicg
Definition: m_fstr.F90:51
integer(kind=kint), parameter knsmnewton
nonlinear solver method (nsm)
Definition: m_fstr.F90:57
integer(kind=kint), pointer nprint
Definition: m_fstr.F90:130
real(kind=kreal) dt
ANALYSIS CONTROL for NLGEOM and HEAT.
Definition: m_fstr.F90:141
integer(kind=kint), pointer nrres
Definition: m_fstr.F90:129
integer(kind=kint), parameter kststatic
Definition: m_fstr.F90:39
subroutine fstr_set_current_config_to_mesh(hecMESH, fstrSOLID, coord)
Definition: m_fstr.F90:1133
integer(kind=kint), parameter kbcinitial
Definition: m_fstr.F90:68
integer(kind=kint), parameter kfloadtype_node
Definition: m_fstr.F90:84
integer(kind=kint), parameter kstprecheck
solution type (st)
Definition: m_fstr.F90:38
integer(kind=kint), parameter knsmquasinewton
Definition: m_fstr.F90:58
integer(kind=kint), parameter kcaalagrange
Definition: m_fstr.F90:62
subroutine hecmat_init(hecMAT)
Definition: m_fstr.F90:894
integer(kind=kint), parameter kststaticeigen
Definition: m_fstr.F90:44
integer(kind=kint), parameter kstheat
Definition: m_fstr.F90:41
integer(kind=kint), parameter ista
Definition: m_fstr.F90:110
subroutine fstr_nullify_fstr_freqanalysis(f)
Definition: m_fstr.F90:823
integer(kind=kint), parameter ksmdirect
Definition: m_fstr.F90:54
subroutine table_amp(hecMESH, fstrSOLID, cstep, jj_n_amp, time, f_t)
Definition: m_fstr.F90:1191
integer(kind=kint), parameter koff
Definition: m_fstr.F90:35
real(kind=kreal), pointer ref_temp
REFTEMP.
Definition: m_fstr.F90:138
integer(kind=kint), parameter kstnzprof
Definition: m_fstr.F90:45
integer(kind=kint), parameter kbctransit
Definition: m_fstr.F90:69
subroutine fstr_solid_phys_clear(fstrSOLID)
Definition: m_fstr.F90:1171
integer(kind=kint), pointer irres
Definition: m_fstr.F90:127
integer(kind=kint), parameter ksmbicgstab
Definition: m_fstr.F90:49
character(len=hecmw_filename_len) cntfilname
FILE NAME.
Definition: m_fstr.F90:105
integer(kind=kint), pointer iecho
FLAG for ECHO/RESULT/POST.
Definition: m_fstr.F90:123
type(fstr_param), target fstrpr
GLOBAL VARIABLE INITIALIZED IN FSTR_SETUP.
Definition: m_fstr.F90:212
integer(kind=kint), parameter kel361fbar
Definition: m_fstr.F90:82
logical function fstr_isboundaryactive(fstrSOLID, nbc, cstep)
Definition: m_fstr.F90:1053
subroutine fstr_nullify_fstr_param(P)
NULL POINTER SETTING TO AVOID RUNTIME ERROR.
Definition: m_fstr.F90:683
integer(kind=kint), parameter ksteigen
Definition: m_fstr.F90:40
type(tinitialcondition), dimension(:), pointer, save g_initialcnd
Definition: m_fstr.F90:153
integer(kind=kint), pointer ivisual
Definition: m_fstr.F90:125
integer(kind=kint), parameter kitrcontinue
iteration control
Definition: m_fstr.F90:91
integer(kind=kint), parameter restart_outlast
restart type
Definition: m_fstr.F90:72
integer(kind=kint), parameter iresout
Definition: m_fstr.F90:116
integer(kind=kint), parameter ksmgmresr
Definition: m_fstr.F90:52
subroutine fstr_nullify_fstr_solid(S)
Definition: m_fstr.F90:697
subroutine fstr_nullify_fstr_dynamic(DY)
Definition: m_fstr.F90:811
integer(kind=kint), parameter kno
Definition: m_fstr.F90:33
integer(kind=kint), parameter kitrdiverged
Definition: m_fstr.F90:93
logical paracontactflag
PARALLEL CONTACT FLAG.
Definition: m_fstr.F90:102
integer(kind=kint), parameter kfloadcase_re
Definition: m_fstr.F90:87
This module manages step information.
Definition: m_out.f90:6
This module manages step information.
Definition: m_step.f90:6
logical function iscontactactive(bnd, stepinfo)
Is contact condition in this step active.
Definition: m_step.f90:119
logical function iselemactivationactive(bnd, stepinfo)
Is elemact condition in this step active.
Definition: m_step.f90:128
logical function isboundaryactive(bnd, stepinfo)
Is boundary condition in this step active.
Definition: m_step.f90:101
logical function isloadactive(bnd, stepinfo)
Is external load in this step active.
Definition: m_step.f90:110
This module manages timepoint information.
Definition: m_timepoint.f90:6
This module manages the data structure for contact calculation.
This modules defines a structure to record history dependent parameter in static analysis.
Definition: mechgauss.f90:6
Data for coupling analysis.
Definition: m_fstr.F90:636
Data for DYNAMIC ANSLYSIS (fstrDYNAMIC)
Definition: m_fstr.F90:530
Package of data used by Lanczos eigenvalue solver.
Definition: m_fstr.F90:618
Data for HEAT ANSLYSIS (fstrHEAT)
Definition: m_fstr.F90:448
FSTR INNER CONTROL PARAMETERS (fstrPARAM)
Definition: m_fstr.F90:156
Data for STATIC ANSLYSIS (fstrSOLID)
Definition: m_fstr.F90:215
Data for section control.
Definition: m_fstr.F90:666
-1:not relation, >1:index of coupled_node
Definition: m_fstr.F90:653
output control such as output filename, output frequency etc.
Definition: m_out.f90:29
Step control such as active boundary condition, convergent condition etc.
Definition: m_step.f90:24
Time points storage for output etc.
Definition: m_timepoint.f90:14
Structure to includes all info needed by contact calculation.
All data should be recorded in every elements.
Definition: mechgauss.f90:35