23 integer(itm_i4),
parameter :: iu6 = 6
25 type (type_param
) :: code_parameters
26 integer(itm_i4),
intent(out) :: return_status
28 type(tree
) :: parameter_list
29 type(element
),
pointer :: temp_pointer
30 integer(itm_i4) :: nparm, n_values
31 character(len = 132) :: cname
39 call euitm_xml_parse(code_parameters, nparm, parameter_list)
43 temp_pointer => parameter_list%first
46 cname = char2str(temp_pointer%cname)
49 temp_pointer => temp_pointer%child
52 case (
"profile_parameters")
53 temp_pointer => temp_pointer%child
56 if (
allocated(temp_pointer%cvalue)) &
57 input_type = char2str(temp_pointer%cvalue)
58 case (
"radial_coordinate")
59 if (
allocated(temp_pointer%cvalue)) &
60 radial_coordinate = char2str(temp_pointer%cvalue)
62 if (
allocated(temp_pointer%cvalue)) &
63 call char2num(temp_pointer%cvalue, hbt)
64 case (
"current_averaging")
65 if (
allocated(temp_pointer%cvalue)) &
66 current_averaging = char2str(temp_pointer%cvalue)
68 case (
"shape_parameters")
69 temp_pointer => temp_pointer%child
72 if (
allocated(temp_pointer%cvalue)) &
73 call char2num(temp_pointer%cvalue, ellip)
75 if (
allocated(temp_pointer%cvalue)) &
76 call char2num(temp_pointer%cvalue, tria)
78 if (
allocated(temp_pointer%cvalue)) &
79 call char2num(temp_pointer%cvalue, quad)
81 if (
allocated(temp_pointer%cvalue)) &
82 call char2num(temp_pointer%cvalue, par1)
84 if (
allocated(temp_pointer%cvalue)) &
85 call char2num(temp_pointer%cvalue, par2)
87 if (
allocated(temp_pointer%cvalue)) &
88 call char2num(temp_pointer%cvalue, par3)
90 if (
allocated(temp_pointer%cvalue)) &
91 call char2num(temp_pointer%cvalue, par4)
93 if (
allocated(temp_pointer%cvalue)) &
94 call char2num(temp_pointer%cvalue, isol)
96 if (
allocated(temp_pointer%cvalue)) &
97 call char2num(temp_pointer%cvalue, ias)
99 if (
allocated(temp_pointer%cvalue)) &
100 call char2num(temp_pointer%cvalue, mfm)
102 if (
allocated(temp_pointer%cvalue)) &
103 call char2num(temp_pointer%cvalue, iarc)
105 if (
allocated(temp_pointer%cvalue)) &
106 call char2num(temp_pointer%cvalue, imesh)
108 if (
allocated(temp_pointer%cvalue)) &
109 call char2num(temp_pointer%cvalue, amesh)
111 if (
allocated(temp_pointer%cvalue)) &
112 call char2num(temp_pointer%cvalue, bmesh)
113 case (
"n_acc_points")
114 if (
allocated(temp_pointer%cvalue)) &
115 call char2num(temp_pointer%cvalue, n_acc_points)
117 if (
allocated(temp_pointer%cvalue)) &
118 call scan_str2varnum(char2str(temp_pointer%cvalue), s_acc, n_values)
120 if (
allocated(temp_pointer%cvalue)) &
121 call scan_str2varnum(char2str(temp_pointer%cvalue), sig, n_values)
123 if (
allocated(temp_pointer%cvalue)) &
124 call scan_str2varnum(char2str(temp_pointer%cvalue), weights, &
127 if (
allocated(temp_pointer%cvalue)) &
128 call char2num(temp_pointer%cvalue, equidistant)
130 case (
"global_parameters")
131 temp_pointer => temp_pointer%child
134 if (
allocated(temp_pointer%cvalue)) &
135 match = char2str(temp_pointer%cvalue)
137 if (
allocated(temp_pointer%cvalue)) &
138 call char2num(temp_pointer%cvalue, eps)
140 if (
allocated(temp_pointer%cvalue)) &
141 call char2num(temp_pointer%cvalue, alfa)
143 if (
allocated(temp_pointer%cvalue)) &
144 call char2num(temp_pointer%cvalue, b)
146 if (
allocated(temp_pointer%cvalue)) &
147 call char2num(temp_pointer%cvalue, ip)
149 if (
allocated(temp_pointer%cvalue)) &
150 call char2num(temp_pointer%cvalue, q95)
152 if (
allocated(temp_pointer%cvalue)) &
153 call char2num(temp_pointer%cvalue, betap)
155 if (
allocated(temp_pointer%cvalue)) &
156 call char2num(temp_pointer%cvalue, wmhd)
158 if (
allocated(temp_pointer%cvalue)) &
159 call char2num(temp_pointer%cvalue, rvac)
161 if (
allocated(temp_pointer%cvalue)) &
162 call char2num(temp_pointer%cvalue, bvac)
164 if (
allocated(temp_pointer%cvalue)) &
165 call char2num(temp_pointer%cvalue, zeff)
167 if (
allocated(temp_pointer%cvalue)) &
168 call char2num(temp_pointer%cvalue, zn0)
170 if (
allocated(temp_pointer%cvalue)) &
171 call char2num(temp_pointer%cvalue, rpe)
173 if (
allocated(temp_pointer%cvalue)) &
174 call char2num(temp_pointer%cvalue, etaei)
176 temp_pointer => temp_pointer%child
177 if (
allocated(temp_pointer%cvalue)) &
178 call char2num(temp_pointer%cvalue, ne%shape)
179 temp_pointer => temp_pointer%sibling
180 if (
allocated(temp_pointer%cvalue)) &
181 call char2num(temp_pointer%cvalue, ne%h)
182 temp_pointer => temp_pointer%sibling
183 if (
allocated(temp_pointer%cvalue)) &
184 call char2num(temp_pointer%cvalue, ne%h_0)
185 temp_pointer => temp_pointer%sibling
186 if (
allocated(temp_pointer%cvalue)) &
187 call char2num(temp_pointer%cvalue, ne%slope)
188 temp_pointer => temp_pointer%sibling
189 if (
allocated(temp_pointer%cvalue)) &
190 call char2num(temp_pointer%cvalue, ne%psi_m)
191 temp_pointer => temp_pointer%sibling
192 if (
allocated(temp_pointer%cvalue)) &
193 call char2num(temp_pointer%cvalue, ne%delta)
194 temp_pointer => temp_pointer%sibling
195 if (
allocated(temp_pointer%cvalue)) &
196 call char2num(temp_pointer%cvalue, ne%psi_0)
197 temp_pointer => temp_pointer%sibling
198 if (
allocated(temp_pointer%cvalue)) &
199 call scan_str2num(char2str(temp_pointer%cvalue), ne%alpha, n_values)
201 temp_pointer => temp_pointer%child
202 if (
allocated(temp_pointer%cvalue)) &
203 call char2num(temp_pointer%cvalue, te%shape)
204 temp_pointer => temp_pointer%sibling
205 if (
allocated(temp_pointer%cvalue)) &
206 call char2num(temp_pointer%cvalue, te%h)
207 temp_pointer => temp_pointer%sibling
208 if (
allocated(temp_pointer%cvalue)) &
209 call char2num(temp_pointer%cvalue, te%h_0)
210 temp_pointer => temp_pointer%sibling
211 if (
allocated(temp_pointer%cvalue)) &
212 call char2num(temp_pointer%cvalue, te%slope)
213 temp_pointer => temp_pointer%sibling
214 if (
allocated(temp_pointer%cvalue)) &
215 call char2num(temp_pointer%cvalue, te%psi_m)
216 temp_pointer => temp_pointer%sibling
217 if (
allocated(temp_pointer%cvalue)) &
218 call char2num(temp_pointer%cvalue, te%delta)
219 temp_pointer => temp_pointer%sibling
220 if (
allocated(temp_pointer%cvalue)) &
221 call char2num(temp_pointer%cvalue, te%psi_0)
222 temp_pointer => temp_pointer%sibling
223 if (
allocated(temp_pointer%cvalue)) &
224 call scan_str2num(char2str(temp_pointer%cvalue), te%alpha, n_values)
226 if (
allocated(temp_pointer%cvalue)) &
227 call char2num(temp_pointer%cvalue, cpsurfin)
229 case (
"numerical_parameters")
230 temp_pointer => temp_pointer%child
233 if (
allocated(temp_pointer%cvalue)) &
234 call char2num(temp_pointer%cvalue, nr)
236 if (
allocated(temp_pointer%cvalue)) &
237 call char2num(temp_pointer%cvalue, np)
239 if (
allocated(temp_pointer%cvalue)) &
240 call char2num(temp_pointer%cvalue, nrmap)
242 if (
allocated(temp_pointer%cvalue)) &
243 call char2num(temp_pointer%cvalue, npmap)
245 if (
allocated(temp_pointer%cvalue)) &
246 call char2num(temp_pointer%cvalue, nchi)
248 if (
allocated(temp_pointer%cvalue)) &
249 call char2num(temp_pointer%cvalue, niter)
251 if (
allocated(temp_pointer%cvalue)) &
252 call char2num(temp_pointer%cvalue, nmesh)
254 if (
allocated(temp_pointer%cvalue)) &
255 call char2num(temp_pointer%cvalue, nouter)
257 if (
allocated(temp_pointer%cvalue)) &
258 call char2num(temp_pointer%cvalue, amix)
260 if (
allocated(temp_pointer%cvalue)) &
261 call char2num(temp_pointer%cvalue, errit)
263 if (
allocated(temp_pointer%cvalue)) &
264 call char2num(temp_pointer%cvalue, errcur)
266 if (
allocated(temp_pointer%cvalue)) &
267 call char2num(temp_pointer%cvalue, nbb)
269 if (
allocated(temp_pointer%cvalue)) &
270 call char2num(temp_pointer%cvalue, abb)
272 if (
allocated(temp_pointer%cvalue)) &
273 call char2num(temp_pointer%cvalue, bbb)
275 if (
allocated(temp_pointer%cvalue)) &
276 call char2num(temp_pointer%cvalue, ampl)
278 case (
"diagnostics_parameters")
279 temp_pointer => temp_pointer%child
282 if (
allocated(temp_pointer%cvalue)) &
283 call char2num(temp_pointer%cvalue, verbosity)
285 if (
allocated(temp_pointer%cvalue)) &
286 output = char2str(temp_pointer%cvalue)
287 case (
"diagnostics_on")
288 if (
allocated(temp_pointer%cvalue)) &
289 call char2num(temp_pointer%cvalue, diagnostics_on)
290 case (
"standard_output")
291 if (
allocated(temp_pointer%cvalue)) &
292 call char2num(temp_pointer%cvalue, standard_output)
293 case (
"elite_output")
294 if (
allocated(temp_pointer%cvalue)) &
295 call char2num(temp_pointer%cvalue, elite_output)
296 case (
"profiles_output")
297 if (
allocated(temp_pointer%cvalue)) &
298 call char2num(temp_pointer%cvalue, profiles_output)
299 case (
"additional_output")
300 if (
allocated(temp_pointer%cvalue)) &
301 call char2num(temp_pointer%cvalue, additional_output)
302 case (
"xmgrace_output")
303 if (
allocated(temp_pointer%cvalue)) &
304 call char2num(temp_pointer%cvalue, xmgrace_output)
306 if (
allocated(temp_pointer%cvalue)) &
307 call char2num(temp_pointer%cvalue, eqdsk_file)
309 if (
allocated(temp_pointer%cvalue)) &
310 call char2num(temp_pointer%cvalue, vec_file)
312 if (
allocated(temp_pointer%cvalue)) &
313 call char2num(temp_pointer%cvalue, edgelabe)
316 write(iu6, *)
'ERROR: invalid parameter', cname
321 if (
associated(temp_pointer%sibling))
then
322 temp_pointer => temp_pointer%sibling
325 if (
associated(temp_pointer%parent, parameter_list%first )) &
327 if (
associated(temp_pointer%parent))
then
328 temp_pointer => temp_pointer%parent
330 if (verbosity > 0)
write(iu6, *)
'ERROR: broken list.'
337 call destroy_xml_tree(parameter_list)
subroutine helena_assign_code_parameters(code_parameters, return_status)
subroutine output(NGRID, betpol, zli3)