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
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 TRU, N, I, J, 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.AND. DO WHILE(OK==0I<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.AND. DO WHILE(OK==0I<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_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
integer, parameter nchartitle
program starter
Definition starter.F:39