1 <?xml version='1.0' encoding='iso-8859-1' ?>
3 <property name="DefaultStudyID" value="1"/>
4 <objref name="CALCIUM_real" id="IDL:Ports/Calcium_Ports/Calcium_Real_Port:1.0"/>
5 <type name="string" kind="string"/>
6 <struct name="Engines/dataref">
7 <member name="ref" type="string"/>
9 <objref name="HOMARD_Boundary" id="IDL:HOMARD/HOMARD_Boundary:1.0"/>
10 <objref name="HOMARD_Cas" id="IDL:HOMARD/HOMARD_Cas:1.0"/>
11 <objref name="HOMARD_Hypothesis" id="IDL:HOMARD/HOMARD_Hypothesis:1.0"/>
12 <objref name="HOMARD_Iteration" id="IDL:HOMARD/HOMARD_Iteration:1.0"/>
13 <objref name="HOMARD_Zone" id="IDL:HOMARD/HOMARD_Zone:1.0"/>
14 <objref name="Study" id="IDL:SALOMEDS/Study:1.0"/>
15 <type name="bool" kind="bool"/>
16 <sequence name="boolvec" content="bool"/>
17 <type name="double" kind="double"/>
18 <sequence name="dblevec" content="double"/>
19 <objref name="file" id="file"/>
20 <type name="int" kind="int"/>
21 <sequence name="intvec" content="int"/>
22 <struct name="stringpair">
23 <member name="name" type="string"/>
24 <member name="value" type="string"/>
26 <sequence name="propvec" content="stringpair"/>
27 <objref name="pyobj" id="python:obj:1.0"/>
28 <sequence name="seqboolvec" content="boolvec"/>
29 <sequence name="seqdblevec" content="dblevec"/>
30 <sequence name="seqint" content="int"/>
31 <sequence name="seqintvec" content="intvec"/>
32 <sequence name="stringvec" content="string"/>
33 <sequence name="seqstringvec" content="stringvec"/>
34 <container name="DefaultContainer">
35 <property name="container_name" value="FactoryServer"/>
36 <property name="name" value="localhost"/>
38 <datanode name="DataInit">
39 <parameter name="MeshFile" type="string">
43 <bloc name="Etude_Initialisation">
44 <inline name="StudyCreation">
45 <script><code><![CDATA[
52 import HOMARD_Iteration_idl
53 import HOMARD_Hypothesis_idl
54 import HOMARD_Zone_idl
55 import HOMARD_Boundary_idl
57 clt = orbmodule.client()
58 StudyManager = clt.Resolve("/myStudyManager")
59 CurrentStudy = StudyManager.GetStudyByID(1)
61 <outport name="CurrentStudy" type="Study"/>
63 <service name="SetCurrentStudy">
64 <component>HOMARD</component>
65 <load container="DefaultContainer"/>
66 <method>SetCurrentStudy</method>
67 <inport name="theStudy" type="Study"/>
69 <control> <fromnode>StudyCreation</fromnode> <tonode>SetCurrentStudy</tonode> </control>
70 <datalink control="false">
71 <fromnode>StudyCreation</fromnode> <fromport>CurrentStudy</fromport>
72 <tonode>SetCurrentStudy</tonode> <toport>theStudy</toport>
75 <while name="Boucle_de_convergence">
76 <bloc name="Alternance_Calcul_HOMARD">
77 <inline name="Calcul">
78 <script><code><![CDATA[
82 Alternance_Calcul_HOMARD_Calcul
85 argu.append("--rep_calc=" + rep_calc)
86 argu.append("--num=%d" % numCalc)
87 argu.append("--mesh_file=" + MeshFile)
89 Script_A = Script(argu)
91 Error, message_erreur, dico_resu = Script_A.compute ()
93 dico_resu["rep_calc"] = rep_calc
96 <inport name="numCalc" type="int"/>
97 <inport name="MeshFile" type="string"/>
98 <outport name="Error" type="int"/>
99 <outport name="dico_resu" type="pyobj"/>
101 <inline name="Analyse">
102 <script><code><![CDATA[
106 NumCalcP1 = NumCalc + 1
109 Analyse_Test_Convergence
115 # If the computation failed, stop:
118 MessInfo = "Computation error # %d" % ErrCalc
122 # If the file is not defined, stop:
124 if dico_resu.has_key("FileName") :
125 FileName = dico_resu["FileName"]
127 MessInfo = "The file for the mesh is not defined."
131 # If the criterion is satisfied, stop:
133 if dico_resu.has_key("V_TEST") :
134 valeur_v = dico_resu["V_TEST"]
138 resu1.append(valeur_v)
141 rap = ( resu1[-1] - solu_m1 ) / solu_m1
142 if abs(rap) < 0.001 :
147 MessInfo = "The value for the test is not available."
151 # If the maximum number of adaptations is reached, stop:
154 if NumCalc >= MaxIter :
155 MessInfo = "The maximum number of adaptations is reached: %d" % (MaxIter+1)
161 <inport name="NumCalc" type="int"/>
162 <inport name="ErrCalc" type="int"/>
163 <inport name="dico_resu" type="pyobj"/>
164 <outport name="Error" type="int"/>
165 <outport name="NumCalcP1" type="int"/>
166 <outport name="FileName" type="string"/>
167 <outport name="MessInfo" type="string"/>
169 <switch name="Adaptation" select="0">
171 <bloc name="Arret_boucle">
172 <inline name="Arret">
173 <script><code><![CDATA[
177 <inport name="MessInfo" type="string"/>
178 <outport name="OK" type="bool"/>
179 <outport name="MeshFile" type="string"/>
180 <outport name="MessInfo" type="string"/>
185 <bloc name="Adaptation_HOMARD">
186 <switch name="HOMARD_Initialisation" select="0">
189 <service name="LastIteration">
190 <node>Etude_Initialisation.SetCurrentStudy</node>
191 <method>LastIteration</method>
192 <inport name="CaseName" type="string"/>
193 <outport name="return" type="HOMARD_Iteration"/>
195 <service name="GetHypothesis">
196 <node>Etude_Initialisation.SetCurrentStudy</node>
197 <method>GetHypothesis</method>
198 <inport name="HypoName" type="string"/>
199 <outport name="return" type="HOMARD_Hypothesis"/>
201 <control> <fromnode>LastIteration</fromnode> <tonode>GetHypothesis</tonode> </control>
206 <service name="CreateCase">
207 <node>Etude_Initialisation.SetCurrentStudy</node>
208 <method>CreateCase</method>
209 <inport name="CaseName" type="string"/>
210 <inport name="MeshName" type="string"/>
211 <inport name="FileName" type="string"/>
212 <outport name="return" type="HOMARD_Cas"/>
214 <inline name="Case_Options">
215 <script><code><![CDATA[
217 # Directory for the adaptation
219 # Associated iteration #0
220 Iter0 = Case.GetIter0()
222 <load container="DefaultContainer"/>
223 <inport name="Case" type="HOMARD_Cas"/>
224 <outport name="Iter0" type="HOMARD_Iteration"/>
226 <service name="CreateHypothesis">
227 <node>Etude_Initialisation.SetCurrentStudy</node>
228 <method>CreateHypothesis</method>
229 <inport name="HypoName" type="string"/>
230 <outport name="return" type="HOMARD_Hypothesis"/>
233 <datalink control="false">
234 <fromnode>CreateCase</fromnode> <fromport>return</fromport>
235 <tonode>Case_Options</tonode> <toport>Case</toport>
240 <inline name="HOMARD_Exec">
241 <script><code><![CDATA[
243 # Directory for the computation
249 # . Name of the hypothesis
250 # ------------------------
251 HypoName = Hypo.GetName()
255 HOMARD_Exec_Hypo_Options
257 # Name of the next iteration
258 # ==========================
259 # . Name of the previous iteration
260 LastIterName = LastIter.GetName()
261 aux = '%03d' % NumAdapt
262 # . At iteration #1, addition
264 IterName = LastIterName + "_" + aux
265 # . Then, substitution
267 IterName = LastIterName[:-3] + aux
269 # Creation of the iteration
270 # =========================
271 Iter = LastIter.NextIteration(IterName)
273 # Options of the iteration
274 # ========================
275 # . Association de l'hypothese
276 Iter.AssociateHypo(HypoName)
278 # . The name of the next mesh
279 Iter.SetMeshName(MeshName)
281 # . The file of the next mesh
282 aux = '%02d' % NumAdapt
283 MeshFile = os.path.join (DirName, "maill."+aux+".med")
284 Iter.SetMeshFile(MeshFile)
286 # . The file for the fields
287 FileName = dico_resu["FileName"]
288 Iter.SetFieldFile(FileName)
290 HOMARD_Exec_Iter_Options
294 Error = Iter.Compute(1,1)
296 # The loops stops if problem
297 # ==========================
300 MessInfo = "Error in HOMARD in the adaptation # %d" % NumAdapt
305 <load container="DefaultContainer"/>
306 <inport name="NumAdapt" type="int"/>
307 <inport name="LastIter" type="HOMARD_Iteration"/>
308 <inport name="Hypo" type="HOMARD_Hypothesis"/>
309 <inport name="dico_resu" type="pyobj"/>
310 <outport name="OK" type="bool"/>
311 <outport name="MessInfo" type="string"/>
312 <outport name="MeshFile" type="string"/>
314 <control> <fromnode>HOMARD_Initialisation</fromnode> <tonode>HOMARD_Exec</tonode> </control>
315 <datalink control="false">
316 <fromnode>HOMARD_Initialisation.default_Iter_n.LastIteration</fromnode> <fromport>return</fromport>
317 <tonode>HOMARD_Exec</tonode> <toport>LastIter</toport>
319 <datalink control="false">
320 <fromnode>HOMARD_Initialisation.p1_Iter_1.Case_Options</fromnode> <fromport>Iter0</fromport>
321 <tonode>HOMARD_Exec</tonode> <toport>LastIter</toport>
323 <datalink control="false">
324 <fromnode>HOMARD_Initialisation.default_Iter_n.GetHypothesis</fromnode> <fromport>return</fromport>
325 <tonode>HOMARD_Exec</tonode> <toport>Hypo</toport>
327 <datalink control="false">
328 <fromnode>HOMARD_Initialisation.p1_Iter_1.CreateHypothesis</fromnode> <fromport>return</fromport>
329 <tonode>HOMARD_Exec</tonode> <toport>Hypo</toport>
334 <control> <fromnode>Calcul</fromnode> <tonode>Analyse</tonode> </control>
335 <control> <fromnode>Analyse</fromnode> <tonode>Adaptation</tonode> </control>
336 <datalink control="false">
337 <fromnode>Analyse</fromnode> <fromport>Error</fromport>
338 <tonode>Adaptation</tonode> <toport>select</toport>
340 <datalink control="false">
341 <fromnode>Analyse</fromnode> <fromport>NumCalcP1</fromport>
342 <tonode>Calcul</tonode> <toport>numCalc</toport>
344 <datalink control="false">
345 <fromnode>Analyse</fromnode> <fromport>NumCalcP1</fromport>
346 <tonode>Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation</tonode> <toport>select</toport>
348 <datalink control="false">
349 <fromnode>Analyse</fromnode> <fromport>NumCalcP1</fromport>
350 <tonode>Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec</tonode> <toport>NumAdapt</toport>
352 <datalink control="false">
353 <fromnode>Analyse</fromnode> <fromport>FileName</fromport>
354 <tonode>Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.CreateCase</tonode> <toport>FileName</toport>
356 <datalink control="false">
357 <fromnode>Analyse</fromnode> <fromport>MessInfo</fromport>
358 <tonode>Adaptation.default_Arret_boucle.Arret</tonode> <toport>MessInfo</toport>
360 <datalink control="false">
361 <fromnode>Calcul</fromnode> <fromport>Error</fromport>
362 <tonode>Analyse</tonode> <toport>ErrCalc</toport>
364 <datalink control="false">
365 <fromnode>Calcul</fromnode> <fromport>dico_resu</fromport>
366 <tonode>Analyse</tonode> <toport>dico_resu</toport>
368 <datalink control="false">
369 <fromnode>Calcul</fromnode> <fromport>dico_resu</fromport>
370 <tonode>Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec</tonode> <toport>dico_resu</toport>
372 <datalink control="false">
373 <fromnode>Adaptation.default_Arret_boucle.Arret</fromnode> <fromport>MeshFile</fromport>
374 <tonode>Calcul</tonode> <toport>MeshFile</toport>
376 <datalink control="false">
377 <fromnode>Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec</fromnode> <fromport>MeshFile</fromport>
378 <tonode>Calcul</tonode> <toport>MeshFile</toport>
381 <datalink control="false">
382 <fromnode>Alternance_Calcul_HOMARD.Analyse</fromnode> <fromport>NumCalcP1</fromport>
383 <tonode>Alternance_Calcul_HOMARD.Analyse</tonode> <toport>NumCalc</toport>
386 <inline name="Bilan">
387 <script><code><![CDATA[
388 from PyQt4 import QtGui
390 app = QtGui.QApplication(sys.argv)
391 MessageBoxTitle = "Bilan"
393 MessInfo = "The convergence is reached."
394 QtGui.QMessageBox.information(None, MessageBoxTitle, MessInfo)
396 QtGui.QMessageBox.critical(None, MessageBoxTitle, MessInfo)
398 <inport name="MessInfo" type="string"/>
400 <control> <fromnode>DataInit</fromnode> <tonode>Etude_Initialisation</tonode> </control>
401 <control> <fromnode>Etude_Initialisation</fromnode> <tonode>Boucle_de_convergence</tonode> </control>
402 <control> <fromnode>Boucle_de_convergence</fromnode> <tonode>Bilan</tonode> </control>
403 <datalink control="false">
404 <fromnode>DataInit</fromnode> <fromport>MeshFile</fromport>
405 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Calcul</tonode> <toport>MeshFile</toport>
407 <datalink control="false">
408 <fromnode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.default_Arret_boucle.Arret</fromnode> <fromport>OK</fromport>
409 <tonode>Boucle_de_convergence</tonode> <toport>condition</toport>
411 <datalink control="false">
412 <fromnode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec</fromnode> <fromport>OK</fromport>
413 <tonode>Boucle_de_convergence</tonode> <toport>condition</toport>
415 <datalink control="false">
416 <fromnode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.default_Arret_boucle.Arret</fromnode> <fromport>MessInfo</fromport>
417 <tonode>Bilan</tonode> <toport>MessInfo</toport>
419 <datalink control="false">
420 <fromnode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec</fromnode> <fromport>MessInfo</fromport>
421 <tonode>Bilan</tonode> <toport>MessInfo</toport>
424 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.CreateCase</tonode><toport>CaseName</toport>
425 <value><string>Calcul</string></value>
428 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Calcul</tonode><toport>numCalc</toport>
429 <value><int>0</int></value>
432 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation</tonode><toport>select</toport>
433 <value><int>0</int></value>
436 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation</tonode><toport>select</toport>
437 <value><int>0</int></value>
440 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.default_Iter_n.LastIteration</tonode><toport>CaseName</toport>
441 <value><string>Calcul</string></value>
444 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.default_Iter_n.GetHypothesis</tonode><toport>HypoName</toport>
445 <value><string>Hypo</string></value>
448 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.CreateHypothesis</tonode><toport>HypoName</toport>
449 <value><string>Hypo</string></value>
452 <tonode>Boucle_de_convergence</tonode><toport>condition</toport>
453 <value><boolean>true</boolean></value>
456 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Analyse</tonode><toport>NumCalc</toport>
457 <value><int>0</int></value>
460 <tonode>Boucle_de_convergence.Alternance_Calcul_HOMARD.Analyse</tonode><toport>ErrCalc</toport>
461 <value><int>0</int></value>
464 <presentation name="__ROOT__" x="0" y="0" width="704" height="977" expanded="1" expx="0" expy="0" expWidth="704" expHeight="977" shownState="0"/>
465 <presentation name="DataInit" x="4" y="32" width="158" height="63" expanded="1" expx="4" expy="32" expWidth="158" expHeight="63" shownState="0"/>
466 <presentation name="Etude_Initialisation" x="175" y="32" width="158" height="38" expanded="0" expx="175" expy="32" expWidth="162.5" expHeight="40.5" shownState="1"/>
467 <presentation name="Etude_Initialisation.StudyCreation" x="0" y="0" width="158" height="36" expanded="1" expx="4" expy="32" expWidth="158" expHeight="36" shownState="2"/>
468 <presentation name="Etude_Initialisation.SetCurrentStudy" x="0" y="0" width="158" height="36" expanded="1" expx="163" expy="32" expWidth="158" expHeight="36" shownState="2"/>
469 <presentation name="Boucle_de_convergence" x="4" y="103" width="569" height="514" expanded="1" expx="4" expy="103" expWidth="569" expHeight="514" shownState="0"/>
470 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD" x="4" y="59" width="561" height="451" expanded="1" expx="10" expy="59" expWidth="561" expHeight="451" shownState="0"/>
471 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Calcul" x="4" y="32" width="158" height="90" expanded="1" expx="4" expy="32" expWidth="158" expHeight="90" shownState="0"/>
472 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Analyse" x="181" y="32" width="158" height="171" expanded="1" expx="181" expy="32" expWidth="158" expHeight="171" shownState="0"/>
473 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation" x="4" y="204" width="553" height="243" expanded="1" expx="4" expy="204" expWidth="553" expHeight="243" shownState="0"/>
474 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.default_Arret_boucle" x="4" y="59" width="166" height="153" expanded="1" expx="4" expy="59" expWidth="166" expHeight="153" shownState="0"/>
475 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.default_Arret_boucle.Arret" x="4" y="32" width="158" height="117" expanded="1" expx="4" expy="32" expWidth="158" expHeight="117" shownState="0"/>
476 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD" x="202" y="59" width="347" height="180" expanded="1" expx="202" expy="59" expWidth="347" expHeight="180" shownState="0"/>
477 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation" x="4" y="32" width="158" height="65" expanded="0" expx="4" expy="32" expWidth="167" expHeight="67.5" shownState="1"/>
478 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1" x="0" y="0" width="162.5" height="40.5" expanded="1" expx="4" expy="59" expWidth="162.5" expHeight="40.5" shownState="2"/>
479 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.CreateCase" x="0" y="0" width="158" height="36" expanded="1" expx="4" expy="32" expWidth="158" expHeight="36" shownState="2"/>
480 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.Case_Options" x="0" y="0" width="158" height="36" expanded="1" expx="163" expy="32" expWidth="158" expHeight="36" shownState="2"/>
481 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.p1_Iter_1.CreateHypothesis" x="0" y="0" width="158" height="36" expanded="1" expx="322" expy="32" expWidth="158" expHeight="36" shownState="2"/>
482 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.default_Iter_n" x="0" y="0" width="162.5" height="40.5" expanded="1" expx="4" expy="1639.5" expWidth="162.5" expHeight="40.5" shownState="2"/>
483 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.default_Iter_n.LastIteration" x="0" y="0" width="158" height="36" expanded="1" expx="4" expy="32" expWidth="158" expHeight="36" shownState="2"/>
484 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Initialisation.default_Iter_n.GetHypothesis" x="0" y="0" width="158" height="36" expanded="1" expx="163" expy="32" expWidth="158" expHeight="36" shownState="2"/>
485 <presentation name="Boucle_de_convergence.Alternance_Calcul_HOMARD.Adaptation.p0_Adaptation_HOMARD.HOMARD_Exec" x="185" y="32" width="158" height="144" expanded="1" expx="185" expy="32" expWidth="158" expHeight="144" shownState="0"/>
486 <presentation name="Bilan" x="350" y="32" width="158" height="63" expanded="1" expx="350" expy="32" expWidth="158" expHeight="63" shownState="0"/>