OpenRadioss 2025.1.11
OpenRadioss project
Loading...
Searching...
No Matches
hm_thvarent.F
Go to the documentation of this file.
1Copyright> OpenRadioss
2Copyright> Copyright (C) 1986-2025 Altair Engineering Inc.
3Copyright>
4Copyright> This program is free software: you can redistribute it and/or modify
5Copyright> it under the terms of the GNU Affero General Public License as published by
6Copyright> the Free Software Foundation, either version 3 of the License, or
7Copyright> (at your option) any later version.
8Copyright>
9Copyright> This program is distributed in the hope that it will be useful,
10Copyright> but WITHOUT ANY WARRANTY; without even the implied warranty of
11Copyright> MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12Copyright> GNU Affero General Public License for more details.
13Copyright>
14Copyright> You should have received a copy of the GNU Affero General Public License
15Copyright> along with this program. If not, see <https://www.gnu.org/licenses/>.
16Copyright>
17Copyright>
18Copyright> Commercial Alternative: Altair Radioss Software
19Copyright>
20Copyright> As an alternative to this open-source version, Altair also offers Altair Radioss
21Copyright> software under a commercial license. Contact Altair to discuss further if the
22Copyright> commercial version may interest you: https://www.altair.com/radioss/.
23!||====================================================================
24!|| hm_thvarvent ../starter/source/output/th/hm_thvarent.F
25!||--- called by ------------------------------------------------------
26!|| hm_thgrki_vent ../starter/source/output/th/hm_thgrki_vent.F
27!||--- calls -----------------------------------------------------
28!|| hm_get_int_array_index ../starter/source/devtools/hm_reader/hm_get_int_array_index.F
29!|| hm_get_intv ../starter/source/devtools/hm_reader/hm_get_intv.F
30!|| hm_get_string_index ../starter/source/devtools/hm_reader/hm_get_string_index.F
31!||--- uses -----------------------------------------------------
32!|| hm_option_read_mod ../starter/share/modules1/hm_option_read_mod.F
33!|| message_mod ../starter/share/message_module/message_mod.F
34!|| submodel_mod ../starter/share/modules1/submodel_mod.F
35!||====================================================================
36 SUBROUTINE hm_thvarvent(VARE,NV,IVAR,VARG,NVG,IVARG,NV0,ID,TITR,
37 . VARVENT,NBVENT_MAX, LSUBMODEL)
38C-----------------------------------------------
39C M o d u l e s
40C-----------------------------------------------
41 USE message_mod
42 USE submodel_mod
44 USE my_alloc_mod
46C-----------------------------------------------
47C I m p l i c i t T y p e s
48C-----------------------------------------------
49#include "implicit_f.inc"
50C-----------------------------------------------
51C C o m m o n B l o c k s
52C-----------------------------------------------
53C-----------------------------------------------
54C D u m m y A r g u m e n t
55C-----------------------------------------------
56 INTEGER NV,NVG,IVAR(*),IVARG(18,*),NV0,VARVENT(*),NBVENT_MAX,KK,IDSMAX
57 CHARACTER*10 VARE(NV),VARG(NVG)
58C-----------------------------------------------
59C L o c a l V a r i a b l e s
60C-----------------------------------------------
61 CHARACTER VAR*10
62 INTEGER JREC,TRU,N,L,M,I,J,K,OK
63 INTEGER ID,NMONV,IMONV,NLABEL
64 CHARACTER(LEN=NCHARTITLE) :: TITR
65 INTEGER NVAR
66 TYPE(submodel_data) LSUBMODEL(NSUBMOD)
67 LOGICAL IS_AVAILABLE
68 INTEGER,DIMENSION(:),ALLOCATABLE :: TAG
69C-----------------------------------------------
70C S o u r c e L i n e s
71C-----------------------------------------------
72 ! Tag must start from 0
73 ALLOCATE(tag(0:nv))
74 nvar=0
75 tru=1
76
77 DO i=1,nv
78 tag(i)=0
79 ENDDO
80
81 CALL hm_get_intv('Number_Of_Variables',nlabel,is_available,lsubmodel)
82
83 DO kk=1,nlabel
84 CALL hm_get_string_index('VAR',var,kk,10,is_available)
85 var(len_trim(var)+1:10)=' '
86 IF (var(1:3) == 'DEF') THEN
87 tag(101:min(150,100+nbvent_max*5))=1
88 varvent(1:nbvent_max*5) = 1
89 ELSEIF(var(1:5) == ' ')THEN
90 cycle
91 ELSE
92 ok=0
93 i=0
94 DO WHILE(ok==0.AND.i<nvg)
95C GENERIC VARIABLES SAVED
96 i=i+1
97 IF(var==varg(i))THEN
98 DO j=1,18
99 IF(ivarg(j,i) /= 0) THEN
100 tag(ivarg(j,i))=1
101 varvent(ivarg(j,i)-100) = 1
102 ENDIF
103 ENDDO
104 ok=1
105 ENDIF
106 ENDDO
107 i=0
108 DO WHILE(ok==0.AND.i<nv)
109C SELECTED VARIABLES SAVED
110 i=i+1
111 IF(var==vare(i))THEN
112 IF(i > 100) THEN
113 varvent(i-100)=1
114 tag(i)=1
115 ELSE
116 tag(i)=0
117 ENDIF
118 ok=1
119 ENDIF
120 ENDDO
121 ENDIF
122 ENDDO
123
124 CALL hm_get_intv('idsmax',nmonv,is_available,lsubmodel)
125 DO imonv=1,nmonv
126 CALL hm_get_int_array_index('ids',n,imonv,is_available,lsubmodel)
127 IF(n/=0)THEN
128 DO i=1,nv
129 IF(tag(i)/=0)THEN
130 nvar=nvar+1
131 ivar(nvar)=i
132 ENDIF
133 ENDDO
134 RETURN
135 ENDIF
136 ENDDO
137
138 DEALLOCATE(tag)
139
140 RETURN
141 END
subroutine hm_get_int_array_index(name, ival, index, is_available, lsubmodel)
subroutine hm_get_intv(name, ival, is_available, lsubmodel)
subroutine hm_get_string_index(name, sval, index, size, is_available)
subroutine hm_thvarvent(vare, nv, ivar, varg, nvg, ivarg, nv0, id, titr, varvent, nbvent_max, lsubmodel)
Definition hm_thvarent.F:38
#define min(a, b)
Definition macros.h:20
integer, parameter nchartitle