Télécharger cfpflu.dgibi

Retour à la liste

Numérotation des lignes :

  1. optio debu 1;
  2. * fichier : cfpflu.dgibi
  3. ************************************************************************
  4. ************************************************************************
  5. OPTI ECHO 1 ;
  6. * repertoire des fichiers "divers"
  7. DIVERS = VENV 'CASTEM_DIVERS';
  8. *
  9.  
  10. **** @ACBLM
  11. DEBPROC @ACBLM VXL*CHPOINT VYL*CHPOINT VZL*CHPOINT TAB1*TABLE ;
  12. *
  13. ********************************************************************
  14. * Procedure de changement de base. On passe de la base cartesienne *
  15. * locale de l'objet modelise a la base cartesienne du maillage. L' *
  16. * axe Y de la base locale est dirige du point de tangence vers le *
  17. * centre du plasma. Alain MOAL (juillet-aout 1995) *
  18. ********************************************************************
  19. *
  20. *--------------- VARIABLES D'ENTREE :
  21. CP = TAB1.'CENTRE_PLASMA' ;
  22. PTG = TAB1.'PT_TGPLASMA' ;
  23. SI ((VALEUR DIME) EGA 2) ;
  24. SI (EXISTE TAB1 <PLAN) ;
  25. IPLAN = TAB1.<PLAN ;
  26. SINON ;
  27. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  28. FINSI ;
  29. FINSI ;
  30. *------------------------------------
  31. *
  32. VECT0 = CP MOINS PTG ;
  33. VX = COOR 1 VECT0 ;
  34. VY = COOR 2 VECT0 ;
  35. *
  36. *---- calcul de l'angle de rotation dans le plan XY
  37. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  38. ANG1 = 0. ;
  39. SINON ;
  40. ANG1 = -1.* (ATG VX VY) ;
  41. FINSI ;
  42. *
  43. SI ((VALEUR DIME) EGA 2) ;
  44. SI (EGA IPLAN 'PHICONS');
  45. * ---- Coupe 2D a Phi constant
  46. VXL1 = VZL ;
  47. VYL1 = VYL ;
  48. VZL1 = VXL * (-1.);
  49. * ---- rotation
  50. VXM = VXL1 * (COS ANG1) + (VYL1 * (-1.) * (SIN ANG1));
  51. VYM = VXL1 * (SIN ANG1) + (VYL1 * (COS ANG1)) ;
  52. VZM = VZL1 ;
  53. FINSI ;
  54. SI (EGA IPLAN 'THETACONS');
  55. * ---- Coupe 2D a Theta constant
  56. * ---- rotation
  57. VXM = VXL * (COS ANG1) + (VYL * (-1.) * (SIN ANG1)) ;
  58. VYM = VXL * (SIN ANG1) + (VYL * (COS ANG1)) ;
  59. VZM = VZL ;
  60. FINSI;
  61. SINON ;
  62. VZ = COOR 3 VECT0 ;
  63. *
  64. * ---- calcul de l'angle de rotation dans le plan Y1Z1
  65. VX1 = VX * (COS ANG1) + (VY * (SIN ANG1)) ;
  66. VY1 = VX * (-1.) * (SIN ANG1) + (VY * (COS ANG1)) ;
  67. VZ1 = VZ ;
  68. *
  69. SI ((VY1 EGA 0.) ET (VZ1 EGA 0.)) ;
  70. ANG2 = 0. ;
  71. SINON ;
  72. ANG2 = ATG VZ1 VY1 ;
  73. FINSI ;
  74. *
  75. * ---- rotations
  76. VXL1 = VXL ;
  77. VYL1 = VYL * (COS ANG2) + (VZL * (-1.) * (SIN ANG2));
  78. VZL1 = VYL * (SIN ANG2) + (VZL * (COS ANG2)) ;
  79. *
  80. VXM = VXL1 * (COS ANG1) + (VYL1 * (-1.) * (SIN ANG1)) ;
  81. VYM = VXL1 * (SIN ANG1) + (VYL1 * (COS ANG1)) ;
  82. VZM = VZL1 ;
  83. FINSI ;
  84. FINPROC VXM VYM VZM ;
  85. **** @ACBML
  86. DEBPROC @ACBML VXM*CHPOINT VYM*CHPOINT VZM*CHPOINT TAB1*TABLE ;
  87. *
  88. **********************************************************************
  89. * Procedure de changement de base. On passe de la base cartesienne *
  90. * du maillage a la base cartesienne locale de l'objet modelise. L' *
  91. * axe Y est dirige du point de tangence vers le centre du plasma. *
  92. * Alain MOAL (juillet-aout 1995) *
  93. **********************************************************************
  94. *
  95. *--------------- VARIABLES D'ENTREE :
  96. CP = TAB1.'CENTRE_PLASMA' ;
  97. PTG = TAB1.'PT_TGPLASMA' ;
  98. SI ((VALEUR DIME) EGA 2) ;
  99. SI (EXISTE TAB1 <PLAN) ;
  100. IPLAN = TAB1.<PLAN ;
  101. SINON ;
  102. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  103. FINSI ;
  104. FINSI ;
  105. *------------------------------------
  106. *
  107. VECT0 = CP MOINS PTG ;
  108. VX = COOR 1 VECT0 ;
  109. VY = COOR 2 VECT0 ;
  110. *
  111. *---- calcul de l'angle de rotation dans le plan XY
  112. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  113. ANG1 = 0. ;
  114. SINON ;
  115. ANG1 = -1.* (ATG VX VY) ;
  116. FINSI ;
  117. *
  118. SI ((VALEUR DIME) EGA 2) ;
  119. * ---- rotation pour aligner l'axe Y avec VECT0
  120. SI (EGA IPLAN 'PHICONS');
  121. * ---- Coupe 2D a Phi constant
  122. VXL1 = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  123. VYL1 = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  124. VZL1 = VZM ;
  125. * ---- Coupe 2D a Phi constant
  126. VXL = VZL1 ;
  127. VYL = VYL1 ;
  128. VZL = VXL1 * (-1.);
  129. FINSI ;
  130. SI (EGA IPLAN 'THETACONS');
  131. * ---- Coupe 2D a Theta constant
  132. * ---- rotation
  133. VXL = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  134. VYL = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  135. VZL = VZM ;
  136. FINSI ;
  137. *
  138. SINON ;
  139. VZ = COOR 3 VECT0 ;
  140. * ---- rotation pour aligner l'axe Y avec VECT0
  141. VXM1 = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  142. VYM1 = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  143. VZM1 = VZM ;
  144. *
  145. VX1 = VX * (COS ANG1) + (VY * (SIN ANG1)) ;
  146. VY1 = VX * (-1.) * (SIN ANG1) + (VY * (COS ANG1)) ;
  147. VZ1 = VZ ;
  148. *
  149. * ---- calcul de l'angle de rotation dans le plan Y1Z1
  150. SI ((VY1 EGA 0.) ET (VZ1 EGA 0.)) ;
  151. ANG2 = 0. ;
  152. SINON ;
  153. ANG2 = ATG VZ1 VY1 ;
  154. FINSI ;
  155. *
  156. VXL = VXM1 ;
  157. VYL = VYM1 * (COS ANG2) + (VZM1 * (SIN ANG2));
  158. VZL = VYM1 * (-1.) * (SIN ANG2) + (VZM1 * (COS ANG2));
  159. *
  160. FINSI ;
  161. *MESS '>>>> @CBMLV' ; LIST VXL ; LIST VYL ; LIST VZL ;
  162. FINPROC VXL VYL VZL ;
  163.  
  164. **** @ACRLM
  165. DEBPROC @ACRLM XL*CHPOINT YL*CHPOINT ZL*CHPOINT TAB1*TABLE ;
  166. *
  167. *******************************************************************
  168. * Procedure de changement de repere. On passe du repere cartesien *
  169. * local de l'objet modelise au repere cartesien du maillage. Le *
  170. * point de tangence au plasma est l'origine du repere local et *
  171. * l'axe Y est dirige vers le centre du plasma. *
  172. * Alain MOAL (juillet-aout 1995) *
  173. *******************************************************************
  174. *
  175. *--------------- VARIABLES D'ENTREE :
  176. CP = TAB1.'CENTRE_PLASMA' ;
  177. PTG = TAB1.'PT_TGPLASMA' ;
  178. SI ((VALEUR DIME) EGA 2) ;
  179. SI (EXISTE TAB1 <PLAN) ;
  180. IPLAN = TAB1.<PLAN ;
  181. SINON ;
  182. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  183. FINSI ;
  184. FINSI ;
  185. *------------------------------------
  186. *
  187. VECT0 = CP MOINS PTG ;
  188. VX = COOR 1 VECT0 ;
  189. VY = COOR 2 VECT0 ;
  190. *
  191. *---- calcul de l'angle de rotation dans le plan XY
  192. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  193. ANG1 = 0. ;
  194. SINON ;
  195. ANG1 = -1.* (ATG VX VY) ;
  196. FINSI ;
  197. *
  198. XPTG = COOR 1 PTG ;
  199. YPTG = COOR 2 PTG ;
  200. *
  201. SI ((VALEUR DIME) EGA 2) ;
  202. SI (EGA IPLAN 'PHICONS');
  203. * ---- Coupe 2D a Phi constant
  204. XL = ZL ;
  205. ZL = ZL * 0.;
  206. * ---- rotation
  207. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  208. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  209. FINSI;
  210. SI (EGA IPLAN 'THETACONS');
  211. * ---- Coupe 2D a Theta constant
  212. * ---- rotation
  213. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  214. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  215. FINSI;
  216. * ---- changement d'origine du repere
  217. XM = XL1 + XPTG ;
  218. YM = YL1 + YPTG ;
  219. ZM = YL1 * 0. ;
  220. SINON ;
  221. VZ = COOR 3 VECT0 ;
  222. ZPTG = COOR 3 PTG ;
  223. *
  224. * ---- calcul de l'angle de rotation dans le plan Y1Z1
  225. VX1 = VX * (COS ANG1) + (VY * (SIN ANG1)) ;
  226. VY1 = VX * (-1.) * (SIN ANG1) + (VY * (COS ANG1)) ;
  227. VZ1 = VZ ;
  228. *
  229. SI ((VY1 EGA 0.) ET (VZ1 EGA 0.)) ;
  230. ANG2 = 0. ;
  231. SINON ;
  232. ANG2 = ATG VZ1 VY1 ;
  233. FINSI ;
  234. *
  235. * ---- rotations
  236. XL1 = XL ;
  237. YL1 = YL * (COS ANG2) + (ZL * (-1.) * (SIN ANG2)) ;
  238. ZL1 = YL * (SIN ANG2) + (ZL * (COS ANG2)) ;
  239. *
  240. XL2 = XL1 * (COS ANG1) + (YL1 * (-1.) * (SIN ANG1)) ;
  241. YL2 = XL1 * (SIN ANG1) + (YL1 * (COS ANG1)) ;
  242. ZL2 = ZL1 ;
  243. *
  244. * ---- changement d'origine du repere
  245. XM = XL2 + XPTG ;
  246. YM = YL2 + YPTG ;
  247. ZM = ZL2 + ZPTG ;
  248. FINSI ;
  249. FINPROC XM YM ZM ;
  250. **** @ACRML
  251. DEBPROC @ACRML XM*CHPOINT YM*CHPOINT ZM*CHPOINT TAB1*TABLE ;
  252. *
  253. *******************************************************************
  254. * Procedure de changement de repere. On passe du repere cartesien *
  255. * du maillage au repere cartesien local de l'objet modelise. Le *
  256. * point de tangence au plasma est l'origine de ce repere et l'axe *
  257. * l'axe Y final est dirige vers le centre du plasma. *
  258. * en 3D l'axe x initial doit etre l'axe toroidal *
  259. * en 2D cas PHICONS l'axe Z initial est l'axe toroidal *
  260. * en 2D cas THETACONS l'axe x initial est l'axe toroidal *
  261. * Alain MOAL (juillet-aout 1995) *
  262. *******************************************************************
  263. *
  264. *--------------- VARIABLES D'ENTREE :
  265. CP = TAB1.'CENTRE_PLASMA' ;
  266. PTG = TAB1.'PT_TGPLASMA' ;
  267. SI ((VALEUR DIME) EGA 2) ;
  268. SI (EXISTE TAB1 <PLAN) ;
  269. IPLAN = TAB1.<PLAN ;
  270. SINON ;
  271. ERRE '>>>> @CRMLC : TAB1.<PLAN n existe pas' ;
  272. FINSI ;
  273. FINSI ;
  274. *------------------------------------
  275. *
  276. VECT0 = CP MOINS PTG ;
  277. VX = COOR 1 VECT0 ;
  278. VY = COOR 2 VECT0 ;
  279. *
  280. *---- calcul de l'angle de rotation dans le plan XY
  281. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  282. ANG1 = 0. ;
  283. SINON ;
  284. ANG1 = -1.* (ATG VX VY) ;
  285. FINSI ;
  286. *
  287. XPTG = COOR 1 PTG ;
  288. YPTG = COOR 2 PTG ;
  289. *
  290. SI ((VALEUR DIME) EGA 2) ;
  291. * ---- changement d'origine du repere
  292. XM1 = XM - XPTG ;
  293. YM1 = YM - YPTG ;
  294. * ---- rotation pour aligner l'axe Y avec VECT0
  295. SI (EGA IPLAN 'PHICONS');
  296. * ---- Coupe 2D a Phi constant
  297. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  298. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  299. ZL = XM * 0. ;
  300. *
  301. ZL = XL ;
  302. XL = XL * 0.;
  303. FINSI;
  304. SI (EGA IPLAN 'THETACONS');
  305. * ---- Coupe 2D a Theta constant
  306. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  307. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  308. ZL = XM * 0. ;
  309. FINSI ;
  310. *
  311. SINON ;
  312. VZ = COOR 3 VECT0 ;
  313. ZPTG = COOR 3 PTG ;
  314. * ---- changement d'origine du repere
  315. XM1 = XM - XPTG ;
  316. YM1 = YM - YPTG ;
  317. ZM1 = ZM - ZPTG ;
  318. * ---- rotation pour aligner l'axe Y avec VECT0
  319. XM2 = XM1 * (COS ANG1) + (YM1 * (SIN ANG1)) ;
  320. YM2 = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1)) ;
  321. ZM2 = ZM1 ;
  322. *
  323. VX1 = VX * (COS ANG1) + (VY * (SIN ANG1)) ;
  324. VY1 = VX * (-1.) * (SIN ANG1) + (VY * (COS ANG1)) ;
  325. VZ1 = VZ ;
  326. *
  327. * ---- calcul de l'angle de rotation dans le plan Y1Z1
  328. SI ((VY1 EGA 0.) ET (VZ1 EGA 0.)) ;
  329. ANG2 = 0. ;
  330. SINON ;
  331. ANG2 = ATG VZ1 VY1 ;
  332. FINSI ;
  333. *
  334. XL = XM2 ;
  335. YL = YM2 * (COS ANG2) + (ZM2 * (SIN ANG2)) ;
  336. ZL = YM2 * (-1.) * (SIN ANG2) + (ZM2 * (COS ANG2)) ;
  337. *
  338. FINSI ;
  339. *MESS '>>>> @CRMLC : XL' ; LIST XL ; LIST YL ; LIST ZL ;
  340. FINPROC XL YL ZL ;
  341.  
  342. **** @AMPLI
  343. DEBPROC @AMPLI XV*CHPOINT YV*CHPOINT ZV*CHPOINT VALDIM*ENTIER MAIL0*MAILLAGE ;
  344. *
  345. *************************************************************
  346. * Procedure d'adaptation du facteur d'amplification utilise *
  347. * pour visualiser un champ de vecteur sur une geometrie. *
  348. * Alain MOAL (juillet 1995) *
  349. *************************************************************
  350. *
  351. XM = COOR 1 MAIL0 ;
  352. YM = COOR 2 MAIL0 ;
  353. SI (VALDIM EGA 2) ;
  354. ZM = XM * 0. ;
  355. SINON ;
  356. ZM = COOR 3 MAIL0 ;
  357. FINSI ;
  358. *
  359. *---- norme du vecteur
  360. VECNORM = ((XV * XV) + (YV * YV) + (ZV * ZV))**0.5 ;
  361. *
  362. *---- calcul d'une longueur caracteristique du maillage
  363. LONGCAR1 = ABS ((MAXI XM) - (MINI XM)) ;
  364. LONGCAR2 = ABS ((MAXI YM) - (MINI YM)) ;
  365. LONGCAR3 = ABS ((MAXI ZM) - (MINI ZM)) ;
  366. *
  367. SI (VALDIM EGA 2) ;
  368. LONGCAR = MINI (PROG LONGCAR1 LONGCAR2) ;
  369. SINON ;
  370. LONGCAR = MINI (PROG LONGCAR1 LONGCAR2 LONGCAR3) ;
  371. FINSI ;
  372. *
  373. AMPLI0 = LONGCAR / (MAXI VECNORM) / 10.;
  374. *
  375. FINPROC AMPLI0 ;
  376. **** @ANADES
  377.  
  378. DEBPROC @ANADES TAB1*TABLE ;
  379. *
  380. *************************************************
  381. * Procedure (inspiree de @ANALY) permettant de *
  382. * descendre les lignes de champ et de calculer *
  383. * avec une methode analytique exacte les points *
  384. * d'intersection sur le plan de reference pour *
  385. * recuperer les valeurs du flux normalise. *
  386. * Alain MOAL (Fevrier 2001) *
  387. *************************************************
  388. *
  389. MESS '---------------------------------> calling @ANADES';
  390. *
  391. *--------------- VARIABLES D'ENTREE :
  392. S_OMBRE = TAB1.LFLUX_EXTE ;
  393. S_OMBRAN = TAB1.<MAILLAGE_FN ;
  394. CHSIGN1 = TAB1.<CHAMP_SIGNE ;
  395. PASB2 = TAB1.<LONGUEUR_PAS_AVEC_TEST ;
  396. DMAX2 = TAB1.<DISTANCE_AVEC_TEST ;
  397. NBPAS2 = TAB1.<NOMBRE_PAS_AVEC_TEST ;
  398. PASB1 = TAB1.<LONGUEUR_PAS_SANS_TEST ;
  399. DMAX1 = TAB1.<DISTANCE_SANS_TEST ;
  400. NBPAS1 = TAB1.<NOMBRE_PAS_SANS_TEST ;
  401. TOL1 = 1.e-9 ;
  402. *------------------------------------
  403. *
  404. * --- PASSAGE EN TRI3 POUR LA PROCEDURE @INTSEC
  405. si (DIME(S_OMBRAN ELEM 'TYPE') EGA 2) ;
  406. stri3 = elem s_ombran tri3 ;
  407. squa4 = elem s_ombran qua4 ;
  408. squtri3 = chan squa4 tri3 ;
  409. s_ombra2 = squtri3 et stri3 ;
  410. sinon ;
  411. s_ombra2 = chan s_ombran tri3 ;
  412. finsi ;
  413. *
  414. * --- CONSTRUCTION DU MAILLAGE DES POINTS A SUIVRE
  415. MAILPTS = MANU POI1 ((chan s_ombre poi1) poin init) ;
  416. TABPTS1 = table ;
  417. TABPTS1 . 1 = (chan s_ombre poi1) poin init ;
  418. npts = 1 ;
  419. tablig1 = table ;
  420.  
  421. * --- CREATION DES 3 CHMELEM DE COORDONNEES AUX ELEMENTS
  422. TAB1.<MAILLAGE = S_OMBRA2 ;
  423. *AM*27/01/04 @RMXYZ TAB1 ;
  424. @RMCOORO TAB1 ;
  425. * --- CALCUL DES NORMALES AUX ELEMENTS SUR LE MAILLAGE OMBRANT
  426. *AM*27/01/04 @AMNORM TAB1 ;
  427. @RMNORM TAB1 ;
  428. * ---- Flux normalise sur le maillage ombrant
  429. @RMFLUN TAB1 ;
  430.  
  431. MESS ' ';
  432. MESS 'WITHOUT TEST';
  433. MESS 'Distance covered :' DMAX1 ;
  434. MESS 'Step :' PASB1 ;
  435. MESS 'Iterations number :' NBPAS1 ;
  436. MESS ' ';
  437. MESS 'WITH TEST';
  438. MESS 'Distance covered :' DMAX2 ;
  439. MESS 'Step :' PASB2 ;
  440. MESS 'Iterations number :' NBPAS2 ;
  441. MESS ' ' ;
  442.  
  443. * --- initialisation du pas
  444. I1 = 0 ;
  445. * ---initialisation de la distance de connexion
  446. CHDIST = manu chpo S_OMBRE 1 'SCAL' 0. nature discret ;
  447. * --- initialisation du flux normalise
  448. CHFNORM = manu chpo S_OMBRE 1 'SCAL' 0. nature discret ;
  449. * --- initialisation du maillage ou on va tester les intersections
  450. s_ombre2 = s_ombre ;
  451. * --- initialisation du maillage ou on va remonter les lignes
  452. mailcou = s_ombre2 et mailpts ;
  453. * ---- initialisation des distances
  454. LCOURAN1 = 0. ;
  455. LMAX1 = 0. ;
  456. * ---- coordonnees
  457. XG_OLD = COOR 1 mailcou ;
  458. YG_OLD = COOR 2 mailcou ;
  459. ZG_OLD = COOR 3 mailcou ;
  460. *
  461. * --- initialisation des lignes de champ remontees
  462. REPETER BOUPTS1 NPTS ;
  463. tablig1 . &BOUPTS1 = TABPTS1 . &BOUPTS1 ;
  464. FIN BOUPTS1 ;
  465.  
  466. *--------------------------------------------------------------
  467. *
  468. * DEBUT DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  469. *
  470. *--------------------------------------------------------------
  471. *
  472. * ----- sans test d'interception
  473. PASB0 = PASB1 ;
  474. * increment de la distance de connexion (= PAS tant qu'il n'y a pas
  475. * d'intersection)
  476.  
  477. chdist9 = manu chpo s_ombre2 1 scal pasb0 ;
  478. chfn9 = manu chpo s_ombre2 1 scal 0. ;
  479. *
  480. * initialisation a 0 des deplacements
  481. DEPX0 = XG_OLD * 0. ;
  482. DEPY0 = YG_OLD * 0. ;
  483. DEPZ0 = ZG_OLD * 0. ;
  484. DEPX0 = NOMC UX DEPX0 NATURE DIFFUS ;
  485. DEPY0 = NOMC UY DEPY0 NATURE DIFFUS ;
  486. DEPZ0 = NOMC UZ DEPZ0 NATURE DIFFUS ;
  487. TAB1.<DEPLACEMENT = DEPX0 ET DEPY0 ET DEPZ0 ;
  488.  
  489. SI (NBPAS1 NEG 0) ;
  490. MESS 'WITHOUT INTERCEPTION TEST';
  491. REPETER BOUCLE1 NBPAS1 ;
  492. I1 = I1 + 1 ;
  493. LCOURAN1 = LCOURAN1 + PASB0 ;
  494. MESS ' ';
  495. MESS 'ITERATION : ' I1 'distance covered' LCOURAN1 ;
  496.  
  497. * ---- Appel de la procedure de descente des lignes de champ
  498. XG_NEW YG_NEW ZG_NEW DEP0 = @descend XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1;
  499. FORM DEP0 ;
  500. TAB1.<DEPLACEMENT = TAB1.<DEPLACEMENT + DEP0 ;
  501.  
  502. * --- CHPOINT CONTENANT LES DISTANCES PARCOURUES AVANT INTERCEPTION
  503. chdist = chdist + CHDIST9 ;
  504.  
  505. * --- construction des lignes de champ remontees
  506. * --- Extraction des coordonnees des points a remonter
  507. * xmailpt2 = redu XG_NEW mailpts ;
  508. * ymailpt2 = redu YG_NEW mailpts ;
  509. * zmailpt2 = redu ZG_NEW mailpts ;
  510. *
  511. * --- Construction des lignes de remontee
  512. * repeter boupts2 npts ;
  513. * xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts2) ;
  514. * yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts2) ;
  515. * zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts2) ;
  516. * prem2 = xprem2 yprem2 zprem2 ;
  517. * tablig1.&boupts2 = (tablig1 . &boupts2) d 1 prem2 ;
  518. * fin boupts2 ;
  519.  
  520. * --- actualisation des champs de coordonnees pour iteration suivante
  521. XG_OLD = XG_NEW ;
  522. YG_OLD = YG_NEW ;
  523. ZG_OLD = ZG_NEW ;
  524. MENA ;
  525. FIN BOUCLE1 ;
  526. FINSI ;
  527.  
  528. MESS 'WITH INTERCEPTION TEST';
  529.  
  530. PASB0 = PASB2 ;
  531. s_ombreP = chan s_ombre poi1 ;
  532. s_ombre2 = chan s_ombre poi1 ;
  533. mailcou = s_ombre2 et mailpts ;
  534.  
  535. I2 = 0 ;
  536. I3 = 0 ;
  537. REPETER BOUCLE2 NBPAS2 ;
  538. I1 = I1 + 1 ;
  539. I3 = I3 + 1 ;
  540. SI (NBNO s_ombre2 > 0) ;
  541. * ---- si il reste des noeuds non encore intersectes
  542. LCOURAN1 = LCOURAN1 + PASB0 ;
  543. MESS ' ';
  544. MESS 'ITERATION : ' I1 'distance covered' LCOURAN1 ;
  545.  
  546. * ---- Appel de la procedure de descente des lignes de champ
  547. XG_NEW YG_NEW ZG_NEW DEP0 = @DESCEND XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1 ;
  548.  
  549. * ---- test sur les eventuels noeuds interceptes
  550. * ---- Les CHPO sont reduits sur les points de s_ombre
  551. * ---- qui n'ont pas encore ete intersectes : s_ombre2
  552. XG_OLD_R = REDU XG_OLD S_OMBRE2 ;
  553. YG_OLD_R = REDU YG_OLD S_OMBRE2 ;
  554. ZG_OLD_R = REDU ZG_OLD S_OMBRE2 ;
  555.  
  556. XG_NEW_R = REDU XG_NEW S_OMBRE2 ;
  557. YG_NEW_R = REDU YG_NEW S_OMBRE2 ;
  558. ZG_NEW_R = REDU ZG_NEW S_OMBRE2 ;
  559.  
  560. XG_OLD_R = NOMC X XG_OLD_R 'NATU' 'DIFFUS' ;
  561. YG_OLD_R = NOMC Y YG_OLD_R 'NATU' 'DIFFUS' ;
  562. ZG_OLD_R = NOMC Z ZG_OLD_R 'NATU' 'DIFFUS' ;
  563.  
  564. CH_OLD = XG_OLD_R ET YG_OLD_R ET ZG_OLD_R ;
  565.  
  566. XG_NEW_R = NOMC X XG_NEW_R 'NATU' 'DIFFUS' ;
  567. YG_NEW_R = NOMC Y YG_NEW_R 'NATU' 'DIFFUS' ;
  568. ZG_NEW_R = NOMC Z ZG_NEW_R 'NATU' 'DIFFUS' ;
  569.  
  570. CH_NEW = XG_NEW_R ET YG_NEW_R ET ZG_NEW_R ;
  571. *
  572. * ---- Test d'interception
  573. * CHDIST9 MINTER CHFN9 DEPMP1 = @INTSEC CH_OLD CH_NEW TOL1 TAB1 ;
  574. CHDIST9 MINTER CHFN9 DEPMP1 = IJET CH_OLD CH_NEW TOL1 TAB1 ;
  575.  
  576. * CHDIST9 = CHPO CONTENANT PAS POUR LES NOEUDS INTERSECTES
  577. * ET D(M,PT_REMONTE) SINON
  578.  
  579. * S_OMBRE2 contient les noeuds de s_ombre qui n'ont
  580. * pas ete intesectes
  581. * s_ombre0 contient les noeuds qui ont deja ete intersectes
  582. * minter contient les noeuds qui viennent d'etre intersectes
  583. s_ombre0 = diff s_ombreP s_ombre2 ;
  584. s_ombre2 = diff s_ombre2 MINTER ;
  585.  
  586. TITRE 'TEST : POINTS INTERCEPTES (BLANC ET JAUNE)' ;
  587. TRAC ((s_ombre2 coul roug) et MINTER et (s_ombre0 COUL JAUNE) et TAB1.<GRILLE_B et TAB1.<MAILLAGE_FN) ;
  588. *
  589. DEP01 = REDU DEP0 s_ombre2 ;
  590. DEP02 = MANU CHPO s_ombre0 3 UX 0. UY 0. UZ 0. NATURE DIFFUS ;
  591. SI ((NBNO MINTER) > 0) ;
  592. DEP0 = DEP01 ET DEP02 ET DEPMP1 ;
  593. SINON ;
  594. DEP0 = DEP01 ET DEP02 ;
  595. FINSI ;
  596.  
  597. FORM DEP0 ;
  598.  
  599. * ---- Test
  600. * i9 = 0 ;
  601. * repeter bouc01 (nbno (EXTR DEP0 'MAIL')) ;
  602. * i9 = i9 + 1 ;
  603. * list ((EXTR DEP0 'MAIL') poin i9) ;
  604. * list (redu CHFN9 ((EXTR DEP0 'MAIL') poin i9)) ;
  605. * fin bouc01 ;
  606. * TITRE 'TEST : NOEUDS SUPPORTS DU DEPLACEMENT';
  607. * TRAC (EXTR DEP0 'MAIL') ;
  608. * ---- Fin test
  609.  
  610. TAB1.<DEPLACEMENT = TAB1.<DEPLACEMENT + DEP0 ;
  611.  
  612. * ---- actualisation du maillage de descente
  613. mailcou = s_ombre2 et mailpts ;
  614.  
  615. CHSIGN1 = REDU CHSIGN1 mailcou ;
  616.  
  617. SI ((NBNO MINTER) > 0) ;
  618. mess (NBNO MINTER) 'intercepted points';
  619. LMAX1 = LCOURAN1 - pasb0 + (mini CHDIST9) ;
  620. FINSI ;
  621.  
  622. * ---- Distances parcourues avant interception
  623. chdist = chdist + CHDIST9 ;
  624. chfnorm = chfnorm + chfn9 ;
  625. mess 'mini maxi connection distance (m)' (mini (prog lmax1 (mini chdist))) lmax1 ;
  626. * list chfnorm ;
  627.  
  628. * --- construction des lignes de champ remontees
  629. * --- Extraction des coordonnees des points a remonter
  630. * xmailpt2 = redu XG_NEW mailpts ;
  631. * ymailpt2 = redu YG_NEW mailpts ;
  632. * zmailpt2 = redu ZG_NEW mailpts ;
  633. *
  634. * --- Construction des lignes de descentes
  635. * repeter boupts3 npts ;
  636. * xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts3) ;
  637. * yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts3) ;
  638. * zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts3) ;
  639. * prem2 = xprem2 yprem2 zprem2 ;
  640. * tablig1 . &boupts3 = (tablig1 . &boupts3) d 1 prem2 ;
  641. * fin boupts3 ;
  642.  
  643. * --- actualisation des champs de coordonnees pour iteration suivante
  644. XG_OLD = redu XG_NEW mailcou;
  645. YG_OLD = redu YG_NEW mailcou;
  646. ZG_OLD = redu ZG_NEW mailcou;
  647. MENA ;
  648. sinon ;
  649. SI (I2 EGA 0) ;
  650. MESS ' ';
  651. MESS 'ALL POINTS ARE INTERCEPTED' ;
  652. MESS ' ';
  653. I2 = I1 ;
  654. FINSI ;
  655. finsi ;
  656. FIN BOUCLE2 ;
  657.  
  658. *--- Sorties dans TAB1
  659. TAB1.<CHAMP_DISTANCE = CHDIST ;
  660. TAB1.<LONGUEUR_CONNEXION_MAX = LMAX1 ;
  661. TAB1.<LONGUEUR_PARCOURUE = LCOURAN1 ;
  662.  
  663. *si (exis tab1 <remontee) ;
  664. * tab1 . <remontee . <ligne = tablig1 ;
  665. *finsi ;
  666.  
  667. MESS '---------------------------------> exiting @ANADES';
  668. FINPROC chfnorm ;
  669.  
  670. **** @ANAJET
  671.  
  672. DEBPROC @ANAJET TAB1*TABLE ;
  673.  
  674. MESS '---------------------------------> calling @ANAJET';
  675. MESS 'METHODE ANALYTIQUE' ;
  676. *
  677. *--------------- VARIABLES D'ENTREE :
  678. *
  679.  
  680. S_OMBRE = TAB1.<S_OMBRE ;
  681. S_OMBRAN = TAB1.<S_OMBRANT ;
  682. IMETHOD = TAB1.<METHODE_REMONTEE ;
  683. CHSIGN1 = TAB1.<CHSIGN ;
  684.  
  685.  
  686. si (exis tab1 <remontee) ;
  687. TABPTS1 = TAB1.<REMONTEE.<POINT ;
  688. tablig1 = table ;
  689. finsi ;
  690.  
  691. PASB2 = TAB1.<PAS_AVEC_TEST ;
  692. DMAX2 = TAB1.<DIST_AVEC_TEST ;
  693. NBPAS2 = TAB1.<NBPAS2 ;
  694.  
  695. SI (EXIS TAB1 <PAS_SANS_TEST) ;
  696. PASB1 = TAB1.<PAS_SANS_TEST ;
  697. DMAX1 = TAB1.<DIST_SANS_TEST ;
  698. NBPAS1 = TAB1.<NBPAS1 ;
  699. FINSI ;
  700.  
  701.  
  702. SI (EXIS TAB1 <TOLERANCE) ;
  703. TOL1 = TAB1.<TOLERANCE ;
  704. SINON ;
  705. TOL1 = 1.e-9 ;
  706. FINSI ;
  707.  
  708. *
  709. * --- PASSAGE EN TRI3 POUR LA PROC @INTERC
  710. *
  711.  
  712. LMOT = s_ombran ELEM 'TYPE' ;
  713. ntyp = dime LMOT ;
  714. si (ntyp ega 2) ;
  715. stri3 = elem s_ombran tri3 ;
  716. squa4 = elem s_ombran qua4 ;
  717. squtri3 = chan squa4 tri3 ;
  718. s_ombra2 = squtri3 et stri3 ;
  719. sinon ;
  720. s_ombra2 = chan s_ombran tri3 ;
  721. finsi ;
  722.  
  723.  
  724. * --- CONSTRUCTION DU MAILLAGE DES POINTS A REMONTER
  725. si (exis tab1 <remontee) ;
  726. MAILPTS = MANU POI1 TABPTS1 . 1 ;
  727. NPTS = DIME TABPTS1 ;
  728. REPETER BOUPTS1 (NPTS - 1) ;
  729. MAILPTS = MAILPTS ET TABPTS1 . (&BOUPTS1 + 1) ;
  730. FIN BOUPTS1 ;
  731. sinon ;
  732. * RM 15/06/2000 MAILPTS = MANU POI1 (s_ombre poin init) ;
  733. MAILPTS = MANU POI1 ((chan s_ombre poi1) poin init) ;
  734. TABPTS1 = table ;
  735. TABPTS1 . 1 = (chan s_ombre poi1) poin init ;
  736. npts = 1 ;
  737. tablig1 = table ;
  738. finsi ;
  739.  
  740.  
  741. si (non (tab1.<reprise)) ;
  742. * --- CREATION DES 3 CHMELEM DE COORDONNEES AUX ELEMENTS
  743. * --- Remarque : ces coordonnees seront exprimees dans le repere globale
  744. TAB1.<MAILLAGE = S_OMBRA2 ;
  745. *AM*27/01/04 si (non (exis tab1 <chamx1)) ;
  746. *AM*27/01/04 @AMCOORO TAB1 ;
  747. @RMCOORO TAB1 ;
  748. *AM*27/01/04 finsi ;
  749. * --- CALCUL DES NORMALES AUX ELEMENTS SUR LE MAILLAGE OMBRANT
  750. *AM*27/01/04 si (non (exis tab1 <cosx)) ;
  751. @RMNORM TAB1 ;
  752. *AM*27/01/04 finsi ;
  753. finsi ;
  754.  
  755.  
  756. *
  757. * --- Rappel des parametres de la procedure
  758. *
  759. MESS ' ';
  760. MESS '##################################################';
  761. MESS ' ';
  762. MESS '>@ANAJET> procedure OMBJET, Rappel des parametres de calcul ';
  763. MESS ' ';
  764.  
  765. si (tab1.<reprise) ;
  766. mess 'Reprise d un calcul';
  767. mess '-------------------';
  768. finsi ;
  769.  
  770. SI (IMETHOD EGA 1) ;
  771. METH = 'methode explicite des tangentes';
  772. FINSI ;
  773. SI (IMETHOD EGA 2) ;
  774. METH = 'methode moyenne des tangentes aux extremitee';
  775. FINSI ;
  776. SI (IMETHOD EGA 3) ;
  777. METH = 'methode du point milieu';
  778. FINSI ;
  779. SI (IMETHOD EGA 4) ;
  780. METH = 'methode de reprojection';
  781. FINSI ;
  782. MESS ' ';
  783.  
  784. SI (EXIS tab1 <PAS_SANS_TEST) ;
  785. MESS 'Calcul en deux parties :';
  786. MESS ' ';
  787. MESS 'SANS TEST';
  788. MESS 'Distance remontee :' DMAX1 ;
  789. MESS 'Pas pour la remontee :' PASB1 ;
  790. MESS 'Nombre d iterations :' NBPAS1 ;
  791. MESS ' ';
  792. MESS 'AVEC TEST';
  793. MESS 'Distance remontee :' DMAX2 ;
  794. MESS 'Pas pour la remontee :' PASB2 ;
  795. MESS 'Nombre d iterations :' NBPAS2 ;
  796. SINON ;
  797. MESS 'Calcul avec test systematique :';
  798. MESS 'Distance remontee :' DMAX2 ;
  799. MESS 'Pas de remontee :' PASB2 ;
  800. MESS 'Nombre d iterations :' NBPAS2 ;
  801. FINSI ;
  802. MESS ' ' ;
  803.  
  804. *
  805. *--------------------------------------------------------------
  806. *
  807. * INITIALISATION DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  808. * --- CAS SANS REPRISE ---
  809. *--------------------------------------------------------------
  810. si (non (tab1.<reprise)) ;
  811. * --- initialisation du pas
  812. I1 = 0 ;
  813. * ---initialisation de la distance de connexion
  814. CHDIST = manu chpo S_OMBRE 1 'SCAL' 0. nature discret ;
  815. * --- initialisation du maillage ou on va tester les intersections
  816. s_ombre2 = s_ombre ;
  817. * --- initialisation du maillage ou on va remonter les lignes
  818. mailcou = s_ombre2 et mailpts ;
  819. *---- initialisation des distances
  820. LCOURAN1 = 0. ;
  821. LMAX1 = 0. ;
  822. * ---- coordonnees dans le repere du maillage
  823. XM0 = COOR 1 mailcou ;
  824. YM0 = COOR 2 mailcou ;
  825. ZM0 = COOR 3 mailcou ;
  826. *---- Coordonnees dans le repere global du tore
  827. XG_OLD = XM0 ;
  828. YG_OLD = YM0 ;
  829. ZG_OLD = ZM0 ;
  830.  
  831. *
  832. * --- initialisation des lignes de champ remontees
  833. REPETER BOUPTS1 NPTS ;
  834. tablig1 . &BOUPTS1 = TABPTS1 . &BOUPTS1 ;
  835. FIN BOUPTS1 ;
  836.  
  837. sinon ;
  838. *
  839. *--------------------------------------------------------------
  840. *
  841. * INITIALISATION DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  842. * --- CAS AVEC REPRISE ---
  843. *--------------------------------------------------------------
  844. * --- initialisation du pas
  845. I1 = tab1.<i_ombrage ;
  846. * --- initialisation de la distance de connexion
  847. CHDIST = tab1.<chdist;
  848. * --- initialisation du maillage ou on va tester les intersections
  849. s_ombre2 = tab1.<s_omb_non_inter ;
  850. * --- initialisation du maillage ou on va remonter les lignes
  851. mailcou = s_ombre2 et mailpts ;
  852.  
  853.  
  854. *---- initialisation des distances
  855. LCOURAN1 = maxi chdist ;
  856. LMAX1 = tab1.<CONNEXION_MAX ;
  857.  
  858. *---- Coordonnees dans le repere global du tore
  859. XG_OLD = exco X tab1.<CHCOOR0 ;
  860. YG_OLD = exco Y tab1.<CHCOOR0 ;
  861. ZG_OLD = exco Z tab1.<CHCOOR0 ;
  862. *
  863.  
  864. * --- initialisation des lignes de champ remontees
  865. si (exis tab1 <remontee) ;
  866. tablig1 = tab1.<remontee.<ligne ;
  867. sinon ;
  868. tablig1 . 1 = (TABPTS1 . 1) d 1 (TABPTS1.1 plus (0. 0. 0.));
  869. finsi ;
  870.  
  871. finsi ;
  872.  
  873. *--------------------------------------------------------------
  874. *
  875. * DEBUT DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  876. *
  877. *--------------------------------------------------------------
  878. *
  879. MESS ' ';
  880. MESS '##################################################';
  881. MESS ' ';
  882.  
  883. SI (EXIS TAB1 <DIST_SANS_TEST) ;
  884.  
  885. * ------------------ Boucle 1 on remonte sans test -------------------
  886. PASB0 = PASB1 ;
  887. * increment de la distance de connexion (= PAS tant qu'il n'y a pas
  888. * d'intersection)
  889. chdist9 = manu chpo s_ombre2 1 scal pasb0 ;
  890.  
  891. *
  892. * initialisation a 0 des deplacements
  893. DEPX0 = XG_OLD * 0. ;
  894. DEPY0 = YG_OLD * 0. ;
  895. DEPZ0 = ZG_OLD * 0. ;
  896. DEPX0 = NOMC UX DEPX0 NATURE DIFFUS ;
  897. DEPY0 = NOMC UY DEPY0 NATURE DIFFUS ;
  898. DEPZ0 = NOMC UZ DEPZ0 NATURE DIFFUS ;
  899. TAB1.<DEPLACE = DEPX0 ET DEPY0 ET DEPZ0 ;
  900.  
  901. MESS 'PREMIERE PARTIE DU CALCUL, SANS TEST D INTERSECTION';
  902. REPETER BOUCLE1 NBPAS1 ;
  903. I1 = I1 + 1 ;
  904. LCOURAN1 = LCOURAN1 + PASB0 ;
  905. MESS ' ';
  906. MESS 'ITERATION : ' I1 'distance remontee' LCOURAN1 ;
  907.  
  908. * ---- Appel de la procedure de remontee des lignes de champ
  909. XG_NEW YG_NEW ZG_NEW DEP0 = @remojet XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1 ;
  910. FORM DEP0 ;
  911. TAB1.<DEPLACE = TAB1.<DEPLACE + DEP0 ;
  912. TITRE 'SANS TEST, ITERATION : 'I1 ;
  913. TRAC ((s_ombre2 coul roug) ET TAB1.<GRILLE_B ET TAB1.<S_OMBRANT) ;
  914.  
  915. *--- CHPOINT CONTENANT LES DISTANCES PARCOURUES AVANT INTERCEPTION
  916. chdist = chdist + CHDIST9 ;
  917.  
  918.  
  919. *-----------------------------------------------------------------
  920. *--- construction des lignes de champ remontees
  921. * --- Extraction des coordonnees des points a remonter
  922. xmailpt1 = redu XG_NEW mailpts ;
  923. ymailpt1 = redu YG_NEW mailpts ;
  924. zmailpt1 = redu ZG_NEW mailpts ;
  925.  
  926. * --- Calcul des coordonnees des points a remonter dans le repere du maillage
  927. xmailpt2 = xmailpt1 ;
  928. ymailpt2 = ymailpt1 ;
  929. zmailpt2 = zmailpt1 ;
  930.  
  931. *
  932. * --- Construction des lignes de remontee
  933. repeter boupts2 npts ;
  934. xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts2) ;
  935. yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts2) ;
  936. zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts2) ;
  937. prem2 = xprem2 yprem2 zprem2 ;
  938. tablig1.&boupts2 = (tablig1 . &boupts2) d 1 prem2 ;
  939. fin boupts2 ;
  940. **-----------------------------------------------------------------
  941.  
  942.  
  943. * --- actualisation des champs de coordonnees pour iteration suivante
  944.  
  945. XG_OLD = XG_NEW ;
  946. YG_OLD = YG_NEW ;
  947. ZG_OLD = ZG_NEW ;
  948.  
  949. MENA ;
  950.  
  951. FIN BOUCLE1 ;
  952. * ------------------------ Fin de la boucle 1 ------------------------
  953. finsi ;
  954.  
  955.  
  956. MESS ' ';
  957. MESS '##################################################';
  958. MESS ' ';
  959.  
  960. MESS 'CALCUL AVEC TEST D INTERSECTION';
  961.  
  962. * ------------------ Boucle 2 on remonte avec test -------------------
  963. PASB0 = PASB2 ;
  964. si (non (tab1.<reprise)) ;
  965. s_ombre2 = chan s_ombre poi1 ;
  966. mailcou = s_ombre2 et mailpts ;
  967. finsi ;
  968. REPETER BOUCLE2 NBPAS2 ;
  969.  
  970. I1 = I1 + 1 ;
  971. LCOURAN1 = LCOURAN1 + PASB0 ;
  972. MESS ' ';
  973. MESS 'ITERATION : ' I1 'distance remontee' LCOURAN1 ;
  974.  
  975. * ---- Appel de la procedure de remonter des lignes de champ
  976. XG_NEW YG_NEW ZG_NEW DEP0 = @remojet XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1 ;
  977. *---- ------test sur les eventuels noeuds interceptes -----------
  978. *---- seulement s'il reste des noeuds non encore intersectes ----
  979. si (nbno s_ombre2 > 0.) ;
  980.  
  981. * --- Les CHPO sont reduits sur les points de s_ombre
  982. * --- qui n'ont pas encore ete intersectes : s_ombre2
  983.  
  984. XG_OLD_R = REDU XG_OLD S_OMBRE2 ;
  985. YG_OLD_R = REDU YG_OLD S_OMBRE2 ;
  986. ZG_OLD_R = REDU ZG_OLD S_OMBRE2 ;
  987.  
  988. XG_NEW_R = REDU XG_NEW S_OMBRE2 ;
  989. YG_NEW_R = REDU YG_NEW S_OMBRE2 ;
  990. ZG_NEW_R = REDU ZG_NEW S_OMBRE2 ;
  991.  
  992.  
  993. XG_OLD_R = NOMC X XG_OLD_R 'NATU' 'DIFFUS' ;
  994. YG_OLD_R = NOMC Y YG_OLD_R 'NATU' 'DIFFUS' ;
  995. ZG_OLD_R = NOMC Z ZG_OLD_R 'NATU' 'DIFFUS' ;
  996.  
  997. CH_OLD = XG_OLD_R ET YG_OLD_R ET ZG_OLD_R ;
  998.  
  999.  
  1000. XG_NEW_R = NOMC X XG_NEW_R 'NATU' 'DIFFUS' ;
  1001. YG_NEW_R = NOMC Y YG_NEW_R 'NATU' 'DIFFUS' ;
  1002. ZG_NEW_R = NOMC Z ZG_NEW_R 'NATU' 'DIFFUS' ;
  1003.  
  1004. CH_NEW = XG_NEW_R ET YG_NEW_R ET ZG_NEW_R ;
  1005.  
  1006. *
  1007. * --- APPEL DE LA PROCEDURE DE CALCUL DES NOEUDS INTERSECTES
  1008. *
  1009. * CHDIST9 MINTER = @INTERC CH_OLD CH_NEW TOL1 TAB1 ;
  1010. CHDIST9 MINTER = ITRC CH_OLD CH_NEW TOL1 TAB1 ;
  1011.  
  1012. * CHDIST9 = CHPO CONTENANT PAS POUR LES NOEUDS INTERSECTES
  1013. * ET D(M,PT_REMONTE) SINON
  1014.  
  1015.  
  1016. * S_OMBRE2 contient les noeuds de s_ombre qui n'ont
  1017. * pas ete intesectes.
  1018. s_ombre2 = diff s_ombre2 MINTER ;
  1019.  
  1020. * actualisation du maillage de remontee
  1021. mailcou = s_ombre2 et mailpts ;
  1022.  
  1023. CHSIGN1 = REDU CHSIGN1 mailcou ;
  1024.  
  1025. SI ((NBNO MINTER) > 0) ;
  1026. mess 'nombre de noeuds intersectes ' (NBNO MINTER) ;
  1027. LMAX1 = LCOURAN1 - pasb0 + (mini CHDIST9) ;
  1028. FINSI ;
  1029.  
  1030. * --- CHPOINT CONTENANT LES DISTANCES PARCOURUES AVANT INTERCEPTION
  1031. chdist = chdist + CHDIST9 ;
  1032. mess 'mini maxi dist connection en m' (mini (prog lmax1 (mini chdist))) lmax1 ;
  1033.  
  1034.  
  1035. finsi ;
  1036. * ------------------ fin du test d'interception ------------------
  1037.  
  1038.  
  1039.  
  1040. *-----------------------------------------------------------------
  1041. *--- construction des lignes de champ remontees
  1042. *--- Extraction des coordonnees des points a remonter
  1043. xmailpt1 = redu XG_NEW mailpts ;
  1044. ymailpt1 = redu YG_NEW mailpts ;
  1045. zmailpt1 = redu ZG_NEW mailpts ;
  1046.  
  1047. *--- Calcul des coordonnees des points a remonter dans le repere du maillage
  1048. xmailpt2 = xmailpt1 ;
  1049. ymailpt2 = ymailpt1 ;
  1050. zmailpt2 = zmailpt1 ;
  1051.  
  1052. *--- Construction des lignes de remontee
  1053. repeter boupts3 npts ;
  1054. xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts3) ;
  1055. yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts3) ;
  1056. zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts3) ;
  1057. prem2 = xprem2 yprem2 zprem2 ;
  1058. tablig1 . &boupts3 = (tablig1 . &boupts3) d 1 prem2 ;
  1059. fin boupts3 ;
  1060. *-----------------------------------------------------------------
  1061.  
  1062.  
  1063.  
  1064. * --- actualisation des champs de coordonnees pour iteration suivante
  1065.  
  1066. XG_OLD = redu XG_NEW mailcou;
  1067. YG_OLD = redu YG_NEW mailcou;
  1068. ZG_OLD = redu ZG_NEW mailcou;
  1069.  
  1070. MENA ;
  1071. FORM DEP0 ;
  1072. TAB1.<DEPLACE = TAB1.<DEPLACE + DEP0 ;
  1073. TITRE 'AVEC TEST, ITERATION : 'I1 ;
  1074. TRAC ((s_ombre2 coul roug) ET MINTER ET TAB1.<GRILLE_B ET TAB1.<S_OMBRANT) ;
  1075.  
  1076. FIN BOUCLE2 ;
  1077. * --------------------- Fin de la boucle 2 ----------------------
  1078.  
  1079.  
  1080. *--- Sorties dans TAB1
  1081.  
  1082. TAB1.<CHDIST = CHDIST ;
  1083. TAB1.<CONNEXION_MAX = LMAX1 ;
  1084. TAB1.<LONGUEUR_REMONTEE = LCOURAN1 ;
  1085.  
  1086. si (exis tab1 <remontee) ;
  1087. tab1 . <remontee . <ligne = tablig1 ;
  1088. finsi ;
  1089.  
  1090. *Sauvegardes pour reprise eventuelle
  1091. XG_OLD = nomc X XG_OLD nature discret ;
  1092. YG_OLD = nomc Y YG_OLD nature discret ;
  1093. ZG_OLD = nomc Z ZG_OLD nature discret ;
  1094. tab1.<CHCOOR0 = (XG_OLD et YG_OLD et ZG_OLD) ;
  1095. tab1.<s_omb_non_inter = s_ombre2 ;
  1096. tab1.<i_ombrage = i1 ;
  1097.  
  1098. MESS '---------------------------------> exiting @ANAJET';
  1099. FINPROC ;
  1100.  
  1101. **** @ANALY
  1102.  
  1103. DEBPROC @ANALY TAB1*TABLE ;
  1104.  
  1105. MESS '---------------------------------> calling @ANALY';
  1106. MESS 'METHODE ANALYTIQUE' ;
  1107. *
  1108. *--------------- VARIABLES D'ENTREE :
  1109. *
  1110.  
  1111. S_OMBRE = TAB1.<S_OMBRE ;
  1112. S_OMBRAN = TAB1.<S_OMBRANT ;
  1113. IMETHOD = TAB1.<METHODE_REMONTEE ;
  1114. CHSIGN1 = TAB1.<CHSIGN ;
  1115.  
  1116. TYPCAL = TAB1.<TYPE_CALCUL ;
  1117. RP = TAB1.<RP ;
  1118. RHO0 = TAB1.<RHO0 ;
  1119. RR = TAB1.<RR ;
  1120. HP = TAB1.<HP ;
  1121. EPS0 = TAB1.<EPS ;
  1122. COEFA = TAB1.<COEFA ;
  1123. COEFB = TAB1.<COEFB ;
  1124. COEFC = TAB1.<COEFC ;
  1125. NBOB = TAB1.<NBOB ;
  1126.  
  1127. si (exis tab1 <remontee) ;
  1128. TABPTS1 = TAB1.<REMONTEE.<POINT ;
  1129. tablig1 = table ;
  1130. finsi ;
  1131.  
  1132. PASB2 = TAB1.<PAS_AVEC_TEST ;
  1133. DMAX2 = TAB1.<DIST_AVEC_TEST ;
  1134. NBPAS2 = TAB1.<NBPAS2 ;
  1135.  
  1136. SI (EXIS TAB1 <PAS_SANS_TEST) ;
  1137. PASB1 = TAB1.<PAS_SANS_TEST ;
  1138. DMAX1 = TAB1.<DIST_SANS_TEST ;
  1139. NBPAS1 = TAB1.<NBPAS1 ;
  1140. FINSI ;
  1141.  
  1142.  
  1143. SI (EXIS TAB1 <TOLERANCE) ;
  1144. TOL1 = TAB1.<TOLERANCE ;
  1145. SINON ;
  1146. TOL1 = 1.e-9 ;
  1147. FINSI ;
  1148.  
  1149. *
  1150. * --- PASSAGE EN TRI3 POUR LA PROC @INTERC
  1151. *
  1152.  
  1153. LMOT = s_ombran ELEM 'TYPE' ;
  1154. ntyp = dime LMOT ;
  1155. si (ntyp ega 2) ;
  1156. stri3 = elem s_ombran tri3 ;
  1157. squa4 = elem s_ombran qua4 ;
  1158. squtri3 = chan squa4 tri3 ;
  1159. s_ombra2 = squtri3 et stri3 ;
  1160. sinon ;
  1161. s_ombra2 = chan s_ombran tri3 ;
  1162. finsi ;
  1163.  
  1164. *
  1165. * ---
  1166. *
  1167. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  1168. ISHIFT = VRAI ;
  1169. IRIPPLE = VRAI ;
  1170. FINSI ;
  1171. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  1172. ISHIFT = VRAI ;
  1173. IRIPPLE = FAUX ;
  1174. FINSI ;
  1175. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  1176. ISHIFT = FAUX ;
  1177. IRIPPLE = VRAI ;
  1178. FINSI ;
  1179. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  1180. ISHIFT = FAUX ;
  1181. IRIPPLE = FAUX ;
  1182. FINSI ;
  1183. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  1184. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  1185. FINSI ;
  1186.  
  1187.  
  1188. * --- CONSTRUCTION DU MAILLAGE DES POINTS A REMONTER
  1189. si (exis tab1 <remontee) ;
  1190. MAILPTS = MANU POI1 TABPTS1 . 1 ;
  1191. NPTS = DIME TABPTS1 ;
  1192. REPETER BOUPTS1 (NPTS - 1) ;
  1193. MAILPTS = MAILPTS ET TABPTS1 . (&BOUPTS1 + 1) ;
  1194. FIN BOUPTS1 ;
  1195. sinon ;
  1196. * RM 15/06/2000 MAILPTS = MANU POI1 (s_ombre poin init) ;
  1197. MAILPTS = MANU POI1 ((chan s_ombre poi1) poin init) ;
  1198. TABPTS1 = table ;
  1199. TABPTS1 . 1 = (chan s_ombre poi1) poin init ;
  1200. npts = 1 ;
  1201. tablig1 = table ;
  1202. finsi ;
  1203.  
  1204.  
  1205. si (non (tab1.<reprise)) ;
  1206. * --- CREATION DES 3 CHMELEM DE COORDONNEES AUX ELEMENTS
  1207. * --- Remarque : ces coordonnees seront exprimees dans le repere globale
  1208. TAB1.<MAILLAGE = S_OMBRA2 ;
  1209. si (non (exis tab1 <chamx1)) ;
  1210. @RMCOORO TAB1 ;
  1211. finsi ;
  1212. * --- CALCUL DES NORMALES AUX ELEMENTS SUR LE MAILLAGE OMBRANT
  1213. si (non (exis tab1 <cosx)) ;
  1214. @RMNORM TAB1 ;
  1215. finsi ;
  1216. finsi ;
  1217.  
  1218.  
  1219. *
  1220. * --- Rappel des parametres de la procedure
  1221. *
  1222. MESS ' ';
  1223. MESS '##################################################';
  1224. MESS ' ';
  1225. MESS '>@ANALY> procedure OMBRAGE, Rappel des parametres de calcul ';
  1226. MESS ' ';
  1227.  
  1228. si (tab1.<reprise) ;
  1229. mess 'Reprise d un calcul';
  1230. mess '-------------------';
  1231. finsi ;
  1232.  
  1233. SI (IMETHOD EGA 1) ;
  1234. METH = 'methode explicite des tangentes';
  1235. FINSI ;
  1236. SI (IMETHOD EGA 2) ;
  1237. METH = 'methode moyenne des tangentes aux extremitee';
  1238. FINSI ;
  1239. SI (IMETHOD EGA 3) ;
  1240. METH = 'methode du point milieu';
  1241. FINSI ;
  1242. SI (IMETHOD EGA 4) ;
  1243. METH = 'methode de reprojection';
  1244. FINSI ;
  1245. MESS ' ';
  1246.  
  1247. SI (EXIS tab1 <PAS_SANS_TEST) ;
  1248. MESS 'Calcul en deux parties :';
  1249. MESS ' ';
  1250. MESS 'SANS TEST';
  1251. MESS 'Distance remontee :' DMAX1 ;
  1252. MESS 'Pas pour la remontee :' PASB1 ;
  1253. MESS 'Nombre d iterations :' NBPAS1 ;
  1254. MESS ' ';
  1255. MESS 'AVEC TEST';
  1256. MESS 'Distance remontee :' DMAX2 ;
  1257. MESS 'Pas pour la remontee :' PASB2 ;
  1258. MESS 'Nombre d iterations :' NBPAS2 ;
  1259. SINON ;
  1260. MESS 'Calcul avec test systematique :';
  1261. MESS 'Distance remontee :' DMAX2 ;
  1262. MESS 'Pas de remontee :' PASB2 ;
  1263. MESS 'Nombre d iterations :' NBPAS2 ;
  1264. FINSI ;
  1265. MESS ' ' ;
  1266.  
  1267. SI ISHIFT ;
  1268. MESS 'Calcul avec shift de Safranov' ;
  1269. SINON ;
  1270. MESS 'Calcul sans shift de Safranov';
  1271. FINSI ;
  1272.  
  1273. SI IRIPPLE ;
  1274. MESS 'Calcul avec ripple du champ toroidal' ;
  1275. SINON ;
  1276. MESS 'Calcul sans ripple du champ toroidal' ;
  1277. FINSI ;
  1278.  
  1279.  
  1280. *
  1281. *--------------------------------------------------------------
  1282. *
  1283. * INITIALISATION DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  1284. * --- CAS SANS REPRISE ---
  1285. *--------------------------------------------------------------
  1286. si (non (tab1.<reprise)) ;
  1287. * --- initialisation du pas
  1288. I1 = 0 ;
  1289. * ---initialisation de la distance de connexion
  1290. CHDIST = manu chpo S_OMBRE 1 'SCAL' 0. nature discret ;
  1291. * --- initialisation du maillage ou on va tester les intersections
  1292. s_ombre2 = s_ombre ;
  1293. * --- initialisation du maillage ou on va remonter les lignes
  1294. mailcou = s_ombre2 et mailpts ;
  1295. *---- initialisation des distances
  1296. LCOURAN1 = 0. ;
  1297. LMAX1 = 0. ;
  1298. * ---- coordonnees dans le repere du maillage
  1299. XM0 = COOR 1 mailcou ;
  1300. YM0 = COOR 2 mailcou ;
  1301. ZM0 = COOR 3 mailcou ;
  1302. *---- Coordonnees dans le repere global du tore
  1303. XG_OLD YG_OLD ZG_OLD = @CRMGC XM0 YM0 ZM0 TAB1 ;
  1304. *
  1305. * --- initialisation des lignes de champ remontees
  1306. REPETER BOUPTS1 NPTS ;
  1307. tablig1 . &BOUPTS1 = TABPTS1 . &BOUPTS1 ;
  1308. FIN BOUPTS1 ;
  1309.  
  1310. sinon ;
  1311. *
  1312. *--------------------------------------------------------------
  1313. *
  1314. * INITIALISATION DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  1315. * --- CAS AVEC REPRISE ---
  1316. *--------------------------------------------------------------
  1317. * --- initialisation du pas
  1318. I1 = tab1.<i_ombrage ;
  1319. * --- initialisation de la distance de connexion
  1320. CHDIST = tab1.<chdist;
  1321. * --- initialisation du maillage ou on va tester les intersections
  1322. s_ombre2 = tab1.<s_omb_non_inter ;
  1323. * --- initialisation du maillage ou on va remonter les lignes
  1324. mailcou = s_ombre2 et mailpts ;
  1325.  
  1326.  
  1327. *---- initialisation des distances
  1328. LCOURAN1 = maxi chdist ;
  1329. LMAX1 = tab1.<CONNEXION_MAX ;
  1330.  
  1331. *---- Coordonnees dans le repere global du tore
  1332. XG_OLD = exco X tab1.<CHCOOR0 ;
  1333. YG_OLD = exco Y tab1.<CHCOOR0 ;
  1334. ZG_OLD = exco Z tab1.<CHCOOR0 ;
  1335. *
  1336.  
  1337. * --- initialisation des lignes de champ remontees
  1338. si (exis tab1 <remontee) ;
  1339. tablig1 = tab1.<remontee.<ligne ;
  1340. sinon ;
  1341. tablig1 . 1 = (TABPTS1 . 1) d 1 (TABPTS1.1 plus (0. 0. 0.));
  1342. finsi ;
  1343.  
  1344. finsi ;
  1345.  
  1346. *--------------------------------------------------------------
  1347. *
  1348. * DEBUT DE LA BOUCLE DE REMONTEE ITERATIVE DES LIGNES DE CHAMP
  1349. *
  1350. *--------------------------------------------------------------
  1351. *
  1352. MESS ' ';
  1353. MESS '##################################################';
  1354. MESS ' ';
  1355.  
  1356. SI (EXIS TAB1 <DIST_SANS_TEST) ;
  1357.  
  1358. * ------------------ Boucle 1 on remonte sans test -------------------
  1359. PASB0 = PASB1 ;
  1360. * increment de la distance de connexion (= PAS tant qu'il n'y a pas
  1361. * d'intersection)
  1362. chdist9 = manu chpo s_ombre2 1 scal pasb0 ;
  1363.  
  1364. MESS 'PREMIERE PARTIE DU CALCUL, SANS TEST D INTERSECTION';
  1365. REPETER BOUCLE1 NBPAS1 ;
  1366. I1 = I1 + 1 ;
  1367. LCOURAN1 = LCOURAN1 + PASB0 ;
  1368. MESS ' ';
  1369. MESS 'ITERATION : ' I1 'distance remontee' LCOURAN1 ;
  1370.  
  1371. * ---- Appel de la procedure de remontee des lignes de champ
  1372. XG_NEW YG_NEW ZG_NEW = @remonte XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1 ;
  1373.  
  1374. *--- CHPOINT CONTENANT LES DISTANCES PARCOURUES AVANT INTERCEPTION
  1375. chdist = chdist + CHDIST9 ;
  1376.  
  1377.  
  1378. *-----------------------------------------------------------------
  1379. *--- construction des lignes de champ remontees
  1380. * --- Extraction des coordonnees des points a remonter
  1381. xmailpt1 = redu XG_NEW mailpts ;
  1382. ymailpt1 = redu YG_NEW mailpts ;
  1383. zmailpt1 = redu ZG_NEW mailpts ;
  1384.  
  1385. * --- Calcul des coordonnees des points a remonter dans le repere du maillage
  1386. xmailpt2 ymailpt2 zmailpt2 = @crgmc xmailpt1 ymailpt1 zmailpt1 tab1 ;
  1387. *
  1388. * --- Construction des lignes de remontee
  1389. repeter boupts2 npts ;
  1390. xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts2) ;
  1391. yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts2) ;
  1392. zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts2) ;
  1393. prem2 = xprem2 yprem2 zprem2 ;
  1394. tablig1.&boupts2 = (tablig1 . &boupts2) d 1 prem2 ;
  1395. fin boupts2 ;
  1396. **-----------------------------------------------------------------
  1397.  
  1398.  
  1399. * --- actualisation des champs de coordonnees pour iteration suivante
  1400.  
  1401. XG_OLD = XG_NEW ;
  1402. YG_OLD = YG_NEW ;
  1403. ZG_OLD = ZG_NEW ;
  1404.  
  1405. MENA ;
  1406.  
  1407. FIN BOUCLE1 ;
  1408. * ------------------------ Fin de la boucle 1 ------------------------
  1409. finsi ;
  1410.  
  1411.  
  1412. MESS ' ';
  1413. MESS '##################################################';
  1414. MESS ' ';
  1415.  
  1416. MESS 'CALCUL AVEC TEST D INTERSECTION';
  1417.  
  1418. * ------------------ Boucle 2 on remonte avec test -------------------
  1419. PASB0 = PASB2 ;
  1420. si (non (tab1.<reprise)) ;
  1421. s_ombre2 = chan s_ombre poi1 ;
  1422. mailcou = s_ombre2 et mailpts ;
  1423. finsi ;
  1424. REPETER BOUCLE2 NBPAS2 ;
  1425.  
  1426. I1 = I1 + 1 ;
  1427. LCOURAN1 = LCOURAN1 + PASB0 ;
  1428. MESS ' ';
  1429. MESS 'ITERATION : ' I1 'distance remontee' LCOURAN1 ;
  1430.  
  1431. * ---- Appel de la procedure de remonter des lignes de champ
  1432. XG_NEW YG_NEW ZG_NEW = @remonte XG_OLD YG_OLD ZG_OLD PASB0 CHSIGN1 TAB1 ;
  1433. *---- ------test sur les eventuels noeuds interceptes -----------
  1434. *---- seulement s'il reste des noeuds non encore intersectes ----
  1435. si (nbno s_ombre2 > 0.) ;
  1436.  
  1437. * --- Les CHPO sont reduits sur les points de s_ombre
  1438. * --- qui n'ont pas encore ete intersectes : s_ombre2
  1439.  
  1440. XG_OLD_R = REDU XG_OLD S_OMBRE2 ;
  1441. YG_OLD_R = REDU YG_OLD S_OMBRE2 ;
  1442. ZG_OLD_R = REDU ZG_OLD S_OMBRE2 ;
  1443.  
  1444. XG_NEW_R = REDU XG_NEW S_OMBRE2 ;
  1445. YG_NEW_R = REDU YG_NEW S_OMBRE2 ;
  1446. ZG_NEW_R = REDU ZG_NEW S_OMBRE2 ;
  1447.  
  1448.  
  1449. XG_OLD_R = NOMC X XG_OLD_R 'NATU' 'DIFFUS' ;
  1450. YG_OLD_R = NOMC Y YG_OLD_R 'NATU' 'DIFFUS' ;
  1451. ZG_OLD_R = NOMC Z ZG_OLD_R 'NATU' 'DIFFUS' ;
  1452.  
  1453. CH_OLD = XG_OLD_R ET YG_OLD_R ET ZG_OLD_R ;
  1454.  
  1455.  
  1456. XG_NEW_R = NOMC X XG_NEW_R 'NATU' 'DIFFUS' ;
  1457. YG_NEW_R = NOMC Y YG_NEW_R 'NATU' 'DIFFUS' ;
  1458. ZG_NEW_R = NOMC Z ZG_NEW_R 'NATU' 'DIFFUS' ;
  1459.  
  1460. CH_NEW = XG_NEW_R ET YG_NEW_R ET ZG_NEW_R ;
  1461.  
  1462. *
  1463. * --- APPEL DE LA PROCEDURE DE CALCUL DES NOEUDS INTERSECTES
  1464. *
  1465. * CHDIST9 MINTER = @INTERC CH_OLD CH_NEW TOL1 TAB1 ;
  1466. CHDIST9 MINTER = ITRC CH_OLD CH_NEW TOL1 TAB1 ;
  1467.  
  1468. * CHDIST9 = CHPO CONTENANT PAS POUR LES NOEUDS INTERSECTES
  1469. * ET D(M,PT_REMONTE) SINON
  1470.  
  1471.  
  1472. * S_OMBRE2 contient les noeuds de s_ombre qui n'ont
  1473. * pas ete intesectes.
  1474. s_ombre2 = diff s_ombre2 MINTER ;
  1475.  
  1476. * actualisation du maillage de remontee
  1477. mailcou = s_ombre2 et mailpts ;
  1478.  
  1479. CHSIGN1 = REDU CHSIGN1 mailcou ;
  1480.  
  1481. SI ((NBNO MINTER) > 0) ;
  1482. mess 'nombre de noeuds intersectes ' (NBNO MINTER) ;
  1483. LMAX1 = LCOURAN1 - pasb0 + (mini CHDIST9) ;
  1484. FINSI ;
  1485.  
  1486. * --- CHPOINT CONTENANT LES DISTANCES PARCOURUES AVANT INTERCEPTION
  1487. chdist = chdist + CHDIST9 ;
  1488. mess 'mini maxi dist connection en m' (mini (prog lmax1 (mini chdist))) lmax1 ;
  1489.  
  1490.  
  1491. finsi ;
  1492. * ------------------ fin du test d'interception ------------------
  1493.  
  1494.  
  1495.  
  1496. *-----------------------------------------------------------------
  1497. *--- construction des lignes de champ remontees
  1498. *--- Extraction des coordonnees des points a remonter
  1499. xmailpt1 = redu XG_NEW mailpts ;
  1500. ymailpt1 = redu YG_NEW mailpts ;
  1501. zmailpt1 = redu ZG_NEW mailpts ;
  1502.  
  1503. *--- Calcul des coordonnees des points a remonter dans le repere du maillage
  1504. xmailpt2 ymailpt2 zmailpt2 = @crgmc xmailpt1 ymailpt1 zmailpt1 tab1 ;
  1505.  
  1506. *--- Construction des lignes de remontee
  1507. repeter boupts3 npts ;
  1508. xprem2 = extr xmailpt2 SCAL (tabpts1 . &boupts3) ;
  1509. yprem2 = extr ymailpt2 SCAL (tabpts1 . &boupts3) ;
  1510. zprem2 = extr zmailpt2 SCAL (tabpts1 . &boupts3) ;
  1511. prem2 = xprem2 yprem2 zprem2 ;
  1512. tablig1 . &boupts3 = (tablig1 . &boupts3) d 1 prem2 ;
  1513. fin boupts3 ;
  1514. *-----------------------------------------------------------------
  1515.  
  1516.  
  1517.  
  1518. * --- actualisation des champs de coordonnees pour iteration suivante
  1519.  
  1520. XG_OLD = redu XG_NEW mailcou;
  1521. YG_OLD = redu YG_NEW mailcou;
  1522. ZG_OLD = redu ZG_NEW mailcou;
  1523.  
  1524. MENA ;
  1525.  
  1526. FIN BOUCLE2 ;
  1527. * --------------------- Fin de la boucle 2 ----------------------
  1528.  
  1529.  
  1530. *--- Sorties dans TAB1
  1531.  
  1532. TAB1.<CHDIST = CHDIST ;
  1533. TAB1.<CONNEXION_MAX = LMAX1 ;
  1534. TAB1.<LONGUEUR_REMONTEE = LCOURAN1 ;
  1535.  
  1536. si (exis tab1 <remontee) ;
  1537. tab1 . <remontee . <ligne = tablig1 ;
  1538. finsi ;
  1539.  
  1540. *Sauvegardes pour reprise eventuelle
  1541. XG_OLD = nomc X XG_OLD nature discret ;
  1542. YG_OLD = nomc Y YG_OLD nature discret ;
  1543. ZG_OLD = nomc Z ZG_OLD nature discret ;
  1544. tab1.<CHCOOR0 = (XG_OLD et YG_OLD et ZG_OLD) ;
  1545. tab1.<s_omb_non_inter = s_ombre2 ;
  1546. tab1.<i_ombrage = i1 ;
  1547.  
  1548. MESS '---------------------------------> exiting @ANALY';
  1549. FINPROC ;
  1550.  
  1551. **** @ARANGU
  1552. DEBPROC @ARANGU T1*FLOTTANT V1*FLOTTANT E1*FLOTTANT ;
  1553. *-------------------------------------------------------------------*
  1554. * R. Mitteau
  1555. * Fatigue du cuivre OFHC
  1556. *
  1557. * D'apres la publi
  1558. *
  1559. *
  1560. * High Temperature Torsional Low Cycle Fatigue of OFHC Copper
  1561. * Ahmet Aran and Dogan Erdun Gucer, Material Research Division,
  1562. * Marmara Research Institute...
  1563. *
  1564. * in Z. Metallkunde
  1565. * T1 temperature en degres K
  1566. * V1 vitesse de deformation en s-1
  1567. * E1 Deformation en .
  1568. *
  1569. *
  1570. *23456789012345678901234567890123456789012345678901234567890123456789012
  1571. * 1 2 3 4 5 6 7
  1572. *-------------------------------------------------------------------*
  1573. MESS '-----------------------------------------------> calling @ARANGU';
  1574. *
  1575. * --- donnees
  1576. *
  1577. * Temperature de la matiere en Kelvin
  1578. TLIEU1 = T1 ;
  1579. * Variation equivalente de la deformation au lieu considere
  1580. EPSETOI1 = E1 ;
  1581. * Vitesse de deformation
  1582. VDEF1 = V1 ;
  1583.  
  1584. *
  1585. * --- Calcul du alpha de la loi de Mansson-Coffin
  1586. *
  1587. EVALPH1 = EVOL MANU 'T' (PROG 293 438 588 668 ) 'ALPH' (PROG .67 .71 .63 .50 );
  1588. EVALPH2 = EVOL MANU 'T' (PROG 293 438 588 668 ) 'ALPH' (PROG .64 .79 .69 .50 );
  1589.  
  1590. VALALPH1 = IPOE EVALPH1 TLIEU1 FIXE;
  1591. VALALPH2 = IPOE EVALPH2 TLIEU1 FIXE;
  1592.  
  1593. EVALPH3 = EVOL MANU 'VDEF' (PROG 1.81E-3 9.05E-3 ) 'ALPH' (PROG VALALPH1 VALALPH2);
  1594.  
  1595. ALPHA1 = IPOE VDEF1 EVALPH3 LINE;
  1596.  
  1597.  
  1598.  
  1599. *
  1600. * --- Calcul du C de la loi de Mansson-Coffin
  1601. *
  1602. EVC1 = EVOL MANU 'T' (PROG 293 438 588 668 ) 'C' (PROG 5.77 6.3 3.56 0.72 );
  1603. EVC2 = EVOL MANU 'T' (PROG 293 438 588 668 ) 'C' (PROG 5.03 12.25 7.01 1.09 );
  1604.  
  1605. VALC1 = IPOE EVC1 TLIEU1 FIXE;
  1606. VALC2 = IPOE EVC2 TLIEU1 FIXE;
  1607.  
  1608. EVC3 = EVOL MANU 'VDEF' (PROG 1.81E-3 9.05E-3 ) 'C' (PROG VALC1 VALC2);
  1609.  
  1610. CA1 = IPOE VDEF1 EVC3 LINE;
  1611.  
  1612.  
  1613. *
  1614. * --- Calcul du nombre de cycles
  1615. *
  1616.  
  1617. NCYCLES1 = (CA1/EPSETOI1) ** (1. / ALPHA1) ;
  1618. NCYCLES2 = ENTI (NCYCLES1 + 1);
  1619. MESS '>@ARANGU> Temperature [K] : ' T1 ;
  1620. MESS '>@ARANGU> Deformation speed [S-1] : ' V1 ;
  1621. MESS '>@ARANGU> Rupture according to Aran-Gucer [cycles]: ' NCYCLES2 ;
  1622.  
  1623. MESS '-----------------------------------------------> exiting @ARANGU';
  1624. FINPROC NCYCLES1;
  1625.  
  1626. **** @BOWRI72
  1627. DEBPROC @BOWRI72 TAB_1*TABLE ;
  1628. *
  1629. *
  1630. * CALCUL DU FLUX CRITIQUE SUIVANT LA CORRELATION DE BOWRING
  1631. *23456789012345678901234567890123456789012345678901234567890123456789012
  1632. * 1 2 3 4 5 6 7
  1633. *
  1634. * --- entrees
  1635. *
  1636. INIVEAU1 = TAB_1.'NIVEAU' ;
  1637. D_DIAM1 = TAB_1.'D_DIAM' ;
  1638. L_LONG1 = TAB_1.'L_HEATED' ;
  1639. P_PRES1 = TAB_1.'P_IN' ;
  1640. V_VITE1 = TAB_1.'V_IN' ;
  1641. T_TEMP1 = TAB_1.'T_IN' ;
  1642. TEST1 = FAUX ;
  1643. SI (EXISTE TAB1 ANNULE_D_DEF);
  1644. SI TAB1.ANNULE_D_DEF ;
  1645. TEST1 = VRAI;
  1646. FINSI ;
  1647. FINSI ;
  1648.  
  1649. *
  1650. * --- racine
  1651. *
  1652. SI (INIVEAU1 >EG 2 ) ;
  1653. MESS '---------------------------------> calling @BOWRI72';
  1654. FINSI ;
  1655. PI = 3.14159;
  1656. LOGI_1 = EXISTE TAB_1 EPTSAT;
  1657. LOGI_2 = EXISTE TAB_1 ETHFG;
  1658. LOGI_3 = EXISTE TAB_1 ETRHOF;
  1659. LOGI_4 = EXISTE TAB_1 ETCPF;
  1660. SI (NON (LOGI_1 ET LOGI_2 ET LOGI_3 ET LOGI_4));
  1661. @TABEAU TAB_1 ;
  1662. FINSI ;
  1663.  
  1664. *
  1665. * --- Test du domaine de definition des entrees
  1666. *
  1667. G_VITE1 = V_VITE1 * (@IPOE TAB_1.ETRHOF T_TEMP1);
  1668.  
  1669. SI TEST1 ;
  1670. * - test sur la vitesse de l'eau
  1671. SI ((G_VITE1 < 136.) OU ( G_VITE1 > 18600.)) ;
  1672. MESS 'Vitesse massique : ' G_VITE1;
  1673. ERRE '@BOWRING -> Vitesse massique hors [136. , 18600.] (Kg/M2/S)';
  1674. FINSI ;
  1675.  
  1676. * - test sur le diametre
  1677. SI ((D_DIAM1 < 2.E-3) OU (D_DIAM1 > 450.E-3)) ;
  1678. MESS 'Diametre : ' D_DIAM1;
  1679. ERRE '@BOWRING -> Diametre hors [0.002 0.45] (M)' ;
  1680. FINSI ;
  1681.  
  1682. * - test sur la Pression
  1683. SI ((P_PRES1 < 1.E5) OU (P_PRES1 > 200.E5)) ;
  1684. MESS 'Pression : ' P_PRES1;
  1685. ERRE '@BOWRING -> Pression hors de [1.E5, 200.E5] (Pa) ' ;
  1686. FINSI ;
  1687.  
  1688. * - test sur la longueur chauffee
  1689. SI ((L_LONG1 < 0.15) OU (L_LONG1 > 3.7)) ;
  1690. MESS 'Longueur : ' L_LONG1;
  1691. ERRE '@BOWRING --> Longueur hors de [0.15,3.7](M) ' ;
  1692. FINSI ;
  1693.  
  1694. * Fin des tests sur les entrees de @BOWRI72
  1695. FINSI ;
  1696.  
  1697. T_SAT = @IPOE TAB_1.EPTSAT P_PRES1 ;
  1698.  
  1699. P1 = P_PRES1 / 6900000. ;
  1700. SI (INIVEAU1 >EG 2) ;
  1701. MESS 'P_PRIME : ' P1 ;
  1702. FINSI ;
  1703.  
  1704. SI (P1 &lt;EG 1.) ;
  1705. F1 = (((P1 ** 18.942) * (EXP (20.8 * (1. - P1)))) + 0.917) / 1.917;
  1706. F2 = (F1 * 1.309)/(((P1 ** 1.316)*(EXP(2.444*(1. - P1)))) + 0.309);
  1707. F3 = (((P1 ** 17.023)*(EXP(16.658*(1. - P1)))) + 0.667)/1.667;
  1708. F4 = F3 * (P1 ** 1.649) ;
  1709. SINON ;
  1710. F1 = (P1 ** (-0.368))*(EXP(0.648*(1. - P1)));
  1711. F2 = (P1 ** (-0.448))*(EXP(0.245*(1. - P1)));
  1712. F3 = P1 ** 0.219;
  1713. F4 = F3 * (P1 ** 1.649) ;
  1714. FINSI ;
  1715.  
  1716. SI (INIVEAU1 >EG 2) ;
  1717. MESS 'F1 : ' F1 ;
  1718. MESS 'F2 : ' F2 ;
  1719. MESS 'F3 : ' F3 ;
  1720. MESS 'F4 : ' F4 ;
  1721. FINSI ;
  1722.  
  1723.  
  1724. L_VAP = @IPOE TAB_1.ETHFG T_TEMP1 ;
  1725. CP__1 = @IPOE TAB_1.ETCPF T_TEMP1 ;
  1726.  
  1727. S_SAT = CP__1 * (T_SAT - T_TEMP1) ;
  1728.  
  1729. SI (INIVEAU1 >EG 2) ;
  1730. MESS 'L_VAP : ' L_VAP ;
  1731. MESS 'CP__1 : ' CP__1 ;
  1732. MESS 'S_SAT : ' S_SAT ;
  1733. FINSI ;
  1734.  
  1735. A__1 = 0.5793 * L_VAP * D_DIAM1 * G_VITE1 * F1 / (1. + (0.0143 * F2 * (D_DIAM1 ** .5) * G_VITE1 )) ;
  1736.  
  1737. B__1 = .25 * D_DIAM1 * G_VITE1 ;
  1738.  
  1739. C__1 = 0.077 * D_DIAM1 * G_VITE1 * F3 / (1. + (0.347 * F4 * ((G_VITE1/1356.) ** (2. - (.5 * P1))))) ;
  1740.  
  1741. SI (INIVEAU1 >EG 5) ;
  1742. MESS 'A : ' A__1 ;
  1743. MESS 'B : ' B__1 ;
  1744. MESS 'C : ' C__1 ;
  1745. FINSI ;
  1746.  
  1747. QCHFW = (A__1 + (B__1 * S_SAT)) / (C__1 + L_LONG1) ;
  1748.  
  1749. G1 = G_VITE1 * PI * D_DIAM1 * D_DIAM1 / 4. ;
  1750. *
  1751. * --- sortie de la procedure
  1752. *
  1753.  
  1754. SI ( INIVEAU1 >EG 1 ) ;
  1755. MESS '>>@BOWRI72>> TUBE DIAMETER (M) : ' D_DIAM1 ;
  1756. MESS '>>@BOWRI72>> TUBE LENGHT (M) : ' L_LONG1 ;
  1757. MESS '>>@BOWRI72>> MASS FLOW VELOCITY (KG/S/M2) : ' G_VITE1;
  1758. MESS '>>@BOWRI72>> INLET MASS FLOW RATE (KG/S) : ' G1 ;
  1759. MESS '>>@BOWRI72>> VELOCITY (M/S) : ' V_VITE1 ;
  1760. MESS '>>@BOWRI72>> FLUID INLET TEMPERATURE (C) : ' T_TEMP1 ;
  1761. MESS '>>@BOWRI72>> FLUID INLET PRESSURE (PA) : ' P_PRES1 ;
  1762. MESS '>>@BOWRI72>> WATER SATURATION TEMPERATURE(C) : ' T_SAT ;
  1763. MESS '>>@BOWRI72>> WALL CRITICAL HEAT FLUX (W/m2) : ' QCHFW ;
  1764. FINSI ;
  1765.  
  1766. SI (INIVEAU1 >EG 2 ) ;
  1767. MESS '---------------------------------> Sortie de @BOWRI72';
  1768. FINSI ;
  1769. *
  1770. * --- sorties
  1771. *
  1772. TAB1.CHF = QCHFW ;
  1773.  
  1774. FINPROC ;
  1775.  
  1776.  
  1777. debproc @calcflu mod1*mmodel cht1*chpoint mat1*chpoint ;
  1778.  
  1779. gradt1 = grad cht1 mod1 ;
  1780. flux1 = mat1 * gradt1 ;
  1781.  
  1782. finproc flux1 ;
  1783.  
  1784. **** @CALHCON
  1785. DEBPROC @CALHCON TAB_1*TABLE ;
  1786.  
  1787. *
  1788. * !!! R. MITTEAU !!! attention, procedure standard
  1789. *
  1790. * un pointeur dans /CASTEM9X/procedures pointe sur cette procedure
  1791. * pour les mises a jour
  1792. *
  1793. *-------------------------------------------------------------------*
  1794. * *
  1795. * COEFFICIENT D ECHANGE TENANT COMPTE *
  1796. * DE L EBULLITION SOUS SATUREE *
  1797. * *
  1798. *-------------------------------------------------------------------*
  1799. *
  1800. DIAM = TAB_1 . D_MAQUETTE ;
  1801. TTAPE = TAB_1 . T_TAPE ;
  1802. YTW1 = TAB_1 . TWIST_RATIO ;
  1803. V1 = TAB_1 . V_LOCAL ;
  1804. *js 20/4/95 je change T_MOY en t_local ????
  1805. T_LOC1 = TAB_1 . 'T_LOCAL' ;
  1806. NIVEAU = TAB_1.'NIVEAU' ;
  1807. P_LOCAL1 = TAB_1.'P_LOCAL' ;
  1808. L1TRAC = TAB_1.'TRAC_GRAPHE' ;
  1809. *
  1810. SI (NIVEAU >EG 4) ;
  1811. MESS '-----------------------------------> calling @CALHCON ' ;
  1812. FINSI ;
  1813. *
  1814. *
  1815. PI = 3.14159 ;
  1816. *S1 = PI * DIAM * DIAM / 4. ;
  1817. SI ( NON ( EXISTE TAB_1 HYPERVAP ) ) ;
  1818. TAB_1.HYPERVAP = FAUX ;
  1819. FINSI ;
  1820. SI ( ( YTW1 EGA 0. 1.E-6 ) ET ( EGA TAB_1.HYPERVAP FAUX ) ) ;
  1821. S1 = PI * DIAM * DIAM / 4. ;
  1822. TAB_1.DH = DIAM ;
  1823. FACV = 1. ;
  1824. FACF = 1. ;
  1825. FINSI ;
  1826. SI ( NON ( EXISTE TAB_1 HELI_WIRE ) ) ;
  1827. TAB_1.HELI_WIRE = FAUX ;
  1828. FINSI ;
  1829. SI ( ( YTW1 EGA 0. 1.E-6 ) ET ( EGA TAB_1.HELI_WIRE VRAI ) ET ( EGA TAB_1.HYPERVAP FAUX ) ) ;
  1830. S1 = PI * DIAM * DIAM / 4. ;
  1831. SM = PI * TAB_1.WIRE_D * TAB_1.WIRE_D / 4. ;
  1832. P1 = PI * DIAM ;
  1833. PM = PI * TAB_1.WIRE_D ;
  1834. TAB_1.DH = 4. * ( S1 - SM ) / ( P1 + PM ) ;
  1835. PIS2Y = PI / ( 2 * TAB_1.PITCH_WIRE ) ;
  1836. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  1837. * FACV = 1. ;
  1838. FACF = 1. ;
  1839. FINSI ;
  1840. *
  1841. SI ( ( YTW1 EGA 0. 1.E-6 ) ET ( EGA TAB_1.HYPERVAP VRAI ) ) ;
  1842. SM = ( TAB_1 . LARG_CANAL * TAB_1 . HMIN_CANAL ) + ( 2. * ( TAB_1 . LARG_ESP * TAB_1 . HFIN ) ) ;
  1843. PM = TAB_1 . LARG_CANAL + ( 2.* TAB_1 . HMAX_CANAL ) + ( 2. * TAB_1 . LARG_ESP ) + ( 2. * TAB_1 . HFIN ) + TAB_1 . LFIN ;
  1844. TAB_1.DH = 4. * SM / PM ;
  1845. FACV = 1. ;
  1846. * FACF = 2.25 ;
  1847. * modif 261099 calcul du rapport Strue/Sapparent
  1848. * N CURT
  1849. SI (TAB_1.HFIN > 0. ) ;
  1850.  
  1851.  
  1852. S_E1 = ((4.*TAB_1.HFIN)+(2.*TAB_1.LARG_ESP)+(TAB_1.LFIN))* (TAB_1.FF + TAB_1.f0) ;
  1853. S_E2 = ((4.*TAB_1.HFIN)+(2.*TAB_1.LARG_ESP)+(TAB_1.LFIN))* (TAB_1.FF) ;
  1854. S_E3 = 2.* (TAB_1.LFIN * (TAB_1.HFIN - TAB_1.RFIN)) ;
  1855. S_E4 = PI * ( TAB_1.RFIN * TAB_1.LFIN) ;
  1856. S_E5 = 2. * (( TAB_1.HFIN + TAB_1.LARG_ESP) * TAB_1.f0) ;
  1857. S_E6 = TAB_1.RFIN * ((2.*TAB_1.f0)-(PI* TAB_1.RFIN)) ;
  1858. FACF = (S_E2+S_E3+S_E4+S_E5+S_E6)/ S_E1 ;
  1859. SINON ;
  1860. FACF = 1. ;
  1861. FINSI ;
  1862. *fin modif
  1863.  
  1864. TAB_1.FACCF = FACF ;
  1865. TAB_1.HYP_SM = SM ;
  1866. FINSI ;
  1867. SI ( YTW1 > 0. ) ;
  1868. QUAS = 4. * ( ( PI * DIAM * DIAM / 8.) - ( TTAPE * DIAM / 2. ) ) ;
  1869. PERI = ( ( PI * DIAM / 2.) - TTAPE + DIAM ) ;
  1870. TAB_1.DH = QUAS / PERI ;
  1871. PIS2Y = PI / ( 2. * YTW1 ) ;
  1872. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  1873. FACF = 1.15 ;
  1874. FINSI ;
  1875. SI ( EXISTE TAB_1 RIP_FLOWS ) ;
  1876. S1 = ( TAB_1 . RIP_FLOWS ) ;
  1877. FINSI ;
  1878. SI ( EXISTE TAB_1 RIP_WETP ) ;
  1879. PERI = ( TAB_1 . RIP_WETP ) ;
  1880. TAB_1.DH = 4. * S1 / PERI ;
  1881. FINSI ;
  1882. SI ( EXISTE TAB_1 RIP_TWIST ) ;
  1883. PIS2Y = PI / ( 2. *( TAB_1 . RIP_TWIST ) ) ;
  1884. FACV2 = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  1885. FACV = MAXI ( PROG FACV FACV2 ) ;
  1886. FINSI ;
  1887.  
  1888. SI ( EGA TAB_1.HYPERVAP FAUX ) ;
  1889. FACD = ( DIAM / TAB_1.DH ) ** 0.2 ;
  1890. FACT = ( FACV ** 0.8 ) * FACD * FACF ;
  1891. SINON ;
  1892. FACD = 1. ;
  1893. FACT = ( FACV ** 0.8 ) * FACD * FACF ;
  1894. FINSI ;
  1895. * modif pour calcul W7x provisoire
  1896. * adaptation du coef correctif W7X du au swirl
  1897. * N CURT 18012000
  1898. * SI ( EGA TAB_1.HYPERVAP FAUX ) ;
  1899. * SI (YTW1 > 0. ) ;
  1900. * FACF = 2.18 * ((YTW1)**(-1 * 0.09)) ;
  1901. * FACF = 2.26 * ((YTW1)**(-1 * 0.248)) ;
  1902. * FACD = 1. ;
  1903. * FACV = 1. ;
  1904. * FACT = ( FACV ** 0.8 ) * FACD * FACF ;
  1905. * SINON ;
  1906. *FACD = ( DIAM / TAB_1.DH ) ** 0.2 ;
  1907. * FACT = ( FACV ** 0.8 ) * FACD * FACF ;
  1908. * FINSI ;
  1909. * SINON ;
  1910. * FACD = 1. ;
  1911. * FINSI ;
  1912. * fin modif
  1913. *
  1914. * attention modification par R. MITTEAU le 7 fevrier 1994
  1915. * j'ai rajoute les " FIXE " pour pouvoir passer un calcul
  1916. * dans lequel l'eau est quasi immobile. Car dans ce cas les valeurs
  1917. * sont en dehors des tables
  1918.  
  1919. * avant modif
  1920. *TSAT = @IPOE P_LOCAL1 TAB_1.EPTSAT ;
  1921. *NNU = @IPOE T_LOC1 TAB_1.ETNNU ;
  1922. *RHO = @IPOE T_LOC1 TAB_1.ETRHOF ;
  1923. *PR = @IPOE T_LOC1 TAB_1.ETPRAF ;
  1924. *LLAM = @IPOE T_LOC1 TAB_1.ETLLA ;
  1925. *NNUB = @IPOE T_LOC1 TAB_1.ETNNU ;
  1926.  
  1927. * apres modif raph
  1928. *MESS '>>PRESS T_MOY S1' P_LOCAL T_LOC1 ;
  1929. TSAT = @IPOE P_LOCAL1 TAB_1.EPTSAT FIXE ;
  1930. NNU = @IPOE T_LOC1 TAB_1.ETNNU FIXE ;
  1931. RHO = @IPOE T_LOC1 TAB_1.ETRHOF FIXE ;
  1932. PR = @IPOE T_LOC1 TAB_1.ETPRAF FIXE ;
  1933. LLAM = @IPOE T_LOC1 TAB_1.ETLLA FIXE ;
  1934. NNUB = @IPOE T_LOC1 TAB_1.ETNNU FIXE ;
  1935.  
  1936. *
  1937. RE = RHO * ( NNU ** -1 ) * V1 * TAB_1.DH * FACV ;
  1938. *
  1939. SI ( T_LOC1 < TSAT ) ;
  1940. LTWALL1 = PROG -52. pas 25. (T_LOC1 + 0.01) pas 25. TSAT pas 25. 350. 400. 450. 500. 1500. 2550. 3000. 3500. 20000. ;
  1941. SINON ;
  1942. LTWALL1 = PROG -52. pas 25. TSAT pas 25. 350. 400. 450. 500. 1500. 2550. 3000. 3500. 20000. ;
  1943. FINSI ;
  1944. *
  1945. LNNUW = @IPOE LTWALL1 TAB_1.ETNNU 'FIXE' ;
  1946. *modif NCURT 10012000
  1947. *calcul nb de Prandtl sur le mur
  1948. LPRW = @IPOE LTWALL1 TAB_1.ETPRAF 'FIXE' ;
  1949. *fin modif
  1950. LTETA = PROG ( DIME LTWALL1 ) * T_LOC1 ;
  1951. *
  1952. LM_ITETA = LTWALL1 MASQUE 'INFERIEUR' T_LOC1 ;
  1953. LM_STETA = LTWALL1 MASQUE 'EGSUP' T_LOC1 ;
  1954. *
  1955. *SI ( EGA TAB_1.L_CONVECT 'DITTUS_BOELTER' ) ;
  1956. NUS_2 = FACF * 0.023 * ( RE ** 0.8 ) * ( PR ** 0.4 ) ;
  1957. NUS_1 = FACF * 0.023 * ( RE ** 0.8 ) * ( PR ** 0.3 ) ;
  1958. LNUS_2 = PROG ( DIME LTWALL1 ) * NUS_2 ;
  1959. LNUS_1 = PROG ( DIME LTWALL1 ) * NUS_1 ;
  1960. LNUS = ( LNUS_1 * LM_ITETA ) + ( LNUS_2 * LM_STETA ) ;
  1961. LH_DB = LNUS * LLAM / TAB_1.DH ;
  1962. LFC_DB = ( LTWALL1 - LTETA ) * LH_DB;
  1963. TITRE 'DITTUS_BOELTER' ;
  1964. EVOFC_DB = EVOL MANU 'TEMPERATURE' LTWALL1 'FLUX' LFC_DB ;
  1965. *FINSI ;
  1966. *
  1967. *SI ( EGA TAB_1.L_CONVECT 'SIEDER_TATE' ) ;
  1968. NUS1 = FACF * 0.027 * ( RE ** 0.8 ) * ( PR ** ( 1. / 3. )) ;
  1969. LNUS = ( ( LNNUW / NNUB ) ** -0.14 ) * NUS1 ;
  1970. LH_ST = LNUS * ( LLAM / TAB_1.DH ) ;
  1971. LFC_ST = ( LTWALL1 - LTETA ) * LH_ST ;
  1972. TITRE 'SIEDER_TATE' ;
  1973. EVOFC_ST = EVOL MANU 'TEMPERATURE' LTWALL1 'FLUX' LFC_ST ;
  1974. *FINSI ;
  1975. *
  1976. *SI ( EGA TAB_1.L_CONVECT 'PETHUKOV' ) ;
  1977. F_P = (1. / ( 1.82 * ( ( LOG RE ) / ( LOG 10.) ) - 1.64 )) ** 2 ;
  1978. X_P = 1.07 + (12.7 * (PR ** (2. / 3.) - 1.) * ( (F_P / 8.) ** 0.5 ));
  1979. NUS1 = ( RE * PR * F_P ) / ( X_P * 8. ) ;
  1980. LNUS_2 = ( ( LNNUW / NNUB ) ** -0.11 ) * FACF * NUS1 ;
  1981. LNUS_1 = ( ( LNNUW / NNUB ) ** -0.25 ) * FACF * NUS1 ;
  1982. LNUS = (LNUS_1 * LM_ITETA) + (LNUS_2 * LM_STETA) ;
  1983. LH_P = LNUS * ( LLAM /TAB_1.DH ) ;
  1984. LFC_P = ( LTWALL1 - LTETA ) * LH_P ;
  1985. TITRE 'PETHUKOV' ;
  1986. EVOFC_P = EVOL MANU 'TEMPERATURE' LTWALL1 'FLUX' LFC_P ;
  1987. *FINSI ;
  1988.  
  1989.  
  1990.  
  1991. *modif NCURT 10012000
  1992. *adaptation de la correlation non courte de Gnielinski
  1993. *cf Greuner 260499
  1994. *SI ( EGA TAB_1.L_CONVECT 'GNIELINSKI' ) ;
  1995. F_G = (1. / (1.82 * ( ( LOG RE ) / ( LOG 10.)) - 1.64 )) ** 2 ;
  1996. R_G = ( (PR ** (2. / 3.)) - 1.) * ( (F_G / 8.) ** 0.5) ;
  1997. X_G = 1. + (12.7 * R_G);
  1998. NUS3 = FACF * (((RE - 1000.)* PR) * F_G) / ( X_G * 8.) ;
  1999. * correlation courte
  2000. * NUS3 = FACF * 0.012 * ((RE ** 0.87) - 280. ) * (PR ** 0.4) ;
  2001. LNUS = ( ( LPRW / PR ) ** -0.11 ) * NUS3 ;
  2002. LH_GN = LNUS * ( LLAM/TAB_1.DH) ;
  2003. LFC_GN = ( LTWALL1 - LTETA ) * LH_GN ;
  2004. TITRE 'GNIELINSKI' ;
  2005. EVOFC_GN = EVOL MANU 'TEMPERATURE' LTWALL1 'FLUX' LFC_GN ;
  2006.  
  2007. *fin modif
  2008.  
  2009.  
  2010. *SI ( EGA TAB_1.L_CONVECT 'JB_CONVEC' ) ;
  2011. SI (NON ( YTW1 EGA 0. 1.E-6 ) ) ;
  2012. FACFJB = 1. + ( 0.7 / YTW1 ) ;
  2013. SINON ;
  2014. FACFJB = 1. ;
  2015. FINSI ;
  2016. NUS_3 = FACFJB * 0.023 * ( RE ** 0.8 ) * ( PR ** 0.4 ) ;
  2017. LNUS = ( ( LNNUW / NNUB ) ** -0.25 ) * NUS_3 ;
  2018. LH_JB = LNUS * ( LLAM / TAB_1.DH ) ;
  2019. LFC_JB = ( LTWALL1 - LTETA ) * LH_JB ;
  2020. TITRE 'JB_CONVEC' ;
  2021. EVOFC_JB = EVOL MANU 'TEMPERATURE' LTWALL1 'FLUX' LFC_JB ;
  2022. *FINSI ;
  2023. *
  2024. SI ( NON ( EXISTE TAB_1 L_CONVECT ) ) ;
  2025. *js TAB_1.L_CONVECT = 'DITTUS_BOELTER' ;
  2026. TAB_1.L_CONVECT = 'SIEDER_TATE' ;
  2027. FINSI ;
  2028. *
  2029. SI ( EGA TAB_1.L_CONVECT 'DITTUS_BOELTER' ) ;
  2030. LHCONV = LH_DB ;
  2031. FINSI ;
  2032. *
  2033. SI ( EGA TAB_1.L_CONVECT 'SIEDER_TATE' ) ;
  2034. LHCONV = LH_ST ;
  2035. FINSI ;
  2036. *
  2037. SI ( EGA TAB_1.L_CONVECT 'PETHUKOV' ) ;
  2038. LHCONV = LH_P ;
  2039. FINSI ;
  2040. *
  2041. SI ( EGA TAB_1.L_CONVECT 'JB_CONVEC') ;
  2042. LHCONV = LH_JB ;
  2043. FINSI ;
  2044.  
  2045. *modif 10012000
  2046. SI ( EGA TAB_1.L_CONVECT 'GNIELINSKI') ;
  2047. LHCONV = LH_GN ;
  2048. FINSI ;
  2049. *fin modif
  2050.  
  2051. *
  2052. * Calculation of TONB FONB Bergles & Rohsenow correlation
  2053. *
  2054. IONB = 0 ;
  2055. TB1 = TSAT + 15. ;
  2056. REPETER BOUCONB ;
  2057. IONB = IONB + 1 ;
  2058. SI ( IONB > 7 ) ;
  2059. QUITTER BOUCONB ;
  2060. FINSI ;
  2061. PRATIO = P_LOCAL1 * 1.E-5 ;
  2062. EXPO1 = 1. / ( 0.463 * ( PRATIO ** 0.0234 ) ) ;
  2063. DUM = ( 1. / 0.556 ) * ( TB1 - TSAT ) ;
  2064. FTBA = 1082. *( PRATIO ** 1.156 )* ( DUM ** EXPO1 ) ;
  2065. HCONV = IPOL TB1 LTWALL1 LHCONV ;
  2066. FTB = ( HCONV * ( TB1 - T_LOC1 ) ) - FTBA ;
  2067. ;
  2068. * **** CALCUL DE LA DERIVEE PAR RAPPORT A TB1-TETA **********
  2069. FTB1 = HCONV - ( ( EXPO1 * FTBA ) / ( TB1 - TSAT ) ) ;
  2070. * **** CALCUL DU NOUVEAU TB **********
  2071. TONB = TB1 - ( FTB / FTB1 ) ;
  2072. SI ( ( ABS ( TONB -TB1 ) ) &lt;EG 0.1 ) ;
  2073. QUITTER BOUCONB ;
  2074. FINSI ;
  2075. TB1 = TONB ;
  2076. FIN BOUCONB ;
  2077. MESS '>@CALHCON> TONB VALUE BY BERG.& ROHS. CORREL.: ' TONB ;
  2078. MESS '>@CALHCON> TONB PRECISION : ' ((TONB - TB1) / TONB);
  2079. *
  2080. *
  2081. SI ( T_LOC1 < TSAT ) ;
  2082. LTWALL2 = PROG -52. pas 25. (T_LOC1 + 0.01) pas 25. TSAT pas 5. (TONB + 0.01) pas 5. (TONB + 50.) pas 25. 450. 500. 1500. 3000. 2.1E4 ;
  2083. SINON ;
  2084. LTWALL2 = PROG -52. pas 25. TSAT pas 5. (TONB + 0.01) pas 5. (TONB + 50.) pas 25. 450. 500. 1500. 3000. 2.1E4 ;
  2085. FINSI ;
  2086.  
  2087. LTWALL = LTWALL2 ;
  2088. *
  2089. LHCONV = @ITPLT LTWALL1 LHCONV 'FIXE' LTWALL2 ;
  2090. LTETA = PROG ( DIME LTWALL ) * T_LOC1 ;
  2091. LTSAT = PROG ( DIME LTWALL ) * TSAT ;
  2092. LTONB = PROG ( DIME LTWALL ) * TONB ;
  2093. *
  2094. LM_ITSAT = LTWALL MASQUE 'INFERIEUR' TSAT ;
  2095. LM_STSAT = LTWALL MASQUE 'EGSUPE' TSAT ;
  2096. LM_ITONB = LTWALL MASQUE 'INFERIEUR' TONB ;
  2097. LM_STONB = LTWALL MASQUE 'EGSUPE' TONB ;
  2098. LM_ITON1 = LTWALL MASQUE 'EGINFE' TONB ;
  2099. LM_STON1 = LTWALL MASQUE 'SUPERIEUR' TONB ;
  2100. *
  2101. *SI ( EGA TAB_1.L_SUBNB 'THOM' ) ;
  2102. VEXPTM = EXP ( 1.E-5 * P_LOCAL1 / 87. ) ;
  2103. LFB_TM = ( LTWALL - LTSAT ) * ( VEXPTM / 22.65 ) ;
  2104. LFB_TM = ( LFB_TM ** 2 ) * 1.E6 ;
  2105. LFB_TM = LFB_TM * LM_STSAT ;
  2106. TITRE 'THOM' ;
  2107. EVOFB_TM = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_TM ;
  2108. EVOFB_T1 = EVOFB_TM ;
  2109. *FINSI ;
  2110. *
  2111. SI ( NON ( EXISTE TAB_1 L_SUBNB ) ) ;
  2112. TAB_1.L_SUBNB = 'THOM_CEA' ;
  2113. SI ( NON ( EXISTE TAB_1 V_EXPTHOM ) ) ;
  2114. TAB_1 . V_EXPTHOM = 2.8 ;
  2115. FINSI ;
  2116. FINSI ;
  2117. *
  2118. SI ( EGA TAB_1.L_SUBNB 'THOM_CEA' ) ;
  2119. VEXPTM = EXP ( 1.E-5 * P_LOCAL1 / 87. ) ;
  2120. LFB_TM = ( LTWALL - LTSAT ) * ( VEXPTM / 22.65 ) ;
  2121. E_TMP = TAB_1.V_EXPTHOM / 2. ;
  2122. LFB_TMP = (( LFB_TM ** 2 ) ** E_TMP) * 1.E6 ;
  2123. LFB_TMP = LFB_TMP * LM_STSAT ;
  2124. TITRE 'THOM_CEA' ;
  2125. EVFB_TMP = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_TMP ;
  2126. EVOFB_T1 = EVOFB_T1 ET EVFB_TMP ;
  2127. FINSI ;
  2128. *
  2129. SI ( EGA TAB_1.L_SUBNB 'T_JAERI' ) ;
  2130. VEXPTM = EXP ( 1.E-5 * P_LOCAL1 / 87. ) ;
  2131. LFB_TM = ( LTWALL - LTSAT ) * ( VEXPTM / 25.72 ) ;
  2132. E_TMJ = 3 / 2. ;
  2133. LFB_TMJ = (( LFB_TM ** 2 ) ** E_TMJ) * 1.E6 ;
  2134. LFB_TMJ = LFB_TMJ * LM_STSAT ;
  2135. TITRE 'T_JAERI' ;
  2136. EVFB_TMJ = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_TMJ ;
  2137. EVOFB_T1 = EVOFB_T1 ET EVFB_TMJ ;
  2138. FINSI ;
  2139. *
  2140. *SI ( EGA TAB_1.L_SUBNB 'JENS_LOTTES' ) ;
  2141. VEXPJL = EXP ( 1.E-5 * P_LOCAL1 / 62. ) ;
  2142. LFB_JL = ( LTWALL - LTSAT ) * ( VEXPJL / 25. ) ;
  2143. LFB_JL = ( LFB_JL ** 4 ) * 1.E6 ;
  2144. LFB_JL = LFB_JL * LM_STSAT ;
  2145. TITRE 'JENS_LOTTES' ;
  2146. EVOFB_JL = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_JL ;
  2147. *FINSI ;
  2148. *
  2149. SI ( EGA TAB_1.L_SUBNB 'YIN' ) ;
  2150. D_YIN1 = 7.195 * ( TAB_1.GAM_YIN ** 1.82 ) ;
  2151. D_YIN2 = ( 1.E-5 * P_LOCAL1 ) ** 0.072 ;
  2152. LFB_YIN = ( 1.E6 * ( LTWALL - LTSAT ) ) / ( D_YIN1 * D_YIN2 ) ;
  2153. LFB_YIN = LFB_YIN * LM_STSAT ;
  2154. TITRE 'YIN' ;
  2155. EVFB_YIN = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_YIN ;
  2156. FINSI ;
  2157. *
  2158. TAC1 = TABLE ;
  2159. TAC1.1 = 'MARQ CROI REGU' ;
  2160. TAC1.2 = 'MARQ PLUS REGU' ;
  2161. TAC1.3 = 'MARQ ETOI REGU' ;
  2162. TAC1.4 = 'MARQ LOSA REGU' ;
  2163. TAC1.5 = 'MARQ CARR REGU' ;
  2164. TAC1.6 = 'MARQ TRIB REGU' ;
  2165. *
  2166. TAC2 = TABLE ;
  2167. TAC2.1 = 'MARQ CARR REGU' ;
  2168. TAC2.2 = 'MARQ LOSA REGU' ;
  2169. TAC2.3 = 'MARQ TRIA REGU' ;
  2170. TAC2.4 = 'MARQ TRIB REGU' ;
  2171. *
  2172. MESS '>@CALHCON> VELOCITY (M/S) : ' V1 ;
  2173.  
  2174. * MESS '>@CALHCON> MASS FLOW RATE ( KG/S ) : '
  2175. * (V1 * S1 * RHO) ;
  2176. MESS '>@CALHCON> FLUID TEMPERATURE (C) : ' T_LOC1 ;
  2177. MESS '>@CALHCON> FLUID PRESSURE ( PA ) : ' P_LOCAL1 ;
  2178. MESS '>@CALHCON> WATER SATURATION TEMPERATURE(C) : ' TSAT ;
  2179. *MESS '>@CALHCON> TUBE DIAMETER (M) : ' DIAM ;
  2180. MESS '>@CALHCON> TUBE HYDRAULIC DIAMETER (M) : ' TAB_1.DH ;
  2181. MESS '>@CALHCON> SWIRL TAPE THICKNESS (M) : ' TTAPE ;
  2182. MESS '>@CALHCON> TWIST RATIO : ' YTW1 ;
  2183. MESS '>@CALHCON> FLUID DENSITY ( KG/M**3) : ' RHO ;
  2184. MESS '>@CALHCON> FLUID CONDUCTIVITY ( W/M.K) : ' LLAM ;
  2185. MESS '>@CALHCON> REYNOLDS NUMBER : ' RE ;
  2186. MESS '>@CALHCON> FLUID VISCOSITY (KG/M.S) : ' NNU ;
  2187. MESS '>@CALHCON> PRANDTL NUMBER : ' PR ;
  2188. MESS '>@CALHCON> FACTOR DUE TO FIN EFFECT : ' FACF ;
  2189. MESS '>@CALHCON> FACTOR DUE TO CHANGE ON HYD.DIAM: ' FACD ;
  2190. *MESS '>@CALHCON> FACTOR DUE TO TWISTED VELOCITY : ' FACV ;
  2191. MESS '>@CALHCON> VELOCITY CORRECTION FACTOR : 'FACV ;
  2192. MESS '>@CALHCON> TOTAL FACT. DUE TO TWIST or RIP.: ' FACT ;
  2193. MESS '>@CALHCON> NUSS. HEATING NUMBER : ' ( IPOL 400. LTWALL1 LNUS ) ;
  2194. *MESS ' EXPERIMENTAL CRITICAL FLUX : ' FCR1 ;
  2195. MESS '>@CALHCON> CONV. COEF. (CONVECTION) : ' ( IPOL 400. LTWALL1 LH_DB ) ;
  2196. MESS '>@CALHCON> FC_DB (TWALL = 400 C ) :' ( IPOL 400. LTWALL1 LFC_DB ) ;
  2197. *
  2198. *
  2199. *
  2200. SI ( EGA TAB_1.L_SUBNB 'THOM' ) ;
  2201. LFB = LFB_TM ;
  2202. FINSI ;
  2203. *
  2204. SI ( EGA TAB_1.L_SUBNB 'THOM_CEA' ) ;
  2205. LFB = LFB_TMP ;
  2206. FINSI ;
  2207. *
  2208. SI ( EGA TAB_1.L_SUBNB 'T_JAERI' ) ;
  2209. LFB = LFB_TMJ ;
  2210. FINSI ;
  2211. *
  2212. SI ( EGA TAB_1.L_SUBNB 'JENS_LOTTES' ) ;
  2213. LFB = LFB_JL ;
  2214. FINSI ;
  2215. *
  2216. SI ( EGA TAB_1.L_SUBNB 'YIN' ) ;
  2217. LFB = LFB_YIN ;
  2218. TAB_1.CONNECT_METHOD = 'ADDITION' ;
  2219. FINSI ;
  2220. *
  2221. SI ( EXISTE TAB_1 AMPL_H ) ;
  2222. LHCONV = LHCONV * ( TAB_1 . AMPL_H ) ;
  2223. FINSI ;
  2224. *
  2225. LFCONV = ( LTWALL - LTETA ) * LHCONV ;
  2226. TITRE TAB_1.L_CONVECT 'CONVECTION FLUX' ;
  2227. EVOFC = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LFCONV ;
  2228. TITRE TAB_1.L_SUBNB 'BOILING FLUX' ;
  2229. EVOFE = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LFB ;
  2230. *
  2231. SI ( NON ( EXISTE TAB_1 CONNECT_METHOD ) ) ;
  2232. TAB_1.CONNECT_METHOD = 'BERG_ROH' ;
  2233. FINSI ;
  2234. *
  2235. SI ( EGA TAB_1.CONNECT_METHOD 'ADDITION' ) ;
  2236. TAB_1.L_SUBNB = 'YIN' ;
  2237. MESS '>@CALHCON> ADDITION DE FSPL ET FSCB CHOISIE ' ;
  2238. LFT = LFCONV + LFB ;
  2239. FINSI ;
  2240. *
  2241. SI ( EGA TAB_1.CONNECT_METHOD 'DIRECT' ) ;
  2242. PA_TEMPE = 10. ;
  2243. TEMPE_PA = TSAT ;
  2244. FLUX_DIC = @IPOE TEMPE_PA EVOFC ;
  2245. FLUX_DIE = @IPOE TEMPE_PA EVOFE ;
  2246. * Recherche du point d'intersection
  2247. REPETER BOUC_DIR ;
  2248. SI ( ( ABS ( FLUX_DIE - FLUX_DIC ) ) &lt;EG 1.E2 ) ;
  2249. QUITTER BOUC_DIR ;
  2250. FINSI ;
  2251. SI ( FLUX_DIE > FLUX_DIC ) ;
  2252. TEMPE_PA = TEMPE_PA - PA_TEMPE ;
  2253. PA_TEMPE = PA_TEMPE / 2. ;
  2254. FINSI ;
  2255. TEMPE_PA = TEMPE_PA + PA_TEMPE ;
  2256. FLUX_DIC = @IPOE TEMPE_PA EVOFC ;
  2257. FLUX_DIE = @IPOE TEMPE_PA EVOFE ;
  2258. FIN BOUC_DIR ;
  2259. RANGE_D = (LTWALL MASQUE 'INFE' 'SOMME' TEMPE_PA) + 1 ;
  2260. LTWALL_D = INSERER LTWALL RANGE_D TEMPE_PA ;
  2261. LFCONV_D = INSERER LFCONV RANGE_D FLUX_DIC ;
  2262. LFB_D = INSERER LFB RANGE_D FLUX_DIE ;
  2263. LM_IFLUX = LFCONV_D MASQUE 'INFERIEUR' FLUX_DIC ;
  2264. LM_SFLUX = LFB_D MASQUE 'EGSUPE' FLUX_DIE ;
  2265. LFCONVI = LFCONV_D * LM_IFLUX ;
  2266. LFBS = LFB_D * LM_SFLUX ;
  2267. LFT = LFCONVI + LFBS ;
  2268. LTWALL = LTWALL_D ;
  2269. LFCONV = LFCONV_D ;
  2270. LFB = LFB_D ;
  2271. LTETA = PROG ( DIME LTWALL_D ) * T_LOC1 ;
  2272. FINSI ;
  2273. *
  2274. SI ( EGA TAB_1.CONNECT_METHOD 'BERG_ROH' ) ;
  2275. LFCONV1 = LFCONV * LM_ITONB ;
  2276. LFCONV2 = LFCONV * LM_STONB ;
  2277. FB_ONB = IPOL TONB LTWALL LFB ;
  2278. LFB_ONB = PROG (DIME LTWALL) * FB_ONB ;
  2279. LDFB = ( LFB - LFB_ONB ) * LM_STONB ;
  2280. LF = ( LFCONV2 ** 2 ) + ( LDFB ** 2 ) ;
  2281. LF = LF ** 0.5 ;
  2282. LF = LF * LM_STONB ;
  2283. LFT = LFCONV1 + LF ;
  2284. FINSI ;
  2285. *
  2286. SI ( EGA TAB_1.CONNECT_METHOD 'JB_METHOD' ) ;
  2287. *
  2288. *liaison par flux = a Tparoi**10 + b
  2289. * LA_1 = ( LFB_ONB1 - LFB_ONB ) / (( LTONB1 ** 10 ) -
  2290. * ( LTONB ** 10 ) ) ;
  2291. * LB_1 = LFB_ONB - ( LA_1 * ( LTONB ** 10 ) ) ;
  2292. * LFPB = ( LA_1 * ( LTWALL_6 ** 10 ) ) + LB_1 ;
  2293. *
  2294. FB_ONB4 = IPOL TONB LTWALL LFB ;
  2295. FB_ONB5 = IPOL TONB LTWALL LFCONV ;
  2296. FB_ONB6 = 2.8 * FB_ONB5 ;
  2297. * EVFB_TMP = EVOL MANU 'TEMPERATURE' LTWALL 'FLUX' LFB_TMP ;
  2298. EVFB_TM1 = EVOL MANU 'FLUX' LFB_TMP 'TEMPERATURE' LTWALL ;
  2299. T_ONB6 = @IPOE FB_ONB6 EVFB_TM1 FIXE ;
  2300. RANGE_6 = ( LTWALL MASQUE 'INFE' 'SOMME' T_ONB6 ) + 1 ;
  2301. LTWALL_6 = INSERER LTWALL RANGE_6 T_ONB6 ;
  2302. *
  2303. LM_ITON2 = LTWALL_6 MASQUE 'INFERIEUR' T_ONB6 ;
  2304. LM_STON2 = LTWALL_6 MASQUE 'EGSUPE' T_ONB6 ;
  2305. LM_ITON3 = LTWALL_6 MASQUE 'INFERIEUR' TONB ;
  2306. LM_STON3 = LTWALL_6 MASQUE 'EGSUPE' TONB ;
  2307. LFB_ONB4 = PROG ( DIME LTWALL_6 ) * FB_ONB4 ;
  2308. LFB_ONB6 = PROG ( DIME LTWALL_6 ) * FB_ONB6 ;
  2309. LTETA1 = PROG ( DIME LTWALL_6 ) * T_LOC1 ;
  2310. *
  2311. LHCONV1 = @ITPLT LTWALL LHCONV 'FIXE' LTWALL_6 ;
  2312. LFCONV1 = ( LTWALL_6 - LTETA1 ) * LHCONV1 ;
  2313. LFB1 = @ITPLT LTWALL LFB 'FIXE' LTWALL_6 ;
  2314. LFCONV2 = LFCONV1 * LM_ITON3 ;
  2315. LFCONV3 = LFCONV1 * LM_STON3 ;
  2316. LFCONV3 = LFCONV3 * LM_ITON2 ;
  2317. LB_1 = ( ( LFB_ONB6 ** 2 ) - ( LFCONV3 ** 2 ) ) / ( ( LFB_ONB6 - LFB_ONB4 ) ** 2 ) ;
  2318. * LB_1 = 1. ;
  2319. LDFB1 = ( LFB1 - LFB_ONB4 ) * LM_STON3 ;
  2320. LFT0 = ( LFCONV3 ** 2 ) + ( LB_1 * ( LDFB1 ** 2 ) ) ;
  2321. LFT0 = LFT0 ** 0.5 ;
  2322. LFT0 = LFT0 * LM_STON3 ;
  2323. LFT1 = LFCONV2 + LFT0 ;
  2324. FINSI ;
  2325. *
  2326. SI ( NON ( EXISTE TAB_1 PFIXTONB ) ) ;
  2327. TAB_1 . PFIXTONB = FAUX ;
  2328. FINSI ;
  2329. *
  2330. SI ( TAB_1 . PFIXTONB ) ;
  2331. F_ONB1 = IPOL TONB LTWALL LFT ;
  2332. LF_ONB1 = PROG (DIME LTWALL) * F_ONB1 ;
  2333. LHT = (LFT - LF_ONB1) / (LTWALL - LTONB) ;
  2334. LTETA_1 = LTONB - ( LF_ONB1 / LHT ) ;
  2335. MESS '>@CALHCON> LTETA_1 :' ;
  2336. TAB_1 . EV_TETA = EVOL MANU 'TEMPERATURE' LTWALL 'TEMPEAU' LTETA_1 ;
  2337. SINON ;
  2338. SI ( EGA TAB_1.CONNECT_METHOD 'JB_METHOD' ) ;
  2339. LFT = LFT1 ;
  2340. LHT = LFT1 / (LTWALL_6 - LTETA1 ) ;
  2341. LTWALL = LTWALL_6 ;
  2342. SINON ;
  2343. LHT = LFT / ( LTWALL - LTETA ) ;
  2344. FINSI ;
  2345. FINSI ;
  2346.  
  2347. TITRE ' HEAT TRANSFER COEFFICIENT ' ;
  2348. EVOCON = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LHT ;
  2349. *TITRE TAB_1.L_CONVECT 'CONVECTION FLUX' ;
  2350. *EVOFC = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LFCONV ;
  2351. *TITRE TAB_1.L_SUBNB 'BOILING FLUX' ;
  2352. *EVOFE = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LFB ;
  2353. TITRE ' COMBINED FLUX ' ;
  2354. EVOFT = EVOL MANU 'TEMPERATURE' LTWALL 'CONVECTION' LFT ;
  2355. *
  2356. TITRE ' COEF. D ECHANGE EN EBULLITION SOUS SATUREE, TONB :' TONB ;
  2357. *TITRE ' HEAT TRANSFER COEFFICIENT , TONB ' TONB ;
  2358. TITRE ' CHOSEN CORRELATIONS , TONB ' TONB ;
  2359.  
  2360. * modif raph/schlo pour couper l'echange au dessus du flux critique
  2361. * en regime transitoire, effectuee par R. MITTEAU le 16 fevrier 94
  2362. SI (EXISTE TAB_1 TRANSITOIRE) ;
  2363. SI TAB_1.TRANSITOIRE ;
  2364. SI (EXISTE TAB_1 FLUCRIT1 ) ;
  2365. EVBIDON1 = EVOL MANU LFT LTWALL ;
  2366. T_CRISE = @IPOE TAB_1.FLUCRIT1 EVBIDON1 ;
  2367. H_CRISE = @IPOE T_CRISE EVOCON ;
  2368. RANGENTI = ( LTWALL MASQUE 'INFE' 'SOMME' T_CRISE ) + 1 ;
  2369. LTWALL3 = INSERER LTWALL RANGENTI T_CRISE ;
  2370. LHT2 = INSERER LHT RANGENTI H_CRISE ;
  2371. LFT2 = INSERER LFT RANGENTI TAB_1.FLUCRIT1 ;
  2372. MASQ1 = LFT2 MASQUE EGINFE TAB_1.FLUCRIT1 ;
  2373. MASQ2 = LFT2 MASQUE SUPERIEUR TAB_1.FLUCRIT1 ;
  2374. LHT3 = (LHT2 * MASQ1 ) + MASQ2 ;
  2375. LFT3 = (LFT2 * MASQ1 ) + MASQ2 ;
  2376. TITRE ' HEAT TRANSFER COEFFICIENT ' ;
  2377. EVOCON = EVOL MANU 'TEMPERATURE' LTWALL3 'CONVECTION' LHT3 ;
  2378. TITRE ' COMBINED FLUX ' ;
  2379. EVOFT = EVOL MANU 'TEMPERATURE' LTWALL3 'CONVECTION' LFT3 ;
  2380. FINSI ;
  2381. FINSI ;
  2382. FINSI ;
  2383. *
  2384. TAB_1.T_SAT = TSAT ;
  2385. TAB_1.V_TONB = TONB ;
  2386. TAB_1.ECONVEC1 = EVOCON ;
  2387. TAB_1.EVOFE1 = EVOFE ;
  2388. *
  2389. TAC1 = TABLE ;
  2390. TAC1.1 = 'MARQ CROI REGU' ;
  2391. TAC1.2 = 'MARQ PLUS REGU' ;
  2392. TAC1.3 = 'MARQ ETOI REGU' ;
  2393. TAC1.4 = 'MARQ LOSA REGU' ;
  2394. TAC1.5 = 'MARQ CARR REGU' ;
  2395. TAC1.6 = 'MARQ TRIB REGU' ;
  2396. *
  2397. TAC2 = TABLE ;
  2398. TAC2.1 = 'MARQ CARR REGU' ;
  2399. TAC2.2 = 'MARQ LOSA REGU' ;
  2400. TAC2.3 = 'MARQ TRIA REGU' ;
  2401. TAC2.4 = 'MARQ TRIB REGU' ;
  2402. *
  2403. SI ( NON ( EXISTE TAB_1 C_TRACE ) ) ;
  2404. TAB_1.C_TRACE = FAUX ;
  2405. FINSI ;
  2406. *
  2407. SI L1TRAC ;
  2408. SI TAB_1.C_TRACE ;
  2409. SI ( EGA TAB_1.L_SUBNB 'YIN' ) ;
  2410. TITRE 'CONVECTIVE AND SUBCOOLED BOILING CORRELATIONS' ;
  2411. DESSIN ( EVOFC_DB ET EVOFC_ST ET EVOFC_P ET EVOFB_T1 ET EVOFB_JL ET EVFB_YIN) XBOR 0. 400. YBOR 0. 7.E7 LEGE TAC1 ;
  2412. SINON ;
  2413. TITRE 'CONVECTIVE AND SUBCOOLED BOILING CORRELATIONS' ;
  2414. DESSIN ( EVOFC_DB ET EVOFC_ST ET EVOFC_P ET EVOFB_T1 ET EVOFB_JL) XBOR 0. 400. YBOR 0. 7.E7 LEGE TAC1 ;
  2415. TAB_1.EVOFC_D1 = EVOFC_DB ;
  2416. TAB_1.EVOFC_S1 = EVOFC_ST ;
  2417. TAB_1.EVOFC_P1 = EVOFC_P ;
  2418. TAB_1.EVOFC_M1 = EVOFC_JB ;
  2419. TAB_1.EVOFB_T2 = EVOFB_T1 ;
  2420. TAB_1.EVOFB_J1 = EVOFB_JL ;
  2421. FINSI ;
  2422. FINSI ;
  2423. SI ( TAB_1 . PFIXTONB ) ;
  2424. DESSIN TAB_1.EV_TETA XBOR T_LOC1 400. YBOR 0. 150000. MIMA ;
  2425. FINSI ;
  2426. DESSIN ( EVOFC ET TAB_1.EVOFE1 ET EVOFT ) XBOR 0. 400. YBOR 0. 7.E7 MIMA LEGE TAC2 ;
  2427. DESSIN TAB_1.ECONVEC1 XBOR 0. 400. YBOR 0. 700000. MIMA ;
  2428. FINSI ;
  2429. TAB_1.EVOFC1 = EVOFC ;
  2430. TAB_1.EVOFT1 = EVOFT ;
  2431. *
  2432. SI (NIVEAU >EG 4) ;
  2433. MESS '-----------------------------------> exit from @CALHCON ';
  2434. FINSI ;
  2435.  
  2436. FINPROC ;
  2437. **** @CALHRAY
  2438. DEBPROC @CALHRAY TAB1*TABLE ;
  2439. MESS ' ';
  2440. *
  2441. * !!! R. MITTEAU !!! attention, procedure standard
  2442. *
  2443. * un pointeur dans /CASTEM9X/procedures pointe sur cette procedure
  2444. * pour les mises a jour
  2445. *
  2446. *-------------------------------------------------------------------*
  2447. * *
  2448. * COEFFICIENT D ECHANGE TENANT COMPTE *
  2449. * DU RAYONNEMENT *
  2450. * *
  2451. *-------------------------------------------------------------------*
  2452. *23456789012345678901234567890123456789012345678901234567890123456789012
  2453. * 1 2 3 4 5 6 7
  2454. *
  2455. * --- entrees
  2456. *
  2457. TZERO = TAB1.'TEMP_RAYO' ;
  2458. EPS1 = TAB1.'EMISSIVITE' ;
  2459. AB_2 = TAB1.'ABSORPTION' ;
  2460. NIVEAU1 = TAB1.'NIVEAU' ;
  2461. LTRAC = TAB1.'TRAC_GRAPHE' ;
  2462.  
  2463. SI (NIVEAU1 >EG 4 ) ;
  2464. MESS '-----------------------------------> calling @CALHRAY ';
  2465. FINSI ;
  2466.  
  2467. LTEMR = PROG -5000. 0. 50. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 1300. 1400. 1500. 1600. 1700. 1800. 1900. 2000. 2100. 2200. 2300. 2400. 2500. 2600. 2700. 2800. 2900. 3000. 3100. 3200. 3300. 3400. 3500. 3600. 3700. 3800. 3900. 2.E4 ;
  2468. SIGMA =5.67E-8 ;
  2469. TZK = 273.3 ;
  2470. MESS '>@CALHRAY> STEFAN CONSTANT : ' SIGMA ;
  2471. MESS '>@CALHRAY> TZERO DEG. C : ' TZERO ;
  2472. MESS '>@CALHRAY> EMISSIVITY : ' EPS1 ;
  2473. MESS '>@CALHRAY> ABSORPTION : ' AB_2 ;
  2474. TZERK = TZERO + TZK ;
  2475. * MESS ' TEMP H FR ' ;
  2476. LISTH = PROG ;
  2477. LISFE = PROG ;
  2478. IH1 = 0 ;
  2479. REPETER CAH1 ( DIME LTEMR ) ;
  2480. IH1 = IH1 + 1 ;
  2481. TEMP = EXTR LTEMR IH1 ;
  2482. TEMK = TEMP + TZK ;
  2483. EPSEQ = (( 1./EPS1 ) + (1./AB_2) - 1.) ** -1 ;
  2484. * FE = SIGMA * ((EPS1 * ( TEMK ** 4 )) - (AB_2 * ( TZERK ** 4 )));
  2485. FE = SIGMA * EPSEQ *( ( TEMK ** 4 ) - ( TZERK ** 4 ) ) ;
  2486. * H1 = TEMK ** 3 ;
  2487. * H2 = ( TEMK ** 2 ) * ( TZERK ) ;
  2488. * H3 = ( TEMK ) * ( TZERK ** 2 ) ;
  2489. * H4 = TZERK ** 3 ;
  2490. * H = SIGMA * EPS1 * ( H1 + H2 + H3 + H4 ) ;
  2491. SI ( EGA TEMK TZERK 1. ) ;
  2492. H = FE / 1. ;
  2493. SINON ;
  2494. H = FE / ( TEMK - TZERK ) ;
  2495. FINSI ;
  2496. LISTH = LISTH ET ( PROG H ) ;
  2497. LISFE = LISFE ET ( PROG FE ) ;
  2498. * MESS TEMP H FE ;
  2499. FIN CAH1 ;
  2500. TITRE '>@CALHRAY> COEFFICIENT ECHANGE DE RAYONNEMENT ' ;
  2501. ERAYON = EVOL MANU 'TEMPERATURE' LTEMR 'COEFFICIENT ECHANGE' LISTH ;
  2502. TITRE '>@CALHRAY> FLUX DE CHALEUR RAYONNEE ' ;
  2503. EVOFE = EVOL MANU 'TEMPERATURE' LTEMR 'RAYONNEMENT' LISFE ;
  2504. TAB1.EVORAYT1 = EVOFE ;
  2505. TAB1.EHRAYON1 = ERAYON ;
  2506. *
  2507. SI LTRAC ;
  2508. DESSIN EVOFE XBOR 0. 3900. YBOR 0. 4.E6 ;
  2509. DESSIN ERAYON XBOR 0. 3900. YBOR 0. 1500. ;
  2510. FINSI;
  2511. *
  2512. SI (NIVEAU1 >EG 4 ) ;
  2513. MESS '-----------------------------------> exiting @CALHRAY ';
  2514. FINSI ;
  2515. FINPROC ERAYON ;
  2516. **** @CALOR
  2517. 'DEBPROC' @CALOR TAB1*'TABLE ' PUI1*FLOTTANT ;
  2518. MESS ' ' ;
  2519. * pour le calcul de la puissance voir CFLUX
  2520. *
  2521. VIN = TAB1 . V_IN ;
  2522. TIN = TAB1 . T_IN ;
  2523. CPF = @IPOE TIN TAB1.ETCPF ;
  2524. SI ( NON ( EXISTE TAB1 V_EMDOTI)) ;
  2525. RHOIN = @IPOE TIN TAB1.ETRHOF ;
  2526. NNUIN = @IPOE TIN TAB1.ETNNU ;
  2527. GIN = RHOIN * VIN ;
  2528. SI ( EXISTE TAB1 RIP_FLOWS ) ;
  2529. EMDOTI = GIN * ( TAB1 . RIP_FLOWS ) ;
  2530. SINON ;
  2531. SI ( EGA TAB1.HYPERVAP VRAI ) ;
  2532. TAB1.HYP_SM = ( TAB1.LARG_CANAL * TAB1.HMIN_CANAL ) + ( 2. * ( TAB1.LARG_ESP * TAB1.HFIN ) ) ;
  2533. EMDOTI = GIN * TAB1.HYP_SM ;
  2534. SINON ;
  2535. PI = 3.14159 ;
  2536. DIAM1 = TAB1 . D_MAQUETTE ;
  2537. TTAPE = TAB1 . T_TAPE ;
  2538. EMDOTI = GIN * ( ( PI * DIAM1 * DIAM1 / 4. ) - ( DIAM1 * TTAPE) ) ;
  2539. FINSI ;
  2540. FINSI ;
  2541. TAB1.V_EMDOTI = EMDOTI ;
  2542. SINON ;
  2543. EMDOTI = TAB1.V_EMDOTI ;
  2544. FINSI ;
  2545. *
  2546. * Modif jb 01/04/95
  2547. * Possibilite de creer une procedure calculant
  2548. * la section de passage
  2549. *SI ( NON ( EXISTE TAB1 SP ) ) ;
  2550. * SI ( EXISTE TAB1 RIP_FLOWS ) ;
  2551. * TAB1.SP = TAB1.RIP_FLOWS ;
  2552. * FINSI ;
  2553. * SI ( EGA TAB1.HYPERVAP VRAI ) ;
  2554. * TAB1.HYP_SM = ( TAB1.LARG_CANAL * TAB1.HMIN_CANAL ) +
  2555. * ( 2. * ( TAB1.LARG_ESP * TAB1.HFIN ) ) ;
  2556. * TAB1.SP = TAB1.HYP_SM ;
  2557. * SINON ;
  2558. * PI = 3.14159 ;
  2559. * DIAM1 = TAB1 . D_MAQUETTE ;
  2560. * TTAPE = TAB1 . T_TAPE ;
  2561. * TAB1.SP = ( PI * DIAM1 * DIAM1 / 4. ) - ( DIAM1 * TTAPE) ;
  2562. * FINSI ;
  2563. *EMDOTI = GIN * TAB1.SP ;
  2564. *
  2565. DELT = PUI1 / (EMDOTI * CPF) ;
  2566. TOUT = TIN + DELT ;
  2567. TAB1.TEMPE_OUT = TOUT ;
  2568. SI ( EGA TAB1.HYPERVAP VRAI ) ;
  2569. TAB1.'T_LOCAL' = TIN ;
  2570. TAB1.'T_MOY' = TIN ;
  2571. SINON ;
  2572. TAB1.'T_LOCAL' = TIN + ((TOUT - TIN) * TAB1.X_LOCAL) ;
  2573. TAB1.'T_MOY' = (TIN + TOUT) / 2. ;
  2574. FINSI ;
  2575. MESS '>@CALOR> TIN :' TIN ;
  2576. MESS '>@CALOR> TOUT DT :' TOUT DELT ;
  2577. MESS '>@CALOR> TMOY :' TAB1.'T_MOY' ;
  2578. MESS '>@CALOR> T_LOCAL :' TAB1.'T_LOCAL' ;
  2579. FINPROC ;
  2580. **** @CAPKPC
  2581. DEBPROC @CAPKPC EV_1*EVOLUTION PC_1*FLOTTANT D_1*FLOTTANT FL_INC*FLOTTANT NIV1/ENTIER;
  2582. *
  2583. * !!! R. MITTEAU !!! attention, procedure standard
  2584. *
  2585. * un pointeur dans /CASTEM9X/procedures pointe sur cette procedure
  2586. * pour les mises a jour
  2587. *
  2588. * calcul du peaking factor correspondant au pourcentage PC_1
  2589. * FL_INC flux incident moyen
  2590. * EV_1 evolution donnant le flux en paroi d eau
  2591. SI (NON (EXISTE NIV1));
  2592. MESS '---------------------------------> calling @CAPKPC';
  2593. SINON;
  2594. SI (NIV1 >EG 4);
  2595. MESS '---------------------------------> calling @CAPKPC';
  2596. FINSI;
  2597. FINSI;
  2598. P_X_1 = EXTR EV_1 'ABSC' 1 ;
  2599. P_Y_1 = EXTR EV_1 'ORDO' 1 ;
  2600. N1 = DIME P_X_1 ;
  2601. VINT0 = MAXI (INTG ( EVOL MANU P_X_1 P_Y_1 )) ;
  2602. SI ( PC_1 >EG 1. ) ;
  2603. MESS ' >>>>> CAPKPC POURCENTAGE SUPERIEUR A 1 ' ;
  2604. ERRE ' >>>>> CAPKPC POURCENTAGE SUPERIEUR A 1 ' ;
  2605. FINSI ;
  2606. VA_1 = PC_1 * VINT0 ;
  2607. VINT1 = VINT0 ;
  2608. REPETER B__1 N1 ;
  2609. I_1 = DIME P_X_1 ;
  2610. P_X_2 = ENLE P_X_1 I_1 ;
  2611. P_Y_2 = ENLE P_Y_1 I_1 ;
  2612. VINT2 = MAXI (INTG ( EVOL MANU P_X_2 P_Y_2 )) ;
  2613. SI( VINT2 &lt;EG VA_1 ) ;
  2614. X_1 = EXTR P_X_1 I_1 ;
  2615. X_2 = EXTR P_X_1 (I_1 - 1) ;
  2616. Y_1 = EXTR P_Y_1 I_1 ;
  2617. Y_2 = EXTR P_Y_1 (I_1 - 1) ;
  2618. PENTE = (Y_1 - Y_2) / (X_1 - X_2) ;
  2619. DELTA = Y_2 ** 2 + ( 2. * PENTE *( VA_1 - VINT2 )) ;
  2620. SI ( DELTA < 0. ) ;
  2621. MESS ' >>>>> CAPKPC y a un truc DELTA < 0. ' ;
  2622. MESS ' >>>>> CAPKPC VINT2 VINT1 VA_1 ' VINT2 VINT1 VA_1 ;
  2623. MESS ' >>>>> CAPKPC Y_2 X_2 Y_1 X_1 ' Y_2 X_2 Y_1 X_1 ;
  2624. FINSI ;
  2625. * X_11 = X_2 + ((X_1 - X_2) / ( VINT1 - VINT2 )
  2626. * * ( VA_1 - VINT2 )) ;
  2627. RDELT = DELTA ** 0.5 ;
  2628. DX_11 = ( (-1. * Y_2) + RDELT ) / PENTE ;
  2629. X_11 = X_2 + DX_11 ;
  2630. SI ( (DX_11 * ( X_11 - X_1)) > 0. ) ;
  2631. MESS ' >>>>> CAPKPC y a un truc X_11 X_1 X_2 ' X_11 X_1 X_2;
  2632. MESS ' >>>>> CAPKPC VINT2 VINT1 VA_1 ' VINT2 VINT1 VA_1 ;
  2633. MESS ' >>>>> CAPKPC Y_2 X_2 Y_1 X_1 ' Y_2 X_2 Y_1 X_1 ;
  2634. MESS ' >>>>> CAPKPC PENTE DELTA RDELT' PENTE DELTA RDELT ;
  2635. FINSI ;
  2636. QUITTER B__1 ;
  2637. FINSI ;
  2638. P_X_1 = P_X_2 ;
  2639. P_Y_1 = P_Y_2 ;
  2640. VINT1 = VINT2 ;
  2641. FIN B__1 ;
  2642. FL_PC = VINT0 / X_11 ;
  2643. AL_1 = 2.* X_11 / D_1 ;
  2644. PKF_1 = FL_PC / FL_INC ;
  2645.  
  2646. SI (NON (EXISTE NIV1));
  2647. MESS '---------------------------------> exiting @CAPKPC';
  2648. SINON;
  2649. SI (NIV1 >EG 4);
  2650. MESS '---------------------------------> exiting @CAPKPC';
  2651. FINSI;
  2652. FINSI;
  2653. FINPROC AL_1 PKF_1 ;
  2654. **** @CBGMV
  2655. DEBPROC @CBGMV BXG*CHPOINT BYG*CHPOINT BZG*CHPOINT TAB1*TABLE ;
  2656. *
  2657. ********************************************************************
  2658. * Procedure de changement de base. On passe de la base cartesienne *
  2659. * globale de la machine definie par l'axe du tore dirige suivant *
  2660. * Z et l'axe X situe dans le plan median entre deux bobines a la *
  2661. * base cartesienne du maillage. *
  2662. * Trois cas sont etudies : 3D, 2D en coupe Phi constant et 2D en *
  2663. * coupe Theta constant. Alain MOAL (Decembre 1995-Janvier 1996) *
  2664. ********************************************************************
  2665. *
  2666. *--------------- VARIABLES D'ENTREE :
  2667. SI ((VALEUR DIME) EGA 2) ;
  2668. IPLAN = TAB1.<PLAN ;
  2669. SI (EGA IPLAN 'PHICONS') ;
  2670. CT0 = TAB1.<CENTRE_TORE ;
  2671. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  2672. P1 = TAB1.<POINT_SUR_OBJET ;
  2673. FINSI ;
  2674. SI (EGA IPLAN 'THECONS') ;
  2675. THETA0 = TAB1.<THETA0 ;
  2676. CP = TAB1.CENTRE_PLASMA ;
  2677. RP = TAB1.<RP ;
  2678. HP = TAB1.<HP ;
  2679. FINSI ;
  2680. SINON ;
  2681. CT0 = TAB1.<CENTRE_TORE ;
  2682. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  2683. P1 = TAB1.<POINT_SUR_OBJET ;
  2684. FINSI ;
  2685. ANGPHI0 = TAB1.<ANG_PHI0 ;
  2686. *------------------------------------
  2687. *
  2688. DIM0 = VALEUR DIME ;
  2689. SI (DIM0 EGA 2) ;
  2690. FINSI ;
  2691. *
  2692. SI (((DIM0 EGA 2) ET (EGA IPLAN 'PHICONS')) OU (DIM0 EGA 3)) ;
  2693. X0 Y0 Z0 = COOR CT0 ;
  2694. X1 Y1 Z1 = COOR CT1 ;
  2695. XP1 YP1 ZP1 = COOR P1 ;
  2696. *
  2697. * ---- Calcul des coordonnees du point P0, projection du point P1 de
  2698. * ---- l'objet dans le plan orthogonal a l'axe du tore en CT0.
  2699. A = X1 - X0 ;
  2700. B = Y1 - Y0 ;
  2701. C = Z1 - Z0 ;
  2702. *
  2703. SI (A EGA 0.) ;
  2704. SI (B EGA 0.) ;
  2705. XP0 = XP1 ;
  2706. YP0 = YP1 ;
  2707. ZP0 = Z0 ;
  2708. FINSI ;
  2709. SI (C EGA 0.) ;
  2710. XP0 = XP1 ;
  2711. YP0 = Y0 ;
  2712. ZP0 = ZP1 ;
  2713. FINSI ;
  2714. SI ((B NEG 0.) ET (C NEG 0.)) ;
  2715. XP0 = XP1 ;
  2716. YP0 = (-1.*B*C*ZP1 + (C*C*YP1) + (B*B*Y0) + (B*C*Z0)) /(B*B + (C*C)) ;
  2717. ZP0 = (B*ZP1 - (C*YP1) + (C*(Y0+Z0)))/(B+C);
  2718. FINSI ;
  2719. SINON ;
  2720. AUX1 = A / (A*A + (B*B) + (C*C)) ;
  2721. AUX2 = (B*B + (C*C)) / A ;
  2722. XP0 = AUX1 * (A*X0 + (B*Y0) + (C*Z0) + (AUX2*XP1) - (B*YP1) - (C*ZP1)) ;
  2723. YP0 = B * (XP0 - XP1) / A + YP1 ;
  2724. ZP0 = C * (XP0 - XP1) / A + ZP1 ;
  2725. FINSI ;
  2726. *
  2727. P0 = XP0 YP0 ZP0 ;
  2728. *
  2729. * ---- Rotation de la ligne (CT0,P0) pour l'aligner sur l'axe X
  2730. * ---- du repere global
  2731. LIG0 = CT0 D 1 P0 ;
  2732. LIG1 = LIG0 TOUR (-1.*ANGPHI0) CT0 CT1 ;
  2733. *
  2734. * ---- Calcul des 3 vecteurs unitaires du repere global
  2735. P0X = LIG1 POIN FINAL ;
  2736. DIR1 = P0X MOIN CT0 ;
  2737. VEC1 = DIR1 / (NORM DIR1) ;
  2738. DIR3 = CT1 MOIN CT0 ;
  2739. VEC3 = DIR3 / (NORM DIR3) ;
  2740. VEC2 = VEC3 PVEC VEC1 ;
  2741. *
  2742. * ---- Changement de repere
  2743. A1 B1 C1 = COOR VEC1 ;
  2744. A2 B2 C2 = COOR VEC2 ;
  2745. A3 B3 C3 = COOR VEC3 ;
  2746. *
  2747. BXM = (A1 * BXG) + (A2 * BYG) + (A3 * BZG) ;
  2748. BYM = (B1 * BXG) + (B2 * BYG) + (B3 * BZG) ;
  2749. BZM = (C1 * BXG) + (C2 * BYG) + (C3 * BZG) ;
  2750. *
  2751. SINON ;
  2752. *
  2753. * ---- en 2D pour une section a Theta constant
  2754. XCP YCP ZCP = COOR CP ;
  2755. NORM_CP = (XCP*XCP + (YCP*YCP) + (ZCP*ZCP))**0.5 ;
  2756. ANG1 = ATG XCP YCP ;
  2757. *
  2758. * ---- Rotation de (90 + ANGPHI0) par rapport a l'axe Z
  2759. BX1 = -1. * BXG * (SIN ANGPHI0) + (BYG * (COS ANGPHI0)) ;
  2760. BY1 = -1. * BXG * (COS ANGPHI0) - (BYG * (SIN ANGPHI0)) ;
  2761. BZ1 = BZG ;
  2762. *
  2763. * ---- Rotation de -THETA0 par rapport a l'axe X
  2764. BX2 = BX1 ;
  2765. BY2 = BY1 * (COS THETA0) - (BZ1 * (SIN THETA0)) ;
  2766. BZ2 = BY1 * (SIN THETA0) + (BZ1 * (COS THETA0)) ;
  2767. *
  2768. * ---- Rotation de ANG1 par rapport a l'axe Z
  2769. BXM = BX2 * (COS ANG1) + (BY2 * (SIN ANG1)) ;
  2770. BYM = -1. * BX2 * (SIN ANG1) + (BY2 * (COS ANG1)) ;
  2771. BZM = BZ2 ;
  2772. *
  2773. FINSI ;
  2774.  
  2775. SI (DIM0 EGA 2) ;
  2776. FINSI ;
  2777. *
  2778. FINPROC BXM BYM BZM ;
  2779. **** @CBGTV
  2780. DEBPROC @CBGTV BX*CHPOINT BY*CHPOINT BZ*CHPOINT THETA*CHPOINT PHI*CHPOINT ;
  2781. *
  2782. **********************************************************************
  2783. * Procedure de changement de base pour un vecteur B de coordonnees *
  2784. * BX, BY, BZ dans la base globale aux coordonnees pseudo-toroidales *
  2785. * BRHO, BTHETA, BPHI. Alain MOAL (mars 1996) *
  2786. **********************************************************************
  2787. *
  2788. *---- Rotation de Phi autour de "l'axe Theta"
  2789. BRHO1 = (COS PHI) * BX + ((SIN PHI) * BY) ;
  2790. BTHETA1 = BZ ;
  2791. BPHI1 = -1.*(SIN PHI) * BX + ((COS PHI) * BY) ;
  2792. *
  2793. *---- Rotation de Theta autour de "l'axe Phi"
  2794. BRHO = (COS THETA) * BRHO1 + ((SIN THETA) * BTHETA1) ;
  2795. BTHETA = -1.*(SIN THETA) * BRHO1 + ((COS THETA) * BTHETA1) ;
  2796. BPHI = BPHI1 ;
  2797. *
  2798. FINPROC BRHO BTHETA BPHI ;
  2799. **** @CBLMV
  2800. DEBPROC @CBLMV VXL*CHPOINT VYL*CHPOINT VZL*CHPOINT TAB1*TABLE ;
  2801. *
  2802. ********************************************************************
  2803. * Version amelioree de l'ancien @CBLMV rebaptise @ACBLM *
  2804. * Procedure de changement de base. On passe de la base cartesienne *
  2805. * locale de l'objet modelise a la base cartesienne du maillage. *
  2806. * l'axe Y est dirige du point de tangence au plasma vers le centre *
  2807. * du plasma. En 3D, L'axe X du repere local est dans la direction *
  2808. * toroidale. *
  2809. * en 2D cas PHICONS l'axe Z du repere local est l'axe toroidal *
  2810. * en 2D cas THECONS l'axe x du repere local est l'axe toroidal *
  2811. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  2812. ********************************************************************
  2813. *
  2814. *--------------- VARIABLES D'ENTREE :
  2815. CP = TAB1.CENTRE_PLASMA ;
  2816. PTG = TAB1.PT_TGPLASMA ;
  2817. SI ((VALEUR DIME) EGA 2) ;
  2818. SI (EXISTE TAB1 <PLAN) ;
  2819. IPLAN = TAB1.<PLAN ;
  2820. SINON ;
  2821. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  2822. FINSI ;
  2823. SINON ;
  2824. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  2825. DIR1 = TAB1.<DIR_TOROIDAL ;
  2826. SINON ;
  2827. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  2828. FINSI ;
  2829. FINSI ;
  2830. *------------------------------------
  2831. *
  2832. SI ((VALEUR DIME) EGA 2) ;
  2833. VECT0 = CP MOINS PTG ;
  2834. VX VY = COOR VECT0 ;
  2835. *
  2836. * ---- calcul de l'angle de rotation dans le plan XY
  2837. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  2838. ANG1 = 0. ;
  2839. SINON ;
  2840. ANG1 = -1.* (ATG VX VY) ;
  2841. FINSI ;
  2842. *
  2843. SI (EGA IPLAN 'PHICONS');
  2844. * ---- Coupe 2D a Phi constant
  2845. VXL1 = VZL ;
  2846. VYL1 = VYL ;
  2847. VZL1 = VXL * (-1.);
  2848. * ---- rotation
  2849. VXM = VXL1 * (COS ANG1) + (VYL1 * (-1.) * (SIN ANG1));
  2850. VYM = VXL1 * (SIN ANG1) + (VYL1 * (COS ANG1)) ;
  2851. VZM = VZL1 ;
  2852. FINSI ;
  2853. SI (EGA IPLAN 'THECONS');
  2854. * ---- Coupe 2D a Theta constant
  2855. * ---- rotation
  2856. VXM = VXL * (COS ANG1) + (VYL * (-1.) * (SIN ANG1)) ;
  2857. VYM = VXL * (SIN ANG1) + (VYL * (COS ANG1)) ;
  2858. VZM = VZL ;
  2859. FINSI;
  2860. *
  2861. SINON ;
  2862. *
  2863. VEC1 = DIR1 / (NORM DIR1) ;
  2864. DIR2 = CP MOINS PTG ;
  2865. VEC2 = DIR2 / (NORM DIR2) ;
  2866. VEC3 = VEC1 PVEC VEC2 ;
  2867. *
  2868. A1 B1 C1 = COOR VEC1 ;
  2869. A2 B2 C2 = COOR VEC2 ;
  2870. A3 B3 C3 = COOR VEC3 ;
  2871. *
  2872. VXM = (A1 * VXL) + (A2 * VYL) + (A3 * VZL) ;
  2873. VYM = (B1 * VXL) + (B2 * VYL) + (B3 * VZL) ;
  2874. VZM = (C1 * VXL) + (C2 * VYL) + (C3 * VZL) ;
  2875. *
  2876. FINSI ;
  2877. FINPROC VXM VYM VZM ;
  2878.  
  2879. **** @CBMGV
  2880. DEBPROC @CBMGV BXM*CHPOINT BYM*CHPOINT BZM*CHPOINT TAB1*TABLE ;
  2881. *
  2882. ********************************************************************
  2883. * Procedure de changement de base. On passe de la base cartesienne *
  2884. * quelconque du maillage a la base cartesienne globale de la *
  2885. * machine definie par l'axe du tore dirige suivant Z et l'axe X *
  2886. * situe dans le plan median entre deux bobines. *
  2887. * Trois cas sont etudies : 3D, 2D en coupe Phi constant et 2D en *
  2888. * coupe Theta constant. Alain MOAL (Decembre 1995-Janvier 1996) *
  2889. ********************************************************************
  2890. *
  2891. *--------------- VARIABLES D'ENTREE :
  2892. SI ((VALEUR DIME) EGA 2) ;
  2893. IPLAN = TAB1.<PLAN ;
  2894. SI (EGA IPLAN 'PHICONS') ;
  2895. CT0 = TAB1.<CENTRE_TORE ;
  2896. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  2897. P1 = TAB1.<POINT_SUR_OBJET ;
  2898. FINSI ;
  2899. SI (EGA IPLAN 'THECONS') ;
  2900. THETA0 = TAB1.<THETA0 ;
  2901. CP = TAB1.CENTRE_PLASMA ;
  2902. RP = TAB1.<RP ;
  2903. HP = TAB1.<HP ;
  2904. FINSI ;
  2905. SINON ;
  2906. CT0 = TAB1.<CENTRE_TORE ;
  2907. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  2908. P1 = TAB1.<POINT_SUR_OBJET ;
  2909. FINSI ;
  2910. ANGPHI0 = TAB1.<ANG_PHI0 ;
  2911. *------------------------------------
  2912. *
  2913. DIM0 = VALEUR DIME ;
  2914. SI (DIM0 EGA 2) ;
  2915. FINSI ;
  2916. *
  2917. SI (((DIM0 EGA 2) ET (EGA IPLAN 'PHICONS')) OU (DIM0 EGA 3)) ;
  2918. * ---- en 3D ou en 2D pour la section Phi constant
  2919. X0 Y0 Z0 = COOR CT0 ;
  2920. X1 Y1 Z1 = COOR CT1 ;
  2921. XP1 YP1 ZP1 = COOR P1 ;
  2922. *
  2923. * ---- Calcul des coordonnees du point P0, projection du point P1 de
  2924. * ---- l'objet dans le plan orthogonal a l'axe du tore en CT0.
  2925. A = X1 - X0 ;
  2926. B = Y1 - Y0 ;
  2927. C = Z1 - Z0 ;
  2928. *
  2929. SI (A EGA 0.) ;
  2930. SI (B EGA 0.) ;
  2931. XP0 = XP1 ;
  2932. YP0 = YP1 ;
  2933. ZP0 = Z0 ;
  2934. FINSI ;
  2935. SI (C EGA 0.) ;
  2936. XP0 = XP1 ;
  2937. YP0 = Y0 ;
  2938. ZP0 = ZP1 ;
  2939. FINSI ;
  2940. SI ((B NEG 0.) ET (C NEG 0.)) ;
  2941. XP0 = XP1 ;
  2942. YP0 = (-1.*B*C*ZP1 + (C*C*YP1) + (B*B*Y0) + (B*C*Z0)) /(B*B + (C*C)) ;
  2943. ZP0 = (B*ZP1 - (C*YP1) + (C*(Y0+Z0)))/(B+C);
  2944. FINSI ;
  2945. SINON ;
  2946. AUX1 = A / (A*A + (B*B) + (C*C)) ;
  2947. AUX2 = (B*B + (C*C)) / A ;
  2948. XP0 = AUX1 * (A*X0 + (B*Y0) + (C*Z0) + (AUX2*XP1) - (B*YP1) - (C*ZP1)) ;
  2949. YP0 = B * (XP0 - XP1) / A + YP1 ;
  2950. ZP0 = C * (XP0 - XP1) / A + ZP1 ;
  2951. FINSI ;
  2952. *
  2953. P0 = XP0 YP0 ZP0 ;
  2954. *
  2955. * ---- Rotation de la ligne (CT0,P0) pour l'aligner sur l'axe X
  2956. * ---- du repere global
  2957. LIG0 = CT0 D 1 P0 ;
  2958. LIG1 = LIG0 TOUR (-1.*ANGPHI0) CT0 CT1 ;
  2959. *
  2960. * ---- Calcul des 3 vecteurs unitaires du repere global
  2961. P0X = LIG1 POIN FINAL ;
  2962. DIR1 = P0X MOIN CT0 ;
  2963. VEC1 = DIR1 / (NORM DIR1) ;
  2964. DIR3 = CT1 MOIN CT0 ;
  2965. VEC3 = DIR3 / (NORM DIR3) ;
  2966. VEC2 = VEC3 PVEC VEC1 ;
  2967. *
  2968. * ---- Changement de repere
  2969. A1 B1 C1 = COOR VEC1 ;
  2970. A2 B2 C2 = COOR VEC2 ;
  2971. A3 B3 C3 = COOR VEC3 ;
  2972. *
  2973. BXG = (A1 * BXM) + (B1 * BYM) + (C1 * BZM) ;
  2974. BYG = (A2 * BXM) + (B2 * BYM) + (C2 * BZM) ;
  2975. BZG = (A3 * BXM) + (B3 * BYM) + (C3 * BZM) ;
  2976. *
  2977. SINON ;
  2978. * ---- en 2D pour une section a Theta constant
  2979. *
  2980. XCP YCP ZCP = COOR CP ;
  2981. NORM_CP = (XCP*XCP + (YCP*YCP) + (ZCP*ZCP))**0.5 ;
  2982. ANG1 = ATG XCP YCP ;
  2983. *
  2984. * ---- Rotation de - ANG1 par rapport a l'axe Z
  2985. BX1 = BXM * (COS ANG1) - (BYM * (SIN ANG1)) ;
  2986. BY1 = BXM * (SIN ANG1) + (BYM * (COS ANG1)) ;
  2987. BZ1 = BZM ;
  2988. *
  2989. * ---- Rotation de THETA0 par rapport a l'axe X
  2990. BX2 = BX1 ;
  2991. BY2 = BY1 * (COS THETA0) + (BZ1 * (SIN THETA0)) ;
  2992. BZ2 = -1. * BY1 * (SIN THETA0) + (BZ1 * (COS THETA0)) ;
  2993. *
  2994. * ---- Rotation de -(90 + ANGPHI0) par rapport a l'axe Z
  2995. BXG = -1. * BX2 * (SIN ANGPHI0) - (BY2 * (COS ANGPHI0)) ;
  2996. BYG = BX2 * (COS ANGPHI0) - (BY2 * (SIN ANGPHI0)) ;
  2997. BZG = BZ2 ;
  2998. *
  2999. FINSI;
  3000. *
  3001. SI (DIM0 EGA 2) ;
  3002. FINSI ;
  3003. *
  3004. FINPROC BXG BYG BZG ;
  3005.  
  3006. **** @CBMLV
  3007. DEBPROC @CBMLV VXM*CHPOINT VYM*CHPOINT VZM*CHPOINT TAB1*TABLE ;
  3008. *
  3009. ********************************************************************
  3010. * Version amelioree de l'ancien @CBMLV rebaptise @ACBML *
  3011. * Procedure de changement de base. On passe de la base cartesienne *
  3012. * du maillage a la base cartesienne locale de l'objet modelise. *
  3013. * l'axe Y final est dirige du point de tangence vers le centre du *
  3014. * plasma. En 3D l'axe x du repere local est donne par la direction *
  3015. * toroidale *
  3016. * en 2D cas PHICONS l'axe Z initial est l'axe toroidal *
  3017. * en 2D cas THECONS l'axe x initial est l'axe toroidal *
  3018. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  3019. ********************************************************************
  3020. *
  3021. *--------------- VARIABLES D'ENTREE :
  3022. CP = TAB1.CENTRE_PLASMA ;
  3023. PTG = TAB1.PT_TGPLASMA ;
  3024. SI ((VALEUR DIME) EGA 2) ;
  3025. SI (EXISTE TAB1 <PLAN) ;
  3026. IPLAN = TAB1.<PLAN ;
  3027. SINON ;
  3028. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  3029. FINSI ;
  3030. SINON ;
  3031. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  3032. DIR1 = TAB1.<DIR_TOROIDAL ;
  3033. SINON ;
  3034. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  3035. FINSI ;
  3036. FINSI ;
  3037. *------------------------------------
  3038. *
  3039. SI ((VALEUR DIME) EGA 2) ;
  3040. VECT0 = CP MOINS PTG ;
  3041. VX VY = COOR VECT0 ;
  3042. *
  3043. * ---- calcul de l'angle de rotation dans le plan XY
  3044. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  3045. ANG1 = 0. ;
  3046. SINON ;
  3047. ANG1 = -1.* (ATG VX VY) ;
  3048. FINSI ;
  3049. *
  3050. * ---- rotation pour aligner l'axe Y avec VECT0
  3051. SI (EGA IPLAN 'PHICONS');
  3052. * ---- Coupe 2D a Phi constant
  3053. VXL1 = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  3054. VYL1 = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  3055. VZL1 = VZM ;
  3056. * ---- Coupe 2D a Phi constant
  3057. VXL = VZL1 ;
  3058. VYL = VYL1 ;
  3059. VZL = VXL1 * (-1.);
  3060. FINSI ;
  3061. SI (EGA IPLAN 'THECONS');
  3062. * ---- Coupe 2D a Theta constant
  3063. * ---- rotation
  3064. VXL = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  3065. VYL = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  3066. VZL = VZM ;
  3067. FINSI ;
  3068. *
  3069. SINON ;
  3070. *
  3071. VEC1 = DIR1 / (NORM DIR1) ;
  3072. DIR2 = CP MOINS PTG ;
  3073. VEC2 = DIR2 / (NORM DIR2) ;
  3074. VEC3 = VEC1 PVEC VEC2 ;
  3075. *
  3076. A1 B1 C1 = COOR VEC1 ;
  3077. A2 B2 C2 = COOR VEC2 ;
  3078. A3 B3 C3 = COOR VEC3 ;
  3079. *
  3080. VXL = (A1 * VXM) + (B1 * VYM) + (C1 * VZM) ;
  3081. VYL = (A2 * VXM) + (B2 * VYM) + (C2 * VZM) ;
  3082. VZL = (A3 * VXM) + (B3 * VYM) + (C3 * VZM) ;
  3083. *
  3084. FINSI ;
  3085. FINPROC VXL VYL VZL ;
  3086. **** @CBTGV
  3087. DEBPROC @CBTGV BRHO*CHPOINT BTHETA*CHPOINT BPHI*CHPOINT THETA*CHPOINT PHI*CHPOINT ;
  3088. *
  3089. *********************************************************************
  3090. * Procedure de changement de base pour un vecteur B de coordonnees *
  3091. * BRHO, BPHI, BTHETA dans une base pseudo-toroidale aux coordonnees *
  3092. * cartesiennes BX, BY, BZ dans la base globale de la machine. *
  3093. * Alain MOAL (decembre 1995) *
  3094. *********************************************************************
  3095. *
  3096. *---- Rotation de - Theta autour de "l'axe Phi"
  3097. BRHO1 = (COS THETA) * BRHO - ((SIN THETA) * BTHETA) ;
  3098. BTHETA1 = (SIN THETA) * BRHO + ((COS THETA) * BTHETA) ;
  3099. BPHI1 = BPHI ;
  3100. *
  3101. *---- Rotation de - Phi autour de "l'axe Theta"
  3102. BRHO2 = (COS PHI) * BRHO1 - ((SIN PHI) * BPHI1) ;
  3103. BTHETA2 = BTHETA1 ;
  3104. BPHI2 = (SIN PHI) * BRHO1 + ((COS PHI) * BPHI1) ;
  3105. *
  3106. BX = BRHO2 ;
  3107. BY = BPHI2 ;
  3108. BZ = BTHETA2 ;
  3109. *
  3110. FINPROC BX BY BZ ;
  3111. **** @CBTLV
  3112. DEBPROC @CBTLV BRHO*CHPOINT BTHETA*CHPOINT BPHI*CHPOINT THETA*CHPOINT PHI*CHPOINT TAB1*TABLE ;
  3113. *
  3114. *********************************************************************
  3115. * Procedure de changement de base pour un vecteur B de coordonnees *
  3116. * BRHO, BPHI, BTHETA dans une base pseudo-toroidale aux coordonnees *
  3117. * cartesiennes BX, BY, BZ dans la base de l'objet. *
  3118. * Alain MOAL (juin 1995) *
  3119. *********************************************************************
  3120. *
  3121. *--------------- VARIABLES D'ENTREE :
  3122. THETA0 = TAB1.<THETA0 ;
  3123. *------------------------------------
  3124. *
  3125. CT = COS THETA ;
  3126. ST = SIN THETA ;
  3127. CT0 = COS THETA0 ;
  3128. ST0 = SIN THETA0 ;
  3129. MST0 = ST0 * -1. ;
  3130. CPHI = COS PHI ;
  3131. SPHI = SIN PHI ;
  3132. MSPHI= SPHI * -1. ;
  3133. *
  3134. *---- 1) rotation de - Theta autour de "l'axe Phi"
  3135. BRHO1 = (CT * BRHO) - (ST * BTHETA) ;
  3136. BTHETA1 = (ST * BRHO) + (CT * BTHETA) ;
  3137. BPHI1 = BPHI ;
  3138. *
  3139. *---- 2) rotation de - Phi autour de "l'axe Theta"
  3140. BRHO2 = (CPHI * BRHO1) + (MSPHI * BPHI1) ;
  3141. BTHETA2 = BTHETA1 ;
  3142. BPHI2 = (SPHI * BRHO1) + (CPHI * BPHI1) ;
  3143. *
  3144. *---- 3) rotation de Theta0 autour de "l'axe Phi"
  3145. BRHO3 = (BRHO2 * CT0) + (BTHETA2 * ST0) ;
  3146. BTHETA3 = (BRHO2 * MST0) + (BTHETA2 * CT0) ;
  3147. BPHI3 = BPHI2 ;
  3148. *
  3149. *---- 4) composantes dans le repere cartesien
  3150. BX = BPHI3 ;
  3151. BY = BRHO3 * -1. ;
  3152. BZ = BTHETA3 ;
  3153. *
  3154. FINPROC BX BY BZ;
  3155. **** PROP_PHY
  3156. DEBPROC PROP_PHY TAB_1*TABLE ;
  3157. ******************************************************************************
  3158. ***** CELATA94 *****
  3159. ******************************************************************************
  3160. * CALCUL DU FLUX CRITIQUE SUIVANT LA CORRELATION DE CELATA 94
  3161. *_____________________________________________________________________________
  3162. *
  3163. *
  3164. *
  3165. *-----------------------------------------------------
  3166. * Calcul des proprietes de l eau a la temperature de
  3167. * saturation correspondant a la pression de sortie
  3168. *-----------------------------------------------------
  3169. *
  3170. @TABEAU TAB_1 ;
  3171. POUT = TAB_1.'P_LOCAL' ;
  3172. TAB_1.TTSAT = @IPOE POUT TAB_1.EPTSAT ;
  3173. TSAT = TAB_1.TTSAT ;
  3174. TAB_1.CCPLOUT = @IPOE TSAT TAB_1.ETCPF ;
  3175. TAB_1.RRHOL = @IPOE TSAT TAB_1.ETRHOF ;
  3176. TAB_1.RRHOV = @IPOE TSAT TAB_1.ETRHOG ;
  3177. TAB_1.LLLV = @IPOE TSAT TAB_1.ETHFG ;
  3178. TAB_1.LLAM = @IPOE TSAT TAB_1.ETLLA ;
  3179. TAB_1.SSIGM = @IPOE TSAT TAB_1.ETSIGM ;
  3180. TAB_1.MMUL = @IPOE TSAT TAB_1.ETNNU ;
  3181. TAB_1.PPRAL = @IPOE TSAT TAB_1.ETPRAF ;
  3182. *
  3183. *-----------------------------------------------------
  3184. * Calcul des proprietes de l eau a la temperature d entree
  3185. *-----------------------------------------------------
  3186. *
  3187. TIN = TAB_1.'T_LOCAL' ;
  3188. TAB_1.CCPLIN = @IPOE TIN TAB_1.ETCPF ;
  3189. TAB_1.RRHOLIN = @IPOE TIN TAB_1.ETRHOF ;
  3190. *
  3191. *-----------------------------------------------------
  3192. * Calcul de quantites utiles
  3193. *-----------------------------------------------------
  3194. *
  3195. PI = 3.1415926 ;
  3196. D = TAB_1.D_MAQUETTE ;
  3197. SI ( NON ( EXISTE TAB_1 T_TAPE ) ) ;
  3198. TAB_1 . T_TAPE = 0. ;
  3199. FINSI ;
  3200. TTAPE = TAB_1 . T_TAPE ;
  3201. SI ( NON ( EXISTE TAB_1 TWIST_RATIO ) ) ;
  3202. TAB_1 . TWIST_RATIO = 0. ;
  3203. FINSI ;
  3204. YTWIST = TAB_1 . TWIST_RATIO ;
  3205. VIN = TAB_1.'V_LOCAL' ;
  3206. *
  3207. *-----------------------------------------------------
  3208. * Prise en compte de l insert torsade
  3209. *-----------------------------------------------------
  3210. *
  3211. SI ( YTWIST EGA 0. ) ;
  3212. TAB_1 . DDH = D ;
  3213. FACV = 1. ;
  3214. VP = VIN ;
  3215. FINSI ;
  3216. SI ( YTWIST > 0. ) ;
  3217. QUAS = 4. * (( PI * D * D / 8. ) - ( TTAPE * D / 2. )) ;
  3218. PERI = (( PI * D / 2. ) - TTAPE + D ) ;
  3219. DH = QUAS / PERI ;
  3220. TAB_1 . DDH = DH ;
  3221. PIS2Y = PI / ( 2. * YTWIST ) ;
  3222. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** ( 1. / 2. ) ;
  3223. FINSI ;
  3224. *-----------------------------------------------------
  3225. * Prise en compte du fil helicoidal
  3226. *-----------------------------------------------------
  3227. *
  3228. SI ( NON ( EXISTE TAB_1 HELI_WIRE ) ) ;
  3229. TAB_1.HELI_WIRE = FAUX ;
  3230. FINSI ;
  3231. SI ( ( YTWIST EGA 0. ) ET ( EGA TAB_1.HELI_WIRE VRAI ) ) ;
  3232. S1 = PI * D1 * D1 / 4. ;
  3233. SM = PI * TAB_1.WIRE_D * TAB_1.WIRE_D / 4. ;
  3234. P1 = PI * D ;
  3235. PM = PI * TAB_1.WIRE_D ;
  3236. DH = 4. * ( S1 - SM ) / ( P1 + PM ) ;
  3237. PIS2Y = PI / ( 2 * TAB_1.PITCH_WIRE ) ;
  3238. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  3239. * FACV = 1. ;
  3240. FINSI ;
  3241. *
  3242. *-----------------------------------------------------
  3243. * Calcul de la vitesse
  3244. *-----------------------------------------------------
  3245. *
  3246. SI (NON (EXISTE TAB_1 FF_SANDIA)) ;
  3247. TAB_1 . FF_SANDIA = FAUX ;
  3248. FINSI ;
  3249. F_SANDIA = TAB_1 . FF_SANDIA ;
  3250. SI ( F_SANDIA EGA VRAI ) ;
  3251. FACV = 1. ;
  3252. FINSI ;
  3253. VP = VIN * FACV ;
  3254. TAB_1 . VITPAROI = VP ;
  3255. *
  3256. *-----------------------------------------------------
  3257. * Prise en compte du chauffage non asymetrique
  3258. *-----------------------------------------------------
  3259. *
  3260. LH = TAB_1 . L_HEATED ;
  3261. SI ( NON ( EXISTE TAB_1 CCHAU_SYM ) ) ;
  3262. TAB_1 . CCHAU_SYM = VRAI ;
  3263. FINSI ;
  3264. SI ( TAB_1 . CCHAU_SYM EGA VRAI ) ;
  3265. TAB_1.HHAR = PI * D * LH ;
  3266. AR = PI * D * D / 4. ;
  3267. SINON ;
  3268. QUAS = 4. * (( PI * D * D / 8. ) - ( TTAPE * D / 2. )) ;
  3269. AR = QUAS / 4. ;
  3270. ** PERI = (( PI * D / 2. ) - TTAPE ) ;
  3271. ** DHC = QUAS / PERI ;
  3272. ** TAB_1.HHAR = PI * ( D / 2. ) * LH ;
  3273. TAB_1.HHAR = D * LH ;
  3274. FINSI ;
  3275. *
  3276. MUL = TAB_1.MMUL ;
  3277. RHOLIN = TAB_1.RRHOLIN ;
  3278. G = RHOLIN * VP ;
  3279. TAB_1.GGAM = RHOLIN * VP * AR ;
  3280. TAB_1.GG = G ;
  3281. REYL = G * TAB_1 . DDH / MUL ;
  3282. *
  3283. *-----------------------------------------------------
  3284. * Calcul du coefficient de frottement
  3285. *-----------------------------------------------------
  3286. *
  3287. * Facteur de Sandia
  3288. * multiplier le coefficient de frottement par
  3289. * 2.75 * ( YTWIST ** ( - 0.406 ) )
  3290. * 2.2 * ( YTWIST ** ( - 0.406 ) )
  3291. FA = 4. * 1.375E-3 * (( 1. + ( 21.544 * ( 0.00375 /( TAB_1 . DDH * 1000. / 2. ))) + ( 100. / REYL )) ** ( 1. / 3. )) ;
  3292. SI ( ( F_SANDIA EGA VRAI ) ET ( YTWIST NEG 0. ) ) ;
  3293. * FA = FA * (2.75 / ( YTWIST ** ( 0.406 ) )) ;
  3294. FA = FA * (2.2 / ( YTWIST ** ( 0.406 ) )) ;
  3295. FINSI ;
  3296. SIGM = TAB_1.SSIGM ;
  3297. RHOL = TAB_1.RRHOL ;
  3298. REPETER BOUCFA 100 ;
  3299. RADEFF = 1.14 - ( 2. * ( LOG ((( 0.72 * SIGM * RHOL ) / ( FA * TAB_1 . DDH * ( G**2 ))) + ( 9.35 / ( REYL *( FA **( 1. / 2. ))))))/( LOG 10 )) ;
  3300. DIF1 = ( RADEFF ** (-2))- FA ;
  3301. DELTAF = ABS (DIF1) ;
  3302. FA = RADEFF**(-2) ;
  3303. SI ( ( F_SANDIA EGA VRAI ) ET ( YTWIST NEG 0. ) ) ;
  3304. * FA = FA * (2.75 * ( YTWIST ** ( -0.406 ) )) ;
  3305. FA = FA * (2.2 * ( YTWIST ** ( -0.406 ) )) ;
  3306. TAB_1.FFA = FA ;
  3307. SINON ;
  3308. TAB_1.FFA = FA ;
  3309. FINSI ;
  3310. SI (DELTAF &lt;EG 1.E-6) ;
  3311. QUITTER BOUCFA ;
  3312. FINSI ;
  3313. FIN BOUCFA ;
  3314. FINPROC ;
  3315. *
  3316. *_____________________________________________________________________________
  3317. *
  3318. **** QCALCO
  3319. DEBPROC QCALCO TAB_1*TABLE Q*FLOTTANT ;
  3320. *
  3321. TIN = TAB_1.T_IN ;
  3322. TSAT = TAB_1.TTSAT ;
  3323. GAM = TAB_1.GGAM ;
  3324. G = TAB_1.GG ;
  3325. HAR = TAB_1.HHAR ;
  3326. *
  3327. *-----------------------------------------------------
  3328. * Calcul de la temperature moyenne du fluide
  3329. *-----------------------------------------------------
  3330. *
  3331. CPLIN = TAB_1.CCPLIN ;
  3332. CPLOUT = TAB_1.CCPLOUT ;
  3333. CPLMED = ( CPLIN + CPLOUT )/ 2. ;
  3334. *MESS ' CPLIN = ' CPLIN ;
  3335. *MESS ' CPLOUT = ' CPLOUT ;
  3336. *MESS ' CPLMED = ' CPLMED ;
  3337. *MESS ' HAR = ' HAR ;
  3338. *MESS ' GAM = ' GAM ;
  3339. *MESS ' Q = ' Q ;
  3340. *TMED = TIN + (( Q * HAR )/( GAM * CPLMED )) ;
  3341. TMED = TIN + (( Q * HAR )/( GAM * CPLIN )) ;
  3342. * MESS 'MEAN FLUID TEMPERATURE (C) :' TMED ;
  3343. *
  3344. *-----------------------------------------------------
  3345. * Calcul de la temperature de la paroi
  3346. *-----------------------------------------------------
  3347. *
  3348. FA = TAB_1.FFA ;
  3349. RHOL = TAB_1.RRHOL ;
  3350. PRAL = TAB_1.PPRAL ;
  3351. MUL = TAB_1.MMUL ;
  3352. D = TAB_1.D_MAQUETTE ;
  3353. *MESS ' FA =' FA ;
  3354. *MESS ' RHOL = ' RHOL ;
  3355. *MESS ' PRAL = ' PRAL ;
  3356. *MESS ' MUL = ' MUL ;
  3357. *MESS ' D = ' D ;
  3358. UTAU = ( FA * ( G **2 ))/(8.*( RHOL**2 ))**(1./2.) ;
  3359. *MESS ' UTAU =' UTAU ;
  3360. QU = Q /(RHOL * CPLOUT * UTAU) ;
  3361. *MESS ' QU = ' QU ;
  3362. R = D / 2. ;
  3363. TT = 1. + (5.* PRAL ) ;
  3364. *MESS ' TT = ' TT ;
  3365. XX = ( R * UTAU * RHOL )/ MUL ;
  3366. *MESS ' XX = ' XX ;
  3367. ZZ = XX - 30. ;
  3368. TW = TMED + ( ( 5. * QU / XX ) * ( (( PRAL / 2. ) * (( 2. * XX ) - 5. )) + (( 5. / PRAL ) * (( TT * ( LOG TT )) + ( 1. - TT ))) + ( ZZ * ( LOG TT )) + (( 1. / 2. ) * ((( LOG ( XX / 30. )) * XX ) + ( 30. - XX ))) ));
  3369. MESS '>QCALCO> WALL TEMPERATURE (C) : ' TW ;
  3370. * MESS ' SATURATION TEMPERATURE (C) : ' TSAT ;
  3371. SI ( TW &lt;EG TSAT ) ;
  3372. IFLAG = 1 ;
  3373. QUITTER QCALCO ;
  3374. MESS '----->>>>>>>>' ;
  3375. FINSI ;
  3376. *
  3377. *-----------------------------------------------------
  3378. * Calcul de l epaisseur de la couche liquide surchauffee
  3379. *-----------------------------------------------------
  3380. *
  3381. *MESS '-----------------------------------> TW>TSAT ' ;
  3382. DT1 = QU * PRAL * 5. ;
  3383. DT2 = 5.* QU * ( PRAL + ( LOG ( 1. + ( 5. * PRAL )))) ;
  3384. SI (( TW - TSAT ) < DT1 ) ;
  3385. YPIU = ( TW - TSAT )/( QU * PRAL ) ;
  3386. SINON ;
  3387. SI (( TW - TSAT ) < DT2 ) ;
  3388. YPIU = 5. + ( ( 5. / PRAL )* ( EXP (( TW - TSAT )/( 5. * QU )- PRAL )- 1. )) ;
  3389. SINON ;
  3390. AA1 = ( TW - TSAT )/( 5. * QU ) ;
  3391. AA2 = 1. + ( 5. * PRAL ) ;
  3392. AA = ( AA1 - PRAL - ( LOG AA2 )) * 2. ;
  3393. YPIU = 30.* (EXP AA) ;
  3394. FINSI ;
  3395. FINSI ;
  3396. YSTAR = ( YPIU * MUL )/( UTAU * RHOL ) ;
  3397. * MESS ' SUPERHEATED LAYER THICKNESS (m) : ' YSTAR ;
  3398. *
  3399. *-----------------------------------------------------
  3400. * Calcul de l epaisseur de l amas de vapeur et de
  3401. * sa distance de la paroi chauffee
  3402. *-----------------------------------------------------
  3403. *
  3404. SIGM = TAB_1.SSIGM ;
  3405. DB = ( 32. / FA ) * ( SIGM * 0.03 * RHOL /( G**2 )) ;
  3406. DELTA = YSTAR - DB ;
  3407. * MESS ' INITIAL LIQUID SUBLAYER THICKNESS (m) : ' DELTA ;
  3408. SI (DELTA &lt;EG 0.) ;
  3409. IFLAG = 1 ;
  3410. QUITTER QCALCO ;
  3411. FINSI ;
  3412. *
  3413. *-----------------------------------------------------
  3414. * Calcul des parametres de l amas de vapeur
  3415. *-----------------------------------------------------
  3416. *
  3417. YPIU = ( DELTA + ( DB / 2. ))* UTAU * RHOL / MUL ;
  3418. SI ( YPIU &lt;EG 5.) ;
  3419. UBL = YPIU * UTAU ;
  3420. * MESS ' YPIU &lt;EG 5. ' ;
  3421. * MESS ' UBL = ' UBL ;
  3422. SINON ;
  3423. SI ( YPIU &lt;EG 30.) ;
  3424. UBL = (( 5. * ( LOG YPIU ) - 3.05 )) * UTAU ;
  3425. * MESS ' YPIU &lt;EG 30. ' ;
  3426. * MESS ' UBL = ' UBL ;
  3427. SINON ;
  3428. UBL = (( 2.5 *( LOG YPIU )) + 5.5 )* UTAU ;
  3429. * MESS ' YPIU > 30. ' ;
  3430. * MESS ' UBL = ' UBL ;
  3431. FINSI ;
  3432. FINSI ;
  3433. RHOV = TAB_1.RRHOV ;
  3434. SI ( NON ( EXISTE TAB_1 FFLOW_HO ) ) ;
  3435. TAB_1 . FFLOW_HO = VRAI ;
  3436. FINSI ;
  3437. SI ( NON ( EXISTE TAB_1 FFLOW_VE ) ) ;
  3438. TAB_1 . FFLOW_VE = FAUX ;
  3439. FINSI ;
  3440. SI ( TAB_1 . FFLOW_HO EGA VRAI ) ;
  3441. UB = UBL ;
  3442. FINSI ;
  3443. SI ( TAB_1 . FFLOW_VE EGA VRAI ) ;
  3444. CD = (2./3.) * DB /(( SIGM /( 9.81 *( RHOL - RHOV )))**(1./2.)) ;
  3445. PI = 3.1415926 ;
  3446. C1 = (( 4.* PI * 9.81 *( RHOL + RHOV ) * ( RHOL - RHOV )) /(( RHOL **2 )* RHOV * CD)) ** (1./2.) ;
  3447. UB1 = ( UBL + ((( UBL **2 ) + ( 4. * C1))**(1./2.)))/2. ;
  3448. UB2 = ( UBL - ((( UBL **2 ) + ( 4. * C1))**(1./2.)))/2. ;
  3449. *UB2<0 toujours
  3450. UB = UB1 ;
  3451. *MESS ' CD = ' CD ;
  3452. *MESS ' C1 = ' C1 ;
  3453. FINSI ;
  3454. *MESS ' UB = ' UB ;
  3455. BLB = (2.*PI*SIGM*(RHOL+RHOV))/(RHOL*RHOV*(UB**2)) ;
  3456. SI (UB &lt;EG 0.) ;
  3457. MESS 'UB<=0 *** ' ;
  3458. IFLAG = 1 ;
  3459. QUITTER QCALCO ;
  3460. FINSI ;
  3461. TAU = BLB/UB ;
  3462. *MESS ' TAU = ' TAU ;
  3463. *MESS ' IFLAG = ' IFLAG ;
  3464. * MESS ' VAPOR BLANKET VELOCITY (m/s) : ' UB ;
  3465. * MESS ' VAPOR BLANKET LENGTH (m) : ' BLB ;
  3466. FINPROC DELTA UB UBL BLB TAU IFLAG ;
  3467. *
  3468. *_____________________________________________________________________________
  3469. *
  3470. **** QUQU
  3471. DEBPROC QUQU TAB_1*TABLE Q*FLOTTANT ;
  3472. *
  3473. DELTA = 0. ;
  3474. UB = 0. ;
  3475. UBL = 0. ;
  3476. BLB = 0. ;
  3477. TAU = 0. ;
  3478. DELTA UB UBL BLB TAU IFLAG = QCALCO TAB_1 Q ;
  3479. SI (IFLAG NEG 0) ;
  3480. * MESS ' On quitte la procedure QUQU sans definir FQ ';
  3481. QUITTER QUQU ;
  3482. FINSI ;
  3483. LLV = TAB_1.LLLV ;
  3484. RHOL = TAB_1.RRHOL ;
  3485. *MESS 'DELTA =' DELTA ;
  3486. *MESS 'RHOL =' RHOL ;
  3487. *MESS 'LLV =' LLV ;
  3488. *MESS 'TAU =' TAU ;
  3489. *MESS 'UB =' UB ;
  3490. *MESS 'UBL =' UBL ;
  3491. *MESS 'Q ='Q ;
  3492. FQ = Q - ( DELTA * RHOL * LLV / TAU) ;
  3493. FINPROC FQ IFLAG ;
  3494. *
  3495. *_____________________________________________________________________________
  3496. *
  3497. **** SECANTI
  3498. DEBPROC SECANTI TAB_1*TABLE X1*FLOTTANT X2*FLOTTANT X1MIN*FLOTTANT ERRMAX*FLOTTANT NMAX*ENTIER ;
  3499. *
  3500. SI (OU (X1 >EG 10.E10) (X2 >EG 10.E10)) ;
  3501. IFLAG = 1 ;
  3502. FINSI ;
  3503. SI (IFLAG NEG 0) ;
  3504. QUITTER SECANTI ;
  3505. FINSI ;
  3506. I = 0 ;
  3507. F1 IFLAG1 = QUQU TAB_1 X1 ;
  3508. F2 IFLAG2 = QUQU TAB_1 X2 ;
  3509. *MESS ' F1 = ' F1 ;
  3510. *MESS ' F2 = ' F2 ;
  3511. XPREC = 0. ;
  3512. REPETER BOUC4(NMAX) ;
  3513. SI (OU (X1 >EG 10.E10) (X2 >EG 10.E10)) ;
  3514. IFLAG = 1 ;
  3515. FINSI ;
  3516. SI (X1 &lt;EG X1MIN) ;
  3517. X1 = X1MIN ;
  3518. FINSI ;
  3519. SI (IFLAG NEG 0) ;
  3520. QUITTER SECANTI ;
  3521. FINSI ;
  3522. X3 = X2-(F2*(X1-X2)/(F1-F2)) ;
  3523. ERR = (ABS ((XPREC-X3)/X3))*100 ;
  3524. F3 IFLAG3 = QUQU TAB_1 X3 ;
  3525. * MESS ' F3 = ' F3 ;
  3526. SI ((ERR &lt;EG ERRMAX) ET (F3 &lt;EG 1.E-3)) ;
  3527. QUITTER SECANTI ;
  3528. FINSI ;
  3529. XPREC = X3 ;
  3530. I = I + 1 ;
  3531. SI ((F1*F3) < 0.) ;
  3532. SI ((F2*F3) < 0.) ;
  3533. A1 = ABS (F3-F1) ;
  3534. A2 = ABS (F3-F2) ;
  3535. SI (A1 > A2) ;
  3536. X1 = X3 ;
  3537. F1 = F3 ;
  3538. SINON ;
  3539. X2 = X3 ;
  3540. F2 = F3 ;
  3541. FINSI ;
  3542. SINON ;
  3543. X2 = X3 ;
  3544. F2 = F3 ;
  3545. FINSI ;
  3546. SINON ;
  3547. SI ((F2*F3) > 0.) ;
  3548. A1 = ABS (F3-F1) ;
  3549. A2 = ABS (F3-F2) ;
  3550. SI (A1 > A2) ;
  3551. X1 = X3 ;
  3552. F1 = F3 ;
  3553. SINON ;
  3554. X2 = X3 ;
  3555. F2 = F3 ;
  3556. FINSI ;
  3557. SINON ;
  3558. X1 = X3 ;
  3559. F1 = F3 ;
  3560. FINSI ;
  3561. FINSI ;
  3562. FIN BOUC4 ;
  3563. *MESS ' X3 = ' X3 ;
  3564. FINPROC X3 ERR IFLAG ;
  3565. *_____________________________________________________________________________
  3566. *
  3567. **** @CELAT94
  3568. DEBPROC @CELAT94 TAB_1*TABLE ;
  3569. *
  3570. * --- entrees
  3571. *
  3572. NIVEAU = TAB_1.'NIVEAU';
  3573. SI (NIVEAU >EG 4);
  3574. MESS '---------------> calling @CELAT94';
  3575. FINSI ;
  3576.  
  3577. PROP_PHY TAB_1 ;
  3578. *
  3579. NORADICI = 0 ;
  3580. *DQ = 2.E3 ;
  3581. DQ = 2.E6 ;
  3582. Q1 = 0. ;
  3583. *Q1 = 20.E6 ;
  3584. REPETER BOUC2 ;
  3585. * MESS '---> BOUC2 ' ;
  3586. QQ = Q1 ;
  3587. IFLAG = 0 ;
  3588. QQ = QQ + DQ ;
  3589. FQ IFLAG = QUQU TAB_1 QQ ;
  3590. * MESS 'FQ =' FQ ;
  3591. * MESS '--------------------------IFLAG =' IFLAG ;
  3592. REPETER BOUC1 ;
  3593. * MESS '--> BOUC1 ' ;
  3594. SI (IFLAG &lt;EG 0) ;
  3595. QUITTER BOUC1 ;
  3596. FINSI ;
  3597. IFLAG = 0 ;
  3598. QQ = QQ + DQ ;
  3599. FQ IFLAG = QUQU TAB_1 QQ ;
  3600. FIN BOUC1 ;
  3601. SI (FQ >EG 0.) ;
  3602. QUITTER BOUC2 ;
  3603. SINON ;
  3604. SI (DQ < 1.E-2) ;
  3605. MESS '---> QUQU HAS NO ZERO ' ;
  3606. NORADICI = 1 ;
  3607. QUITTER BOUC2 ;
  3608. FINSI ;
  3609. Q1 = QQ - DQ ;
  3610. DQ = DQ / 2. ;
  3611. * MESS ' --------QQ = ' QQ ;
  3612. * MESS ' --------Q1 = ' Q1 ;
  3613. * MESS ' FQ = ' FQ ;
  3614. FINSI ;
  3615. FIN BOUC2 ;
  3616. *
  3617. *MESS '--->BOUC3' ;
  3618. *MESS ' **************************** ' ;
  3619. *MESS ' **************************** ' ;
  3620. *MESS ' **************************** ' ;
  3621. *MESS ' **************************** ' ;
  3622. *MESS ' **************************** ' ;
  3623. Q1 = QQ ;
  3624. Q1MIN = Q1 ;
  3625. Q2 = QQ + DQ ;
  3626. *MESS 'Q1 ='Q1 ;
  3627. *MESS 'Q1MIN =' Q1MIN ;
  3628. *MESS 'Q2 =' Q2 ;
  3629. *MESS 'DQ =' DQ ;
  3630. *MESS 'NORADICI =' NORADICI ;
  3631. REPETER BOUC3 ;
  3632. SI (NORADICI EGA 1) ;
  3633. QUITTER BOUC3 ;
  3634. FINSI ;
  3635. IFLAG = 0 ;
  3636. ERRMAX = 0.00001 ;
  3637. SI (OU (Q1 >EG 10.E10) (Q2 >EG 10.E10)) ;
  3638. MESS ' WARNING Q1 OR Q2 EXCEEDED MAXIMUM VALUE ' ;
  3639. QUITTER BOUC3 ;
  3640. FINSI ;
  3641. QCAL ERR IFLAG = SECANTI TAB_1 Q1 Q2 Q1MIN ERRMAX 500 ;
  3642. SI (IFLAG NEG 0) ;
  3643. MESS ' PARAMETER PROBLEM IN TEST ' ;
  3644. IFLAG = 0 ;
  3645. FINSI ;
  3646. SI (QCAL EGA 0.) ;
  3647. QUITTER BOUC3 ;
  3648. FINSI ;
  3649. QUITTER BOUC3 ;
  3650. FIN BOUC3 ;
  3651. *
  3652. MESS 'CELATA94 CRITICAL HEAT FLUX (W/m2) : 'QCAL ;
  3653. *
  3654. QCHFW = QCAL ;
  3655. DELTA = 0. ;
  3656. UB = 0. ;
  3657. UBL = 0. ;
  3658. BLB = 0. ;
  3659. Q1 = 0. ;
  3660. Q2 = 0. ;
  3661. QCAL = 0. ;
  3662. *
  3663. TAB_1.CHF = QCHFW ;
  3664. SI (NIVEAU >EG 4);
  3665. MESS '---------------> exiting @CELAT94';
  3666. FINSI ;
  3667. *FINPROC QCHFW ;
  3668. FINPROC ;
  3669. **** @CERI
  3670. DEBPROC @CERI P_1*POINT P_2*POINT P_3*POINT R_1*FLOTTANT ;
  3671. X_1 = COOR 1 P_1 ;
  3672. Y_1 = COOR 2 P_1 ;
  3673. X_2 = COOR 1 P_2 ;
  3674. Y_2 = COOR 2 P_2 ;
  3675. X_3 = COOR 1 P_3 ;
  3676. Y_3 = COOR 2 P_3 ;
  3677. X_I = (X_1 + X_2 ) / 2. ;
  3678. Y_I = (Y_1 + Y_2 ) / 2. ;
  3679. A_1 = (( X_1 - X_2 ) ** 2 ) + (( Y_1 - Y_2 ) ** 2 ) / 4. ;
  3680. R_12 = R_1 ** 2 ;
  3681. REPETER BLO1 1 ;
  3682. SI ( A_1 EGA R_12 1.E-6 ) ;
  3683. PS_1 = X_I Y_I ;
  3684. P_4 = PS_1 PLUS (( Y_1 - Y_I) ( X_I - X_1)) ;
  3685. X_4 = COOR 1 P_4 ;
  3686. Y_4 = COOR 2 P_4 ;
  3687. PSCAL_1 = ((X_I - X_4) * (X_I - X_3)) + ((Y_I - Y_4) * (Y_I - Y_3)) ;
  3688. SI (PSCAL_1 > 0. ) ;
  3689. P_4 = PS_1 MOIN (( Y_1 - Y_I) ( X_I - X_1)) ;
  3690. FINSI ;
  3691. C_ERC1 = (CERC P_1 PS_1 P_4) ET (CERC P_4 PS_1 P_2);
  3692. QUITTER BLO1 ;
  3693. FINSI ;
  3694.  
  3695. SI ( ( X_1 - X_2 ) NEG 0. 1.E-6) ;
  3696.  
  3697. B_1 = (( Y_1 - Y_2 ) ** 2 ) / (( X_1 - X_2 ) ** 2 ) + 1. ;
  3698. SI ( A_1 < R_12) ;
  3699.  
  3700. YS_1 = Y_I + (((R_12 - A_1) / B_1) ** 0.5 ) ;
  3701. XS_1 = X_I - ((YS_1 - Y_I)*(Y_1 - Y_2 )/(X_1 - X_2 )) ;
  3702. PS_1 = XS_1 YS_1 ;
  3703. PSCAL_1 = ((X_I - XS_1) * (X_I - X_3)) + ((Y_I - YS_1) * (Y_I - Y_3)) ;
  3704. SI (PSCAL_1 < 0. ) ;
  3705. YS_2 = Y_I - (((R_12 - A_1) / B_1) ** 0.5 ) ;
  3706. XS_2 = X_I - ((YS_2 - Y_I)*(Y_1 - Y_2 )/(X_1 - X_2 )) ;
  3707. PS_1 = XS_2 YS_2 ;
  3708. FINSI ;
  3709. C_ERC1 = CERC P_1 PS_1 P_2 ;
  3710. SINON ;
  3711.  
  3712. ERRE '>>@CERI>> DISTANCE ENTRE LES 2 POINTS SUPERIEUR AU DIAMETRE ' ;
  3713. FINSI ;
  3714.  
  3715. SINON ;
  3716. B_1 = (( Y_1 - Y_2 ) ** 2 ) + 1. ;
  3717. R_12 = R_1 ** 2 ;
  3718. YS_1 = Y_I + (((R_12 ) / B_1) ** 0.5 ) ;
  3719. XS_1 = X_I - ((YS_1 - Y_I)*(Y_2 - Y_1 )) ;
  3720. PS_1 = XS_1 YS_1 ;
  3721. PSCAL_1 = ((X_I - XS_1) * (X_I - X_3)) + ((Y_I - YS_1) * (Y_I - Y_3)) ;
  3722. SI (PSCAL_1 < 0. ) ;
  3723. YS_2 = Y_I - (((R_12 ) / B_1) ** 0.5) ;
  3724. XS_2 = X_I - ((YS_2 - Y_I)*(Y_2 - Y_1 )) ;
  3725. PS_1 = XS_2 YS_2 ;
  3726. FINSI ;
  3727. C_ERC1 = CERC P_1 PS_1 P_2 ;
  3728. FINSI ;
  3729. FIN BLO1 ;
  3730. FINPROC C_ERC1 PS_1 ;
  3731.  
  3732.  
  3733. *-----------------------------------------------------------------------
  3734. * Procedure CFLUXTOT
  3735. *-----------------------------------------------------------------------
  3736. DEBPROC CFLUXTOT TAB1*TABLE;
  3737. *
  3738. ***********************************************************************
  3739. * CFLUXTOT developpee par Nicolas URAGO (avr-sept 1994) *
  3740. * largement revisitee par Jacques SCHLOSSER et Alain MOAL (aout 1995) *
  3741. ***********************************************************************
  3742. ******* ATTENTION --> Cette procedure ne tourne qu'en 3D et ne peut
  3743. * traiter que des cas de limiteurs plancher car
  3744. * Z (point tangent) = Z (centre du plasma)
  3745. *
  3746. MESS '---------------------------------> calling CFLUXTOT';
  3747. *
  3748. *-------------------- VARIABLES D'ENTREE
  3749. LPAT1 = TAB1.LFLUX_EXTE ;
  3750. GRP1 = TAB1.GRAND_RAYON ;
  3751. IMESS = TAB1.'NIVEAU' ;
  3752. PTG = TAB1.'PT_TGPLASMA';
  3753. MODEL0 = TAB1.'MODELF' ;
  3754. LAMBQ = TAB1.LAMDAQ ;
  3755. LISFLU = TAB1.LIS_FLUX ;
  3756. OEIL0 = TAB1.VIEW_P ;
  3757. *
  3758. SI (EXISTE TAB1 ANGLE_DEC) ;
  3759. PSI = TAB1.ANGLE_DEC ;
  3760. SINON;
  3761. PSI = 0.0 ;
  3762. FINSI;
  3763. *---------------------------------------
  3764. *
  3765. *---- On calcule pour chaque point de LPAT1, les coordonnees
  3766. *---- de son'centre plasma'.
  3767. XP1 = COOR 1 LPAT1 ;
  3768. YP1 = COOR 2 LPAT1 ;
  3769. ZP1 = COOR 3 LPAT1 ;
  3770. GRAYP1 = (XP1**2 + (YP1**2))**0.5 ;
  3771. XCP1 = XP1 * GRP1 / GRAYP1 ;
  3772. YCP1 = YP1 * GRP1 / GRAYP1 ;
  3773. *
  3774. AUX1 = ((XCP1 - XP1)**2 + ((YCP1 - YP1)**2))**0.5;
  3775. BETA1 = ATG (AUX1/ZP1) ;
  3776. ALPHA2 = ATG YCP1 XCP1 ;
  3777. *
  3778. *---- le vecteur tangent aux lignes de champ B est orthogonal
  3779. *---- a V = P1CP1
  3780. VX1 = XCP1 - XP1 ;
  3781. VY1 = YCP1 - YP1 ;
  3782. VZ1 = ZP1 * -1. ;
  3783. *
  3784. *---- B appartient au plan defini par les vecteurs K (0, 0, 1) et U
  3785. *UX1 = SIN (PSI + ALPHA2) ;
  3786. *UY1 = (COS (PSI + ALPHA2)) * -1. ;
  3787. *UZ1 = UX1 * 0. ;
  3788. *
  3789. UX1 = SIN (PSI - ALPHA2) ;
  3790. UY1 = COS (PSI - ALPHA2) ;
  3791. UZ1 = UX1 * 0. ;
  3792. *
  3793. *---- calcul de B
  3794. BZ = ((VZ1*UX1)**2 + ((VZ1*UY1)**2)) / ((VX1*UX1 + (VY1*UY1))**2) + 1. ;
  3795. BZ = BZ**(-0.5) * -1.;
  3796. BY = BZ * (VZ1*UY1) /(VX1*UX1 + (VY1*UY1)) * -1. ;
  3797. BX = BY * UX1 / UY1 ;
  3798. *
  3799. *---- Calcul du produit scalaire : VECTEUR TANGENT . NORMALE
  3800. NX NY NZ = @VNORM3D (EXTR MODEL0 'MAIL') LPAT1 IMESS ;
  3801. COS_BN = ABS ((BX*NX) + (BY*NY) + (BZ*NZ)) ;
  3802. *
  3803. *---- Coordonnees du point de tangence
  3804. XREF1 = COOR 1 PTG ;
  3805. YREF1 = COOR 2 PTG ;
  3806. ZREF1 = COOR 3 PTG ;
  3807. *
  3808. *---- Centre du plasma au dessus du point de tangence
  3809. XCREF1 = XREF1 * GRP1 / ((XREF1**2 + (YREF1**2))**0.5);
  3810. YCREF1 = YREF1 * GRP1 / ((XREF1**2 + (YREF1**2))**0.5);
  3811. *
  3812. *---- DREF1 est le petit rayon du plasma
  3813. DREF1 = (((XREF1-XCREF1)**2) + ((YREF1-YCREF1)**2) + (ZREF1**2))**.5;
  3814. DIST1 = (((XP1 - XCP1)**2) + ((YP1 - YCP1)**2) + (ZP1**2))**.5;
  3815. *
  3816. *---- Distance a la DSMF
  3817. LDEC1 = DIST1 - DREF1 ;
  3818. *
  3819. *---- Calcul du profil de flux
  3820. VPAT1 = COS_BN * (EXP (LDEC1/(-1.*LAMBQ))) ;
  3821. VFP1 = FLUX MODEL0 VPAT1 ;
  3822. *
  3823. *---- Visualisations
  3824. ARET0 = ARETE LPAT1 ;
  3825. TITRE 'CFLUXTOT : B.N = COSINUS OF THE INCIDENCE ANGLE';
  3826. TRAC OEIL0 COS_BN LPAT1 ARET0;
  3827. TITRE 'CFLUXTOT : TANGENT VECTOR TO THE MAGNETIC LINE';
  3828. VB = @CVECT BX BY BZ LPAT1 VERT;
  3829. TRAC OEIL0 VB LPAT1 ;
  3830. TITRE 'CFLUXTOT : DISTANCE TO THE LCFS' ;
  3831. TRAC OEIL0 LDEC1 LPAT1 ARET0;
  3832. TITRE 'CFLUXTOT : PROFILE OF THE INCIDENT FLUX' ;
  3833. TRAC OEIL0 VPAT1 LPAT1 ARET0;
  3834. *
  3835. *-------------------- VARIABLES EN SORTIE
  3836. *---- flux moyen et puissance
  3837. TAB1.V_SOM1 = (EXTR LISFLU (DIME LISFLU)) * (MAXI (RESU VFP1));
  3838. TAB1.V_FACFM2 = (MAXI (RESU VFP1)) / (MESU LPAT1) ;
  3839. *-----------------------------------------
  3840. *
  3841. MESS '---------------------------------> exiting CFLUXTOT';
  3842. FINPROC VPAT1 ;
  3843.  
  3844.  
  3845.  
  3846.  
  3847.  
  3848. **** @CFPFLU
  3849.  
  3850. DEBPROC @CFPFLU TAB1*TABLE ;
  3851. *
  3852. **************************************************************
  3853. * Procedure de calcul du profil du depot de puissance sur un *
  3854. * objet avec la configuration magnetique de JET. *
  3855. * Alain MOAL (Janvier - Avril 2001) *
  3856. **************************************************************
  3857. * Modif : *
  3858. * 08/11/01 (A.MOAL) : nouveau nom (JETFLU devient CFPFLU) *
  3859. * 08/11/01 (A.MOAL) : calcul de la puissance reelle deposee *
  3860. * 23/11/01 (A.MOAL) : trace de dpsi sur le maillage *
  3861. * 06/12/01 (A.MOAL) : indicateur du passage dans cfpflu *
  3862. * 27/01/04 (A.MOAL) : suppression de l'indicateur <CFPFLU *
  3863. **************************************************************
  3864. *
  3865. MESS '---------------------------------> calling @CFPFLU';
  3866. *
  3867. *---- Valeurs par defaut, verification des indices de la table
  3868. @VDEFJET TAB1 ;
  3869. *
  3870. *--------------- VARIABLES D'ENTREE :
  3871. MAIL0 = TAB1.<MAILLAGE ;
  3872. MMAIL0 = TAB1.MODELF ;
  3873. CONT0 = TAB1.LFLUX_EXTE ;
  3874. IMESS = TAB1.<IMESS ;
  3875. ITRAC = TAB1.<ITRAC ;
  3876. ITYPDEP = TAB1.<TYPE_DEPOT ;
  3877. SI (NON (EXISTE TAB1 <NXM)) ;
  3878. ICALNORM = VRAI ;
  3879. SINON ;
  3880. ICALNORM = FAUX ;
  3881. NXM = TAB1.<NXM ;
  3882. NYM = TAB1.<NYM ;
  3883. NZM = TAB1.<NZM ;
  3884. FINSI ;
  3885. SI ((VALEUR DIME) EGA 3) ;
  3886. OEIL0 = TAB1.VIEW_P ;
  3887. SINON ;
  3888. CONTDES0 = TAB1.LFLUX_EXTE_DESS ;
  3889. FINSI ;
  3890. ICALINCI = TAB1.<CALCUL_INCIDENCE ;
  3891. PUISTOT0 = TAB1.<PUISSANCE_TOTALE ;
  3892. *------------------------------------
  3893. *
  3894. *TAB1.<CFPFLU = VRAI ;
  3895. *
  3896. *---- lecture de la carte de champ magnetique dans un fichier
  3897. @LECTB TAB1 ;
  3898.  
  3899. *--- trace de dpsi sur le maillage
  3900. TAB1.<MAILLAGE_B = CONT0 ;
  3901. CHDPSI = @DPSI TAB1 ;
  3902. TITRE '@CFPFLU : DPSI ON THE MESH' ;
  3903. LISOV0 = PROG -0.66 -0.33 0. 1. 2. 3. ;
  3904. OPTI ISOV LIGNE ;
  3905. TRAC LISOV0 CHDPSI CONT0 ;
  3906. OPTI ISOV SURFACE ;
  3907. *
  3908. *---- lecture du flux normalise sur une ligne dans un fichier
  3909. @LECTF TAB1 ;
  3910. TITRE '@CFPFLU : MAGNETIC DOMAIN, AREA FOR NORMALIZED FLUX AND STUDIED OBJECT';
  3911. *TRAC (TAB1.<GRILLE_B ET TAB1.<MAILLAGE_FN ET MAIL0) ;
  3912. TRAC ((ENVE TAB1.<GRILLE_B) ET (CONT TAB1.<MAILLAGE_FN) ET (ENVE MAIL0)) ;
  3913. *
  3914. *---- calcul du champ B sur la ligne de reference pour
  3915. *---- verification des angles d'incidences
  3916. SI (ICALINCI) ;
  3917. @VERANG TAB1 ;
  3918. FINSI ;
  3919.  
  3920. TAB1.<MAILLAGE_B = TAB1.<MAILLAGE_FN ;
  3921. BR BZ BPHI = @MAGNB TAB1 ;
  3922. *
  3923. *---- calcul du champ magnetique sur le maillage
  3924. TAB1.<MAILLAGE_B = MAIL0 ;
  3925. BR BZ BPHI = @MAGNB TAB1 ;
  3926.  
  3927. PHI = ATG (COOR 2 MAIL0) (COOR 1 MAIL0) ;
  3928. *AM*11/09/01*BXM = BR * (COS PHI) + (BPHI * (SIN PHI));
  3929. *AM*11/09/01*BYM = BR * (SIN PHI) - (BPHI * (COS PHI));
  3930. BXM = BR * (COS PHI) - (BPHI * (SIN PHI));
  3931. BYM = BR * (SIN PHI) + (BPHI * (COS PHI));
  3932. BZM = BZ ;
  3933. MENAGE ;
  3934. *
  3935. *---- calcul des normales a la surface calculees
  3936. *---- dans le repere du maillage
  3937. SI (ICALNORM) ;
  3938. NXM NYM NZM = @VNORM3D MAIL0 CONT0 ;
  3939. TAB1.<NXM = NXM ;
  3940. TAB1.<NYM = NYM ;
  3941. TAB1.<NZM = NZM ;
  3942. FINSI;
  3943. MENAGE ;
  3944. *
  3945. *---- calcul du produit scalaire et de l'angle d'incidence
  3946. B_NORM = ((BXM*BXM) + (BYM*BYM) + (BZM*BZM))**0.5 ;
  3947. VBVN = (ABS ((BXM*NXM) + (BYM*NYM) + (BZM*NZM))) / B_NORM;
  3948. ANGINCI = ATG ((1.-(VBVN**2))**0.5) VBVN ;
  3949. *
  3950. *---- vecteur champ magnetique et vecteur normal dans le repere
  3951. *---- du maillage en vue de la visualisation
  3952. VB1 = @CVECT BXM BYM BZM CONT0 VERT;
  3953. VN1 = @CVECT NXM NYM NZM CONT0 BLEU;
  3954. *
  3955. *---- dans le plan xy du repere du maillage
  3956. BETA2DXY = ATG (BYM*-1.) (BXM*-1.) ;
  3957. *---- dans le plan xz du repere du maillage
  3958. BETA2DXZ = ATG (BZM*-1.) (BXM*-1.) ;
  3959. *
  3960. *---- calcul de la densite de puissance recue par chaque point
  3961. VAR1 = @FLNORM TAB1 ;
  3962. *
  3963. *---- profil du flux pour une puissance de 1 MW deposee sur l'objet
  3964. *---- (flux parallele ou perpendiculaire)
  3965. SI (ITYPDEP) ;
  3966. PROFIL0 = VAR1 * VBVN ;
  3967. SINON ;
  3968. PROFIL0 = VAR1 * ((1. - (VBVN*VBVN)) ** .5) ;
  3969. FINSI ;
  3970. *
  3971. *---- integration du flux sur la surface
  3972. PROCONT0 = NOMC SCAL (FLUX MMAIL0 PROFIL0) ;
  3973. *
  3974. *---- calcul du flux moyen
  3975. PROMOY = (MAXI (RESU PROCONT0)) / (MESU CONT0) ;
  3976. *
  3977. *---- flux reel deposee pour une puissance donnee en MW
  3978. PROFIL1 = PROFIL0 * PUISTOT0 ;
  3979. *
  3980. *---- traces en 3D
  3981. SI (((VALEUR DIME) EGA 3) ET ITRAC) ;
  3982. SI (EGA (VALEUR ELEM) 'CUB8') ;
  3983. ARET1 = ARETE CONT0 ;
  3984. SINON ;
  3985. ARET1 = ARETE CONT0 40. ;
  3986. FINSI ;
  3987. TITRE '@CFPFLU : MAGNETIC FIELD AND NORMAL VECTOR' ;
  3988. TRACE CACH OEIL0 (VB1 ET VN1) MAIL0 ;
  3989. TITRE '@CFPFLU : COSINUS OF THE ANGLE BETWEEN b AND n' ;
  3990. TRACE 20 CACH OEIL0 VBVN CONT0 ARET1;
  3991. TITRE '@CFPFLU : 90 - ANGLE BETWEEN VECTORS B AND SURFACE (DEGREE)';
  3992. TRACE 20 CACH OEIL0 (90. - ANGINCI) CONT0 ARET1;
  3993. TITRE '@CFPFLU : NORM OF THE MAGNETIC FIELD (TESLA)' ;
  3994. TRACE 20 CACH OEIL0 B_NORM CONT0 ARET1 ;
  3995. * TITRE '@CFPFLU : flux0 * exp (- delta / lamdaq)' ;
  3996. * TRACE 20 CACH OEIL0 VAR1 CONT0 ARET1;
  3997. TITRE '@CFPFLU : INCIDENT HEAT FLUX FOR 'PUISTOT0' MW' ;
  3998. * TRACE 2 0CACH OEIL0 PROFIL0 CONT0 ARET1 ;
  3999. TRACE 20 CACH OEIL0 PROFIL1 CONT0 ARET1 ;
  4000. FINSI ;
  4001.  
  4002. SI (IMESS >EG 2) ;
  4003. MESS '>>>> @CFPFLU : BXM '; MESS (MAXI BXM) (MINI BXM) ;
  4004. MESS '>>>> @CFPFLU : BYM '; MESS (MAXI BYM) (MINI BYM) ;
  4005. MESS '>>>> @CFPFLU : BZM '; MESS (MAXI BZM) (MINI BZM) ;
  4006. MESS '>>>> @CFPFLU : PROFIL0 ';
  4007. MESS (MAXI PROFIL0) (MINI PROFIL0) ;
  4008. MESS '>>>> @CFPFLU : PROFIL1 ';
  4009. MESS (MAXI PROFIL1) (MINI PROFIL1) ;
  4010. MESS '>>>> @CFPFLU : VAR1 '; MESS (MAXI VAR1) (MINI VAR1) ;
  4011. MESS '>>>> @CFPFLU : ANGINCI ';
  4012. MESS (MAXI ANGINCI) (MINI ANGINCI) ;
  4013. FINSI ;
  4014. SI (IMESS >EG 3) ;
  4015. MESS '>>>> @CFPFLU : BXM '; LIST BXM ;
  4016. MESS '>>>> @CFPFLU : BYM '; LIST BYM ;
  4017. MESS '>>>> @CFPFLU : BZM '; LIST BZM ;
  4018. MESS '>>>> @CFPFLU : VBVN '; LIST VBVN ;
  4019. MESS '>>>> @CFPFLU : BETA2DXY '; LIST BETA2DXY ;
  4020. MESS '>>>> @CFPFLU : BETA2DXZ '; LIST BETA2DXZ ;
  4021. MESS '>>>> @CFPFLU : ANGINCI '; LIST ANGINCI ;
  4022. MESS '>>>> @CFPFLU : PROFIL0 '; LIST PROFIL0 ;
  4023. MESS '>>>> @CFPFLU : PROFIL1 '; LIST PROFIL1 ;
  4024. FINSI ;
  4025. *
  4026. *--------------- VARIABLES DE SORTIE :
  4027. TAB1.V_FACFM2 = PROMOY ;
  4028. TAB1.<ANGINCI = ANGINCI ;
  4029. TAB1.<VBVN = VBVN ;
  4030. *TAB1.<CFPFLU = FAUX ;
  4031. *-------------------------------------
  4032. MESS '---------------------------------> exiting @CFPFLU';
  4033. FINPROC PROFIL1 ;
  4034.  
  4035. **** @CHAMB
  4036. DEBPROC @CHAMB TAB1*TABLE XG1*CHPOINT YG1*CHPOINT ZG1*CHPOINT ISHIFT*LOGIQUE IRIPPLE*LOGIQUE ;
  4037. *
  4038. ***********************************************************
  4039. * Procedure de calcul du champ magnetique en chaque point *
  4040. * en utilisant le modele Seigneur-Hertout de ripple avec *
  4041. * prise en compte du shift de Shafranov. *
  4042. * Alain MOAL (juin 1995) *
  4043. ***********************************************************
  4044. *123456789012345678901234567890123456789012345678901234567890123456789012
  4045. * 1 2 3 4 5 6 7
  4046. ***********************************************************
  4047. *
  4048. *MESS '---------------------------------> calling @CHAMB';
  4049. *
  4050. *--------------- VARIABLES D'ENTREE :
  4051. RP = TAB1.<RP ;
  4052. HP = TAB1.<HP ;
  4053. RHO0 = TAB1.<RHO0 ;
  4054. THETA0 = TAB1.<THETA0 ;
  4055. ANGPHI0 = TAB1.<ANGPHI0 ;
  4056. RR = TAB1.<RR ;
  4057. LAMB = TAB1.<LAMB ;
  4058. IPLASMA = TAB1.<IPLASMA ;
  4059. COEFA = TAB1.<COEFA ;
  4060. COEFB = TAB1.<COEFB ;
  4061. COEFC = TAB1.<COEFC ;
  4062. EPS = TAB1.<EPS ;
  4063. NBOB = TAB1.<NBOB ;
  4064. NSPI = TAB1.<NSPI ;
  4065. INTENS = TAB1.<INTENS ;
  4066. IMESS = TAB1.<IMESS ;
  4067. ICHAMP = TAB1.<MODEL_CHAMP ;
  4068. *------------------------------------
  4069. *
  4070. PI = 3.141592 ;
  4071. MU0 = PI * 4.E-7 ;
  4072. *
  4073. *---- Coordonnees de chaque point dans le repere du plasma
  4074. RHOP THETAP PHIP = @CRGTC XG1 YG1 ZG1 RP HP ;
  4075. *
  4076. *---- Masque delimitant le domaine de validite du modele de ripple
  4077. *attention domaine de validite etendu de 110 a 180 par
  4078. *E.COSTA/E.TSITRONE le 02/06/97
  4079. *MASK0 = (ABS THETAP) MASQUE INFERIEUR 110. ;
  4080. MASK0 = (ABS THETAP) MASQUE INFERIEUR 181. ;
  4081.  
  4082. *
  4083. *SI (NON ISHIFT) ;
  4084. * LAMB = -1. ;
  4085. *FINSI ;
  4086. *
  4087. *---- Calcul dans le repere du plasma des composantes du champ
  4088. *---- poloidal induit par le courant circulant dans le plasma
  4089. AUX0 = -1. * MU0 * IPLASMA / (2. * PI) ;
  4090. *
  4091. SI (EGA ICHAMP 'SEIGNEUR') ;
  4092. BPOL_RHO = (RHOP ** -2) * (RHO0**2) - 1. ;
  4093. BPOL_RHO = BPOL_RHO * (LAMB + 0.5) + (LOG (RHOP / RHO0)) ;
  4094. BPOL_RHO = BPOL_RHO * (SIN THETAP) * AUX0 / (2. * RP) ;
  4095. *
  4096. BPOL_THE = ((RHOP ** -2) * (RHO0**2)) + 1. ;
  4097. BPOL_THE = BPOL_THE * (LAMB + 0.5) - 1. + (LOG (RHOP / RHO0));
  4098. BPOL_THE = BPOL_THE * RHOP * (COS THETAP) / (2. * RP) + 1. ;
  4099. BPOL_THE = BPOL_THE * (RHOP ** -1) * AUX0 ;
  4100. FINSI ;
  4101. *
  4102. SI (EGA ICHAMP 'SHAFRANOV') ;
  4103. * ---- cette formulation a ma preference, les 2 autres semblent
  4104. * douteuses (A.MOAL)
  4105. BPOL_RHO = ((RHOP ** -2) * (RHO0**2) - 1.) * -1. ;
  4106. BPOL_RHO = BPOL_RHO * (LAMB + 0.5) + (LOG (RHOP / RHO0)) ;
  4107. BPOL_RHO = BPOL_RHO * (SIN THETAP) * AUX0 / (2. * RP) ;
  4108. *
  4109. BPOL_THE = ((RHOP ** -2) * (RHO0**2)) + 1. ;
  4110. BPOL_THE = BPOL_THE * (LAMB + 0.5) - 1. + (LOG (RHOP / RHO0));
  4111. BPOL_THE = BPOL_THE * RHOP * (COS THETAP) / (2. * RP) + 1. ;
  4112. BPOL_THE = BPOL_THE * (RHOP ** -1) * AUX0 ;
  4113. FINSI ;
  4114. *
  4115. SI (EGA ICHAMP 'ARTSIMOVICH') ;
  4116. BPOL_RHO = ((RHOP ** -2) * (RHO0**2) - 1.) * -1. ;
  4117. BPOL_RHO = BPOL_RHO * (LAMB + 0.5) + (LOG (RHOP / RHO0)) ;
  4118. BPOL_RHO = BPOL_RHO * (SIN THETAP) * AUX0 / (2. * RP) ;
  4119. *
  4120. BPOL_THE = ((RHOP ** -2) * (RHO0**2)) + 1. ;
  4121. BPOL_THE = BPOL_THE * (LAMB + 0.5) - 1. + (LOG (RHOP / RHO0));
  4122. BPOL_THE = BPOL_THE * (COS THETAP) / 2. + 1. ;
  4123. BPOL_THE = BPOL_THE * AUX0 / RP ;
  4124. FINSI ;
  4125. *
  4126. SI (NON ISHIFT) ;
  4127. BPOL_THE = ((RHOP * 2. * PI / (MU0 * IPLASMA))**(-1))*(-1.) ;
  4128. BPOL_RHO = BPOL_THE * 0. ;
  4129. FINSI ;
  4130. *
  4131. BPOL_PHI = RHOP * 0. ;
  4132. *
  4133. *---- Passage dans la base cartesienne de la machine
  4134. BXPOL BYPOL BZPOL = @CBTGV BPOL_RHO BPOL_THE BPOL_PHI THETAP PHIP ;
  4135. *
  4136. *---- Coordonnees de chaque point dans le "repere du ripple"
  4137. RHOR THETAR PHIR = @CRGTC XG1 YG1 ZG1 RR 0. ;
  4138. *
  4139. SI IRIPPLE ;
  4140. * ---- Calcul dans le repere adapte au calcul du ripple du champ
  4141. * ---- cree par les bobines toroidales
  4142. *
  4143. * ---- 1) calcul de la coordonnee radiale dans le plan meridien Phi=0
  4144. * ---- de la ligne de champ consideree par une methode de point fixe
  4145. RHO_OLD = RHOR ;
  4146. KAUX = (EXP(THETAR**2 * -1. * COEFC)) * ((COS((PHIR + ANGPHI0) * NBOB)) * -1. + 1.) * COEFA ;
  4147. I = 0 ;
  4148. IMAX = 50 ;
  4149. REPETER BOUCLE IMAX ;
  4150. I = I + 1;
  4151. RHO_NEW = RHOR + (KAUX * (EXP(RHO_OLD * COEFB))) ;
  4152. * MESS ' ITERATIONS NUMBER : ' I ;
  4153. * MESS (maxi RHO_NEW ) ;
  4154. SI ((MAXI (ABS((RHO_NEW - RHO_OLD) / RHO_NEW))) &lt;EG EPS) ;
  4155. * MESS ' ITERATIONS NUMBER : ' I ;
  4156. QUITTER BOUCLE ;
  4157. FINSI ;
  4158. RHO_OLD = RHO_NEW ;
  4159. FIN BOUCLE ;
  4160. SI (I >EG IMAX) ;
  4161. MESS '>>> @CHAMB : NO CONVERGENCE OF THE ITERATIVE METHOD !';
  4162. MESS '>>> PROPOSED SOLUTIONS : ' ;
  4163. MESS '>>> 1) INCREASE THE CONVERGENCE CRITERIUM (TAB1.<EPS) ';
  4164. MESS '>>> 2) CHECK YOU ARE WITHIN MODEL VALIDITY DOMAIN ';
  4165. MESS '>>> 3) ASK FOR THE PROCEDURE CONCEPTOR ';
  4166. *EC* ERRE ' >>> STOP IN @CHAMB';
  4167. ERRE ' >>> STOP IN @CHAMB';
  4168. FINSI ;
  4169. RHOMER = RHO_NEW ;
  4170. *
  4171. * ---- 2) composantes du champ (modele Hertout-Seigneur)
  4172. DRHOMER = (EXP(RHOMER * COEFB)) * (EXP(THETAR**2 * COEFC * -1.)) * COEFA ;
  4173. FINSI ;
  4174. RAUX1 = RHOR * (COS THETAR) + RR ;
  4175. *
  4176. *---- champ toroidal moyen sur le cercle de rayon Rr
  4177. BPHI0 = -1. * MU0 * INTENS * NBOB * NSPI / (2. * PI * RR) ;
  4178. *
  4179. *---- champ toroidal moyen sur le cercle de rayon
  4180. * (Rr + Rhor * cos Thetar)
  4181. BTPHI0 = (RAUX1 ** -1.) * BPHI0 * RR ;
  4182. *
  4183. SI IRIPPLE ;
  4184.  
  4185. *EC mai 1997* BTOR_PHI = RHOR / (RAUX1*RHOR) + COEFB ;
  4186. BTOR_PHI = RR / (RAUX1*RHOR) + COEFB ;
  4187.  
  4188. *AM* BTOR_PHI = ((RHOR * RAUX1)**-1) * (RAUX1 * -1. + (2.*RR)) + COEFB;
  4189.  
  4190. BTOR_PHI = BTOR_PHI * -1. * DRHOMER * (COS((PHIR + ANGPHI0) * NBOB)) + 1. ;
  4191.  
  4192. BTOR_PHI = MASK0 * BTOR_PHI * BTPHI0 + ((1.-MASK0) * BTPHI0);
  4193. *
  4194.  
  4195. BTOR_RHO = MASK0 * (RAUX1 ** -1.) * DRHOMER * BTPHI0 * (SIN((PHIR + ANGPHI0) * NBOB)) * NBOB * (-1.) ;
  4196.  
  4197.  
  4198. *
  4199. BTOR_THE = RHOR * 0. ;
  4200. *
  4201. RHOMER = MASK0 * RHOMER + ((1.-MASK0) * RHOR) ;
  4202. SINON ;
  4203. BTOR_PHI = BTPHI0 ;
  4204. BTOR_RHO = RHOR * 0. ;
  4205. BTOR_THE = RHOR * 0. ;
  4206. RHOMER = RHOR ;
  4207. FINSI ;
  4208.  
  4209. *
  4210. *---- Passage dans la base cartesienne de la machine
  4211. BXTOR BYTOR BZTOR = @CBTGV BTOR_RHO BTOR_THE BTOR_PHI THETAR PHIR ;
  4212. *
  4213. *---- Normes du champ poloidal et du champ toroidal
  4214. N_BPOL = (BXPOL*BXPOL + (BYPOL*BYPOL) + (BZPOL*BZPOL))**0.5 ;
  4215. N_BTOR = (BXTOR*BXTOR + (BYTOR*BYTOR) + (BZTOR*BZTOR))**0.5 ;
  4216. *
  4217. *---- Facteur de securite
  4218. FSECU = (RHOP / (RHOP*(COS THETAP)+RP)) * (N_BTOR / N_BPOL) ;
  4219. *
  4220. *---- Champ total
  4221. SI (EXISTE TAB1 MOAL1) ;
  4222. BXPOL = BXPOL*0.;
  4223. BYPOL = BYPOL*0.;
  4224. BZPOL = BZPOL*0.;
  4225. FINSI ;
  4226. SI (EXISTE TAB1 MOAL2) ;
  4227. BXTOR = BXTOR*0.;
  4228. BYTOR = BYTOR*0.;
  4229. BZTOR = BZTOR*0.;
  4230. FINSI ;
  4231. BX = BXPOL + BXTOR ;
  4232. BY = BYPOL + BYTOR ;
  4233. BZ = BZPOL + BZTOR ;
  4234. *
  4235. *---- Messages de verification du calcul
  4236. SI (IMESS >EG 2) ;
  4237. MESS '>>>> @CHAMB ' ;
  4238. MESS 'max and min of the BPOL components in RP' ;
  4239. MESS (MAXI BPOL_RHO) (MINI BPOL_RHO) ;
  4240. MESS (MAXI BPOL_THE) (MINI BPOL_THE) ;
  4241. MESS (MAXI BPOL_PHI) (MINI BPOL_PHI) ;
  4242. MESS 'max and min of the BTOR components in RR' ;
  4243. MESS (MAXI BTOR_RHO) (MINI BTOR_RHO) ;
  4244. MESS (MAXI BTOR_THE) (MINI BTOR_THE) ;
  4245. MESS (MAXI BTOR_PHI) (MINI BTOR_PHI) ;
  4246. MESS 'max and min of the BPOL components' ;
  4247. MESS (MAXI BXPOL) (MINI BXPOL) ;
  4248. MESS (MAXI BYPOL) (MINI BYPOL) ;
  4249. MESS (MAXI BZPOL) (MINI BZPOL) ;
  4250. MESS 'max and min of the BTOR components' ;
  4251. MESS (MAXI BXTOR) (MINI BXTOR) ;
  4252. MESS (MAXI BYTOR) (MINI BYTOR) ;
  4253. MESS (MAXI BZTOR) (MINI BZTOR) ;
  4254. MESS 'max and min of Rho, Theta, Phi in RP';
  4255. MESS (MAXI RHOP) (MINI RHOP) ;
  4256. MESS (MAXI THETAP) (MINI THETAP) ;
  4257. MESS (MAXI PHIP) (MINI PHIP) ;
  4258. MESS 'max and min of X, Y, Z ';
  4259. MESS (MAXI XG1) (MINI XG1) ;
  4260. MESS (MAXI YG1) (MINI YG1) ;
  4261. MESS (MAXI ZG1) (MINI ZG1) ;
  4262. FINSI ;
  4263. SI (IMESS >EG 3) ;
  4264. MESS '>>>> @CHAMB : BPOL_RHO in RP '; LIST BPOL_RHO;
  4265. MESS '>>>> @CHAMB : BPOL_THE in RP '; LIST BPOL_THE;
  4266. MESS '>>>> @CHAMB : BPOL_PHI in RP '; LIST BPOL_PHI;
  4267. MESS '>>>> @CHAMB : BTOR_RHO in RR '; LIST BTOR_RHO;
  4268. MESS '>>>> @CHAMB : BTOR_THE in RR '; LIST BTOR_THE;
  4269. MESS '>>>> @CHAMB : BTOR_PHI in RR '; LIST BTOR_PHI;
  4270. MESS '>>>> @CHAMB : BXPOL '; LIST BXPOL;
  4271. MESS '>>>> @CHAMB : BYPOL '; LIST BYPOL;
  4272. MESS '>>>> @CHAMB : BZPOL '; LIST BZPOL;
  4273. MESS '>>>> @CHAMB : BXTOR '; LIST BXTOR;
  4274. MESS '>>>> @CHAMB : BYTOR '; LIST BYTOR;
  4275. MESS '>>>> @CHAMB : BZTOR '; LIST BZTOR;
  4276. MESS '>>>> @CHAMB : BTOR_THE in RR '; LIST BTOR_THE;
  4277. MESS '>>>> @CHAMB : BTOR_PHI in RR '; LIST BTOR_PHI;
  4278. MESS '>>>> @CHAMB : X '; LIST XG1;
  4279. MESS '>>>> @CHAMB : Y '; LIST YG1;
  4280. MESS '>>>> @CHAMB : Z '; LIST ZG1;
  4281. MESS '>>>> @CHAMB : RHO in RP '; LIST RHOP;
  4282. MESS '>>>> @CHAMB : THETA in RP '; LIST THETAP;
  4283. MESS '>>>> @CHAMB : PHI in RP '; LIST PHIP;
  4284. MESS '>>>> @CHAMB : RHO in RR '; LIST RHOR;
  4285. MESS '>>>> @CHAMB : THETA in RR '; LIST THETAR;
  4286. MESS '>>>> @CHAMB : PHI in RR '; LIST PHIR;
  4287. MESS '>>>> @CHAMB : RHOMER '; LIST RHOMER ;
  4288. MESS '>>>> @CHAMB : BPHI0 ' ; LIST BPHI0 ;
  4289. FINSI ;
  4290. *
  4291. *MESS '---------------------------------> exiting @CHAMB';
  4292. *
  4293. *--------------- VARIABLES DE SORTIE :
  4294. TAB1.<RHOMER = RHOMER ;
  4295. TAB1.<BXPOL = BXPOL ;
  4296. TAB1.<BYPOL = BYPOL ;
  4297. TAB1.<BZPOL = BZPOL ;
  4298. TAB1.<BXTOR = BXTOR ;
  4299. TAB1.<BYTOR = BYTOR ;
  4300. TAB1.<BZTOR = BZTOR ;
  4301. *-------------------------------------
  4302. FINPROC BX BY BZ FSECU;
  4303.  
  4304. **** @CRLTC
  4305. DEBPROC @CRLTC TAB1*TABLE XM*CHPOINT YM*CHPOINT ZM*CHPOINT R*FLOTTANT ;
  4306. *
  4307. ***************************************************************
  4308. * Procedure de changement de repere, on passe des *
  4309. * coordonnees cartesiennes dans le repere de local de l'objet *
  4310. * XM YM ZM repere defini par TAB1.<RHO0, TAB1.<THETA0 et *
  4311. * TAB1.<RP aux coordonnees pseudo-toroidales defini par un *
  4312. * grand rayon donne R . Alain MOAL (mai 1995) *
  4313. ***************************************************************
  4314. *
  4315. *--------------- VARIABLES D'ENTREE :
  4316. RHO0 = TAB1.<RHO0 ;
  4317. THETA0 = TAB1.<THETA0 ;
  4318. RP = TAB1.<RP ;
  4319. *------------------------------------
  4320. *
  4321. CT0 = COS THETA0 ;
  4322. ST0 = SIN THETA0 ;
  4323. MST0 = ST0 * -1. ;
  4324. *
  4325. *---- 1) rotation d'angle THETA0 autour de l'axe X
  4326. X1 = XM ;
  4327. Y1 = (YM * CT0) + (ZM * ST0) ;
  4328. Z1 = (YM * MST0) + (ZM * CT0) ;
  4329. *
  4330. *---- 2) changement d'origine vers le centre du tore,
  4331. *---- rotation de 180 degres autour de l'axe Z2 pour
  4332. *---- retrouver le repere global puis calcul de PHI
  4333. X2 = X1 ;
  4334. Y2 = Y1 - (RHO0 * CT0 + RP) ;
  4335. Z2 = Z1 + (RHO0 * ST0) ;
  4336. *
  4337. X2 = X2 * -1. ;
  4338. Y2 = Y2 * -1. ;
  4339. PHI = ATG (X2 * -1.) Y2 ;
  4340. *
  4341. *---- 3) rotation d'angle PHI autour de l'axe Z2
  4342. CPHI = COS PHI ;
  4343. SPHI = SIN PHI ;
  4344. MSPHI = SPHI * -1. ;
  4345. X3 = (X2 * CPHI) + (Y2 * SPHI) ;
  4346. Y3 = (X2 * MSPHI) + (Y2 * CPHI) ;
  4347. Z3 = Z2 ;
  4348. *
  4349. *---- 4) changement d'origine vers le centre du nouveau repere
  4350. X4 = X3 ;
  4351. Y4 = Y3 - R ;
  4352. Z4 = Z3 ;
  4353. *
  4354. *---- calcul de RHO et THETA
  4355. RHO = ((Y4 * Y4) + (Z4 * Z4))**0.5 ;
  4356. THETA = ATG Z4 Y4 ;
  4357. *
  4358. MESS '>>>> @CRLTC : max and min of the angle PHI' ;
  4359. MESS (MAXI PHI) (MINI PHI) ;
  4360. *
  4361. FINPROC RHO THETA PHI ;
  4362. **** @CRTLC
  4363. DEBPROC @CRTLC R*FLOTTANT RHO*CHPOINT THETA*CHPOINT PHI*CHPOINT TAB1*TABLE ;
  4364. *
  4365. ***************************************************************
  4366. * Procedure de changement de repere, on passe des coordonnees *
  4367. * pseudo-toroidales centrees sur un grand rayon R aux *
  4368. * coordonnees cartesiennes dans le repere de la structure *
  4369. * modelisee. Alain MOAL (mai 1995) *
  4370. ***************************************************************
  4371. *
  4372. *--------------- VARIABLES D'ENTREE :
  4373. RHO0 = TAB1.<RHO0 ;
  4374. THETA0 = TAB1.<THETA0 ;
  4375. RP = TAB1.<RP ;
  4376. *------------------------------------
  4377. *
  4378. CT0 = COS THETA0 ;
  4379. ST0 = SIN THETA0 ;
  4380. MST0= ST0 * -1. ;
  4381. CPHI = COS PHI ;
  4382. SPHI = SIN PHI ;
  4383. MSPHI = SPHI * -1. ;
  4384. *
  4385. X4 = RHO * 0. ;
  4386. Y4 = RHO * (COS THETA) ;
  4387. Z4 = RHO * (SIN THETA) ;
  4388. *
  4389. *---- 1) changement d'origine vers le centre du tore
  4390. X3 = X4 ;
  4391. Y3 = Y4 + R ;
  4392. Z3 = Z4 ;
  4393. *
  4394. *---- 2) rotation d'angle - PHI autour de l'axe Z3
  4395. * puis rotation de - 180 degres autour de l'axe Z2
  4396. X2 = (X3 * CPHI) + (Y3 * MSPHI) ;
  4397. Y2 = (X3 * SPHI) + (Y3 * CPHI) ;
  4398. Z2 = Z3 ;
  4399. *
  4400. X2 = X2 * -1. ;
  4401. Y2 = Y2 * -1. ;
  4402. *
  4403. *---- 3) changement d'origine vers le centre d'objet
  4404. X1 = X2 ;
  4405. Y1 = Y2 + RP + (RHO0 * CT0) ;
  4406. Z1 = Z2 - (RHO0 * ST0) ;
  4407. *
  4408. *---- 4) rotation d'angle - THETA0 autour de l'axe X1
  4409. XP = X1 ;
  4410. YP = (Y1 * CT0) + (Z1 * MST0) ;
  4411. ZP = (Y1 * ST0) + (Z1 * CT0) ;
  4412. *
  4413. FINPROC XP YP ZP ;
  4414. **** @CRTTC
  4415. DEBPROC @CRTTC R1*FLOTTANT RHO1*CHPOINT THETA1*CHPOINT PHI1*CHPOINT R2*FLOTTANT ;
  4416. *
  4417. ***************************************************************
  4418. * Procedure de changement de repere. On passe d'un repere *
  4419. * pseudo-toroidal defini par son grand rayon R1 a un autre *
  4420. * repere pseudo-toroidal defini par son grand rayon R2. Ces *
  4421. * deux reperes ont la meme orientation toroidale: Phi1 = Phi2 *
  4422. * Alain MOAL (juin 1995) *
  4423. ***************************************************************
  4424. *
  4425. RHO2 = RHO1**2 + ((R1 - R2)**2) ;
  4426. RHO2 = RHO2 + (RHO1*(R1 - R2)*(COS THETA1)*2.) ;
  4427. RHO2 = RHO2**0.5 ;
  4428. *
  4429. AUX1 = RHO1 * (SIN THETA1) ;
  4430. AUX2 = RHO1 * (COS THETA1) - R2 + R1 ;
  4431. THETA2 = ATG AUX1 AUX2 ;
  4432. *
  4433. PHI2 = PHI1 ;
  4434. *
  4435. FINPROC RHO2 THETA2 PHI2 ;
  4436. **** @CRLMC
  4437. DEBPROC @CRLMC XL*CHPOINT YL*CHPOINT ZL*CHPOINT TAB1*TABLE ;
  4438. *
  4439. *******************************************************************
  4440. * Version amelioree de l'ancien @CRLMC rebaptise @ACRLM *
  4441. * Procedure de changement de repere. On passe du repere cartesien *
  4442. * local de l'objet modelise au repere cartesien du maillage. Le *
  4443. * point de tangence au plasma est l'origine du repere local et *
  4444. * l'axe Y est dirige vers le centre du plasma. En 3D, L'axe X du *
  4445. * repere local est dans la direction toroidale. *
  4446. * en 2D cas PHICONS l'axe Z du repere local est l'axe toroidal *
  4447. * en 2D cas THECONS l'axe x du repere local est l'axe toroidal *
  4448. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  4449. *******************************************************************
  4450. *
  4451. *--------------- VARIABLES D'ENTREE :
  4452. CP = TAB1.CENTRE_PLASMA ;
  4453. PTG = TAB1.PT_TGPLASMA ;
  4454. SI ((VALEUR DIME) EGA 2) ;
  4455. SI (EXISTE TAB1 <PLAN) ;
  4456. IPLAN = TAB1.<PLAN ;
  4457. SINON ;
  4458. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  4459. FINSI ;
  4460. SINON ;
  4461. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  4462. DIR1 = TAB1.<DIR_TOROIDAL ;
  4463. SINON ;
  4464. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  4465. FINSI ;
  4466. FINSI ;
  4467. *------------------------------------
  4468. *
  4469. SI ((VALEUR DIME) EGA 2) ;
  4470. VECT0 = CP MOINS PTG ;
  4471. VX VY = COOR VECT0 ;
  4472. *
  4473. * ---- calcul de l'angle de rotation dans le plan XY
  4474. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  4475. ANG1 = 0. ;
  4476. SINON ;
  4477. ANG1 = -1.* (ATG VX VY) ;
  4478. FINSI ;
  4479. *
  4480. XPTG YPTG = COOR PTG ;
  4481. *
  4482. SI (EGA IPLAN 'PHICONS');
  4483. * ---- Coupe 2D a Phi constant
  4484. XL = ZL ;
  4485. ZL = ZL * 0.;
  4486. * ---- rotation
  4487. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  4488. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  4489. FINSI;
  4490. SI (EGA IPLAN 'THECONS');
  4491. * ---- Coupe 2D a Theta constant
  4492. * ---- rotation
  4493. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  4494. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  4495. FINSI;
  4496. * ---- changement d'origine du repere
  4497. XM = XL1 + XPTG ;
  4498. YM = YL1 + YPTG ;
  4499. ZM = YL1 * 0. ;
  4500. *
  4501. SINON ;
  4502. *
  4503. VEC1 = DIR1 / (NORM DIR1) ;
  4504. DIR2 = CP MOINS PTG ;
  4505. VEC2 = DIR2 / (NORM DIR2) ;
  4506. VEC3 = VEC1 PVEC VEC2 ;
  4507. *
  4508. X0 Y0 Z0 = COOR PTG ;
  4509. A1 B1 C1 = COOR VEC1 ;
  4510. A2 B2 C2 = COOR VEC2 ;
  4511. A3 B3 C3 = COOR VEC3 ;
  4512. *
  4513. XM1 = (A1 * XL) + (A2 * YL) + (A3 * ZL) ;
  4514. YM1 = (B1 * XL) + (B2 * YL) + (B3 * ZL) ;
  4515. ZM1 = (C1 * XL) + (C2 * YL) + (C3 * ZL) ;
  4516. *
  4517. XM = XM1 + X0 ;
  4518. YM = YM1 + Y0 ;
  4519. ZM = ZM1 + Z0 ;
  4520. *
  4521. FINSI ;
  4522. FINPROC XM YM ZM ;
  4523. **** @CRMLC
  4524. DEBPROC @CRMLC XM*CHPOINT YM*CHPOINT ZM*CHPOINT TAB1*TABLE ;
  4525. *
  4526. *******************************************************************
  4527. * Version amelioree de l'ancien @CRMLC rebaptise @ACRML *
  4528. * Procedure de changement de repere. On passe du repere cartesien *
  4529. * du maillage au repere cartesien local de l'objet modelise. Le *
  4530. * point de tangence au plasma est l'origine de ce repere et l'axe *
  4531. * l'axe Y final est dirige vers le centre du plasma. *
  4532. * en 3D l'axe x du repere local est donne par la direction *
  4533. * toroidale *
  4534. * en 2D cas PHICONS l'axe Z initial est l'axe toroidal *
  4535. * en 2D cas THECONS l'axe x initial est l'axe toroidal *
  4536. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  4537. *******************************************************************
  4538. *
  4539. *--------------- VARIABLES D'ENTREE :
  4540. CP = TAB1.CENTRE_PLASMA ;
  4541. PTG = TAB1.PT_TGPLASMA ;
  4542. SI ((VALEUR DIME) EGA 2) ;
  4543. SI (EXISTE TAB1 <PLAN) ;
  4544. IPLAN = TAB1.<PLAN ;
  4545. SINON ;
  4546. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  4547. FINSI ;
  4548. SINON ;
  4549. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  4550. DIR1 = TAB1.<DIR_TOROIDAL ;
  4551. SINON ;
  4552. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  4553. FINSI ;
  4554. FINSI ;
  4555. *------------------------------------
  4556. *
  4557. SI ((VALEUR DIME) EGA 2) ;
  4558. VECT0 = CP MOINS PTG ;
  4559. VX VY = COOR VECT0 ;
  4560. *
  4561. * ---- calcul de l'angle de rotation dans le plan XY
  4562. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  4563. ANG1 = 0. ;
  4564. SINON ;
  4565. ANG1 = -1.* (ATG VX VY) ;
  4566. FINSI ;
  4567. *
  4568. XPTG YPTG = COOR PTG ;
  4569. *
  4570. * ---- changement d'origine du repere
  4571. XM1 = XM - XPTG ;
  4572. YM1 = YM - YPTG ;
  4573. * ---- rotation pour aligner l'axe Y avec VECT0
  4574. SI (EGA IPLAN 'PHICONS');
  4575. * ---- Coupe 2D a Phi constant
  4576. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  4577. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  4578. ZL = XM * 0. ;
  4579. *
  4580. ZL = XL ;
  4581. XL = XL * 0.;
  4582. FINSI;
  4583. SI (EGA IPLAN 'THECONS');
  4584. * ---- Coupe 2D a Theta constant
  4585. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  4586. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  4587. ZL = XM * 0. ;
  4588. FINSI ;
  4589. *
  4590. SINON ;
  4591. *
  4592. VEC1 = DIR1 / (NORM DIR1) ;
  4593. DIR2 = CP MOINS PTG ;
  4594. VEC2 = DIR2 / (NORM DIR2) ;
  4595. VEC3 = VEC1 PVEC VEC2 ;
  4596. *
  4597. X0 Y0 Z0 = COOR PTG ;
  4598. A1 B1 C1 = COOR VEC1 ;
  4599. A2 B2 C2 = COOR VEC2 ;
  4600. A3 B3 C3 = COOR VEC3 ;
  4601. *
  4602. XM1 = XM - X0 ;
  4603. YM1 = YM - Y0 ;
  4604. ZM1 = ZM - Z0 ;
  4605. *
  4606. XL = (A1 * XM1) + (B1 * YM1) + (C1 * ZM1) ;
  4607. YL = (A2 * XM1) + (B2 * YM1) + (C2 * ZM1) ;
  4608. ZL = (A3 * XM1) + (B3 * YM1) + (C3 * ZM1) ;
  4609. *
  4610. FINSI ;
  4611. FINPROC XL YL ZL ;
  4612.  
  4613.  
  4614. **** @CBTLV
  4615. DEBPROC @CBTLV BRHO*CHPOINT BTHETA*CHPOINT BPHI*CHPOINT THETA*CHPOINT PHI*CHPOINT TAB1*TABLE ;
  4616. *
  4617. *********************************************************************
  4618. * Procedure de changement de base pour un vecteur B de coordonnees *
  4619. * BRHO, BPHI, BTHETA dans une base pseudo-toroidale aux coordonnees *
  4620. * cartesiennes BX, BY, BZ dans la base de l'objet. *
  4621. * Alain MOAL (juin 1995) *
  4622. *********************************************************************
  4623. *
  4624. *--------------- VARIABLES D'ENTREE :
  4625. THETA0 = TAB1.<THETA0 ;
  4626. *------------------------------------
  4627. *
  4628. CT = COS THETA ;
  4629. ST = SIN THETA ;
  4630. CT0 = COS THETA0 ;
  4631. ST0 = SIN THETA0 ;
  4632. MST0 = ST0 * -1. ;
  4633. CPHI = COS PHI ;
  4634. SPHI = SIN PHI ;
  4635. MSPHI= SPHI * -1. ;
  4636. *
  4637. *---- 1) rotation de - Theta autour de "l'axe Phi"
  4638. BRHO1 = (CT * BRHO) - (ST * BTHETA) ;
  4639. BTHETA1 = (ST * BRHO) + (CT * BTHETA) ;
  4640. BPHI1 = BPHI ;
  4641. *
  4642. *---- 2) rotation de - Phi autour de "l'axe Theta"
  4643. BRHO2 = (CPHI * BRHO1) + (MSPHI * BPHI1) ;
  4644. BTHETA2 = BTHETA1 ;
  4645. BPHI2 = (SPHI * BRHO1) + (CPHI * BPHI1) ;
  4646. *
  4647. *---- 3) rotation de Theta0 autour de "l'axe Phi"
  4648. BRHO3 = (BRHO2 * CT0) + (BTHETA2 * ST0) ;
  4649. BTHETA3 = (BRHO2 * MST0) + (BTHETA2 * CT0) ;
  4650. BPHI3 = BPHI2 ;
  4651. *
  4652. *---- 4) composantes dans le repere cartesien
  4653. BX = BPHI3 ;
  4654. BY = BRHO3 * -1. ;
  4655. BZ = BTHETA3 ;
  4656. *
  4657. FINPROC BX BY BZ;
  4658. **** @CBLMV
  4659. DEBPROC @CBLMV VXL*CHPOINT VYL*CHPOINT VZL*CHPOINT TAB1*TABLE ;
  4660. *
  4661. ********************************************************************
  4662. * Version amelioree de l'ancien @CBLMV rebaptise @ACBLM *
  4663. * Procedure de changement de base. On passe de la base cartesienne *
  4664. * locale de l'objet modelise a la base cartesienne du maillage. *
  4665. * l'axe Y est dirige du point de tangence au plasma vers le centre *
  4666. * du plasma. En 3D, L'axe X du repere local est dans la direction *
  4667. * toroidale. *
  4668. * en 2D cas PHICONS l'axe Z du repere local est l'axe toroidal *
  4669. * en 2D cas THECONS l'axe x du repere local est l'axe toroidal *
  4670. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  4671. ********************************************************************
  4672. *
  4673. *--------------- VARIABLES D'ENTREE :
  4674. CP = TAB1.CENTRE_PLASMA ;
  4675. PTG = TAB1.PT_TGPLASMA ;
  4676. SI ((VALEUR DIME) EGA 2) ;
  4677. SI (EXISTE TAB1 <PLAN) ;
  4678. IPLAN = TAB1.<PLAN ;
  4679. SINON ;
  4680. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  4681. FINSI ;
  4682. SINON ;
  4683. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  4684. DIR1 = TAB1.<DIR_TOROIDAL ;
  4685. SINON ;
  4686. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  4687. FINSI ;
  4688. FINSI ;
  4689. *------------------------------------
  4690. *
  4691. SI ((VALEUR DIME) EGA 2) ;
  4692. VECT0 = CP MOINS PTG ;
  4693. VX VY = COOR VECT0 ;
  4694. *
  4695. * ---- calcul de l'angle de rotation dans le plan XY
  4696. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  4697. ANG1 = 0. ;
  4698. SINON ;
  4699. ANG1 = -1.* (ATG VX VY) ;
  4700. FINSI ;
  4701. *
  4702. SI (EGA IPLAN 'PHICONS');
  4703. * ---- Coupe 2D a Phi constant
  4704. VXL1 = VZL ;
  4705. VYL1 = VYL ;
  4706. VZL1 = VXL * (-1.);
  4707. * ---- rotation
  4708. VXM = VXL1 * (COS ANG1) + (VYL1 * (-1.) * (SIN ANG1));
  4709. VYM = VXL1 * (SIN ANG1) + (VYL1 * (COS ANG1)) ;
  4710. VZM = VZL1 ;
  4711. FINSI ;
  4712. SI (EGA IPLAN 'THECONS');
  4713. * ---- Coupe 2D a Theta constant
  4714. * ---- rotation
  4715. VXM = VXL * (COS ANG1) + (VYL * (-1.) * (SIN ANG1)) ;
  4716. VYM = VXL * (SIN ANG1) + (VYL * (COS ANG1)) ;
  4717. VZM = VZL ;
  4718. FINSI;
  4719. *
  4720. SINON ;
  4721. *
  4722. VEC1 = DIR1 / (NORM DIR1) ;
  4723. DIR2 = CP MOINS PTG ;
  4724. VEC2 = DIR2 / (NORM DIR2) ;
  4725. VEC3 = VEC1 PVEC VEC2 ;
  4726. *
  4727. A1 B1 C1 = COOR VEC1 ;
  4728. A2 B2 C2 = COOR VEC2 ;
  4729. A3 B3 C3 = COOR VEC3 ;
  4730. *
  4731. VXM = (A1 * VXL) + (A2 * VYL) + (A3 * VZL) ;
  4732. VYM = (B1 * VXL) + (B2 * VYL) + (B3 * VZL) ;
  4733. VZM = (C1 * VXL) + (C2 * VYL) + (C3 * VZL) ;
  4734. *
  4735. FINSI ;
  4736. FINPROC VXM VYM VZM ;
  4737.  
  4738. **** @CBMLV
  4739. DEBPROC @CBMLV VXM*CHPOINT VYM*CHPOINT VZM*CHPOINT TAB1*TABLE ;
  4740. *
  4741. ********************************************************************
  4742. * Version amelioree de l'ancien @CBMLV rebaptise @ACBML *
  4743. * Procedure de changement de base. On passe de la base cartesienne *
  4744. * du maillage a la base cartesienne locale de l'objet modelise. *
  4745. * l'axe Y final est dirige du point de tangence vers le centre du *
  4746. * plasma. En 3D l'axe x du repere local est donne par la direction *
  4747. * toroidale *
  4748. * en 2D cas PHICONS l'axe Z initial est l'axe toroidal *
  4749. * en 2D cas THECONS l'axe x initial est l'axe toroidal *
  4750. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  4751. ********************************************************************
  4752. *
  4753. *--------------- VARIABLES D'ENTREE :
  4754. CP = TAB1.CENTRE_PLASMA ;
  4755. PTG = TAB1.PT_TGPLASMA ;
  4756. SI ((VALEUR DIME) EGA 2) ;
  4757. SI (EXISTE TAB1 <PLAN) ;
  4758. IPLAN = TAB1.<PLAN ;
  4759. SINON ;
  4760. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  4761. FINSI ;
  4762. SINON ;
  4763. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  4764. DIR1 = TAB1.<DIR_TOROIDAL ;
  4765. SINON ;
  4766. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  4767. FINSI ;
  4768. FINSI ;
  4769. *------------------------------------
  4770. *
  4771. SI ((VALEUR DIME) EGA 2) ;
  4772. VECT0 = CP MOINS PTG ;
  4773. VX VY = COOR VECT0 ;
  4774. *
  4775. * ---- calcul de l'angle de rotation dans le plan XY
  4776. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  4777. ANG1 = 0. ;
  4778. SINON ;
  4779. ANG1 = -1.* (ATG VX VY) ;
  4780. FINSI ;
  4781. *
  4782. * ---- rotation pour aligner l'axe Y avec VECT0
  4783. SI (EGA IPLAN 'PHICONS');
  4784. * ---- Coupe 2D a Phi constant
  4785. VXL1 = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  4786. VYL1 = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  4787. VZL1 = VZM ;
  4788. * ---- Coupe 2D a Phi constant
  4789. VXL = VZL1 ;
  4790. VYL = VYL1 ;
  4791. VZL = VXL1 * (-1.);
  4792. FINSI ;
  4793. SI (EGA IPLAN 'THECONS');
  4794. * ---- Coupe 2D a Theta constant
  4795. * ---- rotation
  4796. VXL = VXM * (COS ANG1) + (VYM * (SIN ANG1));
  4797. VYL = VXM * (-1.) * (SIN ANG1) + (VYM * (COS ANG1));
  4798. VZL = VZM ;
  4799. FINSI ;
  4800. *
  4801. SINON ;
  4802. *
  4803. VEC1 = DIR1 / (NORM DIR1) ;
  4804. DIR2 = CP MOINS PTG ;
  4805. VEC2 = DIR2 / (NORM DIR2) ;
  4806. VEC3 = VEC1 PVEC VEC2 ;
  4807. *
  4808. A1 B1 C1 = COOR VEC1 ;
  4809. A2 B2 C2 = COOR VEC2 ;
  4810. A3 B3 C3 = COOR VEC3 ;
  4811. *
  4812. VXL = (A1 * VXM) + (B1 * VYM) + (C1 * VZM) ;
  4813. VYL = (A2 * VXM) + (B2 * VYM) + (C2 * VZM) ;
  4814. VZL = (A3 * VXM) + (B3 * VYM) + (C3 * VZM) ;
  4815. *
  4816. FINSI ;
  4817. FINPROC VXL VYL VZL ;
  4818. **** @CHAQT
  4819. 'DEBPROC' @CHAQT MOD_1*MMODEL MCH_1/MCHAML CHP_1/CHPOINT MM_1/MOT ;
  4820. * modification raph MITTEAU le 22 fevrier 1994 pour
  4821. * que CHAQT ne fasse rien en 3D
  4822.  
  4823. MAI_1 = EXTR MOD_1 'MAIL' ;
  4824. SI (EGA (VALE DIME) 2) ;
  4825. SI ( existe MM_1 ) ;
  4826. MM_11 = MM_1 ;
  4827. SINON ;
  4828. MM_11 = 'MECANIQUE ELASTIQUE ' ;
  4829. FINSI ;
  4830. SI ( existe MCH_1 ) ;
  4831. * M_21 = chan 'NOEUD' MOD_1 ( REDU MCH_1 MAI_1) ;
  4832. M_21 = chan 'NOEUD' MOD_1 ( REDU MCH_1 MOD_1) ;
  4833. CHP_21 = chan 'CHPO' MOD_1 M_21 ;
  4834. FINSI ;
  4835. SI ( existe CHP_1 ) ;
  4836. CHP_21 = (REDU CHP_1 MAI_1) ;
  4837. M_21 = chan CHAM CHP_21 MOD_1 'NOEUD' ;
  4838. FINSI ;
  4839. SI ((NON ( existe CHP_1 )) ET (NON ( existe MCH_1))) ;
  4840. ERRE 'IL FAUT DONNER UN CHPOINT OU UN MCHAML' ;
  4841. FINSI ;
  4842. * MAI_2 = chan tri6 MAI_1 ;
  4843. n_t6 = MAXI (nbel MAI_1 ( MOTS TRI6)) ;
  4844. n_q8 = MAXI (nbel MAI_1 ( MOTS QUA8));
  4845. * MESS 'nbre de Q8:' n_q8 'nbre de TRI6:' n_t6 ;
  4846. SI ( n_q8 > 0 ) ;
  4847. MAI_Q8 = MAI_1 ELEM QUA8 ;
  4848. SI ( n_t6 > 0 ) ;
  4849. MAI_T6 = MAI_1 ELEM TRI6 ;
  4850. MAI_2 = (chan tri6 MAI_Q8) ET MAI_T6 ;
  4851. SINON ;
  4852. MAI_2 = chan tri6 MAI_Q8 ;
  4853. FINSI ;
  4854. * MOD_2 = MODE MAI_2 mecanique elastique ;
  4855. TT_1 = TEXTE MM_11 ;
  4856. MOD_2 = MODE MAI_2 TT_1 ;
  4857. * il faut utiliser diff pour ne faire le proi que sur les noeuds nouveaux
  4858. POI_NEW = DIFF ( CHAN POI1 MAI_1 ) ( CHAN POI1 MAI_2 );
  4859. CHP_22 = @ET CHP_21 ( proi POI_NEW M_21 ) ;
  4860. SINON ;
  4861. MAI_2 = MAI_1 ;
  4862. CHP_22 = CHP_21 ;
  4863. MOD_2 = MOD_1 ;
  4864. FINSI ;
  4865. m_22 = chan cham CHP_22 MOD_2 ;
  4866. SINON;
  4867. m_22 = REDU MCH_1 MOD_1 ;
  4868. MOD_2 = MOD_1;
  4869. MAI_2 = MAI_1 ;
  4870. FINSI ;
  4871.  
  4872. 'FINPROC' m_22 MOD_2 MAI_2 ;
  4873.  
  4874.  
  4875. *----------------------------------------------------------------------*
  4876. * *
  4877. * C H A Q T *
  4878. * --------- *
  4879. * DATE 93/05/07
  4880. * procedure CHAQT (DRFC - J. Schlosser)
  4881. * ------------------------------------------
  4882. *
  4883. * MCHPO2 MAIL2 = CHAQT3D MOD1 OBJET1 MAIL1
  4884. *
  4885. *
  4886. *
  4887. * Objet :
  4888. * _________
  4889. *
  4890. * Etant donne un objet de type MCHAML ou CHPOINT , OBJET1,
  4891. * defini sur un MMODEL massif,MOD1,compose de QUA8 et TRI6 (ou
  4892. * en 3D de CU20 PR15) et un sous ensemble MAIL1 du maillage MAITOT1
  4893. * correspondant a MOD1 ( en 3D par exemple
  4894. * l enveloppe) compose de QUA8 et TRI6. La procedure cree
  4895. * un CHPOINT defini sur un nouveau maillage compose exclusivement
  4896. * de TRI6 afin de pouvoir effectue un trace d isovaleur plus correct
  4897. * ( le QUA8 initial se trouve ainsi transforme en QUA9 avec un point
  4898. * milieu ce qui permet un decoupage en 8 triangles lineaires. Cela
  4899. * revient a approximer la variation quadratique dans l element par
  4900. * une variation bilineaire)
  4901. *
  4902. * *
  4903. * Commentaire
  4904. * _____________
  4905. *
  4906. *
  4907. * MOD1 : objet de type MODE (elements massifs)
  4908. *
  4909. * OBJET1 : objet de type MCHAML ou CHPOINT
  4910. *
  4911. * MAIL1 : objet de type MAILLAGE compose de TRI6 et de QUA8
  4912. *
  4913. * MCHPO2 : objet de type CHPOINT
  4914. *
  4915. * MAIL2 : objet de type MAILLAGE compose de TRI6
  4916. *
  4917. *
  4918. *
  4919. * *
  4920. * Remarque
  4921. * _____________
  4922. *
  4923. *
  4924. * la procedure utilise grosso modo
  4925. * MAIL2 = chan tri6 MAIL1 ;
  4926. * MCHPO2 =proi MAIL2 MCHPO1 ;
  4927. * ce shema brut est optimisee et la procedure ne
  4928. * fait la projection que sur les points nouveaux milieux des QUA8
  4929. * ( malheureusement PROI ne calcule pas dans ce cas les bonnnes valeurs)
  4930. *
  4931. * Attention on voit que l on passe par l intermediaire d un CHPOINT
  4932. * les valeurs vont se trouver moyennees aux interfaces des materiaux
  4933. * si vous le souhaitez, procedez materiau par materiau !
  4934. * l' OBJET1 est REDUIT a MOD_1 a l entree de la procedure
  4935. *----------------------------------------------------------------------*
  4936. *123456789012345678901234567890123456789012345678901234567890123456789012
  4937. * 1 2 3 4 5 6 7
  4938. 'DEBPROC' CHAQT3D MOD_1*MMODEL MCH_1/MCHAML CHP_1/CHPOINT MAI_1*MAILLAGE ;
  4939. MAITOT1 = EXTR MOD_1 'MAIL' ;
  4940. SI ( existe MCH_1 ) ;
  4941. M_21 = REDU MCH_1 MOD_1 ;
  4942. M_21 = chan 'NOEUD' MOD_1 M_21 ;
  4943. CHP_21 = chan 'CHPO' MOD_1 M_21 ;
  4944. CHP_20 = REDU CHP_21 MAI_1 ;
  4945. FINSI ;
  4946. SI ( existe CHP_1 ) ;
  4947. CHP_20 = REDU CHP_1 MAI_1 ;
  4948. CHP_21 = REDU CHP_1 MAITOT1 ;
  4949. M_21 = chan CHAM CHP_21 MOD_1 'NOEUD' ;
  4950. * M_21 = chan CHAM CHP_21 MOD_1 'STRESSES' ;
  4951. FINSI ;
  4952. SI ((NON ( existe CHP_1 )) ET (NON ( existe MCH_1))) ;
  4953. ERRE 'IL FAUT DONNER UN CHPOINT OU UN MCHAML' ;
  4954. FINSI ;
  4955. *
  4956. n_t6 = MAXI (nbel MAI_1 ( MOTS TRI6)) ;
  4957. n_q8 = MAXI (nbel MAI_1 ( MOTS QUA8));
  4958. MESS 'nbre de Q8:' n_q8 'nbre de TRI6:' n_t6 ;
  4959. SI ( n_q8 > 0 ) ;
  4960. MAI_Q8 = MAI_1 ELEM QUA8 ;
  4961. SI ( n_t6 > 0 ) ;
  4962. MAI_T6 = MAI_1 ELEM TRI6 ;
  4963. MAI_2 = (chan tri6 MAI_Q8) ET MAI_T6 ;
  4964. SINON ;
  4965. MAI_2 = chan tri6 MAI_Q8 ;
  4966. FINSI ;
  4967.  
  4968. * il faut utiliser diff pour ne faire le proi que sur les noeuds nouveaux
  4969. POI_NEW = DIFF ( CHAN POI1 MAI_1 ) ( CHAN POI1 MAI_2 );
  4970. * trac ( 1.e5 5.e4 -1.e5 ) CHP_20 MAI_1 ;
  4971. * trac ( 1.e5 5.e4 -1.e5 ) M_21 MOD_1 MAI_1 ;
  4972. * trac ( 1.e5 5.e4 -1.e5 ) ( MAI_1 et POI_NEW );
  4973. * trac face ( 1.e5 5.e4 -1.e5 ) MAI_2 ;
  4974. CHP_22 = CHP_20 ET ( proi POI_NEW M_21 ) ;
  4975. * trac ( 1.e5 5.e4 -1.e5 ) CHP_22 MAI_2 ;
  4976.  
  4977. SINON ;
  4978. MAI_2 = MAI_1 ;
  4979. CHP_22 = CHP_21 ;
  4980. FINSI ;
  4981. 'FINPROC' CHP_22 MAI_2 ;
  4982.  
  4983. ******************************************
  4984. * *
  4985. * procedure CHREP : changement de repere *
  4986. * *
  4987. ******************************************
  4988. DEBPROC CHREP CHOIX*MOT CH_2/CHPOINT CH_M/MCHAML CH_PP2/CHPOINT CH_MP/MCHAML ;
  4989. MESS '----------------------> entree dans CHREP ';
  4990. SI ( EXISTE CH_2);
  4991. CH_1 = CH_2 ;
  4992. CH_PP = CH_PP2 ;
  4993. SINON ;
  4994. CH_1 = CH_M ;
  4995. CH_PP = CH_MP;
  4996. FINSI;
  4997.  
  4998. V1 = VALEUR DIME ;
  4999. MESS'DIMENSION';
  5000. V2 = VALEUR MODE ;
  5001. P = TABLE ;
  5002. P.1 = TABLE ;
  5003. P.2 = TABLE ;
  5004. P.3 = TABLE ;
  5005. S = TABLE ;
  5006. S.1 = TABLE ;
  5007. S.2 = TABLE ;
  5008. S.3 = TABLE ;
  5009. SP = TABLE ;
  5010. SP.1 = TABLE ;
  5011. SP.2 = TABLE ;
  5012. SP.3 = TABLE ;
  5013.  
  5014. LISTCOM1 = EXTR CH_1 'COMP';
  5015. LISTCOM2 = EXTR CH_PP 'COMP';
  5016.  
  5017. MR2D_1 = CHAINE 'TX ' 'TY ' 'NX ' 'NY ' ;
  5018. MR2D_2 = CHAINE 'P11 ' 'P12 ' 'P21 ' 'P22 ' ;
  5019. MR3D_1 = CHAINE 'TX ' 'TY ' 'TZ ' 'NX ' 'NY ' 'NZ ' 'BX ' 'BY ' 'BZ ';
  5020. MR3D_2 = CHAINE 'P11 ' 'P12 ' 'P13 ' 'P21 ' 'P22 ' 'P23 ' 'P31 ' 'P32 ' 'P33 ' ;
  5021. SI ( EGA CHOIX 'CONTRAINTES' ) ;
  5022. MC2D_1 = CHAINE 'SMXX' 'SMYY' 'SMZZ' 'SMXY' ;
  5023. MC2D_2 = CHAINE 'SMRR' 'SMZZ' 'SMTT' 'SMRZ' ;
  5024. MC3D_1 = CHAINE 'SMXX' 'SMYY' 'SMZZ' 'SMXY' 'SMXZ' 'SMYZ' ;
  5025. FINSI ;
  5026. SI ( EGA CHOIX 'DEFORMATIONS' ) ;
  5027. MC2D_1 = CHAINE 'EPXX' 'EPYY' 'EPZZ' 'EPXY' ;
  5028. MC2D_2 = CHAINE 'EPRR' 'EPZZ' 'EPTT' 'EPRZ' ;
  5029. MC3D_1 = CHAINE 'EPXX' 'EPYY' 'EPZZ' 'EPXY' 'EPXZ' 'EPYZ' ;
  5030. FINSI ;
  5031. SI (V1 EGA 2) ;
  5032. MCR1 = CHAINE (EXTR LISTCOM2 1) (EXTR LISTCOM2 2) (EXTR LISTCOM2 3) (EXTR LISTCOM2 4) ;
  5033. MCC1 = CHAINE (EXTR LISTCOM1 1) (EXTR LISTCOM1 2) (EXTR LISTCOM1 3) (EXTR LISTCOM1 4) ;
  5034. MESS '>>>CHREP>>>' MCR1 ;
  5035. MESS '>>>CHREP>>>' MR2D_1 ;
  5036. SI ( NON (( EGA MCR1 MR2D_1) OU ( EGA MCR1 MR2D_2)) ) ;
  5037. MESS '>>>CHREP>>> COMPOSANTES REPERE TROUVEES :' MCR1 ;
  5038. MESS '>>>CHREP>>> AU LIEU DE :' MR2D_1 ;
  5039. MESS '>>>CHREP>>> OU BIEN :' MR2D_2 ;
  5040. ERREUR 'COMP_REP_NON_ADMISES' ;
  5041. FINSI;
  5042. SI ( NON (( EGA MCC1 MC2D_1) OU ( EGA MCC1 MC2D_2)) ) ;
  5043. MESS '>>>CHREP>>> COMPOSANTES REPERE TROUVEES :' MCC1 ;
  5044. MESS '>>>CHREP>>> AU LIEU DE :' MC2D_1 ;
  5045. MESS '>>>CHREP>>> OU BIEN :' MC2D_2 ;
  5046. ERREUR 'COMP_CHAMP_NON_ADMISES' ;
  5047. FINSI;
  5048. FINSI;
  5049. SI (V1 EGA 3) ;
  5050. MCR1 = CHAINE (EXTR LISTCOM2 1) (EXTR LISTCOM2 2) (EXTR LISTCOM2 3) (EXTR LISTCOM2 4) (EXTR LISTCOM2 5) (EXTR LISTCOM2 6) (EXTR LISTCOM2 7) (EXTR LISTCOM2 8) (EXTR LISTCOM2 9) ;
  5051. MCC1 = CHAINE (EXTR LISTCOM1 1) (EXTR LISTCOM1 2) (EXTR LISTCOM1 3) (EXTR LISTCOM1 4) (EXTR LISTCOM1 5) (EXTR LISTCOM1 6) ;
  5052. SI ( NON ( EGA MCR1 MR3D_1) ) ;
  5053. MESS '>>>CHREP>>> COMPOSANTES REPERE TROUVEES :' MCR1 ;
  5054. MESS '>>>CHREP>>> AU LIEU DE :' MR3D_1 ;
  5055. ERREUR 'COMP_REP_NON_ADMISES' ;
  5056. FINSI;
  5057. SI ( NON ( EGA MCC1 MC3D_1) ) ;
  5058. MESS '>>>CHREP>>> COMPOSANTES REPERE TROUVEES :' MCC1 ;
  5059. MESS '>>>CHREP>>> AU LIEU DE :' MC3D_1 ;
  5060. ERREUR 'COMP_CHAMP_NON_ADMISES' ;
  5061. FINSI;
  5062. FINSI;
  5063.  
  5064. SI (V1 EGA 2);
  5065. P.1 . 1 = EXCO (EXTR LISTCOM2 1) CH_PP SCAL ;
  5066. P.1 . 2 = EXCO (EXTR LISTCOM2 2) CH_PP SCAL ;
  5067. P.2 . 1 = EXCO (EXTR LISTCOM2 3) CH_PP SCAL ;
  5068. P.2 . 2 = EXCO (EXTR LISTCOM2 4) CH_PP SCAL ;
  5069. S.1 . 1 = EXCO (EXTR LISTCOM1 1) CH_1 SCAL ;
  5070. S.1 . 2 = EXCO (EXTR LISTCOM1 4) CH_1 SCAL ;
  5071. S.2 . 1 = S.1 . 2 ;
  5072. S.2 . 2 = EXCO (EXTR LISTCOM1 2) CH_1 SCAL ;
  5073. S.3 . 3 = EXCO (EXTR LISTCOM1 3) CH_1 SCAL ;
  5074. FINSI;
  5075. SI (V1 > 2) ;
  5076. P.1 . 1 = EXCO (EXTR LISTCOM2 1) CH_PP SCAL ;
  5077. P.1 . 2 = EXCO (EXTR LISTCOM2 2) CH_PP SCAL ;
  5078. P.1 . 3 = EXCO (EXTR LISTCOM2 3) CH_PP SCAL ;
  5079. P.2 . 1 = EXCO (EXTR LISTCOM2 4) CH_PP SCAL ;
  5080. P.2 . 2 = EXCO (EXTR LISTCOM2 5) CH_PP SCAL ;
  5081. P.2 . 3 = EXCO (EXTR LISTCOM2 6) CH_PP SCAL ;
  5082. P.3 . 1 = EXCO (EXTR LISTCOM2 7) CH_PP SCAL ;
  5083. P.3 . 2 = EXCO (EXTR LISTCOM2 8) CH_PP SCAL ;
  5084. P.3 . 3 = EXCO (EXTR LISTCOM2 9) CH_PP SCAL ;
  5085. *
  5086. S.1 . 1 = EXCO (EXTR LISTCOM1 1) CH_1 SCAL ;
  5087. S.1 . 2 = EXCO (EXTR LISTCOM1 4) CH_1 SCAL ;
  5088. S.2 . 1 = S.1 . 2 ;
  5089. S.2 . 2 = EXCO (EXTR LISTCOM1 2) CH_1 SCAL ;
  5090. S.3 . 3 = EXCO (EXTR LISTCOM1 3) CH_1 SCAL ;
  5091. S.1 . 3 = EXCO (EXTR LISTCOM1 5) CH_1 SCAL ;
  5092. S.2 . 3 = EXCO (EXTR LISTCOM1 6) CH_1 SCAL ;
  5093. S.3 . 1 = S.1 . 3 ;
  5094. S.3 . 2 = S.2 . 3 ;
  5095.  
  5096. I = 0;
  5097. REPETER BOUCS1 3;
  5098. I = I + 1;
  5099. J = I - 1;
  5100. REPETER BOUCS2 ( 3 + 1 - I );
  5101. J = J + 1;
  5102. SP.I.J = 0.;
  5103. L = 0;
  5104. REPETER BOUCS3 3;
  5105. L = L + 1;
  5106. Q = 0;
  5107. REPETER BOUCS4 3;
  5108. Q = Q + 1;
  5109. SP.I.J = (SP.I.J) + ( (P.I.L) * ( P.J.Q) * (S.L.Q )) ;
  5110. FIN BOUCS4;
  5111. FIN BOUCS3;
  5112. FIN BOUCS2;
  5113. FIN BOUCS1;
  5114. SI ( EGA CHOIX CONTRAINTES);
  5115. CH_2 = ( NOMC 'SMTT' SP.1 . 1 ) @ET ( NOMC 'SMNN' SP.2 . 2 ) @ET ( NOMC 'SMBB' SP.3 . 3 ) @ET ( NOMC 'SMTN' SP.1 . 2 ) @ET ( NOMC 'SMTB' SP.1 . 3 ) @ET ( NOMC 'SMNB' SP.2 . 3 );
  5116. SINON;
  5117. CH_2 = ( NOMC 'EPTT' SP.1 . 1 ) @ET ( NOMC 'EPNN' SP.2 . 2 ) @ET ( NOMC 'EPBB' SP.3 . 3 ) @ET ( NOMC 'EPTN' SP.1 . 2 ) @ET ( NOMC 'EPTB' SP.1 . 3 ) @ET ( NOMC 'EPNB' SP.2 . 3 );
  5118. FINSI;
  5119.  
  5120. SINON;
  5121. I = 0;
  5122. REPETER BOUCS11 2;
  5123. I = I + 1;
  5124. J = I-1;
  5125. REPETER BOUCS21 (2+1-I);
  5126. J = J + 1;
  5127. SP.I.J = 0. ;
  5128. L = 0;
  5129. REPETER BOUCS31 2;
  5130. L = L + 1;
  5131. Q = 0 ;
  5132. REPETER BOUCS41 2;
  5133. Q = Q + 1;
  5134. SP.I.J = (SP.I.J) + ( (P.I.L) * ( P.J.Q) * (S.L.Q )) ;
  5135. FIN BOUCS41;
  5136. FIN BOUCS31;
  5137. FIN BOUCS21;
  5138. FIN BOUCS11;
  5139. SP.3 . 3 = S.3 . 3;
  5140. SI ( EGA CHOIX CONTRAINTES);
  5141. CH_2 = ( NOMC 'SMTT' SP.1 . 1 ) @ET ( NOMC 'SMNN' SP.2 . 2 ) @ET ( NOMC 'SMBB' SP.3 . 3 ) @ET ( NOMC 'SMTN' SP.1 . 2 );
  5142. SINON;
  5143. CH_2 = ( NOMC 'EPTT' SP.1 . 1 ) @ET ( NOMC 'EPNN' SP.2 . 2 ) @ET ( NOMC 'EPBB' SP.3 . 3 ) @ET ( NOMC 'EPTN' SP.1 . 2 );
  5144. FINSI;
  5145.  
  5146. FINSI;
  5147. MESS '----------------------> sortie de CHREP ';
  5148. FINPROC CH_2;
  5149. **** @CLAMQ
  5150. DEBPROC @CLAMQ TAB1*TABLE XM*CHPOINT YM*CHPOINT ZM*CHPOINT ISHIFT*LOGIQUE IRIPPLE*LOGIQUE ;
  5151. *
  5152. ***********************************************************
  5153. * Procedure de calcul du parametre Lambdaq necessaire au *
  5154. * calcul du profil du depot de puissance en chaque point *
  5155. * de la surface de la structure modelisee. *
  5156. * Alain MOAL (juin 1995) *
  5157. ***********************************************************
  5158. *
  5159. MESS '---------------------------------> calling @CLAMQ';
  5160. *
  5161. *--------------- VARIABLES D'ENTREE :
  5162. RP = TAB1.<RP ;
  5163. HP = TAB1.<HP ;
  5164. RHO0 = TAB1.<RHO0 ;
  5165. THETA0 = TAB1.<THETA0 ;
  5166. ANGPHI0 = TAB1.<ANGPHI0 ;
  5167. RR = TAB1.<RR ;
  5168. LAMB = TAB1.<LAMB ;
  5169. LAMBQREF = TAB1.<LAMBQREF ;
  5170. THETAREF = TAB1.<THETAREF ;
  5171. IPLASMA = TAB1.<IPLASMA ;
  5172. COEFA = TAB1.<COEFA ;
  5173. COEFB = TAB1.<COEFB ;
  5174. COEFC = TAB1.<COEFC ;
  5175. RHOMER = TAB1.<RHOMER ;
  5176. NBOB = TAB1.<NBOB ;
  5177. IMESS = TAB1.<IMESS ;
  5178. *------------------------------------
  5179. *
  5180. PI = 3.141592 ;
  5181. MU0 = 4.E-7 * PI ;
  5182. *
  5183. *---- Coordonnees de chaque point dans le repere du plasma
  5184. RHOP THETAP PHIP = @CRGTC XM YM ZM RP HP ;
  5185. *
  5186. *---- Masque delimitant le domaine de validite du modele de ripple
  5187. *attention domaine de validite etendu a 180 par E.COSTA et
  5188. *E.TSITRONE le 02/06/97
  5189. *MASK0 = (ABS THETAP) MASQUE INFERIEUR 110. ;
  5190. MASK0 = (ABS THETAP) MASQUE INFERIEUR 180. ;
  5191. *
  5192. SI ISHIFT ;
  5193. AUX0 = -1. * MU0 * IPLASMA / (2. * PI) ;
  5194. *
  5195. BPTHEREF = (((RHOP/RP) * (COS THETAREF) * LAMB) + 1.) * AUX0 ;
  5196. BPTHE = (((COS THETAP) * (RHOP/RP) * LAMB) + 1.) * AUX0 ;
  5197. *
  5198. * ---- facteur de compression des lignes de champ due au shift
  5199. H1 = (RHOP * (COS THETAREF) + RP) * BPTHEREF ;
  5200. H2 = ((COS THETAP) * RHOP + RP) * BPTHE ;
  5201. HS = H2 ** -1 * H1 ;
  5202. SINON ;
  5203. HS = RHOP * 0. + 1. ;
  5204. FINSI ;
  5205. *
  5206. SI IRIPPLE ;
  5207. * ---- enveloppe de la DSMF dans le repere adapte au calcul du ripple
  5208. * ---- Rho0 dans le "repere du ripple"
  5209. RHOR THETAR PHIR = @CRGTC XM YM ZM RR 0. ;
  5210. *
  5211. RHO0R = ((RHO0**2) + ((RP - RR)**2) + (2. * RHO0 * (RP - RR) * (COS THETAP)))**0.5 ;
  5212. RHODSMFR = (EXP((THETAR**2) * -1. * COEFC)) * (EXP(COEFB * RHO0R)) * ((COS((PHIR + ANGPHI0) * NBOB)) - 1.) * COEFA + RHO0R;
  5213. * ---- dans le repere du plasma
  5214. RHODSMFP = RHODSMFR * 2. * (RR - RP) * (COS THETAR) ;
  5215. RHODSMFP = RHODSMFP + ((RR - RP)**2) + (RHODSMFR**2) ;
  5216. RHODSMFP = RHODSMFP**0.5 ;
  5217. RHOMERP = RHOMER * 2. * (RR - RP) * (COS THETAR) ;
  5218. RHOMERP = RHOMERP + ((RR - RP)**2) + (RHOMER**2) ;
  5219. RHOMERP = RHOMERP**0.5 ;
  5220. *
  5221. * ---- facteur de compression des lignes de champ due au ripple
  5222. * ---- Rem : le masque sert a traiter le cas Rhomer = Rho0r
  5223. * ---- dans le repere du ripple
  5224. *AM1** MASQ1 = ((ABS(RHOR - RHODSMFR)) MASQUE INFERIEUR 1.E-6)*1.E-6;
  5225. *AM1** MASQ2 = ((ABS(RHOMER - RHO0R)) MASQUE INFERIEUR 1.E-6)*1.E-6 ;
  5226. *AM1** HR = ((RHOR - RHODSMFR) + MASQ1) / ((RHOMER - RHO0R) + MASQ2) ;
  5227. * ---- dans le repere du plasma
  5228. *AM2** MASQ1 = ((ABS(RHOP - RHODSMFP)) MASQUE INFERIEUR 1.E-6)*1.E-6;
  5229. *AM2** MASQ2 = ((ABS(RHOMERP - RHO0)) MASQUE INFERIEUR 1.E-6)*1.E-6 ;
  5230. *AM2** HR = ((RHOP - RHODSMFP) + MASQ1) / ((RHOMERP - RHO0) + MASQ2);
  5231. *AM*** HR = MASK0 * HR + ((1.-MASK0) * 1.) ;
  5232. * ---- Pas de compression des lignes de champ due au ripple
  5233. HR = RHOP * 0. + 1. ;
  5234. SINON ;
  5235. HR = RHOP * 0. + 1. ;
  5236. FINSI ;
  5237. *
  5238. LAMBQ = HR * HS * LAMBQREF ;
  5239. *
  5240. *---- distance a la derniere surface magnetique avec ripple
  5241. SI IRIPPLE ;
  5242. * ---- dans le repere du plasma
  5243. DELTA = MASK0 * (RHOP - RHODSMFP) + ((1.-MASK0) * (RHOP - RHO0));
  5244. * ---- dans le repere du ripple
  5245. *AM1** DELTA = MASK0 * (RHOR - RHODSMFR) + ((1.-MASK0) * (RHOR - RHO0R));
  5246. SINON ;
  5247. DELTA = RHOP - RHO0 ;
  5248. FINSI ;
  5249. *
  5250. *---- messages de verification
  5251. SI (IMESS >EG 3) ;
  5252. MESS '>>>> in @CLAMQ : RHO0R '; LIST RHO0R ;
  5253. MESS '>>>> in @CLAMQ : RHODSMFR '; LIST RHODSMFR ;
  5254. MESS '>>>> in @CLAMQ : RHO0R '; LIST RHO0R ;
  5255. MESS '>>>> in @CLAMQ : HR '; LIST HR ;
  5256. MESS '>>>> in @CLAMQ : HS '; LIST HS ;
  5257. MESS '>>>> in @CLAMQ : LAMBQ '; LIST LAMBQ ;
  5258. MESS '>>>> in @CLAMQ : DELTA '; LIST DELTA ;
  5259. FINSI ;
  5260. *
  5261. SI (IMESS >EG 2) ;
  5262. MESS '>>>> in @CLAMQ : max and min values of HR ';
  5263. MESS (MAXI HR) (MINI HR) ;
  5264. MESS '>>>> in @CLAMQ : max and min values of HS ';
  5265. MESS (MAXI HS) (MINI HS) ;
  5266. MESS '>>>> in @CLAMQ : max and min values of LAMBQ ';
  5267. MESS (MAXI LAMBQ) (MINI LAMBQ) ;
  5268. MESS '>>>> in @CLAMQ : max and min values of DELTA ';
  5269. MESS (MAXI DELTA) (MINI DELTA) ;
  5270. FINSI ;
  5271. *
  5272. MESS '---------------------------------> exiting @CLAMQ';
  5273. FINPROC LAMBQ HS HR DELTA ;
  5274.  
  5275.  
  5276.  
  5277.  
  5278. **** @CLIGB
  5279. DEBPROC @CLIGB NBPAS0*ENTIER PASB0*FLOTTANT TAB1*TABLE TABLIG1*TABLE IMETHOD*ENTIER;
  5280. *
  5281. *****************************************************************
  5282. * Procedure de calcul des lignes de champ magnetique partant de *
  5283. * chaque point d'une geometrie donnee. *
  5284. * methode 1 : methode explicite (tangentes) *
  5285. * methode 2 : Methode iterative avec convergence sur un critere *
  5286. * d'appartenance a la surface magnetique *
  5287. * Alain MOAL (mars 1996) *
  5288. *****************************************************************
  5289. *
  5290. MESS '---------------------------------> calling @CLIGB';
  5291. *
  5292. * ---- Valeurs par defaut
  5293. @VDEFAUT TAB1 ;
  5294. *
  5295. *--------------- VARIABLES D'ENTREE :
  5296. LISTE0 = TAB1.<LI_LIGNE_B ;
  5297. TYPCAL = TAB1.<TYPE_CALCUL ;
  5298. RP = TAB1.<RP ;
  5299. RR = TAB1.<RR ;
  5300. HP = TAB1.<HP ;
  5301. EPS0 = TAB1.<EPS ;
  5302. COEFA = TAB1.<COEFA ;
  5303. COEFB = TAB1.<COEFB ;
  5304. COEFC = TAB1.<COEFC ;
  5305. NBOB = TAB1.<NBOB ;
  5306. SI (EXISTE TAB1 <LPT) ;
  5307. RHO0 = TAB1.<RHO0 ;
  5308. FINSI ;
  5309. *------------------------------------
  5310. *
  5311. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  5312. ISHIFT = VRAI ;
  5313. IRIPPLE = VRAI ;
  5314. FINSI ;
  5315. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  5316. ISHIFT = VRAI ;
  5317. IRIPPLE = FAUX ;
  5318. FINSI ;
  5319. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  5320. ISHIFT = FAUX ;
  5321. IRIPPLE = VRAI ;
  5322. FINSI ;
  5323. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  5324. ISHIFT = FAUX ;
  5325. IRIPPLE = FAUX ;
  5326. FINSI ;
  5327. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  5328. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  5329. FINSI ;
  5330.  
  5331. SI (IMETHOD EGA 1) ;
  5332. * ---- Methode explicite simple (tangentes)
  5333. I0 = 0 ;
  5334.  
  5335. REPETER BOUCLE0 (DIME LISTE0);
  5336.  
  5337. I0 = I0 + 1 ; list I0 ;
  5338. P0 = TEXT (EXTR I0 LISTE0) ;
  5339. XM YM ZM = COOR P0 ;
  5340. TABLIG1.I0 = ((XM+1.E-6) YM ZM) D 1 P0 ;
  5341.  
  5342. * ---- Transformation en champ par point
  5343. XM0 = MANU CHPO P0 1 SCAL XM ;
  5344. YM0 = MANU CHPO P0 1 SCAL YM ;
  5345. ZM0 = MANU CHPO P0 1 SCAL ZM ;
  5346.  
  5347. * ---- Coordonnees dans le repere global du tore
  5348. XG_OLD YG_OLD ZG_OLD = @CRMGC XM0 YM0 ZM0 TAB1 ;
  5349. *
  5350. I1 = 0 ;
  5351. REPETER BOUCLE1 NBPAS0 ;
  5352. * I1 = I1 + 1 ; MESS 'I1 = ' I1;
  5353. * ---- Calcul du champ dans le repere global
  5354. BXG BYG BZG FSECU = @CHAMB TAB1 XG_OLD YG_OLD ZG_OLD ISHIFT IRIPPLE ;
  5355.  
  5356. NORM_B = ((BXG*BXG) + (BYG*BYG) + (BZG*BZG))**0.5 ;
  5357.  
  5358. XG_NEW = XG_OLD - (BXG * PASB0 / NORM_B) ;
  5359. YG_NEW = YG_OLD - (BYG * PASB0 / NORM_B) ;
  5360. ZG_NEW = ZG_OLD - (BZG * PASB0 / NORM_B) ;
  5361.  
  5362. * ---- Coordonnees dans le repere du maillage
  5363. XM_NEW YM_NEW ZM_NEW = @CRGMC XG_NEW YG_NEW ZG_NEW TAB1 ;
  5364.  
  5365. XM1 = EXTR XM_NEW SCAL P0 ;
  5366. YM1 = EXTR YM_NEW SCAL P0 ;
  5367. ZM1 = EXTR ZM_NEW SCAL P0;
  5368.  
  5369. SI (EXISTE TAB1 <LPT) ;
  5370. * ---- traitement particulier pour le LPT
  5371. * ---- on change la couleur de la ligne qui
  5372. * ---- passe au dessous
  5373. XM2 YM2 ZM2 = @CRGMC XG_OLD YG_OLD ZG_OLD TAB1;
  5374.  
  5375. SI ((ZG_NEW >EG RHO0) ET (ZG_OLD >EG RHO0)) ;
  5376. TABLIG1.I0 = TABLIG1.I0 ET (((XM2 YM2 ZM2) D 1 (XM1 YM1 ZM1)) COUL ROUG);
  5377. SINON ;
  5378. TABLIG1.I0 = TABLIG1.I0 ET (((XM2 YM2 ZM2) D 1 (XM1 YM1 ZM1)) COUL JAUN);
  5379. FINSI ;
  5380. FINSI ;
  5381.  
  5382. TABLIG1.I0 = TABLIG1.I0 D 1 (XM1 YM1 ZM1) ;
  5383.  
  5384. XG_OLD = XG_NEW ;
  5385. YG_OLD = YG_NEW ;
  5386. ZG_OLD = ZG_NEW ;
  5387.  
  5388. MENAGE ;
  5389.  
  5390. FIN BOUCLE1 ;
  5391.  
  5392. * ---- calcul de l'erreur sur Rho
  5393.  
  5394. SI ((NON ISHIFT) ET (NON IRIPPLE)) ;
  5395. * ---- Coordonnees du point initial dans le repere
  5396. * ---- global du tore
  5397. XG0 YG0 ZG0 = @CRMGC XM0 YM0 ZM0 TAB1 ;
  5398.  
  5399. * ---- Coordonnees du point initial dans le repere
  5400. * ---- pseudo-toroidal du plasma
  5401. RHO0 THE0 PHI0 = @CRGTC XG0 YG0 ZG0 RP HP ;
  5402.  
  5403. * ---- Coordonnees du point final dans le repere
  5404. * ---- pseudo-toroidal du plasma
  5405. RHO1 THE1 PHI1 = @CRGTC XG_OLD YG_OLD ZG_OLD RP HP;
  5406.  
  5407. * ---- sans ripple, on doit avoir Rho constant le
  5408. * ---- long de la ligne de champ
  5409. DRHO0 = RHO1 - RHO0 ;
  5410. ERREUR0 = (ABS DRHO0) / RHO0 ;
  5411. MESS 'Variation en Rho : ' ; LIST DRHO0 ;
  5412. MESS 'Erreur en Rho : ' ; LIST ERREUR0 ;
  5413. FINSI ;
  5414.  
  5415. FIN BOUCLE0 ;
  5416. FINSI ;
  5417.  
  5418. SI (IMETHOD EGA 2) ;
  5419. * ---- Methode iterative avec convergence sur un critere
  5420. * ---- d'appartenance a la surface magnetique
  5421. I0 = 0 ;
  5422.  
  5423. REPETER BOUCLE0 (DIME LISTE0);
  5424.  
  5425. I0 = I0 + 1 ;
  5426. P0 = TEXT (EXTR I0 LISTE0) ;
  5427. XM YM ZM = COOR P0 ;
  5428. TABLIG1.I0 = ((XM+1.E-6) YM ZM) D 1 P0 ;
  5429.  
  5430. * ---- Transformation en champ par point
  5431. XM0 = MANU CHPO P0 1 SCAL XM ;
  5432. YM0 = MANU CHPO P0 1 SCAL YM ;
  5433. ZM0 = MANU CHPO P0 1 SCAL ZM ;
  5434.  
  5435. * ---- Coordonnees dans le repere global du tore
  5436. XG_OLD YG_OLD ZG_OLD = @CRMGC XM0 YM0 ZM0 TAB1 ;
  5437. *
  5438. I1 = 0 ;
  5439. REPETER BOUCLE1 NBPAS0 ;
  5440.  
  5441. I1 = I1 + 1 ; MESS 'I1 = ' I1;
  5442. * ---- Calcul du champ dans le repere global
  5443. BXG BYG BZG FSECU = @CHAMB TAB1 XG_OLD YG_OLD ZG_OLD ISHIFT IRIPPLE ;
  5444.  
  5445. NORM_B = ((BXG*BXG) + (BYG*BYG) + (BZG*BZG))**0.5 ;
  5446.  
  5447. XG_NEW0 = XG_OLD - (BXG * PASB0 / NORM_B) ;
  5448. YG_NEW0 = YG_OLD - (BYG * PASB0 / NORM_B) ;
  5449. ZG_NEW0 = ZG_OLD - (BZG * PASB0 / NORM_B) ;
  5450.  
  5451. * ---- Coordonnees dans le repere
  5452. * ---- pseudo-toroidal du ripple
  5453. RHOR THER PHIR = @CRGTC XG_OLD YG_OLD ZG_OLD RR 0.;
  5454.  
  5455. * ---- calcul de la coordonnee radiale dans le
  5456. * ---- plan meridien Phi=0 de la ligne de champ
  5457. * ---- consideree par une methode de point fixe
  5458. RHOR_OLD = RHOR ;
  5459. KAUX = (EXP(THER**2 * -1. * COEFC)) * ((COS (PHIR * NBOB)) * -1. + 1.) * COEFA ;
  5460. I3 = 0 ;
  5461. REPETER BOUCLE3 50 ;
  5462. I3 = I3 + 1; MESS ' I3 = ' I3;
  5463. RHOR_NEW = RHOR + (KAUX * (EXP(RHOR_OLD * COEFB)));
  5464. SI ((MAXI (ABS((RHOR_NEW - RHOR_OLD) / RHOR_NEW))) &lt;EG EPS0) ;
  5465. QUITTER BOUCLE3 ;
  5466. FINSI ;
  5467. RHOR_OLD = RHOR_NEW ;
  5468. FIN BOUCLE3 ;
  5469.  
  5470. RHOMER = RHOR_NEW ;
  5471.  
  5472. * ---- le point obtenu doit etre sur la surface magnetique
  5473. I2 = 0 ;
  5474. REPETER BOUCLE2 2 ;
  5475. I2 = I2 + 1 ; MESS ' I2 = ' I2;
  5476. * ---- Coordonnees dans le repere
  5477. * ---- pseudo-toroidal du ripple
  5478. RHORN THERN PHIRN = @CRGTC XG_NEW0 YG_NEW0 ZG_NEW0 RR 0.;
  5479.  
  5480. DRHOMERN = (EXP(RHOMER * COEFB)) * (EXP(THERN**2 * COEFC * -1.)) * COEFA ;
  5481.  
  5482. RHORIP = DRHOMERN * ((COS (PHIRN*NBOB)) - 1.) + RHOMER;
  5483.  
  5484. * ---- Coordonnees dans le repere global
  5485. XG_NEW1 YG_NEW1 ZG_NEW1 = @CRTGC RHORIP THERN PHIRN RR 0.;
  5486.  
  5487. * ---- Calcul du champ dans le repere global
  5488. BXG0 BYG0 BZG0 FSECU0 = @CHAMB TAB1 XG_NEW1 YG_NEW1 ZG_NEW1 ISHIFT IRIPPLE ;
  5489.  
  5490. * ---- on prend la moyenne des 2 tangentes
  5491. BXG1 = (BXG + BXG0)/2. ;
  5492. BYG1 = (BYG + BYG0)/2. ;
  5493. BZG1 = (BZG + BZG0)/2. ;
  5494.  
  5495. NORM_B1 = ((BXG1*BXG1) + (BYG1*BYG1) + (BZG1*BZG1))**0.5 ;
  5496.  
  5497. XG_NEW0 = XG_OLD - (BXG1 * PASB0 / NORM_B1) ;
  5498. YG_NEW0 = YG_OLD - (BYG1 * PASB0 / NORM_B1) ;
  5499. ZG_NEW0 = ZG_OLD - (BZG1 * PASB0 / NORM_B1) ;
  5500.  
  5501. SI (I2 EGA 2) ;
  5502. XG_NEW = XG_NEW0 ;
  5503. YG_NEW = YG_NEW0 ;
  5504. ZG_NEW = ZG_NEW0 ;
  5505. FINSI ;
  5506.  
  5507. FIN BOUCLE2 ;
  5508.  
  5509. * ---- Coordonnees dans le repere du maillage
  5510. XM_NEW YM_NEW ZM_NEW = @CRGMC XG_NEW YG_NEW ZG_NEW TAB1 ;
  5511.  
  5512. XG_OLD = XG_NEW ;
  5513. YG_OLD = YG_NEW ;
  5514. ZG_OLD = ZG_NEW ;
  5515.  
  5516. XM1 = EXTR XM_NEW SCAL P0 ;
  5517. YM1 = EXTR YM_NEW SCAL P0 ;
  5518. ZM1 = EXTR ZM_NEW SCAL P0;
  5519.  
  5520. TABLIG1.I0 = TABLIG1.I0 D 1 (XM1 YM1 ZM1) ;
  5521. MENAGE ;
  5522.  
  5523. FIN BOUCLE1 ;
  5524. FIN BOUCLE0 ;
  5525. FINSI ;
  5526. MESS '---------------------------------> exiting @CLIGB';
  5527. FINPROC ;
  5528.  
  5529. **** @CLIGB0
  5530. DEBPROC @CLIGB0 DPHI*FLOTTANT PHIMAX*FLOTTANT TAB1*TABLE TABLIG1*TABLE IMETHOD*ENTIER;
  5531. *
  5532. *****************************************************************
  5533. * Procedure de calcul des lignes de champ magnetique partant de *
  5534. * chaque point d'une geometrie donnee. *
  5535. * methode 1 : methode explicite (tangentes) *
  5536. * methode 2 : Runge-Kutta du 4eme ordre a pas constant *
  5537. * Alain MOAL (mars 1996) *
  5538. *****************************************************************
  5539. *
  5540. MESS '---------------------------------> calling @CLIGB';
  5541. *
  5542. *--------------- VARIABLES D'ENTREE :
  5543. LISTE0 = TAB1.<LI_LIGNE_B ;
  5544. OEIL0 = TAB1.VIEW_P ;
  5545. RP = TAB1.<RP ;
  5546. HP = TAB1.<HP ;
  5547. ANGPHI0 = TAB1.<ANG_PHI0 ;
  5548. TYPCAL = TAB1.<TYPE_CALCUL ;
  5549. *------------------------------------
  5550. *
  5551. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  5552. ISHIFT = VRAI ;
  5553. IRIPPLE = VRAI ;
  5554. FINSI ;
  5555. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  5556. ISHIFT = VRAI ;
  5557. IRIPPLE = FAUX ;
  5558. FINSI ;
  5559. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  5560. ISHIFT = FAUX ;
  5561. IRIPPLE = VRAI ;
  5562. FINSI ;
  5563. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  5564. ISHIFT = FAUX ;
  5565. IRIPPLE = FAUX ;
  5566. FINSI ;
  5567. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  5568. ERRE ' >>>> @CLIGB0 : check the value of TAB1.<TYPE_CALCUL';
  5569. FINSI ;
  5570.  
  5571. * ---- Valeurs par defaut
  5572. @VDEFAUT TAB1 ;
  5573. TABLIG1 = TABLE ;
  5574. *
  5575. SI (IMETHOD EGA 1) ;
  5576. * ---- Methode explicite (tangentes)
  5577. TEMPS ZERO ;
  5578. I0 = 0 ;
  5579. REPETER BOUCLE0 (DIME LISTE0);
  5580.  
  5581. I0 = I0 + 1 ;
  5582. P0 = TEXT (EXTR I0 LISTE0) ;
  5583. XM YM ZM = COOR P0 ;
  5584. TABLIG1.I0 = ((XM+1.E-6) YM ZM) D 1 P0 ;
  5585. *
  5586. * ---- Transformation en champ par point
  5587. XM0 = MANU CHPO P0 1 SCAL XM ;
  5588. YM0 = MANU CHPO P0 1 SCAL YM ;
  5589. ZM0 = MANU CHPO P0 1 SCAL ZM ;
  5590. DPHI0 = MANU CHPO P0 1 SCAL DPHI ;
  5591. *
  5592. * ---- Coordonnees dans le repere global du tore
  5593. XG_OLD YG_OLD ZG_OLD = @CRMGC XM0 YM0 ZM0 TAB1 ;
  5594. *
  5595. LISTRHO = PROG ;
  5596. LISTTHE = PROG ;
  5597. LISTPHI = PROG ;
  5598. LISTFSE = PROG ;
  5599. *
  5600. PHIAUX = ANGPHI0 ;
  5601. *
  5602. REPETER BOUCLE1 (ENTI (PHIMAX/DPHI)) ;
  5603. *
  5604. PHIAUX = PHIAUX + DPHI ;
  5605. * ---- Numero du grand tour calcule a partir du plan
  5606. * ---- median entre bobines
  5607. NTOUR0 = (ENTI (PHIAUX / 360.)) + 1 ;
  5608. *
  5609. * ---- Calcul du champ dans le repere global
  5610. BX BY BZ FSECU = @CHAMB TAB1 XG_OLD YG_OLD ZG_OLD ISHIFT IRIPPLE ;
  5611. *
  5612. * ---- Coordonnees dans le repere pseudo-toroidal du plasma
  5613. RHO_OLD THE_OLD PHI_OLD = @CRGTC XG_OLD YG_OLD ZG_OLD RP HP ;
  5614. *
  5615. * ---- Champ dans le repere pseudo-toroidal du plasma
  5616. BRHO BTHETA BPHI = @CBGTV BX BY BZ THE_OLD PHI_OLD ;
  5617. *
  5618. DRHO0 = (RHO_OLD * (COS THE_OLD) + RP) * BRHO * DPHI0 / BPHI;
  5619. DTHE0 = (RHO_OLD * (COS THE_OLD) + RP) * BTHETA * DPHI0 / BPHI / RHO_OLD;
  5620.  
  5621. RHO_NEW = RHO_OLD + DRHO0 ;
  5622. THE_NEW = THE_OLD + DTHE0 ;
  5623. * MESS 'PHI_OLD+DPHI0 '; LIST (MAXI (PHI_OLD+DPHI0));
  5624. SI (((MAXI (PHI_OLD+DPHI0)) >EG 0.) ET ((MAXI (PHI_OLD+DPHI0)) &lt;EG 180.));
  5625. PHI_NEW = PHI_OLD + DPHI0 + (360. * (NTOUR0-1));
  5626. FINSI ;
  5627. SI (((MAXI (PHI_OLD+DPHI0)) > -180.) ET ((MAXI (PHI_OLD+DPHI0)) < 0.));
  5628. PHI_NEW = PHI_OLD + DPHI0 + (360. * NTOUR0) ;
  5629. FINSI ;
  5630. SI ((MAXI (PHI_OLD+DPHI0)) > 180.) ;
  5631. PHI_NEW = PHI_OLD + DPHI0 ;
  5632. FINSI ;
  5633.  
  5634. LISTRHO = LISTRHO ET (PROG (MAXI RHO_NEW)) ;
  5635. LISTTHE = LISTTHE ET (PROG (MAXI THE_NEW)) ;
  5636. LISTPHI = LISTPHI ET (PROG (MAXI PHI_NEW)) ;
  5637. LISTFSE = LISTFSE ET (PROG (MAXI FSECU)) ;
  5638. *
  5639. * ---- Coordonnees dans le repere global
  5640. XG_NEW YG_NEW ZG_NEW = @CRTGC RHO_NEW THE_NEW PHI_NEW RP HP;
  5641. *
  5642. MESS 'TOUR : ' ; LIST NTOUR0 ;
  5643. MESS 'MAX DE PHI '; LIST (MAXI PHI_NEW);
  5644. MESS 'MAX DE RHO '; LIST (MAXI RHO_NEW);
  5645. MESS 'MAX DE THE '; LIST (MAXI THE_NEW);
  5646. MESS 'MAX DE FSECU '; LIST (MAXI FSECU);
  5647.  
  5648. * MESS 'MAX DE BPHI '; LIST (MAXI BPHI);
  5649. * MESS 'MAX DE BRHO '; LIST (MAXI BRHO);
  5650. * MESS 'MAX DE BTHE '; LIST (MAXI BTHETA);
  5651.  
  5652. * ---- Coordonnees dans le repere du maillage
  5653. XM_NEW YM_NEW ZM_NEW = @CRGMC XG_NEW YG_NEW ZG_NEW TAB1 ;
  5654. *
  5655. XG_OLD = XG_NEW ;
  5656. YG_OLD = YG_NEW ;
  5657. ZG_OLD = ZG_NEW ;
  5658.  
  5659. XM1 = EXTR XM_NEW SCAL P0 ;
  5660. YM1 = EXTR YM_NEW SCAL P0 ;
  5661. ZM1 = EXTR ZM_NEW SCAL P0;
  5662.  
  5663. TABLIG1.I0 = TABLIG1.I0 D 1 (XM1 YM1 ZM1) ;
  5664.  
  5665. SI ((MAXI PHI_NEW) >EG PHIMAX) ;
  5666. MESS '>>>> The maximum value of Phi is reached';
  5667. QUITTER BOUCLE1 ;
  5668. FINSI ;
  5669. MENAGE ;
  5670.  
  5671. FIN BOUCLE1 ;
  5672.  
  5673. EVRHO = EVOL JAUN MANU 'PHI' LISTPHI 'RHO' LISTRHO ;
  5674. EVTHE = EVOL ROUG MANU 'PHI' LISTPHI 'THETA' LISTTHE ;
  5675. EVFSE = EVOL VERT MANU 'PHI' LISTPHI 'FSECU' LISTFSE ;
  5676. DESSIN EVRHO MIMA ;
  5677. DESSIN EVTHE MIMA ;
  5678. DESSIN EVFSE MIMA ;
  5679. FIN BOUCLE0 ;
  5680. TEMPS ;
  5681. FINSI ;
  5682.  
  5683. SI (IMETHOD EGA 2) ;
  5684. * ---- Runge-Kutta d'ordre 4 a pas constant
  5685. TEMPS ZERO ;
  5686. I0 = 0 ;
  5687. REPETER BOUCLE0 (DIME LISTE0);
  5688.  
  5689. I0 = I0 + 1 ;
  5690. P0 = TEXT (EXTR I0 LISTE0) ;
  5691. XM YM ZM = COOR P0 ;
  5692. TABLIG1.I0 = ((XM+1.E-6) YM ZM) D 1 P0 ;
  5693. *
  5694. * ---- Transformation en champ par point
  5695. XM0 = MANU CHPO P0 1 SCAL XM ;
  5696. YM0 = MANU CHPO P0 1 SCAL YM ;
  5697. ZM0 = MANU CHPO P0 1 SCAL ZM ;
  5698. DPHI0 = MANU CHPO P0 1 SCAL DPHI ;
  5699. *
  5700. * ---- Coordonnees dans le repere global du tore
  5701. XG_OLD YG_OLD ZG_OLD = @CRMGC XM0 YM0 ZM0 TAB1 ;
  5702. *
  5703. LISTRHO = PROG ;
  5704. LISTTHE = PROG ;
  5705. LISTPHI = PROG ;
  5706. LISTFSE = PROG ;
  5707. *
  5708. PHIAUX = ANGPHI0 ;
  5709. *
  5710. REPETER BOUCLE1 (ENTI (PHIMAX/DPHI)) ;
  5711. *
  5712. PHIAUX = PHIAUX + DPHI ;
  5713. * ---- Numero du grand tour calcule a partir du plan
  5714. * ---- median entre bobine
  5715. NTOUR0 = (ENTI (PHIAUX / 360.)) + 1 ;
  5716. *
  5717. * ---- Calcul du champ dans le repere global
  5718. BX BY BZ FSECU = @CHAMB TAB1 XG_OLD YG_OLD ZG_OLD ISHIFT IRIPPLE ;
  5719.  
  5720. * ---- Coordonnees dans le repere pseudo-toroidal du plasma
  5721. RHO_OLD THE_OLD PHI_OLD = @CRGTC XG_OLD YG_OLD ZG_OLD RP HP ;
  5722.  
  5723. * ---- Champ dans le repere pseudo-toroidal du plasma
  5724. BRHO BTHE BPHI = @CBGTV BX BY BZ THE_OLD PHI_OLD ;
  5725. *
  5726. * ---- calcul de K0 et L0
  5727. K0 = (RHO_OLD * (COS THE_OLD) + RP) * BRHO / BPHI;
  5728. L0 = (RHO_OLD * (COS THE_OLD) + RP) * BTHE / BPHI / RHO_OLD;
  5729.  
  5730. * ---- calcul de K1 et L1
  5731. RHO1_OLD = RHO_OLD + (K0/2.) ;
  5732. THE1_OLD = THE_OLD + (L0/2.) ;
  5733. * SI (((MAXI (PHI_OLD+DPHI0)) >EG 0.) ET
  5734. * ((MAXI (PHI_OLD+DPHI0)) &lt;EG 180.));
  5735. * PHI1_OLD = PHI_OLD + (DPHI0/2.) + (360. * (NTOUR0-1));
  5736. * FINSI ;
  5737. * SI (((MAXI (PHI_OLD+DPHI0)) > -180.) ET
  5738. * ((MAXI (PHI_OLD+DPHI0)) < 0.));
  5739. * PHI1_OLD = PHI_OLD + (DPHI0/2.) + (360. * NTOUR0) ;
  5740. * FINSI ;
  5741. * SI ((MAXI (PHI_OLD+DPHI0)) > 180.) ;
  5742. PHI1_OLD = PHI_OLD + (DPHI0/2) ;
  5743. * FINSI ;
  5744.  
  5745. XG1_OLD YG1_OLD ZG1_OLD = @CRTGC RHO1_OLD THE1_OLD PHI1_OLD RP HP;
  5746.  
  5747. * ---- Calcul du champ dans le repere global
  5748. BX1 BY1 BZ1 FSECU = @CHAMB TAB1 XG1_OLD YG1_OLD ZG1_OLD IRIPPLE ISHIFT ;
  5749.  
  5750. * ---- Champ dans le repere pseudo-toroidal du plasma
  5751. BRHO1 BTHE1 BPHI1 = @CBGTV BX1 BY1 BZ1 THE1_OLD PHI1_OLD ;
  5752.  
  5753. K1 = (RHO1_OLD * (COS THE1_OLD) + RP)*BRHO1 /BPHI1 * DPHI0;
  5754. L1 = (RHO1_OLD * (COS THE1_OLD) + RP)*BTHE1/BPHI1 / RHO1_OLD * DPHI0;
  5755.  
  5756. * ---- calcul de K2 et L2
  5757. RHO2_OLD = RHO_OLD + (K1/2.) ;
  5758. THE2_OLD = THE_OLD + (L1/2.) ;
  5759. * SI (((MAXI (PHI_OLD+DPHI0)) >EG 0.) ET
  5760. * ((MAXI (PHI_OLD+DPHI0)) &lt;EG 180.));
  5761. * PHI2_OLD = PHI_OLD + (DPHI0/2.) + (360. * (NTOUR0-1));
  5762. * FINSI ;
  5763. * SI (((MAXI (PHI_OLD+DPHI0)) > -180.) ET
  5764. * ((MAXI (PHI_OLD+DPHI0)) < 0.));
  5765. * PHI2_OLD = PHI_OLD + (DPHI0/2.) + (360. * NTOUR0);
  5766. * FINSI ;
  5767. * SI ((MAXI (PHI_OLD+DPHI0)) > 180.) ;
  5768. PHI2_OLD = PHI_OLD + (DPHI0/2) ;
  5769. * FINSI ;
  5770.  
  5771. XG2_OLD YG2_OLD ZG2_OLD = @CRTGC RHO2_OLD THE2_OLD PHI2_OLD RP HP;
  5772.  
  5773. * ---- Calcul du champ dans le repere global
  5774. BX2 BY2 BZ2 FSECU = @CHAMB TAB1 XG2_OLD YG2_OLD ZG2_OLD ISHIFT IRIPPLE ;
  5775.  
  5776. * ---- Champ dans le repere pseudo-toroidal du plasma
  5777. BRHO2 BTHE2 BPHI2 = @CBGTV BX2 BY2 BZ2 THE2_OLD PHI2_OLD ;
  5778.  
  5779. K2 = (RHO2_OLD * (COS THE2_OLD) + RP)*BRHO2 /BPHI2 * DPHI0;
  5780. L2 = (RHO2_OLD * (COS THE2_OLD) + RP)*BTHE2/BPHI2 / RHO2_OLD * DPHI0;
  5781.  
  5782. * ---- calcul de K3 et L3
  5783. RHO3_OLD = RHO_OLD + K2 ;
  5784. THE3_OLD = THE_OLD + L2 ;
  5785. * SI (((MAXI (PHI_OLD+DPHI0)) >EG 0.) ET
  5786. * ((MAXI (PHI_OLD+DPHI0)) &lt;EG 180.));
  5787. * PHI3_OLD = PHI_OLD + DPHI0 + (360. * (NTOUR0-1));
  5788. * FINSI ;
  5789. * SI (((MAXI (PHI_OLD+DPHI0)) > -180.) ET
  5790. * ((MAXI (PHI_OLD+DPHI0)) < 0.));
  5791. * PHI3_OLD = PHI_OLD + DPHI0 + (360. * NTOUR0);
  5792. * FINSI ;
  5793. * SI ((MAXI (PHI_OLD+DPHI0)) > 180.) ;
  5794. PHI3_OLD = PHI_OLD + DPHI0 ;
  5795. * FINSI ;
  5796.  
  5797. XG3_OLD YG3_OLD ZG3_OLD = @CRTGC RHO3_OLD THE3_OLD PHI3_OLD RP HP;
  5798.  
  5799. * ---- Calcul du champ dans le repere global
  5800. BX3 BY3 BZ3 FSECU = @CHAMB TAB1 XG3_OLD YG3_OLD ZG3_OLD ISHIFT IRIPPLE ;
  5801.  
  5802. * ---- Champ dans le repere pseudo-toroidal du plasma
  5803. BRHO3 BTHE3 BPHI3 = @CBGTV BX3 BY3 BZ3 THE3_OLD PHI3_OLD ;
  5804.  
  5805. K3 = (RHO3_OLD * (COS THE3_OLD) + RP)*BRHO3 / BPHI3 * DPHI0;
  5806. L3 = (RHO3_OLD * (COS THE3_OLD) + RP)*BTHE3/BPHI3 / RHO3_OLD * DPHI0;
  5807.  
  5808. RHO_NEW = RHO_OLD + ((K0 + (2.*K1) + (2.*K2) + K3)/6.);
  5809. THE_NEW = THE_OLD + ((L0 + (2.*L1) + (2.*L2) + L3)/6.);
  5810.  
  5811. SI (((MAXI (PHI_OLD+DPHI0)) >EG 0.) ET ((MAXI (PHI_OLD+DPHI0)) &lt;EG 180.));
  5812. PHI_NEW = PHI_OLD + DPHI0 + (360. * (NTOUR0-1));
  5813. FINSI ;
  5814. SI (((MAXI (PHI_OLD+DPHI0)) > -180.) ET ((MAXI (PHI_OLD+DPHI0)) < 0.));
  5815. PHI_NEW = PHI_OLD + DPHI0 + (360. * NTOUR0) ;
  5816. FINSI ;
  5817. SI ((MAXI (PHI_OLD+DPHI0)) > 180.) ;
  5818. PHI_NEW = PHI_OLD + DPHI0 ;
  5819. FINSI ;
  5820.  
  5821. LISTRHO = LISTRHO ET (PROG (MAXI RHO_NEW)) ;
  5822. LISTTHE = LISTTHE ET (PROG (MAXI THE_NEW)) ;
  5823. LISTPHI = LISTPHI ET (PROG (MAXI PHI_NEW)) ;
  5824. LISTFSE = LISTFSE ET (PROG (MAXI FSECU)) ;
  5825.  
  5826. * ---- Coordonnees dans le repere global
  5827. XG_NEW YG_NEW ZG_NEW = @CRTGC RHO_NEW THE_NEW PHI_NEW RP HP;
  5828. MESS 'TOUR : ' ; LIST NTOUR0 ;
  5829. MESS 'MAX DE PHI '; LIST (MAXI PHI_NEW);
  5830. MESS 'MAX DE RHO '; LIST (MAXI RHO_NEW);
  5831. MESS 'MAX DE THE '; LIST (MAXI THE_NEW);
  5832. MESS 'MAX DE FSECU '; LIST (MAXI FSECU);
  5833.  
  5834. * ---- Coordonnees dans le repere du maillage
  5835. XM_NEW YM_NEW ZM_NEW = @CRGMC XG_NEW YG_NEW ZG_NEW TAB1 ;
  5836. *
  5837. XG_OLD = XG_NEW ;
  5838. YG_OLD = YG_NEW ;
  5839. ZG_OLD = ZG_NEW ;
  5840.  
  5841. XM1 = EXTR XM_NEW SCAL P0 ;
  5842. YM1 = EXTR YM_NEW SCAL P0 ;
  5843. ZM1 = EXTR ZM_NEW SCAL P0;
  5844.  
  5845. TABLIG1.I0 = TABLIG1.I0 D 1 (XM1 YM1 ZM1) ;
  5846.  
  5847. SI ((MAXI PHI_NEW) >EG PHIMAX) ;
  5848. MESS '>>>> The maximum value of Phi is reached';
  5849. QUITTER BOUCLE1 ;
  5850. FINSI ;
  5851. MENAGE ;
  5852.  
  5853. FIN BOUCLE1 ;
  5854.  
  5855. EVRHO = EVOL JAUN MANU 'PHI' LISTPHI 'RHO' LISTRHO ;
  5856. EVTHE = EVOL ROUG MANU 'PHI' LISTPHI 'THETA' LISTTHE ;
  5857. EVFSE = EVOL VERT MANU 'PHI' LISTPHI 'FSECU' LISTFSE ;
  5858. DESSIN EVRHO MIMA ;
  5859. DESSIN EVTHE MIMA ;
  5860. DESSIN EVFSE MIMA ;
  5861. FIN BOUCLE0 ;
  5862. TEMPS ;
  5863. FINSI ;
  5864.  
  5865. MESS '---------------------------------> exiting @CLIGB0';
  5866. FINPROC ;
  5867.  
  5868. **** CONTACT
  5869. *---------------------------------------------------------------------
  5870. * PROCEDURE CONTACT VERSION DU 15/10/87
  5871. *---------------------------------------------------------------------
  5872. * CETTE PROCEDURE SERT A DEFINIR LE CONTACT ENTRE 2 SOLIDES
  5873. * OU ENTRE 1 SOLIDE ET UN OBSTACLE .
  5874. *
  5875. * SYNTAXE :
  5876. * -------
  5877. *
  5878. *
  5879. * BLC BLT FFF COEF =
  5880. *
  5881. * CONTACT | MINI | NOMINC | POI1 ( POI2 ) |
  5882. * | MAXI | DIRECTION V1 | GEO1 ( GEO2 ) |
  5883. *
  5884. * | CONSTANT | MU ( JEU | VVAL | ) ;
  5885. * | COULOMB | | CHSCA |
  5886. * | CHP |
  5887. *
  5888. *
  5889. * ATTENTION METTRE LES NOMS CONNUS EN 4 LETTRES |
  5890. * EXEMPLE : METTRE DIRE ET NON PAS DIRECTION
  5891. *
  5892. * ( EXPLICATION : CF BLOQUER , RELA ET DEPI )
  5893. *
  5894. * BLC ET BLT: LES BLOCAGES ASSOCIES AU CONTACT
  5895. * ( NORMAUX ET TANGENTIELS )
  5896. * FFF : LE SECOND MEMBRE ( NON NUL SI JEU )
  5897. * COEF : LES COEFFICIENTS DE FROTTEMENT
  5898. *
  5899. *---------------------------------------------------------------------
  5900. DEBPROC CONTACT MOMIN*MOT DDL*MOT V1/POINT POI1/POINT POI2/POINT MA1/MAILLAGE MA2/MAILLAGE MFRO*MOT ZFRO*FLOTTANT MJEU/MOT VVAL/FLOTTANT VCHP/CHPOINT ;
  5901. *
  5902. IDIR = 0 ;
  5903. SSDIM = VALE DIME ;
  5904. SI ( EGA DDL DIRE ) ;
  5905. IDIR = 1 ; FINSI ;
  5906. *------------------------------
  5907. * ON RECUPERE LA GEOMETRIE
  5908. *------------------------------
  5909. IDEUX = 0 ;
  5910. SI ( EGA IDIR 0 ) ;
  5911. SI ( EXISTE V1 ) ;
  5912. GEO1 = V1 ;
  5913. SI ( EXISTE POI1 ) ;
  5914. IDEUX = 1 ;
  5915. GEO2 = POI1 ;
  5916. FINSI ;
  5917. FINSI ;
  5918. SINON ;
  5919. SI ( EXISTE POI1 ) ;
  5920. GEO1 = POI1 ;
  5921. SI ( EXISTE POI2 ) ;
  5922. IDEUX = 1 ;
  5923. GEO2 = POI2 ;
  5924. FINSI ;
  5925. FINSI;
  5926. FINSI ;
  5927. SI ( EXISTE MA1 ) ;
  5928. GEO1 = MA1 ;
  5929. FINSI ;
  5930. SI ( EXISTE MA2 ) ;
  5931. IDEUX = 1 ;
  5932. GEO2 = MA2 ;
  5933. FINSI ;
  5934. SI ( EGA IDEUX 1 ) ;
  5935. GEO = GEO1 ET GEO2 ; SINON ;
  5936. GEO = GEO1 ;
  5937. FINSI ;
  5938. *
  5939. *------------------------------
  5940. * ON RECUPERE LA DIRECTION
  5941. *------------------------------
  5942. SI ( EGA IDIR 1 ) ;
  5943. IDIR = 1 ;
  5944. SI ( EGA SSDIM 2 ) ;
  5945. V1X V1Y = COOR V1 ;
  5946. V2 = V1Y ( 0 - V1X ) ;
  5947. SINON ;
  5948. V1X V1Y V1Z = COOR V1 ;
  5949. V2X = 0. - V1Y ;
  5950. V2Y = V1X ;
  5951. V2Z = 0. ;
  5952. V2 = V2X V2Y V2Z ;
  5953. V2NOR = NORM V2 ;
  5954. SI ( EGA V2NOR 0. ) ;
  5955. V2 = 0. ( 0. - V1Z ) V1Y ;
  5956. FINSI ;
  5957. V3 = PVECT V1 V2 ;
  5958. FINSI ;
  5959. SINON ;
  5960. SI ( EGA DDL UX ) ;
  5961. SI ( EGA SSDIM 2 ) ;
  5962. V1 = 1 0 ;
  5963. V2 = 0 -1 ;
  5964. SINON ;
  5965. V1 = 1 0 0 ;
  5966. V2 = 0 1 0 ;
  5967. V3 = 0 0 1 ;
  5968. FINSI ;
  5969. FINSI ;
  5970. SI ( EGA DDL UY ) ;
  5971. SI ( EGA SSDIM 2 ) ;
  5972. V1 = 0 1 ;
  5973. V2 = 1 0 ;
  5974. SINON ;
  5975. V1 = 0 1 0 ;
  5976. V2 = 0 0 1;
  5977. V3 = 1 0 0 ;
  5978. FINSI ;
  5979. FINSI ;
  5980. SI ( EGA DDL UR ) ;
  5981. V1 = 1 0 ;
  5982. V2 = 0 1 ;
  5983. FINSI ;
  5984. SI ( EGA DDL UZ ) ;
  5985. SI ( EGA SSDIM 2 ) ;
  5986. V1 = 0 1 ;
  5987. V2 = 1 0 ;
  5988. SINON ;
  5989. V1 = 0 0 1 ;
  5990. V2 = 1 0 0;
  5991. V3 = 0 1 0 ;
  5992. FINSI ;
  5993. FINSI ;
  5994. FINSI ;
  5995. *-----------------------
  5996. * ON RECUPERE LE JEU
  5997. *-----------------------
  5998. IJEU = 0 ;
  5999. SI ( EXISTE MJEU ) ;
  6000. IJEU = 1 ;
  6001. SI ( EXISTE VVAL ) ;
  6002. VJEU = VVAL ;
  6003. FINSI ;
  6004. SI ( EXISTE VCHP ) ;
  6005. VJEU = VCHP ;
  6006. FINSI ;
  6007. FINSI ;
  6008. *--------------------------
  6009. * ON CREE LES BLOCAGES
  6010. *--------------------------
  6011. *
  6012. SI ( EGA IDEUX 0 ) ;
  6013. BLC = BLOQUE MOMIN DEPL DIRECTION V1 GEO1 ;
  6014. BLT = BLOQUE FROT DEPL DIRECTION V2 GEO1 ;
  6015. SI ( EGA SSDIM 3 ) ;
  6016. BLT = BLT ET ( BLOQUE FROT DEPL DIRECTION V3 GEO1 ) ;
  6017. FINSI ;
  6018. SINON ;
  6019. BLC = RELA MOMIN DEPL DIREC V1 GEO1 - DEPL DIREC V1 GEO2 ;
  6020. BLT = RELA FROT DEPL DIREC V2 GEO1 - DEPL DIREC V2 GEO2 ;
  6021. SI ( EGA SSDIM 3 ) ;
  6022. BLT = BLT ET ( RELA FROT DEPL DIREC V3 GEO1 - DEPL DIREC V3 GEO2 ) ;
  6023. FINSI ;
  6024. FINSI ;
  6025. *BLOCAG = BLC ET BLT ;
  6026. *-------------------------------------------
  6027. * ON CALCULE LES FORCES AU SECOND MEMBRE
  6028. *-------------------------------------------
  6029. SI ( EGA IJEU 1 ) ;
  6030. SI ( EGA MOMIN MAXI ) ;
  6031. FAC = 1.;
  6032. SINON ;
  6033. FAC = -1. ;
  6034. FINSI ;
  6035. FFF = DEPI BLC ( FAC * VJEU ) ;
  6036. SINON ;
  6037. FFF = MANU CHPO GEO 1 FLX 0. ;
  6038. FINSI ;
  6039. *---------------------------------------------
  6040. * ON CALCULE LES COEFFICIENTS DE FROTTEMENT
  6041. *---------------------------------------------
  6042. GEOT = EXTR BLT MAIL MULT ;
  6043. COEF = MANU CHPO GEOT 1 MFRO ZFRO ;
  6044. *----------------------------------------------------------------------
  6045. * SORTIE DE LA PROCEDURE
  6046. *----------------------------------------------------------------------
  6047. FINPROC BLC BLT FFF COEF ;
  6048. * 1 2 3 4 5 6 7*
  6049. *123456789012345678901234567890123456789012345678901234567890123456789012
  6050. * *
  6051. * *
  6052. * *
  6053. DEBPROC CONTRAPH LIGN_1*MAILLAGE INSTEVOL*FLOTTANT MOD1*MMODEL TAB1*TABLE SM1/EVOLUTION SM2/EVOLUTION VAL1/FLOTTANT;
  6054.  
  6055. MESS '-----------------------------------> entree dans CONTRAPH ' ;
  6056.  
  6057. DIM1 = VALEUR DIME ;
  6058. * test sur la dimension
  6059. SI (EGA DIM1 2) ;
  6060. MESS ' attention au SMZZ en 2D' ;
  6061. SINON ;
  6062. MESS ' !!! ATTENTION !!! en 3 D ' ;
  6063. MESS ' utilisation a vos risques et perils a cause du fonctionement incertain de PROI ' ;
  6064. MESS ' la remarque est sans objet si LIGN_1 appartient au maillage ';
  6065. FINSI;
  6066.  
  6067.  
  6068. SI (NON (EXISTE TAB1 RESUCONT)) ;
  6069. MESS ' TAB1 NE CONTIENT PAS DE CONTRAINTES ' ;
  6070. MESS ' SORTIE DE CONTRAPH ' ;
  6071. QUITTER CONTRAPH ;
  6072. FINSI ;
  6073.  
  6074. * test sur la dimension de LIGN_1*MAILLAGE : a faire
  6075.  
  6076. LCONFON = FAUX ;
  6077. MAIL_1 = MOD1 EXTR 'MAIL' ;
  6078. N_1 = NBNO MAIL_1 ;
  6079. N_2 = NBNO (MAIL_1 ET LIGN_1 ) ;
  6080.  
  6081. SI ( EGA N_1 N_2 ) ;
  6082. LCONFON = VRAI ;
  6083. FINSI ;
  6084.  
  6085. SI (NON(EXISTE TAB1 TETMAT)) ;
  6086. MESS ' TAB1 NE CONTIENT PAS DE TETMAT ' ;
  6087. MESS ' SORTIE DE CONTRAPH ' ;
  6088. QUITTER CONTRAPH ;
  6089. FINSI ;
  6090.  
  6091. SI (NON(EXISTE (TAB1.TETMAT) MOD1)) ;
  6092. MESS ' TAB1.TETMAT NE CONTIENT PAS DE MODELE ' ;
  6093. MESS ' SORTIE DE CONTRAPH ' ;
  6094. QUITTER CONTRAPH ;
  6095. FINSI ;
  6096.  
  6097. SI (NON(EXISTE (TAB1.TETMAT.MOD1) SIGY)) ;
  6098. MESS ' LE MATERIAU DEMANDE N EST PAS PLASTIQUE ' ;
  6099. MESS ' SORTIE DE CONTRAPH ' ;
  6100. QUITTER CONTRAPH ;
  6101. FINSI ;
  6102.  
  6103. L1TITR = CHAIN 'DEPOUILLEMENT LE LONG DE LA LIGNE A' INSTEVOL ;
  6104. TITR L1TITR ;
  6105.  
  6106. LIMELAS1 = VARI TAB1.CHPOTHETA.INSTEVOL TAB1.TETMAT.MOD1.'SIGY' ;
  6107.  
  6108. SI (EXISTE SM1) ;
  6109. LIMSM1 = VARI TAB1.CHPOTHETA.INSTEVOL SM1 ;
  6110. FINSI ;
  6111. SI (EXISTE SM2) ;
  6112. LIMSM2 = VARI TAB1.CHPOTHETA.INSTEVOL SM2 ;
  6113. FINSI ;
  6114. VMIS1 = VMIS MOD1 TAB1.RESUCONT. INSTEVOL ;
  6115.  
  6116. CHEP4 = EXCO TAB1.RESUVARI.INSTEVOL EPSE ;
  6117. CHEP3 = REDU CHEP4 MOD1 ;
  6118. CHEP2 = (CHAN NOEUD CHEP3 MOD1 );
  6119.  
  6120. SI LCONFON ;
  6121. CHVM1 = CHAN 'CHPO' MOD1 (CHAN NOEUD MOD1 VMIS1) ;
  6122. LIMELAS2 = LIMELAS1 ;
  6123. CHEP1 = CHAN 'CHPO' MOD1 CHEP2 ;
  6124. SI (EXISTE SM1 ) ;
  6125. LIM2SM1 = LIMSM1 ;
  6126. FINSI ;
  6127. SI (EXISTE SM2 ) ;
  6128. LIM2SM2 = LIMSM2 ;
  6129. FINSI ;
  6130. SINON ;
  6131. CHVM1 = PROI LIGN_1 (CHAN NOEUD MOD1 VMIS1) ;
  6132. LIMELAS2 = PROI LIGN_1 (CHAN CHAM LIMELAS1 MOD1 NOEUD) ;
  6133. CHEP1 = PROI LIGN_1 CHEP2 ;
  6134. SI (EXISTE SM1) ;
  6135. LIM2SM1 = PROI LIGN_1 (CHAN CHAM LIMSM1 MOD1 NOEUD) ;
  6136. FINSI ;
  6137. SI (EXISTE SM2) ;
  6138. LIM2SM2 = PROI LIGN_1 (CHAN CHAM LIMSM2 MOD1 NOEUD) ;
  6139. FINSI ;
  6140. FINSI ;
  6141.  
  6142. TAC1 = TABLE ;
  6143. EVVM1 = EVOL ROUG CHPO CHVM1 LIGN_1 ;
  6144. EVEL1 = EVOL BLEU CHPO LIMELAS2 LIGN_1 ;
  6145. * champs dde t le long de la ligne
  6146. TCHAM = CHAN CHAM (TAB1.CHPOTHETA.INSTEVOL) MOD1 NOEUD ;
  6147. PTCH = PROI TCHAM LIGN_1 ;
  6148. EVTE1 = EVOL JAUN CHPO (PTCH * 1.E6) 'T' LIGN_1 ;
  6149. TAC1.1 = CHAI 'MARQ CARR REGU TITR V_MISES ' ;
  6150. TAC1.3 = CHAI 'MARQ LOSA REGU TITR LIM_ELAS' ;
  6151. TAC1.5 = CHAI 'MARQ CROI REGU TITR TEMPERAT' ;
  6152. EV_OTT = EVVM1 ET EVEL1 ET EVTE1 ;
  6153.  
  6154. SI (EXISTE SM1) ;
  6155. EVRU1 = EVOL TURQ CHPO LIM2SM1 LIGN_1 ;
  6156. TAC1.7 = CHAI 'MARQ TRIA REGU TITR SM' ;
  6157. SI (EXISTE SM2) ;
  6158. EVRU2 = EVOL VERT CHPO LIM2SM2 LIGN_1 ;
  6159. TAC1.9 = CHAI 'MARQ TRIB REGU TITR 3SM_ou_RM' ;
  6160. SI (EXISTE VAL1) ;
  6161. EVVA1 = EVOL CHPO VAL1 LIGN_1 ;
  6162. TAC1.11 = CHAI 'MARQ ETOI REGU TITR VALEUR' ;
  6163. EV_OTT = EV_OTT ET EVRU1 ET EVRU2 ET EVVA1 ;
  6164. SINON ;
  6165. EV_OTT = EV_OTT ET EVRU1 ET EVRU2 ;
  6166. FINSI ;
  6167. SINON ;
  6168. SI (EXISTE VAL1) ;
  6169. EVVA1 = EVOL CHPO VAL1 LIGN_1 ;
  6170. TAC1.9 = CHAI 'MARQ ETOI REGU TITR VALEUR' ;
  6171. EV_OTT = EV_OTT ET EVRU1 ET EVVA1 ;
  6172. FINSI ;
  6173. *tc ajout du finsi cidessous au pif
  6174. FINSI; ;
  6175. SINON ;
  6176. SI (EXISTE VAL1 ) ;
  6177. EVVA1 = EVOL CHPO VAL1 LIGN_1 ;
  6178. TAC1.7 = CHAI 'MARQ ETOI REGU TITR VALEUR' ;
  6179. EV_OTT = EV_OTT ET EVVA1 ;
  6180. FINSI ;
  6181. FINSI ;
  6182.  
  6183. DESS EV_OTT LEGE MIMA TAC1 ;
  6184.  
  6185. MESS '-----------------------------------> sortie de CONTRAPH ' ;
  6186.  
  6187. FINPROC ;
  6188. **** @COUTOR1
  6189. *****************************************************************
  6190. * PROCEDURE @COUTOR1 :
  6191. *****************************************************************
  6192.  
  6193. DEBPROC @COUTOR1 IEL*MAILLAGE CHT*CHPOINT CHN*CHPOINT CHB*CHPOINT ;
  6194. PI = 3.14159 ;
  6195. P2 = IEL POIN INITIAL ;
  6196. P3 = IEL POIN FINAL ;
  6197. DIMGEO1 = VALEUR DIME ;
  6198. SI (DIMGEO1 > 2);
  6199. NXI2 = EXTR CHN NX P2 ;
  6200. NYI2 = EXTR CHN NY P2 ;
  6201. NZI2 = EXTR CHN NZ P2 ;
  6202. VN2 = NXI2 NYI2 NZI2 ;
  6203. TXI2 = EXTR CHT TX P2 ;
  6204. TYI2 = EXTR CHT TY P2 ;
  6205. TZI2 = EXTR CHT TZ P2 ;
  6206. VT2 = TXI2 TYI2 TZI2 ;
  6207. BXI2 = EXTR CHB BX P2 ;
  6208. BYI2 = EXTR CHB BY P2 ;
  6209. BZI2 = EXTR CHB BZ P2 ;
  6210. VB2 = BXI2 BYI2 BZI2 ;
  6211. NXI3 = EXTR CHN NX P3 ;
  6212. NYI3 = EXTR CHN NY P3 ;
  6213. NZI3 = EXTR CHN NZ P3 ;
  6214. VN3 = NXI3 NYI3 NZI3 ;
  6215. TXI3 = EXTR CHT TX P3 ;
  6216. TYI3 = EXTR CHT TY P3 ;
  6217. TZI3 = EXTR CHT TZ P3 ;
  6218. VT3 = TXI3 TYI3 TZI3 ;
  6219. BXI3 = EXTR CHB BX P3 ;
  6220. BYI3 = EXTR CHB BY P3 ;
  6221. BZI3 = EXTR CHB BZ P3 ;
  6222. VB3 = BXI3 BYI3 BZI3 ;
  6223. XR = VT3 PSCA VT2 ;
  6224. YR = VT3 PSCA VN2 ;
  6225. * MESS 'XR =' XR 'YR =' YR ;
  6226. ALPHA = ATG YR XR ;
  6227. * MESS 'ALPHA =' ALPHA ;
  6228. DS2 = NORM (MOIN P2 P3) ;
  6229. RR = (ALPHA*PI/180.)/DS2 ;
  6230. SI (RR NEG 0.) ;
  6231. R = 1./RR ;
  6232. SINON ;
  6233. R = 1.E99 ;
  6234. FINSI ;
  6235. * MESS 'R =' R ;
  6236. XT = VB2 PSCA VB3 ;
  6237. YT = VB2 PSCA VN3 ;
  6238. * MESS 'XT =' XT 'YT =' YT ;
  6239. BETA = ATG YT XT ;
  6240. * MESS 'BETA =' BETA ;
  6241. TT = -1*(BETA*PI/180.)/DS2 ;
  6242. SI (TT NEG 0.) ;
  6243. T = 1./TT ;
  6244. SINON ;
  6245. T = 1.E99 ;
  6246. FINSI ;
  6247. * MESS 'T =' T ;
  6248.  
  6249. SINON;
  6250. NXI2 = EXTR CHN NX P2 ;
  6251. NYI2 = EXTR CHN NY P2 ;
  6252. VN2 = NXI2 NYI2 ;
  6253. TXI2 = EXTR CHT TX P2 ;
  6254. TYI2 = EXTR CHT TY P2 ;
  6255. VT2 = TXI2 TYI2 ;
  6256. BXI2 = EXTR CHB BX P2 ;
  6257. BYI2 = EXTR CHB BY P2 ;
  6258. VB2 = BXI2 BYI2 ;
  6259. NXI3 = EXTR CHN NX P3 ;
  6260. NYI3 = EXTR CHN NY P3 ;
  6261. VN3 = NXI3 NYI3 ;
  6262. TXI3 = EXTR CHT TX P3 ;
  6263. TYI3 = EXTR CHT TY P3 ;
  6264. VT3 = TXI3 TYI3 ;
  6265. BXI3 = EXTR CHB BX P3 ;
  6266. BYI3 = EXTR CHB BY P3 ;
  6267. VB3 = BXI3 BYI3 ;
  6268. XR = VT3 PSCA VT2 ;
  6269. YR = VT3 PSCA VN2 ;
  6270. * MESS 'XR =' XR 'YR =' YR ;
  6271. ALPHA = ATG YR XR ;
  6272. * MESS 'ALPHA =' ALPHA ;
  6273. DS2 = NORM (MOIN P2 P3) ;
  6274. RR = (ALPHA*PI/180.)/DS2 ;
  6275. SI (RR NEG 0.) ;
  6276. R = 1./RR ;
  6277. SINON ;
  6278. R = 1.E99 ;
  6279. FINSI ;
  6280. * MESS 'R =' R ;
  6281. BETA = 0.;
  6282. T = 0.;
  6283. FINSI;
  6284. FINPROC DS2 R T ALPHA BETA ;
  6285. **** @COUTOR2
  6286. *****************************************************************
  6287. * PROCEDURE @COUTOR2 : CREATION DE 2 CHAMPS PAR ELEMENTS R ET T
  6288. *****************************************************************
  6289. DEBPROC @COUTOR2 GEOFRE*MAILLAGE CHT*CHPOINT CHN*CHPOINT CHB*CHPOINT ;
  6290.  
  6291. NBELGEO = NBEL GEOFRE;
  6292. DIMGEO1 = VALEUR DIME ;
  6293. NBEL1 = 0;
  6294. REPETER BOUCEL NBELGEO;
  6295. NBEL1 = NBEL1 + 1;
  6296. ELEMCOUR = GEOFRE ELEM NBEL1;
  6297. PTINIT = ELEMCOUR POIN INITIAL;
  6298. PTFIN = ELEMCOUR POIN FINAL;
  6299. SI (DIMGEO1 > 2);
  6300. NXI2 = EXTR CHN NX PTINIT ;
  6301. NYI2 = EXTR CHN NY PTINIT ;
  6302. NZI2 = EXTR CHN NZ PTINIT ;
  6303. VN2 = NXI2 NYI2 NZI2 ;
  6304. TXI2 = EXTR CHT TX PTINIT ;
  6305. TYI2 = EXTR CHT TY PTINIT ;
  6306. TZI2 = EXTR CHT TZ PTINIT ;
  6307. VT2 = TXI2 TYI2 TZI2 ;
  6308. BXI2 = EXTR CHB BX PTINIT ;
  6309. BYI2 = EXTR CHB BY PTINIT ;
  6310. BZI2 = EXTR CHB BZ PTINIT ;
  6311. VB2 = BXI2 BYI2 BZI2 ;
  6312. NXI3 = EXTR CHN NX PTFIN ;
  6313. NYI3 = EXTR CHN NY PTFIN ;
  6314. NZI3 = EXTR CHN NZ PTFIN ;
  6315. VN3 = NXI3 NYI3 NZI3 ;
  6316. TXI3 = EXTR CHT TX PTFIN ;
  6317. TYI3 = EXTR CHT TY PTFIN ;
  6318. TZI3 = EXTR CHT TZ PTFIN ;
  6319. VT3 = TXI3 TYI3 TZI3 ;
  6320. BXI3 = EXTR CHB BX PTFIN ;
  6321. BYI3 = EXTR CHB BY PTFIN ;
  6322. BZI3 = EXTR CHB BZ PTFIN ;
  6323. VB3 = BXI3 BYI3 BZI3 ;
  6324. XR = VT3 PSCA VT2 ;
  6325. YR = VT3 PSCA VN2 ;
  6326. * MESS 'XR =' XR 'YR =' YR ;
  6327. ALPHA = ATG YR XR ;
  6328. * MESS 'ALPHA =' ALPHA ;
  6329. DS2 = NORM (MOIN PTINIT PTFIN) ;
  6330. RR = (ALPHA*PI/180.)/DS2 ;
  6331. SI (RR NEG 0.) ;
  6332. R = 1./RR ;
  6333. SINON ;
  6334. R = 1.E99 ;
  6335. FINSI ;
  6336. * MESS 'R =' R ;
  6337. XT = VB2 PSCA VB3 ;
  6338. YT = VB2 PSCA VN3 ;
  6339. * MESS 'XT =' XT 'YT =' YT ;
  6340. BETA = ATG YT XT ;
  6341. * MESS 'BETA =' BETA ;
  6342. TT = -1*(BETA*PI/180.)/DS2 ;
  6343. SI (TT NEG 0.) ;
  6344. T = 1./TT ;
  6345. SINON ;
  6346. T = 1.E99 ;
  6347. FINSI ;
  6348. * MESS 'T =' T ;
  6349.  
  6350. SINON;
  6351. NXI2 = EXTR CHN NX PTINIT ;
  6352. NYI2 = EXTR CHN NY PTINIT ;
  6353. VN2 = NXI2 NYI2 ;
  6354. TXI2 = EXTR CHT TX PTINIT ;
  6355. TYI2 = EXTR CHT TY PTINIT ;
  6356. VT2 = TXI2 TYI2 ;
  6357. BXI2 = EXTR CHB BX PTINIT ;
  6358. BYI2 = EXTR CHB BY PTINIT ;
  6359. VB2 = BXI2 BYI2 ;
  6360. NXI3 = EXTR CHN NX PTFIN ;
  6361. NYI3 = EXTR CHN NY PTFIN ;
  6362. VN3 = NXI3 NYI3 ;
  6363. TXI3 = EXTR CHT TX PTFIN ;
  6364. TYI3 = EXTR CHT TY PTFIN ;
  6365. VT3 = TXI3 TYI3 ;
  6366. BXI3 = EXTR CHB BX PTFIN ;
  6367. BYI3 = EXTR CHB BY PTFIN ;
  6368. VB3 = BXI3 BYI3 ;
  6369. XR = VT3 PSCA VT2 ;
  6370. YR = VT3 PSCA VN2 ;
  6371. * MESS 'XR =' XR 'YR =' YR ;
  6372. ALPHA = ATG YR XR ;
  6373. * MESS 'ALPHA =' ALPHA ;
  6374. DS2 = NORM (MOIN PTINIT PTFIN) ;
  6375. RR = (ALPHA*PI/180.)/DS2 ;
  6376. SI (RR NEG 0.) ;
  6377. R = 1./RR ;
  6378. SINON ;
  6379. R = 1.E99 ;
  6380. FINSI ;
  6381. * MESS 'R =' R ;
  6382. BETA = 0.;
  6383. T = 0.;
  6384. FINSI;
  6385. SI (EGA NBEL1 1) ;
  6386. CHCOU = PROG R ;
  6387. CHTOR = PROG T ;
  6388. SINON ;
  6389. CHCOU =CHCOU ET (PROG R) ;
  6390. CHTOR = CHTOR ET ( PROG T ) ;
  6391. FINSI;
  6392. FIN BOUCEL;
  6393. CHRT = MANU CHML GEOFRE 'R' CHCOU 'T' CHTOR TYPE GRAVITE ;
  6394. FINPROC CHRT;
  6395. **** @CRCACY
  6396. DEBPROC @CRCACY XG*CHPOINT YG*CHPOINT ZG*CHPOINT ;
  6397. *
  6398. ***************************************************************
  6399. * NICOLAS CURT 30032000Procedure de changement de repere.
  6400. * cartesiennes => cylindriques
  6401. *
  6402. ***************************************************************
  6403. *
  6404. PHI = ATG YG XG ;
  6405.  
  6406. RHO = (XG*XG + (YG*YG))**0.5 ;
  6407. *
  6408. FINPROC RHO PHI ZG ;
  6409.  
  6410.  
  6411. **** @CRGMC
  6412. DEBPROC @CRGMC XG*CHPOINT YG*CHPOINT ZG*CHPOINT TAB1*TABLE ;
  6413. *
  6414. *******************************************************************
  6415. * Procedure de changement de repere. On passe du repere cartesien *
  6416. * global de la machine defini par son origine au centre du tore, *
  6417. * l'axe du tore dirige suivant Z et l'axe X situe dans le plan *
  6418. * median entre deux bobines au repere cartesien du maillage. *
  6419. * Trois cas sont etudies : 3D, 2D en coupe Phi constant et 2D en *
  6420. * coupe Theta constant. Alain MOAL (Decembre 1995-Janvier 1996) *
  6421. *******************************************************************
  6422. *
  6423. *--------------- VARIABLES D'ENTREE :
  6424. SI ((VALEUR DIME) EGA 2) ;
  6425. IPLAN = TAB1.<PLAN ;
  6426. SI (EGA IPLAN 'PHICONS') ;
  6427. CT0 = TAB1.<CENTRE_TORE ;
  6428. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  6429. P1 = TAB1.<POINT_SUR_OBJET ;
  6430. FINSI ;
  6431. SI (EGA IPLAN 'THECONS') ;
  6432. THETA0 = TAB1.<THETA0 ;
  6433. CP = TAB1.CENTRE_PLASMA ;
  6434. RP = TAB1.<RP ;
  6435. HP = TAB1.<HP ;
  6436. FINSI ;
  6437. SINON ;
  6438. CT0 = TAB1.<CENTRE_TORE ;
  6439. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  6440. P1 = TAB1.<POINT_SUR_OBJET ;
  6441. FINSI ;
  6442. ANGPHI0 = TAB1.<ANG_PHI0 ;
  6443. *------------------------------------
  6444. *
  6445. DIM0 = VALEUR DIME ;
  6446. SI (DIM0 EGA 2) ;
  6447. FINSI ;
  6448. *
  6449. SI (((DIM0 EGA 2) ET (EGA IPLAN 'PHICONS')) OU (DIM0 EGA 3)) ;
  6450. * ---- en 3D ou en 2D pour la section Phi constant
  6451. X0 Y0 Z0 = COOR CT0 ;
  6452. X1 Y1 Z1 = COOR CT1 ;
  6453. XP1 YP1 ZP1 = COOR P1 ;
  6454. *
  6455. * ---- Calcul des coordonnees du point P0, projection du point P1 de
  6456. * ---- l'objet dans le plan orthogonal a l'axe du tore en CT0.
  6457. A = X1 - X0 ;
  6458. B = Y1 - Y0 ;
  6459. C = Z1 - Z0 ;
  6460. *
  6461. SI (A EGA 0.) ;
  6462. SI (B EGA 0.) ;
  6463. XP0 = XP1 ;
  6464. YP0 = YP1 ;
  6465. ZP0 = Z0 ;
  6466. FINSI ;
  6467. SI (C EGA 0.) ;
  6468. XP0 = XP1 ;
  6469. YP0 = Y0 ;
  6470. ZP0 = ZP1 ;
  6471. FINSI ;
  6472. SI ((B NEG 0.) ET (C NEG 0.)) ;
  6473. XP0 = XP1 ;
  6474. YP0 = (-1.*B*C*ZP1 + (C*C*YP1) + (B*B*Y0) + (B*C*Z0)) /(B*B + (C*C)) ;
  6475. ZP0 = (B*ZP1 - (C*YP1) + (C*(Y0+Z0)))/(B+C);
  6476. FINSI ;
  6477. SINON ;
  6478. AUX1 = A / (A*A + (B*B) + (C*C)) ;
  6479. AUX2 = (B*B + (C*C)) / A ;
  6480. XP0 = AUX1 * (A*X0 + (B*Y0) + (C*Z0) + (AUX2*XP1) - (B*YP1) - (C*ZP1)) ;
  6481. YP0 = B * (XP0 - XP1) / A + YP1 ;
  6482. ZP0 = C * (XP0 - XP1) / A + ZP1 ;
  6483. FINSI ;
  6484. *
  6485. P0 = XP0 YP0 ZP0 ;
  6486. *
  6487. * ---- Rotation de la ligne (CT0,P0) pour l'aligner sur l'axe X
  6488. * ---- du repere global
  6489. LIG0 = CT0 D 1 P0 ;
  6490. LIG1 = LIG0 TOUR (-1.*ANGPHI0) CT0 CT1 ;
  6491. *
  6492. * ---- Calcul des 3 vecteurs unitaires du repere global
  6493. P0X = LIG1 POIN FINAL ;
  6494. DIR1 = P0X MOIN CT0 ;
  6495. VEC1 = DIR1 / (NORM DIR1) ;
  6496. DIR3 = CT1 MOIN CT0 ;
  6497. VEC3 = DIR3 / (NORM DIR3) ;
  6498. VEC2 = VEC3 PVEC VEC1 ;
  6499. *
  6500. * ---- Changement de repere
  6501. A1 B1 C1 = COOR VEC1 ;
  6502. A2 B2 C2 = COOR VEC2 ;
  6503. A3 B3 C3 = COOR VEC3 ;
  6504. *
  6505. XM1 = (A1 * XG) + (A2 * YG) + (A3 * ZG) ;
  6506. YM1 = (B1 * XG) + (B2 * YG) + (B3 * ZG) ;
  6507. ZM1 = (C1 * XG) + (C2 * YG) + (C3 * ZG) ;
  6508. *
  6509. XM = XM1 + X0 ;
  6510. YM = YM1 + Y0 ;
  6511. ZM = ZM1 + Z0 ;
  6512. *
  6513. SINON ;
  6514. *
  6515. * ---- en 2D pour une section a Theta constant
  6516. XCP YCP ZCP = COOR CP ;
  6517. NORM_CP = (XCP*XCP + (YCP*YCP) + (ZCP*ZCP))**0.5 ;
  6518. ANG1 = ATG XCP YCP ;
  6519. *
  6520. * ---- Rotation de (90 + ANGPHI0) par rapport a l'axe Z
  6521. X1 = -1. * XG * (SIN ANGPHI0) + (YG * (COS ANGPHI0)) ;
  6522. Y1 = -1. * XG * (COS ANGPHI0) - (YG * (SIN ANGPHI0)) ;
  6523. Z1 = ZG ;
  6524. *
  6525. * ---- Changement d'origine vers le centre du plasma
  6526. X2 = X1 ;
  6527. Y2 = Y1 + RP + (NORM_CP * (COS THETA0)) ;
  6528. Z2 = Z1 - HP - (NORM_CP * (SIN THETA0)) ;
  6529. *
  6530. * ---- Rotation de -THETA0 par rapport a l'axe X
  6531. X3 = X2 ;
  6532. Y3 = Y2 * (COS THETA0) - (Z2 * (SIN THETA0)) ;
  6533. Z3 = Y2 * (SIN THETA0) + (Z2 * (COS THETA0)) ;
  6534. *
  6535. * ---- Rotation de ANG1 par rapport a l'axe Z
  6536. XM = X3 * (COS ANG1) + (Y3 * (SIN ANG1)) ;
  6537. YM = -1. * X3 * (SIN ANG1) + (Y3 * (COS ANG1)) ;
  6538. ZM = Z3 ;
  6539. *
  6540. FINSI ;
  6541. *
  6542. SI (DIM0 EGA 2) ;
  6543. FINSI ;
  6544. *
  6545. FINPROC XM YM ZM ;
  6546.  
  6547. **** @CRGTC
  6548. DEBPROC @CRGTC XG*CHPOINT YG*CHPOINT ZG*CHPOINT R*FLOTTANT H*FLOTTANT ;
  6549. *
  6550. ***************************************************************
  6551. * Procedure de changement de repere. On passe des coordonnees *
  6552. * cartesiennes dans le repere global de la machine defini par *
  6553. * son origine au centre du tore, l'axe du tore dirige suivant *
  6554. * Z et l'axe X situe dans le plan median entre deux bobines *
  6555. * aux coordonnees pseudo-toroidales dans un repere defini par *
  6556. * son grand rayon R et la hauteur H de son centre par rapport *
  6557. * au plan equatorial. Alain MOAL (decembre 1995) *
  6558. ***************************************************************
  6559. *mess ' ---> calling @CRGTC';
  6560. *
  6561. PHI = ATG YG XG ;
  6562. *
  6563. *
  6564. *---- Rotation de Phi par rapport a l'axe Z
  6565. *
  6566. X1 = (COS PHI) * XG + ((SIN PHI) * YG) ;
  6567. Y1 = -1. * (SIN PHI) * XG + ((COS PHI) * YG) ;
  6568. Z1 = ZG ;
  6569. *
  6570. *---- Changement d'origine vers le centre du nouveau repere
  6571. X2 = X1 - R ;
  6572. Y2 = Y1 ;
  6573. Z2 = Z1 - H ;
  6574. *
  6575. *---- Calcul de Theta et Rho
  6576. *
  6577. THETA = ATG Z2 X2 ;
  6578. RHO = (X2*X2 + (Z2*Z2))**0.5 ;
  6579. *mess ' ---> exiting @CRGTC';
  6580. FINPROC RHO THETA PHI ;
  6581. **** @CRIT
  6582. DEBPROC @CRIT TAB1*TABLE;
  6583.  
  6584. MESS '---------------------------------> calling @CRIT';
  6585. MESS ' Calcul du critere d interception par le code';
  6586. *
  6587. * ========= PARAMETRES D'ENTREE
  6588. MAIL2 = TAB1.<S_OMBRANT;
  6589. ALPHA = TAB1.<INCIDENCE_MAXIMALE ;
  6590. PASB0 = TAB1.<PAS_AVEC_TEST ;
  6591.  
  6592.  
  6593. * CALCUL DES PARAMETRES GEOMETRIQUES ENTRANT DANS *
  6594. * LE CALCUL DE DELIM *
  6595.  
  6596. * ---- CAS 3D
  6597. SI ((VALEUR DIME) EGA 3) ;
  6598. C2MAX = 0. ;
  6599. LMOT = MAIL2 ELEM 'TYPE' ;
  6600. typ = table ;
  6601. ntyp = dime LMOT ;
  6602. bootri = faux ;
  6603. booqua = faux ;
  6604. repeter bouty ntyp ;
  6605. i = &bouty ;
  6606. typ.i = extr LMOT i ;
  6607. si (ega typ.i tri3);bootri = vrai; finsi ;
  6608. si (ega typ.i qua4);booqua = vrai; finsi ;
  6609. fin bouty ;
  6610.  
  6611.  
  6612.  
  6613. * ---- BOUCLE LES MAILLES TRIANGULAIRES *
  6614. si bootri ;
  6615. nbtri = nbel (MAIL2 elem tri3) ;
  6616. repeter boutri nbtri ;
  6617. i = &boutri ;
  6618. eli = MAIL2 elem tri3 i ;
  6619. eli = chan eli poi1 ;
  6620. * ---- CALCUL DES DISTANCES A UN DES SOMMETS DE LA MAILLE *
  6621. nbmai = nbno eli ;
  6622. pt1 = elem eli point 1 ;
  6623. pt2 = elem eli point 2 ;
  6624. pt3 = elem eli point 3 ;
  6625. d1_2 = NORM (MOIN PT1 PT2) ;
  6626. d1_3 = NORM (MOIN PT1 PT3) ;
  6627. d3_2 = NORM (MOIN PT3 PT2) ;
  6628. lid = prog d1_2 d1_3 d3_2 ;
  6629. C2 = MAXI lid ;
  6630. C1 = MINI lid ;
  6631.  
  6632. * --- ON CONSIDERE LA MAILLE LA PLUS GRANDE
  6633. SI (C2 > C2MAX) ;
  6634. C2MAX = C2 ;
  6635. C1CO = C1 ;
  6636. FINSI ;
  6637. fin boutri ;
  6638. finsi ;
  6639.  
  6640.  
  6641.  
  6642. * ---- BOUCLE LES MAILLES QUADRANGULAIRES *
  6643. si booqua ;
  6644. nbqua = nbel (MAIL2 elem qua4) ;
  6645.  
  6646. repeter bouqua nbqua ;
  6647. i = &bouqua ;
  6648. eli = MAIL2 elem qua4 i ;
  6649. eli = chan eli poi1 ;
  6650. * ---- CALCUL DES DISTANCES ENTRE LES SOMMETS DE LA MAILLE *
  6651. nbmai = nbel eli ;
  6652. pt1 = elem eli point 1 ;
  6653. pt2 = elem eli point 2 ;
  6654. pt3 = elem eli point 3 ;
  6655. pt4 = elem eli point 4 ;
  6656. d1_2 = NORM (MOIN PT1 PT2) ;
  6657. d2_3 = NORM (MOIN PT3 PT2) ;
  6658. d3_4 = NORM (MOIN PT3 PT4) ;
  6659. d4_1 = NORM (MOIN PT1 PT4) ;
  6660.  
  6661. * ---- CAS DES RECTANGLES *
  6662. SI ((d1_2 ega d3_4) et (d2_3 ega d4_1)) ;
  6663. lid = prog d1_2 d2_3 ;
  6664. c2 = maxi lid ;
  6665. c1 = mini lid ;
  6666.  
  6667.  
  6668. * ---- CAS D'UNE MAILLE NON STRUCTUREE *
  6669. SINON ;
  6670. lid = ORDONNER (prog d1_2 d2_3 d3_4 d4_1) ;
  6671.  
  6672. C2 = EXTR LID 4 ;
  6673. C1 = EXTR LID 3 ;
  6674.  
  6675. FINSI ;
  6676.  
  6677. * --- ON CONSIDERE LA MAILLE LA PLUS GRANDE
  6678. SI (C2 > C2MAX) ;
  6679. C2MAX = C2 ;
  6680. C1CO = C1 ;
  6681. FINSI ;
  6682.  
  6683. fin bouqua ;
  6684. finsi ;
  6685.  
  6686.  
  6687. * --- CALCUL DU CRITERE SELON LA FORMULE TROUVEE
  6688. delim = (((C2MAX**2)+(PASB0**2)+((C1CO*(SIN ALPHA))**2))**0.5) / 2. ;
  6689.  
  6690.  
  6691.  
  6692. * ---- CAS 2D (On considere le pas non projete => majore delim
  6693. SINON ;
  6694. NSEG2 = NBEL (MAIL2 elem SEG2) ;
  6695. CMAX = 0. ;
  6696. REPETER BOUSEG2 NSEG2 ;
  6697. I = &BOUSEG2 ;
  6698. ELI = MAIL2 ELEM SEG2 I ;
  6699. eli = chan eli poi1 ;
  6700. * ---- CALCUL DE LA DISTANCE ENTRE LES EXTREMITES DE LA MAILLE *
  6701. pt1 = elem eli point 1 ;
  6702. pt2 = elem eli point 2 ;
  6703. D1_2 = NORM (MOIN PT1 PT2) ;
  6704. * ---- On stocke la distance la plus grande
  6705. SI (D1_2 > CMAX) ;
  6706. CMAX = D1_2 ;
  6707. FINSI ;
  6708. FIN BOUSEG2 ;
  6709.  
  6710.  
  6711. * --- CALCUL DU CRITERE SELON LA FORMULE TROUVEE
  6712. DELIM = (((PASB0**2)+((CMAX*(SIN ALPHA))**2))**0.5) / 2. ;
  6713. FINSI ;
  6714.  
  6715. MESS '---------------------------------> exiting @CRIT';
  6716. FINPROC delim ;
  6717. **** @CRLMC
  6718. DEBPROC @CRLMC XL*CHPOINT YL*CHPOINT ZL*CHPOINT TAB1*TABLE ;
  6719. *
  6720. *******************************************************************
  6721. * Version amelioree de l'ancien @CRLMC rebaptise @ACRLM *
  6722. * Procedure de changement de repere. On passe du repere cartesien *
  6723. * local de l'objet modelise au repere cartesien du maillage. Le *
  6724. * point de tangence au plasma est l'origine du repere local et *
  6725. * l'axe Y est dirige vers le centre du plasma. En 3D, L'axe X du *
  6726. * repere local est dans la direction toroidale. *
  6727. * en 2D cas PHICONS l'axe Z du repere local est l'axe toroidal *
  6728. * en 2D cas THECONS l'axe x du repere local est l'axe toroidal *
  6729. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  6730. *******************************************************************
  6731. *
  6732. *--------------- VARIABLES D'ENTREE :
  6733. CP = TAB1.CENTRE_PLASMA ;
  6734. PTG = TAB1.PT_TGPLASMA ;
  6735. SI ((VALEUR DIME) EGA 2) ;
  6736. SI (EXISTE TAB1 <PLAN) ;
  6737. IPLAN = TAB1.<PLAN ;
  6738. SINON ;
  6739. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  6740. FINSI ;
  6741. SINON ;
  6742. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  6743. DIR1 = TAB1.<DIR_TOROIDAL ;
  6744. SINON ;
  6745. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  6746. FINSI ;
  6747. FINSI ;
  6748. *------------------------------------
  6749. *
  6750. SI ((VALEUR DIME) EGA 2) ;
  6751. VECT0 = CP MOINS PTG ;
  6752. VX VY = COOR VECT0 ;
  6753. *
  6754. * ---- calcul de l'angle de rotation dans le plan XY
  6755. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  6756. ANG1 = 0. ;
  6757. SINON ;
  6758. ANG1 = -1.* (ATG VX VY) ;
  6759. FINSI ;
  6760. *
  6761. XPTG YPTG = COOR PTG ;
  6762. *
  6763. SI (EGA IPLAN 'PHICONS');
  6764. * ---- Coupe 2D a Phi constant
  6765. XL = ZL ;
  6766. ZL = ZL * 0.;
  6767. * ---- rotation
  6768. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  6769. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  6770. FINSI;
  6771. SI (EGA IPLAN 'THECONS');
  6772. * ---- Coupe 2D a Theta constant
  6773. * ---- rotation
  6774. XL1 = XL * (COS ANG1) + (YL * (-1.) * (SIN ANG1));
  6775. YL1 = XL * (SIN ANG1) + (YL * (COS ANG1));
  6776. FINSI;
  6777. * ---- changement d'origine du repere
  6778. XM = XL1 + XPTG ;
  6779. YM = YL1 + YPTG ;
  6780. ZM = YL1 * 0. ;
  6781. *
  6782. SINON ;
  6783. *
  6784. VEC1 = DIR1 / (NORM DIR1) ;
  6785. DIR2 = CP MOINS PTG ;
  6786. VEC2 = DIR2 / (NORM DIR2) ;
  6787. VEC3 = VEC1 PVEC VEC2 ;
  6788. *
  6789. X0 Y0 Z0 = COOR PTG ;
  6790. A1 B1 C1 = COOR VEC1 ;
  6791. A2 B2 C2 = COOR VEC2 ;
  6792. A3 B3 C3 = COOR VEC3 ;
  6793. *
  6794. XM1 = (A1 * XL) + (A2 * YL) + (A3 * ZL) ;
  6795. YM1 = (B1 * XL) + (B2 * YL) + (B3 * ZL) ;
  6796. ZM1 = (C1 * XL) + (C2 * YL) + (C3 * ZL) ;
  6797. *
  6798. XM = XM1 + X0 ;
  6799. YM = YM1 + Y0 ;
  6800. ZM = ZM1 + Z0 ;
  6801. *
  6802. FINSI ;
  6803. FINPROC XM YM ZM ;
  6804. **** @CRLTC
  6805. DEBPROC @CRLTC TAB1*TABLE XM*CHPOINT YM*CHPOINT ZM*CHPOINT R*FLOTTANT ;
  6806. *
  6807. ***************************************************************
  6808. * Procedure de changement de repere, on passe des *
  6809. * coordonnees cartesiennes dans le repere de local de l'objet *
  6810. * XM YM ZM repere defini par TAB1.<RHO0, TAB1.<THETA0 et *
  6811. * TAB1.<RP aux coordonnees pseudo-toroidales defini par un *
  6812. * grand rayon donne R . Alain MOAL (mai 1995) *
  6813. ***************************************************************
  6814. *
  6815. *--------------- VARIABLES D'ENTREE :
  6816. RHO0 = TAB1.<RHO0 ;
  6817. THETA0 = TAB1.<THETA0 ;
  6818. RP = TAB1.<RP ;
  6819. *------------------------------------
  6820. *
  6821. CT0 = COS THETA0 ;
  6822. ST0 = SIN THETA0 ;
  6823. MST0 = ST0 * -1. ;
  6824. *
  6825. *---- 1) rotation d'angle THETA0 autour de l'axe X
  6826. X1 = XM ;
  6827. Y1 = (YM * CT0) + (ZM * ST0) ;
  6828. Z1 = (YM * MST0) + (ZM * CT0) ;
  6829. *
  6830. *---- 2) changement d'origine vers le centre du tore,
  6831. *---- rotation de 180 degres autour de l'axe Z2 pour
  6832. *---- retrouver le repere global puis calcul de PHI
  6833. X2 = X1 ;
  6834. Y2 = Y1 - (RHO0 * CT0 + RP) ;
  6835. Z2 = Z1 + (RHO0 * ST0) ;
  6836. *
  6837. X2 = X2 * -1. ;
  6838. Y2 = Y2 * -1. ;
  6839. PHI = ATG (X2 * -1.) Y2 ;
  6840. *
  6841. *---- 3) rotation d'angle PHI autour de l'axe Z2
  6842. CPHI = COS PHI ;
  6843. SPHI = SIN PHI ;
  6844. MSPHI = SPHI * -1. ;
  6845. X3 = (X2 * CPHI) + (Y2 * SPHI) ;
  6846. Y3 = (X2 * MSPHI) + (Y2 * CPHI) ;
  6847. Z3 = Z2 ;
  6848. *
  6849. *---- 4) changement d'origine vers le centre du nouveau repere
  6850. X4 = X3 ;
  6851. Y4 = Y3 - R ;
  6852. Z4 = Z3 ;
  6853. *
  6854. *---- calcul de RHO et THETA
  6855. RHO = ((Y4 * Y4) + (Z4 * Z4))**0.5 ;
  6856. THETA = ATG Z4 Y4 ;
  6857. *
  6858. MESS '>>>> @CRLTC : max and min of the angle PHI' ;
  6859. MESS (MAXI PHI) (MINI PHI) ;
  6860. *
  6861. FINPROC RHO THETA PHI ;
  6862. **** @CRMGC
  6863. DEBPROC @CRMGC XM*CHPOINT YM*CHPOINT ZM*CHPOINT TAB1*TABLE ;
  6864. *
  6865. *******************************************************************
  6866. * Procedure de changement de repere. On passe du repere cartesien *
  6867. * quelconque du maillage au repere cartesien global de la machine *
  6868. * defini par son origine au centre du tore, l'axe du tore dirige *
  6869. * suivant Z et l'axe X situe dans le plan median entre deux *
  6870. * bobines. Trois cas sont etudies : 3D, 2D en coupe Phi constant *
  6871. * et 2D en coupe Theta constant. Alain MOAL (Decembre 1995) *
  6872. *******************************************************************
  6873. *
  6874. *--------------- VARIABLES D'ENTREE :
  6875. SI ((VALEUR DIME) EGA 2) ;
  6876. IPLAN = TAB1.<PLAN ;
  6877. SI (EGA IPLAN 'PHICONS') ;
  6878. CT0 = TAB1.<CENTRE_TORE ;
  6879. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  6880. P1 = TAB1.<POINT_SUR_OBJET ;
  6881. FINSI ;
  6882. SI (EGA IPLAN 'THECONS') ;
  6883. THETA0 = TAB1.<THETA0 ;
  6884. CP = TAB1.CENTRE_PLASMA ;
  6885. RP = TAB1.<RP ;
  6886. HP = TAB1.<HP ;
  6887. FINSI ;
  6888. SINON ;
  6889. CT0 = TAB1.<CENTRE_TORE ;
  6890. CT1 = TAB1.<POINT_SUR_AXE_TORE ;
  6891. P1 = TAB1.<POINT_SUR_OBJET ;
  6892. FINSI ;
  6893. ANGPHI0 = TAB1.<ANG_PHI0 ;
  6894. *------------------------------------
  6895. *
  6896. DIM0 = VALEUR DIME ;
  6897. SI (DIM0 EGA 2) ;
  6898. FINSI ;
  6899. *
  6900. SI (((DIM0 EGA 2) ET (EGA IPLAN 'PHICONS')) OU (DIM0 EGA 3)) ;
  6901. * ---- en 3D ou en 2D pour la section Phi constant
  6902. X0 Y0 Z0 = COOR CT0 ;
  6903. X1 Y1 Z1 = COOR CT1 ;
  6904. XP1 YP1 ZP1 = COOR P1 ;
  6905. *
  6906. * ---- Calcul des coordonnees du point P0, projection du point P1 de
  6907. * ---- l'objet dans le plan orthogonal a l'axe du tore en CT0.
  6908. A = X1 - X0 ;
  6909. B = Y1 - Y0 ;
  6910. C = Z1 - Z0 ;
  6911. *
  6912. SI (A EGA 0.) ;
  6913. SI (B EGA 0.);
  6914. XP0 = XP1 ;
  6915. YP0 = YP1 ;
  6916. ZP0 = Z0 ;
  6917. FINSI ;
  6918. SI (C EGA 0.) ;
  6919. XP0 = XP1 ;
  6920. YP0 = Y0 ;
  6921. ZP0 = ZP1 ;
  6922. FINSI ;
  6923. SI ((B NEG 0.) ET (C NEG 0.)) ;
  6924. XP0 = XP1 ;
  6925. YP0 = (-1.*B*C*ZP1 + (C*C*YP1) + (B*B*Y0) + (B*C*Z0)) /(B*B + (C*C)) ;
  6926. ZP0 = (B*ZP1 - (C*YP1) + (C*(Y0+Z0)))/(B+C);
  6927. FINSI ;
  6928. SINON ;
  6929. AUX1 = A / (A*A + (B*B) + (C*C)) ;
  6930. AUX2 = (B*B + (C*C)) / A ;
  6931. XP0 = AUX1 * (A*X0 + (B*Y0) + (C*Z0) + (AUX2*XP1) - (B*YP1) - (C*ZP1)) ;
  6932. YP0 = B * (XP0 - XP1) / A + YP1 ;
  6933. ZP0 = C * (XP0 - XP1) / A + ZP1 ;
  6934. FINSI ;
  6935. *
  6936. P0 = XP0 YP0 ZP0 ;
  6937. *
  6938. * ---- Rotation de la ligne (CT0,P0) pour l'aligner sur l'axe X
  6939. * ---- du repere global
  6940. LIG0 = CT0 D 1 P0 ;
  6941. LIG1 = LIG0 TOUR (-1.*ANGPHI0) CT0 CT1 ;
  6942. *
  6943. * ---- Calcul des 3 vecteurs unitaires du repere global
  6944. P0X = LIG1 POIN FINAL ;
  6945. DIR1 = P0X MOIN CT0 ;
  6946. VEC1 = DIR1 / (NORM DIR1) ;
  6947. DIR3 = CT1 MOIN CT0 ;
  6948. VEC3 = DIR3 / (NORM DIR3) ;
  6949. VEC2 = VEC3 PVEC VEC1 ;
  6950. *
  6951. * ---- Changement de repere
  6952. A1 B1 C1 = COOR VEC1 ;
  6953. A2 B2 C2 = COOR VEC2 ;
  6954. A3 B3 C3 = COOR VEC3 ;
  6955. *
  6956. XG1 = XM - X0 ;
  6957. YG1 = YM - Y0 ;
  6958. ZG1 = ZM - Z0 ;
  6959. *
  6960. XG = (A1 * XG1) + (B1 * YG1) + (C1 * ZG1) ;
  6961. YG = (A2 * XG1) + (B2 * YG1) + (C2 * ZG1) ;
  6962. ZG = (A3 * XG1) + (B3 * YG1) + (C3 * ZG1) ;
  6963. *
  6964. SINON ;
  6965. * ---- en 2D pour une section a Theta constant
  6966. *
  6967. XCP YCP ZCP = COOR CP ;
  6968. NORM_CP = (XCP*XCP + (YCP*YCP) + (ZCP*ZCP))**0.5 ;
  6969. ANG1 = ATG XCP YCP ;
  6970. *
  6971. * ---- Rotation de - ANG1 par rapport a l'axe Z
  6972. X1 = XM * (COS ANG1) - (YM * (SIN ANG1)) ;
  6973. Y1 = XM * (SIN ANG1) + (YM * (COS ANG1)) ;
  6974. Z1 = ZM ;
  6975. *
  6976. * ---- Rotation de THETA0 par rapport a l'axe X
  6977. X2 = X1 ;
  6978. Y2 = Y1 * (COS THETA0) + (Z1 * (SIN THETA0)) ;
  6979. Z2 = -1. * Y1 * (SIN THETA0) + (Z1 * (COS THETA0)) ;
  6980. *
  6981. * ---- Changement d'origine vers le centre du tore
  6982. X3 = X2 ;
  6983. Y3 = Y2 - RP - (NORM_CP * (COS THETA0)) ;
  6984. Z3 = Z2 + HP + (NORM_CP * (SIN THETA0)) ;
  6985. *
  6986. * ---- Rotation de -(90 + ANGPHI0) par rapport a l'axe Z
  6987. XG = -1. * X3 * (SIN ANGPHI0) - (Y3 * (COS ANGPHI0)) ;
  6988. YG = X3 * (COS ANGPHI0) - (Y3 * (SIN ANGPHI0)) ;
  6989. ZG = Z3 ;
  6990. *
  6991. FINSI;
  6992. *
  6993. SI (DIM0 EGA 2) ;
  6994. FINSI ;
  6995. *
  6996. FINPROC XG YG ZG ;
  6997.  
  6998.  
  6999.  
  7000. **** @CRMLC
  7001. DEBPROC @CRMLC XM*CHPOINT YM*CHPOINT ZM*CHPOINT TAB1*TABLE ;
  7002. *
  7003. *******************************************************************
  7004. * Version amelioree de l'ancien @CRMLC rebaptise @ACRML *
  7005. * Procedure de changement de repere. On passe du repere cartesien *
  7006. * du maillage au repere cartesien local de l'objet modelise. Le *
  7007. * point de tangence au plasma est l'origine de ce repere et l'axe *
  7008. * l'axe Y final est dirige vers le centre du plasma. *
  7009. * en 3D l'axe x du repere local est donne par la direction *
  7010. * toroidale *
  7011. * en 2D cas PHICONS l'axe Z initial est l'axe toroidal *
  7012. * en 2D cas THECONS l'axe x initial est l'axe toroidal *
  7013. * Jacques SCHLOSSER et Alain MOAL (Decembre 1995) *
  7014. *******************************************************************
  7015. *
  7016. *--------------- VARIABLES D'ENTREE :
  7017. CP = TAB1.CENTRE_PLASMA ;
  7018. PTG = TAB1.PT_TGPLASMA ;
  7019. SI ((VALEUR DIME) EGA 2) ;
  7020. SI (EXISTE TAB1 <PLAN) ;
  7021. IPLAN = TAB1.<PLAN ;
  7022. SINON ;
  7023. ERRE '>>>> TAB1.<PLAN n existe pas' ;
  7024. FINSI ;
  7025. SINON ;
  7026. SI (EXISTE TAB1 <DIR_TOROIDAL) ;
  7027. DIR1 = TAB1.<DIR_TOROIDAL ;
  7028. SINON ;
  7029. ERRE '>>>> TAB1.<DIR_TOROIDAL n existe pas' ;
  7030. FINSI ;
  7031. FINSI ;
  7032. *------------------------------------
  7033. *
  7034. SI ((VALEUR DIME) EGA 2) ;
  7035. VECT0 = CP MOINS PTG ;
  7036. VX VY = COOR VECT0 ;
  7037. *
  7038. * ---- calcul de l'angle de rotation dans le plan XY
  7039. SI ((VX EGA 0.) ET (VY EGA 0.)) ;
  7040. ANG1 = 0. ;
  7041. SINON ;
  7042. ANG1 = -1.* (ATG VX VY) ;
  7043. FINSI ;
  7044. *
  7045. XPTG YPTG = COOR PTG ;
  7046. *
  7047. * ---- changement d'origine du repere
  7048. XM1 = XM - XPTG ;
  7049. YM1 = YM - YPTG ;
  7050. * ---- rotation pour aligner l'axe Y avec VECT0
  7051. SI (EGA IPLAN 'PHICONS');
  7052. * ---- Coupe 2D a Phi constant
  7053. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  7054. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  7055. ZL = XM * 0. ;
  7056. *
  7057. ZL = XL ;
  7058. XL = XL * 0.;
  7059. FINSI;
  7060. SI (EGA IPLAN 'THECONS');
  7061. * ---- Coupe 2D a Theta constant
  7062. XL = XM1 * (COS ANG1) + (YM1 * (SIN ANG1));
  7063. YL = XM1 * (-1.) * (SIN ANG1) + (YM1 * (COS ANG1));
  7064. ZL = XM * 0. ;
  7065. FINSI ;
  7066. *
  7067. SINON ;
  7068. *
  7069. VEC1 = DIR1 / (NORM DIR1) ;
  7070. DIR2 = CP MOINS PTG ;
  7071. VEC2 = DIR2 / (NORM DIR2) ;
  7072. VEC3 = VEC1 PVEC VEC2 ;
  7073. *
  7074. X0 Y0 Z0 = COOR PTG ;
  7075. A1 B1 C1 = COOR VEC1 ;
  7076. A2 B2 C2 = COOR VEC2 ;
  7077. A3 B3 C3 = COOR VEC3 ;
  7078. *
  7079. XM1 = XM - X0 ;
  7080. YM1 = YM - Y0 ;
  7081. ZM1 = ZM - Z0 ;
  7082. *
  7083. XL = (A1 * XM1) + (B1 * YM1) + (C1 * ZM1) ;
  7084. YL = (A2 * XM1) + (B2 * YM1) + (C2 * ZM1) ;
  7085. ZL = (A3 * XM1) + (B3 * YM1) + (C3 * ZM1) ;
  7086. *
  7087. FINSI ;
  7088. FINPROC XL YL ZL ;
  7089.  
  7090.  
  7091. **** @CRTGC
  7092. DEBPROC @CRTGC RHO*CHPOINT THETA*CHPOINT PHI*CHPOINT R*FLOTTANT H*FLOTTANT ;
  7093. *
  7094. *****************************************************************
  7095. * Procedure de changement de repere. On passe des coordonnees *
  7096. * pseudo-toroidales dans un repere defini par son grand rayon R *
  7097. * et la hauteur H de son centre par rapport au plan equatorial *
  7098. * aux coordonnees cartesiennes dans le repere global de la *
  7099. * machine defini par son origine au centre du tore, l'axe du *
  7100. * tore dirige suivant Z et l'axe X situe dans le plan median *
  7101. * entre deux bobines. Alain MOAL (decembre 1995) *
  7102. *****************************************************************
  7103. *
  7104. X2 = RHO * (COS THETA) ;
  7105. Y2 = RHO * 0. ;
  7106. Z2 = RHO * (SIN THETA) ;
  7107. *
  7108. *---- Changement d'origine vers le centre du tore
  7109. X1 = X2 + R ;
  7110. Y1 = Y2 ;
  7111. Z1 = Z2 + H ;
  7112. *
  7113. *---- Rotation de - phi par rapport a l'axe Z
  7114. XG = (COS PHI) * X1 - ((SIN PHI) * Y1) ;
  7115. YG = (SIN PHI) * X1 + ((COS PHI) * Y1) ;
  7116. ZG = Z1 ;
  7117. *
  7118. FINPROC XG YG ZG ;
  7119. **** @CRTLC
  7120. DEBPROC @CRTLC R*FLOTTANT RHO*CHPOINT THETA*CHPOINT PHI*CHPOINT TAB1*TABLE ;
  7121. *
  7122. ***************************************************************
  7123. * Procedure de changement de repere, on passe des coordonnees *
  7124. * pseudo-toroidales centrees sur un grand rayon R aux *
  7125. * coordonnees cartesiennes dans le repere de la structure *
  7126. * modelisee. Alain MOAL (mai 1995) *
  7127. ***************************************************************
  7128. *
  7129. *--------------- VARIABLES D'ENTREE :
  7130. RHO0 = TAB1.<RHO0 ;
  7131. THETA0 = TAB1.<THETA0 ;
  7132. RP = TAB1.<RP ;
  7133. *------------------------------------
  7134. *
  7135. CT0 = COS THETA0 ;
  7136. ST0 = SIN THETA0 ;
  7137. MST0= ST0 * -1. ;
  7138. CPHI = COS PHI ;
  7139. SPHI = SIN PHI ;
  7140. MSPHI = SPHI * -1. ;
  7141. *
  7142. X4 = RHO * 0. ;
  7143. Y4 = RHO * (COS THETA) ;
  7144. Z4 = RHO * (SIN THETA) ;
  7145. *
  7146. *---- 1) changement d'origine vers le centre du tore
  7147. X3 = X4 ;
  7148. Y3 = Y4 + R ;
  7149. Z3 = Z4 ;
  7150. *
  7151. *---- 2) rotation d'angle - PHI autour de l'axe Z3
  7152. * puis rotation de - 180 degres autour de l'axe Z2
  7153. X2 = (X3 * CPHI) + (Y3 * MSPHI) ;
  7154. Y2 = (X3 * SPHI) + (Y3 * CPHI) ;
  7155. Z2 = Z3 ;
  7156. *
  7157. X2 = X2 * -1. ;
  7158. Y2 = Y2 * -1. ;
  7159. *
  7160. *---- 3) changement d'origine vers le centre d'objet
  7161. X1 = X2 ;
  7162. Y1 = Y2 + RP + (RHO0 * CT0) ;
  7163. Z1 = Z2 - (RHO0 * ST0) ;
  7164. *
  7165. *---- 4) rotation d'angle - THETA0 autour de l'axe X1
  7166. XP = X1 ;
  7167. YP = (Y1 * CT0) + (Z1 * MST0) ;
  7168. ZP = (Y1 * ST0) + (Z1 * CT0) ;
  7169. *
  7170. FINPROC XP YP ZP ;
  7171. **** @CRTTC
  7172. DEBPROC @CRTTC R1*FLOTTANT RHO1*CHPOINT THETA1*CHPOINT PHI1*CHPOINT R2*FLOTTANT ;
  7173. *
  7174. ***************************************************************
  7175. * Procedure de changement de repere. On passe d'un repere *
  7176. * pseudo-toroidal defini par son grand rayon R1 a un autre *
  7177. * repere pseudo-toroidal defini par son grand rayon R2. Ces *
  7178. * deux reperes ont la meme orientation toroidale: Phi1 = Phi2 *
  7179. * Alain MOAL (juin 1995) *
  7180. ***************************************************************
  7181. *
  7182. RHO2 = RHO1**2 + ((R1 - R2)**2) ;
  7183. RHO2 = RHO2 + (RHO1*(R1 - R2)*(COS THETA1)*2.) ;
  7184. RHO2 = RHO2**0.5 ;
  7185. *
  7186. AUX1 = RHO1 * (SIN THETA1) ;
  7187. AUX2 = RHO1 * (COS THETA1) - R2 + R1 ;
  7188. THETA2 = ATG AUX1 AUX2 ;
  7189. *
  7190. PHI2 = PHI1 ;
  7191. *
  7192. FINPROC RHO2 THETA2 PHI2 ;
  7193. **** @CSHIFT
  7194. DEBPROC @CSHIFT RHOM*CHPOINT THETAM*CHPOINT PHIM*CHPOINT IMETHOD*ENTIER TAB1*TABLE ;
  7195. *
  7196. ***************************************************************
  7197. * Procedure de calcul des grand et petit rayons du "cercle de *
  7198. * Shafranov" en chaque point M defini dans le repere centre *
  7199. * sur le plasma. On calcule de plus l'angle theta dans le *
  7200. * repere centre sur le cercle calcule. *
  7201. * Deux methodes sont utilisees pour calculer le grand rayon. *
  7202. * Alain MOAL (aout-sept 1995) *
  7203. ***************************************************************
  7204. *
  7205. *--------------- VARIABLES D'ENTREE :
  7206. RP = TAB1.<RP ;
  7207. RHO0 = TAB1.<RHO0 ;
  7208. LAMB = TAB1.<LAMB ;
  7209. *------------------------------------
  7210. *
  7211. SI ((NON (IMETHOD EGA 1)) ET (NON (IMETHOD EGA 2))) ;
  7212. ERRE '>>>> @CSHIFT : YOU MUST CHOOSE THE METHOD 1 OR 2' ;
  7213. FINSI ;
  7214. *
  7215. *---- variables auxiliaires
  7216. A = ((RHOM/RHO0)**-2) + 1. ;
  7217. A = A * (LAMB + 0.5) ;
  7218. A = A + (LOG (RHOM/RHO0)) - 1. ;
  7219. B = LOG (RHOM/RHO0) ;
  7220. B = B - ((((RHOM/RHO0)**-2) - 1.) * (LAMB + 0.5)) ;
  7221. STM = SIN THETAM ;
  7222. CTM = COS THETAM ;
  7223. AUX1 = 1. + LAMB ;
  7224. AUX2 = RHOM * CTM + RP ;
  7225. AUX3 = RHOM * STM ;
  7226. *
  7227. *---- TEST : calcul du decentrement par la methode de Shafranov
  7228. DELT0 = B * (RHOM**2) / (2.*RP) ;
  7229. MESS '*** TEST : DELT0 *** '; LIST DELT0 ;
  7230. *---- FIN TEST
  7231. *
  7232. SI (IMETHOD EGA 1) ;
  7233. * ---- calcul du grand rayon
  7234. *
  7235. * RM 08/04/97 J'enleve STM qui figure a la fois au numerateur et au denominateur
  7236. *dans l'expression definie par les trois lignes suivantes
  7237. * Il provoque une division par 0 quand des points du maillage sont dans le plan
  7238. * equatorial
  7239. * GRANDR = RHOM * RP * CTM * (A - B) ;
  7240. GRANDR = GRANDR + (2.*(RP**2) - (B*(RHOM**2))) ;
  7241. GRANDR = GRANDR / (2.*RP + (RHOM*CTM*(A - B))) ;
  7242. FINSI ;
  7243. *
  7244. SI (IMETHOD EGA 2) ;
  7245. DELTA = ((AUX2**2) * (AUX1**2)) - ((AUX1 + 1.) * ( ((AUX2**2) + (AUX3**2)) * AUX1 - (RP**2) - ((RHO0**2) * AUX1))) ;
  7246. *
  7247. * ---- deux cercles possibles
  7248. GRANDR1 = ((AUX2 * AUX1) + (DELTA**0.5))/(AUX1 + 1.) ;
  7249. GRANDR2 = ((AUX2 * AUX1) - (DELTA**0.5))/(AUX1 + 1.) ;
  7250. *
  7251. * ---- choix du bon cercle
  7252. SI ((COS THETAM) >EG 0.) ;
  7253. GRANDR = GRANDR2 ;
  7254. SINON ;
  7255. GRANDR = GRANDR1 ;
  7256. FINSI ;
  7257. FINSI ;
  7258. *
  7259. *---- calcul du petit rayon
  7260. PETITR = ((RHOM*CTM+RP-GRANDR)**2 + ((RHOM*STM)**2))**0.5 ;
  7261. *
  7262. *--- calcul de theta dans le repere centre sur le cercle calcule
  7263. THETAR = ATG (RHOM * STM) (RHOM * CTM + RP - GRANDR) ;
  7264. *
  7265. *---- test (methode 1)
  7266. *AM*TERME1 = PETITR * LAMB * (COS THETAR) / GRANDR ;
  7267. *AM*TERME2 = (STM**2 * B + ((CTM**2) * A))/(2.*RP) ;
  7268. *AM*TERME2 = TERME2 + (CTM / RHOM) ;
  7269. *AM*TERME2 = TERME2 * (RP - GRANDR);
  7270. *AM*TERME2 = TERME2 + (RHOM * CTM * A / (2.*RP)) ;
  7271. *AM*ERREUR0 = (ABS ((TERME1-TERME2)/TERME2)) ;
  7272. *AM*MESS 'TEST'; LIST TERME1; LIST TERME2; LIST ERREUR0;
  7273. *
  7274. FINPROC GRANDR PETITR THETAR;
  7275.  
  7276. **** @CVECT
  7277. DEBPROC @CVECT XV*CHPOINT YV*CHPOINT ZV*CHPOINT MAIL0*MAILLAGE COUL0*MOT AMPLI0/FLOTTANT;
  7278. *
  7279. **************************************************************
  7280. * Procedure de creation d'un objet de type vecteur a partir *
  7281. * des composantes d'un champ de vecteurs. *
  7282. * Si le facteur d'amplification pour visualiser un champ de *
  7283. * vecteur sur une geometrie n'est pas donne,il est adapte *
  7284. * aux dimensions geometriques du probleme. *
  7285. * Alain MOAL (juillet 1995) *
  7286. **************************************************************
  7287. *
  7288. XM = COOR 1 MAIL0 ;
  7289. YM = COOR 2 MAIL0 ;
  7290. SI ((VALEUR DIME) EGA 2) ;
  7291. ZM = XM * 0. ;
  7292. SINON ;
  7293. ZM = COOR 3 MAIL0 ;
  7294. FINSI ;
  7295. *
  7296. SI (NON (EXISTE AMPLI0)) ;
  7297. * ---- norme du vecteur
  7298. VECNORM = ((XV * XV) + (YV * YV) + (ZV * ZV))**0.5 ;
  7299. * RM 16.01.03
  7300. mess '>> ccect' ;
  7301. @listmm VECNORM ;
  7302. *
  7303. * ---- calcul d'une longueur caracteristique du maillage
  7304. LONGCAR1 = ABS ((MAXI XM) - (MINI XM)) ;
  7305. LONGCAR2 = ABS ((MAXI YM) - (MINI YM)) ;
  7306. LONGCAR3 = ABS ((MAXI ZM) - (MINI ZM)) ;
  7307. *
  7308. SI ((VALEUR DIME) EGA 2) ;
  7309. LONGCAR = MINI (PROG LONGCAR1 LONGCAR2) ;
  7310. SINON ;
  7311. LONGCAR = MINI (PROG LONGCAR1 LONGCAR2 LONGCAR3) ;
  7312. FINSI ;
  7313. *
  7314. AMPLI0 = LONGCAR / (MAXI VECNORM) / 3.;
  7315. *AM* AMPLI0 = LONGCAR / (MAXI VECNORM) ;
  7316. *AM* AMPLI0 = 2. * LONGCAR / (MAXI VECNORM) ;
  7317. FINSI ;
  7318. *
  7319. SI ((VALEUR DIME) EGA 2) ;
  7320. CHV1 = @ET (NOMC UX XV) (NOMC UY YV) ;
  7321.  
  7322.  
  7323. *CAST94* CHV1 = (NOMC UX XV) ET (NOMC UY YV) ;
  7324. VECT1 = VECT CHV1 AMPLI0 UX UY COUL0 ;
  7325. SINON ;
  7326. CHV1 = @ET (@ET (NOMC UX XV) (NOMC UY YV)) (NOMC UZ ZV) ;
  7327. *CAST94* CHV1 = (NOMC UX XV) ET (NOMC UY YV) ET (NOMC UZ ZV) ;
  7328. VECT1 = VECT CHV1 AMPLI0 UX UY UZ COUL0 ;
  7329. FINSI ;
  7330. FINPROC VECT1 ;
  7331.  
  7332. **** ARBRE derniere modif 16/04/91
  7333. DEBPROC ARBRE MAILSEG*MAILLAGE IMEN*ENTIER;
  7334. * determination du maillage des aretes de la surface de separation
  7335. * en seg2 sera a changer si p2 au lieu de p1
  7336. * HDL CHPOINT VIDE SUR DFCAN EN ENTREE
  7337. MAILSEG = MAILSEG COUL BLAN ;
  7338. NPB= MAILSEG NBNO ;
  7339. IP= 0;
  7340. MESS ' ************************** ' ;
  7341. * TEMPS ;
  7342. MESS ' ************************** ' ;
  7343. MESS ' NBRE DE POINTS DE LA SURFACE DE SEPARATION ' NPB;
  7344. MESS ' NBRE D ELEMENTS DE LA SURFACE DE SEPARATION ' (MAILSEG NBEL);
  7345. IPASS= 0;IMA= 0 ;
  7346. REPETER BOUC1 ;
  7347. IPASS= IPASS + 1;IMA= IMA + 1 ;
  7348. ALBERT= MAILSEG ELEM BLAN ;
  7349. ITUR= 0;
  7350. REPETER BOUCON ;
  7351. ITUR= ITUR + 1 ;
  7352. P1= ALBERT POINT ITUR;
  7353. SEGBL= ALBERT ELEM 'APPUYE' LARGEMENT P1 ;NBL= SEGBL NBEL ;
  7354. SEGPT= MAILSEG ELEM 'APPUYE' LARGEMENT P1 ;NBT= SEGPT NBEL ;
  7355. SI (( NBL < NBT) OU ('EGA' IPASS 1)) ; QUITTER BOUCON ;FINSI ;
  7356. FIN BOUCON ;
  7357. SI (IPASS > 1);
  7358. * TRAC OEIL ((SEGBL COUL ROUG)
  7359. * ET (MAILSEG ELEM BLAN) ET (MAILSEG ELEM VERT)) NOEUDS;
  7360. FINSI ;
  7361. IBL= 0 ;
  7362. * on ordonne les segments connectes a P1 sens P1 PN
  7363. REPETER BOUC0 NBL ;
  7364. IBL= IBL + 1 ;
  7365. SSS= SEGBL ELEM IBL ; 1P= SSS POINT INITIAL ;2P= SSS POINT FINAL ;
  7366. SI ( 1P NEG P1 ) ; SSS= (INVE SSS) ; FINSI ;
  7367. SI (IBL EGA 1 ) ; SSI= SSS;SINON ;
  7368. SSI = SSI ET SSS ; FINSI ;
  7369. 2P= SSS POINT FINAL ;
  7370. FIN BOUC0 ;
  7371. SEGBL= SSI ;
  7372.  
  7373. * SI NBL > 1 ON VA ELIMINER LES DOUBLES DE SEGBL
  7374.  
  7375. IA=0 ;
  7376. SI ( NBL EGA 1 );SEG1= (SEGBL ELEM 1 ) COUL VERT ;
  7377. 2P= SEG1 POINT FINAL ;
  7378. MAILSEG= ( DIFF MAILSEG SEG1 ) ET SEG1 ;
  7379. FINSI ;
  7380. SI ( NBL > 1 ) ;
  7381. REPETER BOUC2 (NBL - 1 );
  7382. IA= IA + 1 ;
  7383. SEG1 = ( SEGBL ELEM IA ) COUL VERT ;
  7384. PP1= SEG1 POINT FINAL ;
  7385. I3= IA + 1 ;
  7386. REPETER BOUC3 ;
  7387. SI ( I3 > NBL ) QUITTER BOUC3 ; FINSI ;
  7388. SEG2 = SEGBL ELEM I3 ;
  7389. PP2=SEG2 POINT FINAL;
  7390. SI ( PP1 EGA PP2 ) ;
  7391. MAILSEG= (DIFF MAILSEG SEG2 );
  7392. * MESS ' ELIMINATION DU NO ' I3 ;
  7393. FINSI ;
  7394. I3= I3 + 1;
  7395. FIN BOUC3 ;
  7396. MAILSEG = ( DIFF MAILSEG SEG1 ) ET SEG1;
  7397. FIN BOUC2 ;
  7398. FINSI ;
  7399. N1= (MAILSEG ELEM VERT) NBEL ;N2= MAILSEG NBEL ;
  7400. * TRAC OEIL MAILSEG ;
  7401. SI ( N1 EGA N2 ) ; QUITTER BOUC1 ; FINSI ;
  7402. SI ( EGA IMA IMEN) ; MENAGE ;IMA = 0 ; FINSI ;
  7403. FIN BOUC1 ;
  7404. SAUTER 2 LIGNES ;
  7405. MESS ' NB D ARETES AYANT SERVI A L INTEGRATION ' N2 ;
  7406. MESS ' ************************** ' ;
  7407. *TEMPS ;
  7408. MAILSEG= MAILSEG ELEM VERT ;
  7409. * HDL= IN_MINI (MAILSEG ELEM VERT ) TABHS ORIG B_ANTI ;
  7410. FINPROC MAILSEG;
  7411. **** FL_HS derniere modif 16/04/91
  7412. DEBPROC FL_HS DFCANT*MAILLAGE TABHS*TABLE TYEL*MOT OBJV*MMODEL;
  7413. * chamelem des projections de hs sur les normales des elements
  7414. * au cdg
  7415. HPX=REDU (TABHS.1) DFCANT ;
  7416. HPY=REDU (TABHS.2) DFCANT ;
  7417. HPZ=REDU (TABHS.3) DFCANT ;
  7418. IP= 0;
  7419. OB1= DFCANT AFFECT (MODELE STANDARD ) TYEL ;
  7420. NBP= DFCANT NBNO ;
  7421. FLHS= MANU CHPO DFCANT 1 'Q' ( PROG NBP * 0. );
  7422. * calcul des moyennes sur l element
  7423. HSXM = PRCH HPX OB1 'GRAVITE' ;
  7424. HSYM = PRCH HPY OB1 'GRAVITE' ;
  7425. HSZM = PRCH HPZ OB1 'GRAVITE' ;
  7426. HNMP = MANU CHAM OB1 'GRAVITE' SCAL 0. ;
  7427. BBNEL= DFCANT NBEL ;
  7428. *
  7429. IP= 0 ;
  7430. IMENA= 0 ;
  7431. REPETER BOUCEL BBNEL ;
  7432. IMENA= IMENA + 1 ;
  7433. IP=IP + 1 ; TOTO= DFCANT ELEM IP ; ITOT= CHAN POI1 TOTO ;
  7434. T1= ITOT POINT 1 ;T2= ITOT POINT 2 ; T3= ITOT POINT 3 ;
  7435. * normale a l element
  7436. V1= T2 MOINS T1 ; V2= T3 MOINS T1 ; NNN= V1 PVECT V2 ;
  7437. NNNR= NNN / (NORM NNN) ;
  7438. CVX= COOR 1 NNNR ;CVY= COOR 2 NNNR ; CVZ= COOR 3 NNNR ;
  7439. HSXE= EXTR HSXM SCAL 1 IP 1 ;
  7440. HSYE= EXTR HSYM SCAL 1 IP 1 ;
  7441. HSZE= EXTR HSZM SCAL 1 IP 1 ;
  7442. VPROJ = (HSXE * CVX ) + (HSYE * CVY ) + (HSZE * CVZ) ;
  7443. FLHS1= FLHS + ( FLUX OBJV VPROJ TOTO ) ;
  7444. DETR FLHS ;FLHS = FLHS1 ;DETR TOTO ;DETR ITOT;
  7445. SI ( EGA IMENA 50 ) ; MESS ' menage ';
  7446. MENAGE ; IMENA= 0 ; FINSI ;
  7447. FIN BOUCEL ;
  7448. FINPROC FLHS ;
  7449. **** IN_MINI derniere modif 16/04/91
  7450. 'DEBPROC' IN_MINI FCAN*'MAILLAGE' TABHS*TABLE ORIG*POINT B_ANTI*MAILLAGE ;
  7451. * integration de v par minimisation fonctionnelle
  7452. * en entree maillage frontiere cote phi et hs sur ce maiilage
  7453. * en sortie V(b)= phi(b)-psi(b) chpoint sur fcan
  7454. * avec psi(p1) = phi(p1)
  7455. HX=TABHS.1;HY=TABHS.2;HZ=TABHS.3;
  7456. nbi = nbno ( fcan elem 1 ) ;
  7457. I= 0 ;
  7458. MESS ' SEPARATION ' (FCAN NBNO) 'POINTS' (FCAN NBEL) 'ELEM ';
  7459. REPE BLOCALC (NBEL FCAN);
  7460. I= I + 1 ;
  7461. SEGCOU = FCAN ELEM I;
  7462. P1 = SEGCOU POIN 1;
  7463. P2 = SEGCOU POIN 2;
  7464. HX1 = EXTR HX SCAL P1 ; HX2 = EXTR HX SCAL P2 ;
  7465. HY1 = EXTR HY SCAL P1 ; HY2 = EXTR HY SCAL P2 ;
  7466. HZ1 = EXTR HZ SCAL P1 ; HZ2 = EXTR HZ SCAL P2 ;
  7467. HMOY =(( HX1 + HX2) / 2.) ( ( HY1 + HY2) / 2.) ((HZ1 + HZ2) / 2.);
  7468. * si ( ega nbi 3 ) ;
  7469. * p3= segcou point 3 ;
  7470. * hmx= extr hx scal p3 ;
  7471. * hmy= extr hy scal p3 ;
  7472. * hmz= extr hz scal p3 ;
  7473. * hmil= ( hmx hmy hmz ) * 4. ;
  7474. * hmoy =( hmoy / 3. ) + ( hmil / 6. )
  7475. * finsi ;
  7476. VL= P2 MOINS P1 ;DL= NORM VL ;VL=VL / DL ;
  7477. DV = (VL PSCAL HMOY ) ;DVI= DV * -1.;
  7478. TI= 1. / DL ;IT= -1. * TI ;
  7479. RIGEL= MANU RIGIDITE SEGCOU (MOTS T ) (PROG TI IT TI) ;
  7480. HH= MANU CHPO SEGCOU 1 'Q' (PROG DVI DV );
  7481. SI (EGA I 1);
  7482. RIGT = RIGEL ;
  7483. HTH = HH ;
  7484. SINON ;
  7485. RIGT1= RIGT ET RIGEL;
  7486. HTH1= HTH ET HH ;
  7487. DETR RIGT;RIGT= RIGT1 ; DETR HTH ;HTH= HTH1 ;
  7488. DETR HH; DETR RIGEL ;
  7489. FINSI ;
  7490. FIN BLOCALC ;
  7491. TITI = RELA 'ENSE' T B_ANTI ;
  7492. TUTU= BLOQUE ORIG T;
  7493. HHHH= RESOU (RIGT ET TUTU ET TITI ) HTH ;
  7494. HHHH= (ENLEVER HHHH LX ) NOMC 'SCAL';
  7495. FINPROC HHHH ;
  7496. **** ARBRE_IN derniere modif 16/04/91
  7497. DEBPROC ARBRE_IN DFCAN*MAILLAGE TABHS*TABLE ORIG*POINT ;
  7498. * CALCUL DE L ARBORESCENCE ET INTEGRATION DE HS.DL
  7499. * cette methode amene des differences suivant le chemin choisi
  7500. * il vaut mieux utiliser l autre ( minimisation)
  7501. * DFCAN SURFACE DE SEPARATION
  7502. * HDL CHPOINT VIDE SUR DFCAN EN ENTREE
  7503. NPB= DFCAN NBNO ;
  7504. HDL= MANU CHPO DFCAN 1 SCAL ( PROG NPB * 0.) ;
  7505.  
  7506. DFCAN= DFCAN COUL BLAN ;
  7507. DFCAN1 = DFCAN ELEM QUA4 ;NELSURF1= DFCAN1 NBEL;
  7508. DFCAN2 = DFCAN ELEM TRI3 ; NELSURF2= DFCAN2 NBEL;
  7509. MAILSEG= CONT ( DFCAN1 ELEM 1 );
  7510. I= 1 ;
  7511. REPE BOUCSEG1 ( NELSURF1 - 1 );
  7512. I = I + 1;
  7513. MAILSEG = MAILSEG ET (CONT (DFCAN1 ELEM I));
  7514. FIN BOUCSEG1;
  7515. I= 0 ;
  7516. REPE BOUCSEG2 NELSURF2;
  7517. I = I + 1;
  7518. MAILSEG = MAILSEG ET (CONT (DFCAN2 ELEM I));
  7519. FIN BOUCSEG2;
  7520.  
  7521. NPB= MAILSEG NBNO ;
  7522. IP= 0;
  7523. MESS ' ************************** ' ;
  7524. *TEMPS ;
  7525. MESS ' ************************** ' ;
  7526. MESS ' NBRE DE POINTS DE LA SURFACE DE SEPARATION ' NPB;
  7527. MESS ' NBRE D ELEMENTS DE LA SURFACE DE SEPARATION ' (MAILSEG NBEL);
  7528. IPASS= 0;
  7529. REPETER BOUC1 ;
  7530. IPASS= IPASS + 1;
  7531. ALBERT= MAILSEG ELEM BLAN ;
  7532. ITUR= 0;
  7533. REPETER BOUCON ;
  7534. ITUR= ITUR + 1 ;
  7535. P1= ALBERT POINT ITUR;
  7536. SEGBL= ALBERT ELEM 'APPUYE' LARGEMENT P1 ;NBL= SEGBL NBEL ;
  7537. SEGPT= MAILSEG ELEM 'APPUYE' LARGEMENT P1 ;NBT= SEGPT NBEL ;
  7538. SI (( NBL < NBT) OU ('EGA' IPASS 1)) ; QUITTER BOUCON ;FINSI ;
  7539. FIN BOUCON ;
  7540. DETR ALBERT ; DETR SEGPT ;
  7541. SI (IPASS > 1);
  7542. * TRAC OEIL ((SEGBL COUL ROUG)
  7543. * ET (MAILSEG ELEM BLAN) ET (MAILSEG ELEM VERT)) NOEUDS;
  7544. FINSI ;
  7545. IBL= 0 ;
  7546. * on ordonne les segments connectes a P1 sens P1 PN
  7547. REPETER BOUC0 NBL ;
  7548. IBL= IBL + 1 ;
  7549. SSS= SEGBL ELEM IBL ; 1P= SSS POINT INITIAL ;2P= SSS POINT FINAL ;
  7550. SI ( 1P NEG P1 ) ; SSS= (INVE SSS) ; FINSI ;
  7551. SI (IBL EGA 1 ) ; SSI= SSS;SINON ;
  7552. SSI1 = SSI ET SSS ;DETR SSI ; SSI = SSI1 ;
  7553. FINSI ;
  7554. 2P= SSS POINT FINAL ;DETR SSS ;
  7555. FIN BOUC0 ;
  7556. SEGBL= SSI ;
  7557.  
  7558. * SI NBL > 1 ON VA ELIMINER LES DOUBLES DE SEGBL
  7559.  
  7560. IA=0 ;
  7561. SI ( NBL EGA 1 );SEG1= (SEGBL ELEM 1 ) COUL VERT ;
  7562. 2P= SEG1 POINT FINAL ;
  7563. VV= EXTR HDL SCAL 2P ;
  7564. SI (( EGA VV 0.) ET (2P NEG ORIG));
  7565. HDL=INT_BIOT HDL P1 2P ORIG TABHS ;
  7566. FINSI ;
  7567. MAILSEG= ( DIFF MAILSEG SEG1 ) ET SEG1 ;
  7568. FINSI ;
  7569. SI ( NBL > 1 ) ;
  7570. REPETER BOUC2 (NBL - 1 );
  7571. IA= IA + 1 ;
  7572. SEG1 = ( SEGBL ELEM IA ) COUL VERT ;
  7573. PP1= SEG1 POINT FINAL ;
  7574. VV= EXTR HDL SCAL PP1 ;
  7575. SI ((EGA VV 0.) ET (PP1 NEG ORIG));
  7576. HDL=INT_BIOT HDL P1 PP1 ORIG TABHS ;
  7577. FINSI ;
  7578. I3= IA + 1 ;
  7579. REPETER BOUC3 ;
  7580. SI ( I3 > NBL ) QUITTER BOUC3 ; FINSI ;
  7581. SEG2 = SEGBL ELEM I3 ;
  7582. PP2=SEG2 POINT FINAL;
  7583. SI ( PP1 EGA PP2 ) ;
  7584. MAILSEG1= (DIFF MAILSEG SEG2 );DETR MAILSEG ;MAILSEG= MAILSEG1 ;
  7585. * MESS ' ELIMINATION DU NO ' I3 ;
  7586. FINSI ;
  7587. *tc mise en commentaire du finsi ci dessous
  7588. * FINSI;
  7589. I3= I3 + 1;
  7590. FIN BOUC3 ;
  7591. MAILSEG1 = ( DIFF MAILSEG SEG1 ) ET SEG1;
  7592. DETR MAILSEG ; MAILSEG= MAILSE1 ;
  7593. FIN BOUC2 ;
  7594. FINSI ;
  7595. N1= (MAILSEG ELEM VERT) NBEL ;N2= MAILSEG NBEL ;
  7596. * TRAC OEIL MAILSEG ;
  7597. SI ( N1 EGA N2 ) ; QUITTER BOUC1 ; FINSI ;
  7598. FIN BOUC1 ;
  7599. DETR SEGBL ;
  7600. SAUTER 2 LIGNES ;
  7601. MESS ' NB D ARETES AYANT SERVI A L INTEGRATION ' N2 ;
  7602. MESS ' ************************** ' ;
  7603. *TEMPS ;
  7604. MESS ' ************************** ' ;
  7605. * sortie hdl chpoint de V
  7606. FINPROC HDL ;
  7607. **** INT_BIOT derniere modif 16/04/91
  7608. DEBPROC INT_BIOT HDL*CHPOINT 1P*POINT 2P*POINT ORIG*POINT TABHS*TABLE ;
  7609. * integration de ht.dl sur le long des aretes sur la surface de
  7610. * separation
  7611. HSX= TABHS.1 ;HSY=TABHS.2;HSZ= TABHS.3 ;
  7612. * HDL EST LE STOCKAGE DU RESULTAT
  7613. * integrale sur le segment
  7614. XHS1= EXTR HSX SCAL 1P;YHS1= EXTR HSY SCAL 1P; ZHS1= EXTR HSZ SCAL 1P;
  7615. XHS2= EXTR HSX SCAL 2P;YHS2= EXTR HSY SCAL 2P; ZHS2= EXTR HSZ SCAL 2P;
  7616. XHM= (XHS1 + XHS2 ) / 2.;
  7617. YHM= (YHS1 + YHS2 ) / 2.;
  7618. ZHM= (ZHS1 + ZHS2 ) / 2.;
  7619. DL= 2P MOINS 1P ;
  7620. INTSEG=(XHM * (COOR 1 DL)) + (YHM * (COOR 2 DL)) +(ZHM * (COOR 3 DL));
  7621. VAL = EXTR HDL SCAL 1P ;
  7622. VINT = VAL + INTSEG ;
  7623. *LIST (1P ET 2P);
  7624. *MESS 'VAL1P INTSEG VINT2P ' VAL INTSEG VINT ;
  7625. * le cas ou 2p est ORIG a ete exclu a l exterieur
  7626. HDL= HDL + ( MANU CHPO 2P 1 SCAL VINT ) ;
  7627. FINPROC HDL;
  7628. **** SAUT_POT derniere modif 16/04/91
  7629. DEBPROC SAUT_POT FCAN*MAILLAGE FFER*MAILLAGE LLLL*CHPOINT ORIG*POINT ;
  7630. * calcul du saut de potentiel
  7631. ***************************************************************
  7632. * relations entre points homologues de la separation
  7633. * orig est le point ou psi=phi=0.
  7634. * attention a la coherence avec la condition limite
  7635. ***************************************************************
  7636. NNN= FCAN NBNO;
  7637. IK= 0 ;ILO= 0 ;
  7638. REPETER BLOC1 NNN;
  7639. IK= IK + 1 ;
  7640. IP=FCAN POINT IK ;IQ= FFER POINT PROCHE IP ;
  7641. SI (NEG IP ORIG) ;
  7642. RELP= RELA 1. T IP - 1. T IQ ;
  7643. DEPIP= DEPIMP RELP (EXTR LLLL SCAL IP);
  7644. SI (EGA ILO 0 ) ;
  7645. REL1=RELP; FDEPI= DEPIP ;
  7646. ILO= 1 ;
  7647. SINON ;
  7648. REL2= REL1 ET RELP ;
  7649. FDEPI2= FDEPI ET DEPIP ;
  7650. DETR REL1 ; REL1= REL2 ; DETR FDEPI ; FDEPI= FDEPI2 ;
  7651. DETR RELP ;DETR DEPIP ;
  7652. FINSI;
  7653. FINSI;
  7654. FIN BLOC1 ;
  7655. FINPROC REL1 FDEPI;
  7656. **** B_ARETES derniere modif 16/04/91
  7657. DEBPROC B_ARETES SEP_PHI*MAILLAGE ;
  7658. * reduit un maillage surfacique p1 a ses aretes
  7659. * en conservant les doubles
  7660. NBU= SEP_PHI NBEL ;
  7661. DFCAN1 = SEP_PHI ELEM QUA4 ;NBQU= DFCAN1 NBEL ;
  7662. MAILSEG= CONT ( DFCAN1 ELEM 1 );
  7663.  
  7664. SI (NEG NBU NBQU);
  7665. DFCAN2 = SEP_PHI ELEM TRI3 ; NTRI= DFCAN2 NBEL;
  7666. I= 0 ;
  7667. REPE BOUCSEGT NTRI;
  7668. I = I + 1;
  7669. MAILSEG = MAILSEG ET (CONT (DFCAN2 ELEM I));
  7670. FIN BOUCSEGT;
  7671. FINSI ;
  7672. I= 1 ;
  7673. REPE BOUCSEGQ (NBQU - 1 );
  7674. I = I + 1;
  7675. MAILSEG = MAILSEG ET (CONT (DFCAN1 ELEM I));
  7676. FIN BOUCSEGQ;
  7677. TITRE 'MAILSEG ' (MAILSEG NBEL );
  7678. * TRAC OEIL MAILSEG QUAL ;
  7679. FINPROC MAILSEG ;
  7680.  
  7681. *
  7682. **** LIRBIOT derniere modif 16/04/91
  7683. DEBPROC LIRBIOT SEP_PHI*MAILLAGE MU0*FLOTTANT ;
  7684. ***************************************************************
  7685. * RECUP BIOT ET SAVART SUR FRONTIERE
  7686. * genere en exterieur la surface frontiere a ete sortie pas sort
  7687. * noopt precedement et a servi a calculer hs
  7688. * on recupere le tout coordonnees et hs et on elmine pour etre sur
  7689. * du support (ordre )
  7690. ***************************************************************
  7691. NFN=SEP_PHI NBNO ;
  7692. IMET= 2 ;
  7693. SI ( EGA IMET 1);
  7694. OPTION ACQUERIR 9 ;
  7695.  
  7696. ACQUERIR HX*LISTREEL NFN HY*LISTREEL NFN HZ*LISTREEL NFN ;
  7697. HS= MANU CHPO SEP_PHI 3 'HX' HX 'HY' HY 'HZ' HZ ;
  7698. SINON ;
  7699.  
  7700. * AUTRE FACON A ESSAYER
  7701. *
  7702. PPRO= PROG NFN * 0 ;
  7703. HS= MANU CHPO SEP_PHI 3 'HX' PPRO 'HY' PPRO 'HZ' PPRO ;
  7704. OPTION ACQUERIR 8 ;
  7705. IP= 0;
  7706. REPETER BOUCA NFN ;
  7707. ACQUERIR X*FLOTTANT Y*FLOTTANT Z*FLOTTANT HX*FLOTTANT HY*FLOTTANT HZ*FLOTTANT ;
  7708. * X= EXTR VALP 1 ;Y= EXTR VALP 2 ; Z= EXTR VALP 3;
  7709. * HX= EXTR VALP 4 ;HY= EXTR VALP 5 ; HZ= EXTR VALP 6;
  7710. P1= X Y Z ; PT= SEP_PHI POINT PROCHE P1 ;
  7711. HP= MANU CHPO PT 3 'HX' HX 'HY' HY 'HZ' HZ ;
  7712. HS2 = HS + HP ; DETR HS ; HS= HS2 ;
  7713. *tc mise en commentaire du finsi cidessous
  7714. * FINSI ;
  7715. *
  7716. FIN BOUCA;
  7717. FINSI;
  7718. * provisoire chambob donne B on divise par mu0
  7719. HS= HS / MU0 ;
  7720. * ELIM .1 SEP_PHI PT ;
  7721. FINPROC HS ;
  7722. **** FOR_CONT derniere modif 16/04/91
  7723. DEBPROC FOR_CONT CCONT*MAILLAGE SOL1*CHPOINT COURI*FLOTTANT;
  7724. * calcul des forces par integrale de contour
  7725. OBSEG = CCONT AFFECT ( MODELE STANDARD ) SEG2 ;
  7726. AA = PRCH OBSEG SOL1 'GRAVITE';
  7727. NBSEG = CCONT NBEL ;
  7728. IEL = 0 ;SOMX = 0. ; SOMY = 0. ;SMM = 0. ;
  7729. *
  7730. REPETER BOUC NBSEG ;
  7731. IEL = IEL + 1 ; SEGC= CCONT ELEM IEL ;
  7732. I1 = SEGC POINT INITIAL ; I2 = SEGC POINT FINAL ;
  7733. X1 = COOR 1 I1 ; X2 = COOR 1 I2 ; RX = ( X1 + X2) / 2. ;
  7734. Y1 = COOR 2 I1 ; Y2 = COOR 2 I2 ; RY = ( Y1 + Y2) / 2. ;
  7735. DX = X2 - X1 ; DY = Y2 - Y1 ;
  7736. AME = EXTR AA 'SCAL' 1 IEL 1 ;
  7737. SOMX = SOMX + ( AME * DX) ;
  7738. SOMY = SOMY + ( AME * DY) ;
  7739. MOMM = (RX * DX) + (RY * DY ) ;
  7740. SMM= SMM + ( AME * MOMM ) ;
  7741. FIN BOUC ;
  7742. *
  7743. FXX = COURI * SOMY ; FYY = -1. * COURI * SOMX ;
  7744. MOMT = -1. * COURI * SMM ;
  7745. CDG1 = BARY CCONT ;
  7746. RFORC = MANU CHPO CDG1 2 'FX' FXX 'FY' FYY ;
  7747. FINPROC RFORC SMM ;
  7748. **** FORBLOC derniere modif 16/04/91
  7749. DEBPROC FORBLOC BLOC*MAILLAGE BX*CHAMELEM BY*CHAMELEM OBJO*MMODEL COUR*FLOTTANT ;
  7750. * bobi maillage non complexe
  7751. * bb champ induction AUX CDG du maillage reduit
  7752. * integration de j vectoriel b sur les elements resultats aux cdg
  7753. * sort un champ par points aux cdgs dans rfor
  7754. * sort un champ par point aux noeuds dans rpt
  7755. NNN= BLOC NBEL ;
  7756. IP= 0 ;IPAS= 0 ;
  7757. REPETER BOUE NNN ;
  7758. IPAS= IPAS + 1 ;
  7759. IP = IP + 1 ; IEL =BLOC ELEM IP ;CDG= BARY IEL ;
  7760. EL_SUR= MAXI (RESU (SOURCE OBJ0 COUR IEL ));
  7761. FEX= (EXTR BY 'SCAL' 1 IP 1 ) * EL_SUR;FEX= FEX * -1. ;
  7762. FEY= (EXTR BX 'SCAL' 1 IP 1 ) * EL_SUR;
  7763. R_F= MANU CHPO CDG 2 'FX' FEX 'FY' FEY ;
  7764. NNI = IEL NBNO ;
  7765. RFXP= MANU CHPO IEL 1 'FX' ( PROG NNI * ( FEX / NNI )) ;
  7766. RFYP= MANU CHPO IEL 1 'FY' ( PROG NNI * ( FEY / NNI )) ;
  7767. SI ( EGA IP 1) ;RFOR = R_F ;RPX = RFXP ;RPY=RFYP ;
  7768. SINON ;
  7769. RFOR = RFOR + R_F ;RPX= RPX + RFXP ; RPY= RPY + RFYP ;
  7770. FINSI ;
  7771. * SI ( EGA IPAS 10 ) ;MESS 'menage';MENAGE ; IPAS = 0 ; FINSI ;
  7772. RPT= RPX + RPY ;
  7773. FIN BOUE ;
  7774. *
  7775. FINPROC RFOR RPT ;
  7776. **** INDUCTIO derniere modif fevrier/92
  7777. ******************************************************************
  7778. DEBPROC INDUCTIO GEO*MAILLAGE SOL1*CHPOINT AXI*LOGIQUE ;
  7779. ****************************************************************
  7780. * 2D UNIQUEMENT
  7781. * calcul; de l induction en potentiel vecteur *
  7782. * GEO maillage sur lequel on recherche B *
  7783. * SOL1 solution en potentiel vecteur *
  7784. * AXI logique vrai si axi *
  7785. ****************************************************************
  7786. OBJ0 = GEO MODE THERMIQUE ISOTROPE ;
  7787. GRA_ELR = GRAD OBJ0 SOL1 ;
  7788. DERIV = CHAN CHPO GRA_ELR OBJ0 ;
  7789. SI ( AXI ) ;
  7790. IMET = 2 ;
  7791. SI ( EGA IMET 1 ) ;
  7792. mess '* methode 1';
  7793. 1SRAY = MUAXI2 GEO 1. 1 ;
  7794. FINSI ;
  7795. SI ( EGA IMET 2 ) ;
  7796. 1SRAY = MUAXI2 GEO 1. 2 ;
  7797. FINSI ;
  7798. mess '* axisymetrique methode 'imet ;
  7799. BX = ((EXCO DERIV 'T,Y') * 1SRAY * -1. ) NOMC 'BX' ;
  7800. BY = ((EXCO DERIV 'T,X' ) * 1SRAY ) NOMC 'BY' ;
  7801. SINON ;
  7802. mess '* probleme plan ';
  7803. BX = (EXCO DERIV 'T,Y') NOMC 'BX' ;
  7804. BY = (( EXCO DERIV 'T,X' )* -1.) NOMC 'BY' ;
  7805. FINSI ;
  7806. BTOT = BX + BY ;
  7807. FINPROC BTOT ;
  7808. **** POT_VECT derniere modif 1/03/92
  7809. DEBPROC POT_VECT MATAB*TABLE SOLIN/MOT ;
  7810. ********************************************************************
  7811. * MAGETOSTATIQUE 2D EN POTENTIEL VECTEUR *
  7812. ********************************************************************
  7813. * MATAB TABLE D ENTREE CONTENANT
  7814. * MATAB.'MU0' PERMEABILITE DE L AIR (PAR DEFAUT UNITE METRE *
  7815. * MATAB.'MUREL' MU RELATIF DEPART 2900 PAR DEFAUT *
  7816. * MATAB.'AIR' PARTIE AIR NON REDUITE A UN SUPER ELEMENT *
  7817. * MATAB.'FER' FER *
  7818. * MATAB.'MAITRES' POINT MAITRES SI SUPER ELEMENT *
  7819. * MATAB.'AIRSUP' PARTIE AIR TRAITEE EN SUPER (NON OBLIGATOIRE)*
  7820. * MATAB.'ENCS ' LIMITE A A NULL SUR LE SUPER ELEMENT (MAILL) *
  7821. * MATAB.'BLOCAGE' LIMITE A A NULL SUR LA ZONE STANDARD( MAILL) *
  7822. * MATAB.'COUR' TABLE DE TABLES CONTENANT LA DESCRIPTION DES *
  7823. * BLOCS DE COURANTS CONSTITUEE PAR UN OU DES *
  7824. * APPEL(S) A LA PROCEDURE DESCOUR *
  7825. * MATAB.'AXI' = VRAI SI PROBLEME AXISYMETRIQUE *
  7826. * SOLIN MOT OPTIONNNEL POUR LE CALCUL DU PREMIER PAS LINEAIRE*
  7827. ********************************************************************
  7828. * EN SORTIE MATAB CONTIENT LES OBJETS NECESSAIRES *
  7829. * AU CALCUL NON LINEAIRE *
  7830. * ET LA SOLUION DU PREMIER PAS SI DEMANDEE DS MATAB.'POTENTIEL *
  7831. ********************************************************************
  7832. AXI= FAUX ;
  7833. SI ( EXISTE MATAB 'AXI' ); AXI = MATAB.'AXI' ; FINSI ;
  7834. MUAIR = 4 * PI * 1.E-7 ;
  7835. SI ( EXISTE MATAB 'MU0') ;MUAIR = MATAB.'MU0' ;FINSI ;
  7836. SI ( EXISTE MATAB 'MUREL' ) ;
  7837. MUFER = MUAIR * (MATAB.'MUREL') ;
  7838. SINON ; MUFER = MUAIR * 2900 ;
  7839. FINSI ;
  7840. MATAB.'MUAIR'= MUAIR ;
  7841. AIR = MATAB.'AIR' ;
  7842. FER = MATAB.'FER' ;
  7843. OBJ1=MODE AIR THERMIQUE ISOTROPE ;
  7844. OBJ2=MODE FER THERMIQUE ISOTROPE ;
  7845. SI ( AXI ) ;
  7846. MAT1= MUAXI2 AIR MUAIR 1;
  7847. MAT2= MUAXI2 FER MUFER 1;
  7848. SINON ;
  7849. * rectification conductibilites
  7850. MAT1= MATE OBJ1 'K' ( 1. / MUAIR ) ;
  7851. MAT2= MATE OBJ2 'K' ( 1. / MUFER ) ;
  7852. FINSI ;
  7853. SI ( EXISTE MATAB 'AIRSUP') ;
  7854. AIRSUP = MATAB.'AIRSUP' ;
  7855. OBJ3=MODE AIRSUP THERMIQUE ISOTROPE ;
  7856. SI ( AXI ) ;
  7857. MAT3 = MUAXI2 AIRSUP MUAIR 1 ;
  7858. SINON;
  7859. MAT3= MATE OBJ3 'K' ( 1. / MUAIR ) ;
  7860. FINSI ;
  7861. SI ( EXISTE MATAB 'ENCS' );
  7862. RIGB= (CONDUC OBJ3 MAT3 ) ET ( BLOQUER (MATAB.'ENCS' ) T ) ;
  7863. SFAC = MATAB.'MAITRES';
  7864. SUP1 = SUPER 'RIGIDITE' RIGB SFAC ;
  7865. MATAB.'SUPER' = SUP1 ;
  7866. FINSI ;
  7867. FINSI ;
  7868. RIGA= CONDUC OBJ1 MAT1 ;
  7869. RIGF= CONDUC OBJ2 MAT2 ;
  7870. *
  7871. SI ( EXISTE MATAB 'MAITRES') ;
  7872. RIGCON= RIGA ET ( EXTRAI SUP1 'RIGI' );
  7873. SINON ;
  7874. RIGCON = RIGA ;
  7875. FINSI ;
  7876. * charge
  7877. TABCOUR = TABLE ;
  7878. TABCOUR = MATAB.'COUR';
  7879. III = INDEX TABCOUR ;
  7880. IZ= 'ENTIER' 0 ;
  7881.  
  7882. REPETER BOUC ;
  7883. IZ= IZ + 1 ;
  7884. SI ( 'NON' ('EXISTE' III IZ )) ;QUITTER BOUC ; FINSI ;
  7885. STN = TABCOUR.IZ ;GEO = STN.'GEO' ;
  7886. FEIZ = SOURCE OBJ1 1. GEO ;
  7887. SSS = EXTR (RESU FEIZ) 'Q' (( EXTR FEIZ MAIL ) POINT 1);
  7888. *
  7889. SI ( EXISTE STN 'AMP' ) ;
  7890. J = STN.'AMP' ;
  7891. STN.'AT' = SSS * J ;
  7892. SINON ;
  7893. SDO = STN.'AT' ;
  7894. J = SDO / SSS ;
  7895. STN.'AMP'= J ;
  7896. FINSI ;
  7897. *
  7898. FEIZ = FEIZ * J ;
  7899. *
  7900. MESS ' BLOC ' IZ ' JAMP ' J ' NI' STN.'AT' ;
  7901. SI ( EGA IZ 1 ) ; FE = FEIZ ; SINON ;
  7902. FE = FE + FEIZ ;
  7903. FINSI ;
  7904. FIN BOUC ;
  7905.  
  7906. MATAB.'RHS'= FE ;
  7907.  
  7908. MATAB.'RIGCON'= RIGCON;
  7909. MATAB.'RIGFER'= RIGF;
  7910. SI ( EXISTE SOLIN ) ;
  7911. MESS ' *****************************************************';
  7912. MESS ' * CALCUL DE LA SOLUTION LINEAIRE *';
  7913. MESS ' *****************************************************';
  7914. SI ( EXISTE MATAB 'BLOCAGE' );
  7915. BBB = BLOQUER ( MATAB.'BLOCAGE') T ;
  7916. MATAB.'BLOCAGE'= BBB ;
  7917. SOL1= RESOU ( RIGF ET RIGCON ET BBB ) (MATAB.'RHS') ;
  7918. SINON ;
  7919. SOL1= RESOU ( RIGF ET RIGCON ) (MATAB.'RHS') ;
  7920. FINSI ;
  7921. MATAB.'POTENTIEL'= SOL1 ;
  7922. FINSI ;
  7923. *
  7924. FINPROC ;
  7925. **** DESCOUR derniere modif 16/04/91
  7926. DEBPROC DESCOUR TAB*TABLE I*ENTIER BLOCI*MAILLAGE MM*MOT J*FLOTTANT ;
  7927. *******************************************************************
  7928. * DESCRIPTION D UNE ZONE DE COURANTS *
  7929. * TAB TABLE QUI CONTIENDRA LE DESCIPTIF DE TOUTES LES *
  7930. * ZONES DE COURANTS *
  7931. * I NUMERO D ORDRE DE LA ZONE DE COURANT *
  7932. * BLOCI ZONE DE COURANT TYPE MAILLAGE *
  7933. * MM MOT 'AMP' OU 'AT' *
  7934. * J FLOTTANT DENSITE DE COURANT OU AMPERES TOURS *
  7935. *******************************************************************
  7936. STN= TABLE ;
  7937. STN.'GEO'= BLOCI ;
  7938. SI ( EGA MM 'AMP') ;
  7939. STN.'AMP' = J ;
  7940. SINON ;
  7941. STN.'AT' = J ;
  7942. FINSI ;
  7943. TAB.I= STN ;
  7944. FINPROC ;
  7945. **** MAG_NLIN derniere modif 16/04/91
  7946. 'DEBPROC' MAG_NLIN ETAB*'TABLE ' ;
  7947. *----------------------------------------------------------------------*
  7948. * *
  7949. * INSPIRE DE TRANSIT1 *
  7950. * POUR TENIR COMPTE DE PLUSIEURS MATERIAUX DONT UN NON LINEAIRE *
  7951. * POUR TRAITER PB MAGNETOSTATIQUE *
  7952. * --------------- *
  7953. * *
  7954. * RESOLUTION D'UN PROBLEME DE MAGNETOSTATIQUE NON-LINEAIRE *
  7955. * EN REGIME PERMANENT,A L'AIDE DE LA METHODE DU POINT FIXE *
  7956. * ETAB, TABLE CONTENANT EN ENTREE : *
  7957. * OBLIGATOIRE *
  7958. * INDICE 'SOUSTYPE' THERMIQUE *
  7959. * INDICE 'AXI ' LOGIQUE VRAI EN 2D SI AXISYM ( PLAN DEFAUT) *
  7960. * *
  7961. * INDICE 'EVOCOND' EVOLUTION DE Mu CREE PAR LA PROCEDURE H_B *
  7962. * QUI REND LA COURBE AD HOC POUR POT VECT OU POT SCALAIRE *
  7963. * OPTIONNEL *
  7964. * INDICE 'CRITERE' CRITERE DE CONVERGENCE *
  7965. * INDICE 'OME' COEFF AMORTISSEMENT OSCI 0< OME < 1. *
  7966. * (10E-5 PAR DEFAUT) *
  7967. * INDICE 'NITER' REACTUALISATION DE LA CONDUCTIVITE TOUTES *
  7968. * LES NITER ITERATIONS (NITER=1 PAR DEFAUT) *
  7969. * INDICE 'NIVEAU' NIVEAU DE MESSAGES (NIVEAU=0 PAR DEFAUT) *
  7970. * INDICE 'ITERMAX' NOMBRE D'ITERATIONS MAXIMUM *
  7971. * (ITERMAX=10 PAR DEFAUT) *
  7972. ************************************************************************
  7973. * arguments fabriques dans les passages soit ds pot_vect ou pot_scal *
  7974. * INDICE 'FLUX' FLUX EQUIVALENTS *
  7975. * INDICE 'BLOCAGE' MATRICE DE BLOCAGE (CREEE PAR "BLOQUE") *
  7976. * INDICE 'IMPOSE' VALEURS IMPOSEES (CREE PAR "DEPI") *
  7977. * INDICE 'RIGCON ' RAIDEUR CONSTANTE *
  7978. * INDICE 'RIGFER ' RAIDEUR VARIABLE *
  7979. * ETAB CONTENANT EN SORTIE : *
  7980. * *
  7981. * INDICE 'POTENTIEL' POTENTIEL RESULTAT *
  7982. * *
  7983. * D.R., LE 7 JUILLET 1988.VERSION DU 18 JANVIER 1989. *
  7984. * MODIFIE PAR BAZE MAI 90
  7985. *----------------------------------------------------------------------*
  7986. CONVERGE = FAUX ;ETAB.CONVERGE= FAUX ;
  7987. 'REPETER' PROC 1 ;
  7988. 'SI' ( 'NEG' ( ETAB.'SOUSTYPE' ) 'THERMIQUE' ) ;
  7989. 'MESS' 'SOUS TYPAGE INCORRECT DE LA TABLE EN ENTREE|' ;
  7990. 'QUITTER' PROC ;
  7991. 'FINSI' ;
  7992. 'SI' ( 'EXISTE' ETAB 'NIVEAU' ) ;
  7993. NIV_MESS = ETAB.'NIVEAU' ;
  7994. 'SINON' ;
  7995. NIV_MESS = 0 ;
  7996. 'FINSI' ;
  7997. 'SI' ( NIV_MESS '>EG' 1 ) ;
  7998. 'SAUTER' 1 'LIGNE' ;
  7999. 'MESS' '*** DEBUT DE LA PROCEDURE "MAG_NONLIN" ***' ;
  8000. 'FINSI' ;
  8001. *
  8002. *--- RECUPERATION DE L'INFORMATION CONTENUE DANS "ETAB"
  8003. *
  8004. 'SI' ('EXISTE' ETAB BLOCAGE );
  8005. MAT_BLO = ETAB.'BLOCAGE' ;
  8006. 'FINSI';
  8007. RIG_CON = ETAB.'RIGCON';
  8008. 'SI' ( 'EXISTE' ETAB 'IMPOSE' );
  8009. VAL_IMPO = ETAB.'IMPOSE' ;
  8010. 'FINSI' ;
  8011. * IL FAUT EXTRAIRE LE FER ;
  8012. FER = EXTRA ( ETAB.RIGFER ) MAIL;
  8013. AXI = FAUX ;
  8014. SI ( EXISTE ETAB 'AXI') ; AXI = ETAB.'AXI' ;FINSI ;
  8015. SI AXI ;
  8016. obmod = MODE FER THERMIQUE ISOTROPE ;
  8017. cp_rpoa = (coor 1 FER ) ;
  8018. ce_rpoa = CHAN 'CHAM' CP_RPOA OBMOD 'GRAVITE';
  8019. RFER = CHAN CHPO OBMOD (CHAN 'NOEUD' OBMOD ce_rpoa );
  8020. FINSI ;
  8021. * SI ( EXISTE ETAB 'SUPER' ) ;
  8022. MAIL_CHP= FER ET ( EXTRA RIG_CON MAIL );
  8023. * SINON ;
  8024. * MAIL_CHP= ETAB.'GEORED' ;
  8025. * FINSI ;
  8026. NBRE_NOE = 'NBNO' MAIL_CHP ;
  8027. VEC1= MANU CHPO MAIL_CHP 1 'T' (PROG NBRE_NOE * 1. ) ;
  8028. QTE_FLUX = ETAB.'RHS' ;
  8029. EVO_COND = ETAB.'EVOCOND' ;
  8030. LIS_COND = 'EXTRAIRE' EVO_COND 'CONDUCTIVITE' ;
  8031. LIS_TEMP = 'EXTRAIRE' EVO_COND 'TEMPERATURE' ;
  8032. VAL_COND=EXTR LIS_COND 1 ;
  8033. * SAUTER 3 LIGNES ;
  8034. * MESS ' CONDUCTIVITE INITIALE DU FER ' VAL_COND ;
  8035. SAUTER 3 LIGNES ;
  8036. 'SI' ( 'EXISTE' ETAB 'CRITERE' ) ;
  8037. EPSILON = ETAB.'CRITERE' ;
  8038. 'SINON' ;
  8039. EPSILON = 1.E-5 ;
  8040. 'FINSI' ;
  8041. 'SI' ( 'EXISTE' ETAB 'NITER' ) ;
  8042. NBRE_ITE = ETAB.'NITER' ;
  8043. 'SI' ( NIV_MESS '>EG' 1 ) ;
  8044. 'SAUTER' 1 'LIGNE' ;
  8045. 'MESS' 'REACTUALISATION DE LA MATRICE DE CONDUCTIVITE A L ENTREE ' 'PUIS TOUTES LES ' NBRE_ITE 'ITERATIONS' ;
  8046. 'FINSI' ;
  8047. 'SINON' ;
  8048. NBRE_ITE = 1 ;
  8049. 'FINSI' ;
  8050. 'SI' ( 'EXISTE' ETAB 'ITERMAX' ) ;
  8051. ITER_MAX = ETAB.'ITERMAX' ;
  8052. 'SINON' ;
  8053. ITER_MAX = 10 ;
  8054. 'FINSI' ;
  8055. **************************
  8056. OBJ_MFER = 'MODE' FER 'THERMIQUE' 'ISOTROPE' ;
  8057. 'SI' ( 'EXISTE' ETAB 'IMPOSE');
  8058. FF1 = QTE_FLUX 'ET' VAL_IMPO ;
  8059. 'SINON';
  8060. FF1 = QTE_FLUX;
  8061. 'FINSI';
  8062. ome= ETAB.'OME' ;
  8063. 'SI' ('NON' ( 'EXISTE' ETAB 'POTENTIEL')) ;
  8064. MESS '*************************************************************';
  8065. MESS '************** CALCUL INITIAL *******************************';
  8066. MESS 'SUPPOSE UN PASSAGE PREALABLE AU MOINS DS POT_VECT OU POT_SCAL';
  8067. MESS '*************************************************************';
  8068. klast= manu chpo fer 1 'SCAL' ( prog ( fer nbno ) * val_cond );
  8069. SI ( AXI ) ;
  8070. KLAST = (KLAST * ( RFER ** -1. )) ;
  8071. CHAM_CND = CHAMELEM FER (KLAST 'NOMC' 'K') 'CARACTERISTIQUES';
  8072. SINON ;
  8073. CHAM_CND='MATE' OBJ_MFER 'K' VAL_COND ;
  8074. FINSI ;
  8075. CND1 = 'CONDUCTIVITE' OBJ_MFER CHAM_CND ;
  8076. 'SI' ( 'EXISTE' ETAB BLOCAGE ) ;
  8077. RIG1 = CND1 ET RIG_CON ET MAT_BLO ;
  8078. 'SINON';
  8079. RIG1 = CND1 ET RIG_CON ;
  8080. 'FINSI' ;
  8081. U1_T = 'RESOUDRE' RIG1 FF1 ;
  8082. ETAB.'POTENTIEL'= U1_T ENLEVER LX ;
  8083. * CI= (LUMP RIG1 ) * VEC1 ; C2= (LUMP RIG1 ( MOTS T )) * VEC1 ;
  8084. * CI = (C2 - CI ) NOMC 'SCAL';
  8085. SINON ;
  8086. MESS ' ******************************************************';
  8087. MESS ' ****************** REPRISE *****************';
  8088. MESS ' ******************************************************';
  8089. SI (EXISTE ETAB 'KLAST') ;
  8090. KLAST= ETAB.'KLAST' ;
  8091. SINON ;
  8092. klast= manu chpo fer 1 'SCAL' ( prog ( fer nbno ) * val_cond );
  8093. FINSI ;
  8094. U1_T = 'EXCO' ( ETAB.'POTENTIEL') 'T' 'NOID' 'T' ;
  8095. * CI = ETAB.'CI' ;
  8096. MESS ' menage ' ; MENAGE ;
  8097. FINSI ;
  8098. 'SI' ( NIV_MESS '>EG' 2 ) ;
  8099. 'SAUTER' 1 'LIGNE' ;
  8100. 'MESS' 'CHAMP THERMIQUE AVANT ITERATION ' ;
  8101. 'LISTE' U1_T ;
  8102. 'FINSI' ;
  8103. DAN= 1.;
  8104. *
  8105. MOESP='REA' ;
  8106. *
  8107. MESS ' AMAX AMIN DU/U ';
  8108. *
  8109. ***********************************************************
  8110. *--- ... ITERATIONS ...
  8111. ***********************************************************
  8112. NUM_ITE = 0 ;
  8113. IFOIS = 0 ;
  8114. 'REPETER' BOUC_1 ;
  8115. NUM_ITE = NUM_ITE + 1 ;
  8116. IFOIS = IFOIS + 1 ;
  8117. *
  8118. * calcul du champ dans le fer -----> modif de mufer
  8119. U1_FER=REDU U1_T FER ;
  8120. DERIV= CHAN CHPO ( GRAD OBJ_MFER U1_FER) OBJ_MFER;
  8121. SI ( AXI ) ;
  8122. DERIV = DERIV / RFER ;
  8123. FINSI ;
  8124. SI (EXISTE DERIV 'T,Z' ) ;
  8125. DAX= (EXCO DERIV 'T,X') NOMC SCAL;
  8126. DAY= (EXCO DERIV 'T,Y') NOMC SCAL;
  8127. DAZ= (EXCO DERIV 'T,Z') NOMC SCAL;
  8128. BB= (( DAY * DAY ) + ( DAX * DAX ) +( DAZ * DAZ )) ** .5 ;
  8129. BB= BB NOMC T ;
  8130. SINON ;
  8131. DAX= (EXCO DERIV 'T,X') NOMC SCAL ;
  8132. DAY= (EXCO DERIV 'T,Y') NOMC SCAL ;
  8133. BB= ((( DAY * DAY ) + ( DAX * DAX ) ) ** .5 ) NOMC T ;
  8134. FINSI ;
  8135.  
  8136. BMAX= MAXIMUM BB ;BMIN= MINI BB ;
  8137. MESS IFOIS MOESP ' ** CHAMP MAXI MINI FER ' BMAX BMIN ;
  8138. * SAUTER 1 LIGNE ;
  8139.  
  8140. K1 = 'IPOL' BB LIS_TEMP LIS_COND ;
  8141. K1= COLI (K1 NOMC 'SCAL') OME KLAST (1. - OME) ;
  8142. KLAST = K1 ;
  8143. K2 = 'NOMC' 'K' K1 ;
  8144. SI ( AXI ) ;
  8145. K2 = (K2 * ( RFER ** -1. )) NOMC 'K' ;
  8146. CHAM_CND = CHAMELEM FER K2 'CARACTERISTIQUES';
  8147. SINON ;
  8148. CHAM_CND = 'CHAMELEM' FER K2 'CARACTERISTIQUES' ;
  8149. FINSI ;
  8150. CND2 = 'CONDUCTIVITE' OBJ_MFER CHAM_CND ;
  8151. RR2= CND2 ET RIG_CON ;
  8152. RESID= ( FF1 - ( RR2 * U1_T ) ) ENLEVER 'FLX' ;
  8153. *
  8154. * tests de convergence
  8155. *
  8156. RESID= RESID NOMC 'SCAL';
  8157. NORES= (XTX RESID ) ** .5 ;
  8158. ERRMAX= MAXI ( ABS RESID ) ;
  8159. MAXA= MAXI U1_T ;MIXA= MINI U1_T ;
  8160. DETR RESID ;
  8161. MESS IFOIS MAXA MIXA DAN ;
  8162. *
  8163. *
  8164. 'SI' (( NUM_ITE 'EGA' NBRE_ITE ) 'OU' ( IFOIS 'EGA' 1 ) );
  8165. *****************************************************************
  8166. * --- REACTUALISATION DE LA MATRICE DE CONDUCTIVITE
  8167. *****************************************************************
  8168. MOESP='REA' ;
  8169. * CI= (LUMP RR2 ) * VEC1 ; C2= (LUMP RR2 ( MOTS T )) * VEC1 ;
  8170. * CI = (C2 - CI ) NOMC 'SCAL';
  8171. 'SI' ( 'EXISTE' ETAB BLOCAGE );
  8172. RIG1 = RR2 ET MAT_BLO ;
  8173. 'SINON';
  8174. RIG1 = RR2 ;
  8175. 'FINSI' ;
  8176. U2 = 'RESOUDRE' RIG1 FF1 ;
  8177. NUM_ITE = 0 ;
  8178. 'SINON' ;
  8179. *****************************************************************
  8180. * --- RE-EQUILIBRAGE DU SECOND MEMBRE
  8181. *****************************************************************
  8182. MOESP=' ' ;
  8183. FF2 = ( RIG1 * U1_T ) - ( RR2 * U1_T ) ;
  8184. FF3 = FF1 + FF2 ;
  8185. U2 = 'RESOUDRE' RIG1 FF3 ;
  8186. * 'DETR' CND2 ;DETR RR1 ; DETR RR2 ;
  8187. 'FINSI' ;
  8188. *****************************************************************
  8189. *****************************************************************
  8190. U2_T = 'EXCO' U2 'T' 'NOID' 'T' ;
  8191. *
  8192. 'SI' ( NIV_MESS '>EG' 2 ) ;
  8193. 'SAUTER' 1 'LIGNE' ;
  8194. 'MESS' 'CHAMP THERMIQUE A L ITERATION :' IFOIS ;
  8195. 'LISTE' U2_T ;
  8196. 'FINSI' ;
  8197. *
  8198. CDIF= U2_T - U1_T ;
  8199. DAN= (XTX CDIF) / ( XTX U1_T) ;
  8200. DAN = DAN ** .5 ;
  8201. *
  8202. * 'SI' ( ERROR < EPSILON ) ;
  8203. 'SI' ( DAN < EPSILON ) ;
  8204. CONVERGE = VRAI ;
  8205. 'SINON' ;
  8206. CONVERGE = FAUX ;
  8207. 'FINSI' ;
  8208. *
  8209. *--- LE CRITERE DE CONVERGENCE EST-IL SATISFAIT ?
  8210. MENAGE ;
  8211.  
  8212. 'SI' ( CONVERGE ) ;
  8213. 'SI' ( NIV_MESS '>EG' 1 ) ;
  8214. * 'SAUTER' 1 'LIGNE' ;
  8215. 'MESS' 'CONVERGENCE A L ITERATION :' IFOIS ;
  8216. 'MESS' 'CRITERE DE CONVERGENCE :' EPSILON ;
  8217. 'FINSI' ;
  8218. 'QUITTER' BOUC_1 ;
  8219. 'FINSI' ;
  8220. U1_T = U2_T ;
  8221. 'SI' ( 'EGA' IFOIS ITER_MAX ) ;
  8222. * 'SAUTER' 1 'LIGNE' ;
  8223. 'MESS' 'PAS DE CONVERGENCE A L ITERATION :' ITER_MAX ;
  8224. ETAB.CONV = CONVERGE ;
  8225. 'QUITTER' BOUC_1 ;
  8226. 'FINSI' ;
  8227. * ON FAIT LE MENAGE
  8228. 'FIN' BOUC_1 ;
  8229. ETAB.NBITER= IFOIS;
  8230. *
  8231. *--- ARCHIVAGE DES RESULTATS DANS "ETAB"
  8232. *
  8233. ETAB.'KLAST'= KLAST ;
  8234. ETAB.'POTENTIEL' = U2_T ;
  8235. * ETAB.'CI'= CI ;
  8236. 'SI' ( NIV_MESS '>EG' 1 ) ;
  8237. 'SAUTER' 1 'LIGNE' ;
  8238. 'MESS' '*** FIN DE LA PROCEDURE "MAG_NLIN" ***' ;
  8239. 'FINSI' ;
  8240. 'FIN' PROC ;
  8241. 'FINPROC' ETAB ;
  8242. ************************
  8243. **** H_B derniere modif 16/04/91
  8244. DEBPROC H_B MU0*FLOTTANT POT_SCAL/MOT;
  8245. * definition de la courbe mu de b ou h
  8246. * mu0 systeme mksa 4 pi 10-7 ;
  8247. MUVRA = 4. * 3.14159 * 1.E-7 ;RAP= MU0 / MUVRA ;
  8248. * B= PROG 0. 1.09 1.5 1.57 1.67 1.81 1.92 2.01 20.1 ;
  8249. * H= PROG 0. 300 800 1250 3000 8000 13000 20000 200000 ;
  8250.  
  8251. B= PROG 0. .8 1.2 1.4 1.5 PAS .05 2.15 2.175 2.2 2.25 2.28 2.3 2.3443 2.3996 2.4905 2.5627 2.6706 2.8498 3.2074 3.5644 4.2782 4.8134 5.7052 6.4186 7.4887 17.48 27.48 200. 400. 600. 10000. 30000.;
  8252. H= PROG 0. 159.2 294.4 501.3 795.8 1154. 1795. 2862. 4383. 6044. 8122. 10590. 13610. 17220. 21170. 26750. 33760. 43800. 52440. 66000. 99470. 120960. 141210. 169600. 212170. 283130. 339890. 425040. 566950. 850760. 1134600. 1702300. 2128000. 2837700. 3405100. 4256700. 12215578. 20174457. 155800000. 311600000. 467400000. 7.32E9 21.E9 ;
  8253. * TITRE ' COURBE H B A/M TESLAS ****** ';
  8254. * BHEVO=EVOL MANU 'H' H 'B' B ;
  8255. * DESS BHEVO;
  8256. * RECTIF POUR COHERENCE UNITES
  8257. H= H / RAP ;
  8258. H_1= ENLEVER H 1 ;B_1= ENLEVER B 1 ;
  8259. MUV= H_1 / B_1;TU= EXTRA MUV 1;MUV= ( PROG TU ) ET MUV ;
  8260. SI ('EXISTE' POT_SCAL );
  8261. BOBO= TEXTE ' MU F(H) POT SCAL ' ;
  8262. TITRE BOBO ;
  8263. REVOL = EVOL MANU 'TEMPERATURE ' H 'CONDUCTIVITE ' ( MUV ** -1.) ;
  8264. SINON ;
  8265. BOBO= TEXTE ' MU F(B) POT VECT ';
  8266. TITRE BOBO ;
  8267. REVOL=EVOL 'MANU' 'TEMPERATURE' B 'CONDUCTIVITE' MUV ;
  8268. FINSI ;
  8269. SAUTER 3 LIGNES ;
  8270. MESS BOBO ;
  8271. SAUTER 3 LIGNES ;
  8272. FINPROC REVOL ;
  8273. *
  8274. **** POT_SCAL derniere modif 10/02/92
  8275. DEBPROC POT_SCAL TABGEO*TABLE SOLIN/MOT ;
  8276. *********************************************************************
  8277. * procedure de mise en place des elements d un calcul 3d *
  8278. * magnetostatique potentiel scalaire reduit et total *
  8279. * DPHI zone de potentiel reduit *
  8280. * DPsI zone de potentiel total
  8281. ***** desciption du domaine dphi ( pas de super pour le moment)****
  8282. * TABGEO.'DPHI' = geometrie DPHI *
  8283. * TABGEO.'SEPPHI'= surface de separation appartient a DPHI
  8284. * attention pour le moment on doit verifier l orientation de la *
  8285. * normale a sepphi ( exterieure ) en attendant extension de flux *
  8286. * TABGEO.'B_ANTI' = partie de sepphi appartenant a la limite *
  8287. * TABGEO.'MUAIR' = mu0 *
  8288. * d antisymetrie pour B *
  8289. *******description du domaine dpsi **********************************
  8290. * on donne la descprition du fer puis une table tdolin de tables *
  8291. * contenant chacune la descrition d un sous domaine *
  8292. * TABGEO.'FER' =zone du fer appartient a DPSI
  8293. * TABGEO.'MUFER' = mufer ( mu0 * murelatif) valeur de depart *
  8294. * TABGEO.'TDOLIN'
  8295. * TDOLIN.I = TABLE STN *
  8296. * STN.'GEO' = maillage du sous domaine *
  8297. * STN.'MU' = permeabilite
  8298. * eventuellement *
  8299. * STN.'BLOCAGE'= type maillage *
  8300. * STN.'IMPOSE' = type chpoint *
  8301. * STN.'MAITRES' = type maillage *
  8302. * *
  8303. * TABGEO.'SEPPSI'= surface de separation appartient a DPSI *
  8304. * TABGEO.'ORIG' = point ou on impose PHI = PSI *
  8305. * TABGEO.'BLOQUE' = condition limite generale (sauf super elements) *
  8306. * TABGEO.'BIOT' = table contenant le champ de la bobine sur DPHI *
  8307. * TABGEO.'MAILSEG' = elements d aretes de sep_phi (optionnel) *
  8308. * la routine l etablira si il n existe pas *
  8309. * TABGEO.'LISMO1' = listmot de elements de volumes utilises *
  8310. * TABGEO.'LISMO2' = listmot de elements de surface utilises *
  8311. * SOLIN si present on calcule un la solution lineaire *
  8312. * si absent le premier pas sera fait dans MAG_NLIN *
  8313. * jm baze aout 90 *
  8314. *********************************************************************
  8315. MU0 = TABGEO.'MUAIR' ;
  8316. SI ( EXISTE TABGEO 'DPHI' ) ;
  8317. MESS '*************************************************************';
  8318. MESS '*********** POTENTIEL REDUIT ---- POTENTIEL TOTAL *********';
  8319. MESS '*************************************************************';
  8320. DPHI = TABGEO.'DPHI' ;
  8321. SEP_PHI= TABGEO.'SEPPHI';
  8322. B_ANTI = TABGEO.'B_ANTI';
  8323. SEP_PSI= TABGEO.'SEPPSI';
  8324. ORIG = TABGEO.'ORIG' ;
  8325. TABHT= TABGEO.'BIOT';
  8326. LIMO1= TABGEO.'LISMO1';
  8327. LIMO2= TABGEO.'LISMO2';
  8328. * reduction de biot et savart sur sep_phi
  8329. TABHS= TABLE ;
  8330. TABHS.1 = REDU ( TABHT.1 ) SEP_PHI ;
  8331. TABHS.2 = REDU ( TABHT.2 ) SEP_PHI ;
  8332. TABHS.3 = REDU ( TABHT.3 ) SEP_PHI ;
  8333. sauter 5 lignes ;
  8334. MMM= TEXTE ' THERMIQUE ISOTROPE ';
  8335. OBJPHI= MODE DPHI MMM;
  8336. MATPHI= MATE OBJPHI 'K' MU0 ; RIGCON=CONDUC OBJPHI MATPHI ;
  8337. MESS ' COORD POINT ORIGINE INTEGRATION DE V ';
  8338. LIST ORIG ;
  8339. sauter 5 lignes ;
  8340. MESS ' CALCUL DU FLUX DE HS SUR LES ELEMENTS FRONTIERE ';
  8341. NBLD= DIMENSION LIMO2 ;
  8342. MESS ' FLUX DE HS MU0 ';
  8343. TTTT= EXTR LIMO2 1 ;TTTI= EXTR LIMO1 1 ;
  8344. SEP_PHI1=SEP_PHI ELEM TTTI ;
  8345. FLHS = FL_HS SEP_PHI1 TABHS TTTT OBJPHI ;
  8346. SI ( EGA NBLD 2 ) ;
  8347. TTTT= EXTR LIMO2 2 ;TTTI= EXTR LIMO1 2 ;
  8348. SEP_PHI2=SEP_PHI ELEM TTTI ;
  8349. FLHS2 = FL_HS SEP_PHI2 TABHS TTTT OBJPHI;
  8350. FLHS = FLHS + FLHS2 ;
  8351. FINSI ;
  8352. * TEMPS PLACE ;
  8353. FLHS= FLHS * MU0 ;
  8354. FLURED = RESU FLHS ;
  8355. MESS ' RESULTANTE DU FLUX * MUO ' ( MAXI FLURED ) ;
  8356. sauter 5 lignes ;
  8357. * integration sur la surface de separation de l equation de
  8358. * de continuite tangentielle
  8359. SI ( 'EXISTE' TABGEO 'MAILSEG' ) ;
  8360. MAILSEG= TABGEO.'MAILSEG';
  8361. SINON ;
  8362. * decomposition de la surface de separation en element d aretes
  8363. MESS ' CALCUL DES ELEMENTS ARETES DE LA SEPARATION ';
  8364. RESEAU= B_ARETES SEP_PHI ;
  8365. imena = 50 ;
  8366. MAILSEG = ARBRE RESEAU IMENA ;
  8367. TABGEO.'MAILSEG'= MAILSEG ;
  8368. FINSI;
  8369. * TEMPS PLACE ;
  8370. MESS ' CALCUL DU SAUT DE POTENTIEL ';
  8371. METHOD = 1 ;
  8372. SAUTER 4 LIGNES ;
  8373. IMENA= 3 ;
  8374. SI (EGA METHOD 1) ;
  8375. MESS ' CALCUL PAR MINIMISATION ';
  8376. LLLL= IN_MINI MAILSEG TABHS ORIG B_ANTI ;
  8377. SINON;
  8378. MESS ' CALCUL PAR INTEGRATION ';
  8379. LLLL = ARBRE_IN SEP_PHI TABHS ORIG ;
  8380. FINSI ;
  8381. *****************!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!1
  8382. TABGEO.'LLLL'=LLLL ;
  8383. MESS ' FIN DE CALCUL DU SAUT DE POTENTIEL ';
  8384. *
  8385. SEP_PHI = CHAN POI1 SEP_PHI ;
  8386. SEP_RED= DIFF SEP_PHI B_ANTI;
  8387. LRED= REDU LLLL SEP_RED ;
  8388.  
  8389. RELT FDEPI= SAUT_POT SEP_RED SEP_PSI LRED ORIG ;
  8390. MESS ' FIN D APPLICATION DU SAUT DE POTENTIEL ';
  8391. *****************
  8392. RIGCON = RIGCON ET RELT ;RHS = FLHS ET FDEPI ;
  8393. *****************
  8394. * LIST FSAUT ;
  8395. sauter 5 lignes ;
  8396. * TEMPS PLACE ;
  8397. SINON ;
  8398. SAUTER 5 LIGNES ;
  8399. MESS '*************************************************************';
  8400. MESS '*********** DPHI N EXISTE PAS --> POTENTIEL TOTAL *********';
  8401. MESS '*************************************************************';
  8402. SAUTER 5 LIGNES ;
  8403. FINSI ;
  8404. **
  8405. DFER = TABGEO.'FER' ;
  8406. MUFER = TABGEO.'MUFER' ;
  8407.  
  8408. OBJ2=MODE DFER MMM;
  8409. MAT2= MATE OBJ2 'K' MUFER ; RIGFER=CONDUC OBJ2 MAT2 ;
  8410. * boucle sur les domaines lineaires non contenus dans dphi
  8411. SI ('EXISTE' TABGEO 'DOLIN' );
  8412. TDOLIN = TABGEO.'DOLIN' ;
  8413. III = INDEX TDOLIN ;
  8414. IDOM = 0 ;
  8415. REPETER BOUCDOM ;
  8416. IDOM = IDOM + 1 ;
  8417. SI ( 'NON' ( 'EXISTE' III IDOM )) ; QUITTER BOUCDOM ;FINSI ;
  8418. STN = TDOLIN.IDOM ;
  8419. LIST STN ;
  8420. GEO = STN.'GEO' ;OBJI= MODE GEO MMM ;
  8421. MUI = STN.'MU' ;
  8422. MATI= MATE OBJI 'K' MUI ; RIGO=CONDUC OBJI MATI ;
  8423. *
  8424. SI ( EXISTE STN 'BLOQUE' ) ;
  8425. ENC1 = BLOQUER (STN.'BLOQUE') 'T';
  8426. RIGO = RIGO ET ENC1 ;
  8427. FINSI ;
  8428. SI ( EXISTE STN 'IMPOSE' ) ;
  8429. CHIMP = (STN.'IMPOSE' ) NOMC 'T';
  8430. MAII = EXTR CHIMP MAILLAGE ;
  8431. RIMP = BLOQUER MAII 'T' ; FPOTI = DEPIMP RIMP CHIMP ;
  8432. RIGO = RIGO ET RIMP ;RHS = RHS ET FPOTI ;
  8433. FINSI ;
  8434. SI ( EXISTE STN 'MAITRES');
  8435. ******************************************************************
  8436. * construction eventuelle du super element
  8437. ******************************************************************
  8438. * attention ici si il y a une charge OU UN IMPOSE
  8439. SUP1 = SUPER 'RIGIDITE' RIGO ( STN.'MAITRES' ) ;
  8440. RIGCON = RIGCON ET ( EXTRA SUP1 'RIGI' ) ;
  8441. SINON ;
  8442. RIGCON = RIGCON ET RIGO ;
  8443. FINSI ;
  8444. FIN BOUCDOM ;
  8445. * fin de la boucle sur les table de domaines lineaires de dpsi
  8446. FINSI ;
  8447. *
  8448. SI( EXISTE TABGEO 'IMPOSE') ;
  8449. MESS ' CONDITION GENERALE IMPOSEE ' ;
  8450. CHIMG = (TABGEO.'IMPOSE' ) NOMC 'T';
  8451. MAIG = EXTR CHIMG MAILLAGE ;
  8452. RIMG = BLOQUER MAIG 'T' ; FPOTG = DEPIMP RIMG CHIMG ;
  8453. RIGCON = RIGCON ET RIMG ;RHS = RHS ET FPOTG ;
  8454. FINSI ;
  8455. *
  8456. SI (EXISTE TABGEO 'BLOQUE') ;
  8457. MESS ' CONDITION GENERALE BLOQUEE ' ;
  8458. ENCG = BLOQUER (TABGEO.'BLOQUE') 'T';
  8459. RIGCON= RIGCON ET ENCG ;
  8460. TABGEO.'BLOCAGE' = ENCG ;
  8461. FINSI ;
  8462. *
  8463. *
  8464. SI ( EXISTE SOLIN ) ;
  8465. MESS '********************************************************* ';
  8466. MESS '***************** CALCUL LINEAIRE ******************** ';
  8467. MESS '********************************************************* ';
  8468.  
  8469. RIGT = RIGCON ET RIGFER ;
  8470. TABGEO.'RHS'= RHS ;
  8471. TABGEO.'RIGCON'= RIGCON ;
  8472. TABGEO.'RIGFER'= RIGFER ;
  8473. SOL0= RESOU RIGT RHS ;
  8474. TABGEO.'POTENTIEL'=(ENLEVER SOL0 LX) ;
  8475. FINSI ;
  8476. *
  8477. FINPROC ;
  8478. **** A_HOMO derniere modif 10/02/92
  8479. DEBPROC A_HOMO AKN*LISTREEL RHARM*FLOTTANT RCIRC*FLOTTANT NHARM*ENTIER;
  8480. SAUTER 2 LIGNES ;
  8481. OPTION ELEM SEG2 ;
  8482. BDIP= EXTR AKN 1;BQUAD = EXTR AKN 2 ;G0 = BQUAD / RHARM ;
  8483. SAUTER 2 LIGNES ;
  8484. MESS '******************* BDIP ' BDIP ;
  8485. MESS '******************* BQUAD' BQUAD;
  8486. MESS '******************* G0 ' G0 ;
  8487. SAUTER 2 LIGNES ;
  8488. C2R = EXTR AKN 2 ;
  8489. K= 0 ;
  8490. REPETER BLOCC NHARM ;
  8491. K= K + 1; COK = EXTR AKN K ;
  8492. AKM= COK / ( RHARM ** (K - 1)) ;
  8493. CQUA= COK / C2R ;
  8494. CDIP = COK / BDIP;
  8495. MESS K AKM CQUA ;
  8496. FIN BLOCC ;
  8497. SAUTER 2 LIGNES ;
  8498. * ON CONSTRUIT UN CHPO SUR LE RAYON ANALYSE CE QUI SERA PRATIQUE POUR
  8499. * TRACER DES EVOLUTIONS ;
  8500. OP = RCIRC 0.;OO= 0. 0. ;
  8501. LSUP= D 10 OO OP;
  8502. NN= 11 ;
  8503. DX =2.;
  8504. X= -2. ;
  8505. IP=0 ;
  8506. REPETER BLOCA 11 ;
  8507. IP= IP + 1 ;
  8508. X =X + DX ; Z = X / RHARM ;
  8509. B = 0 ; G = G0 ; BQUAD = C2R * Z ;
  8510. K= 0 ;
  8511. REPETER BLOCB NHARM ;
  8512. K= K + 1 ; COK = EXTR AKN K ;
  8513. SI ( K EGA 1 ) ; B = B + COK ;SINON ;TERM= COK * ( Z ** (K - 1 ));
  8514. B= B + TERM ;
  8515. SI ( (K >EG 3 ) ET ( (ABS X ) >EG 1.E-4 ) );
  8516. G = G + (( TERM / X ) * (K - 1)) ;
  8517. FINSI ;
  8518. FINSI ;
  8519. FIN BLOCB ;
  8520. * SI (( ABS X ) >EG 1.E-4 ) ;
  8521. HQUAD= (B - BDIP - BQUAD ) /C2R ;
  8522. GQUAD= (G - G0 ) / G0 ;
  8523. HDIP = (B - BDIP) / BDIP ;
  8524. * FINSI;
  8525. SI ( IP EGA 1 ) ;
  8526. LHQ= PROG HQUAD ;LG= PROG G ;
  8527. LGQ = PROG GQUAD ; LB= PROG B;
  8528. SINON ;
  8529. LHQ= LHQ ET (PROG HQUAD ) ;LG= LG ET ( PROG G );
  8530. LGQ = LGQ ET (PROG GQUAD );LB= LB ET (PROG B );
  8531. FINSI ;
  8532. FIN BLOCA ;
  8533. SAUTER 2 LIGNES ;
  8534. CX= COOR 1 LSUP ;
  8535.  
  8536. TUTU= MANU CHPO LSUP 4 'B' LB 'DB/B' LHQ 'G' LG 'DG/G' LGQ ;
  8537. SAUTER 2 LIGNES ;
  8538. MESS ' ANALYSE CONFORME A HARMBIS ';
  8539. SAUTER 2 LIGNES ;
  8540. RECAP = CX ET TUTU ;
  8541. LIST RECAP ;
  8542. FINPROC ;
  8543. *
  8544. **** INT_COMP derniere modif janvier /92
  8545. 'DEBPROC' INT_COMP GEOP*MAILLAGE CCCC*CHPOINT GEOF*MAILLAGE ;
  8546. ************************************************************************
  8547. * interpolation d une composante sur un maillage *
  8548. * TYEL TYPE D ELEMENTS *
  8549. * entree cccc chpoint original a 1 composante de support geop *
  8550. * sortie chpo de support geof *
  8551. ************************************************************************
  8552. TYT = VALE ELEM ;
  8553. SI ( NON ( EGA TYT 'TRI3'));
  8554. GEOP = CHAN GEOP TRI3 ;
  8555. MESS 'ON PASSE EN TRI3 POUR UTLISER PROI ( DEGUEULASSE EN TRI6....)';
  8556. FINSI ;
  8557.  
  8558. OBS1 = AFFECT GEOP ( MODELE STANDARD ) TRI3 ;
  8559. CEL1 = PRCH CCCC OBS1 'NOEUD' ;
  8560. CRES = PROI GEOF CEL1 ;
  8561. FINPROC CRES ;
  8562. *
  8563. **** IDE_ELE derniere modif fevrier/92
  8564. DEBPROC IDE_ELE ;
  8565. **********************************************************************
  8566. * IDENTIFICATION DU TYPE D ELEMENTS UTILISES
  8567. **********************************************************************
  8568. TIDIM = VALE DIME ;
  8569. TVAL = VALE ELEM ;
  8570. SI ( EGA TIDIM 2 ) ;
  8571. SI (( EGA TVAL 'QUA8') 'OU' (EGA TVAL 'TRI6')) ;
  8572. TYEL = TEXTE 'QUA8' 'TRI6' ;
  8573. SINON ;
  8574. TYEL = TEXTE 'QUA4' 'TRI3' ;
  8575. FINSI ;
  8576. SINON ;
  8577. SI (( EGA TVAL 'CU20') 'OU' (EGA TVAL 'PRI16')) ;
  8578. TYEL = TEXTE 'CU20' 'PR15' 'TET10';
  8579. SINON ;
  8580. TYEL = TEXTE 'CUB8' 'PRI6' 'TET4';
  8581. FINSI ;
  8582. FINSI ;
  8583. FINPROC TYEL ;
  8584. **** MUAXI2 MODIFIE FEVRIER 92
  8585. DEBPROC MUAXI2 GEO*MAILLAGE MU*FLOTTANT IDI*ENTIER ;
  8586. ***********************************************************************
  8587. * SORTIE De CONDUCTIBILITE = 1/(MU*R) EN AXISYMETRIQUE *
  8588. * IDI = 1 sortie chamelem 'caracteristique au noeuds DEFAUT*
  8589. * IDI = 2 sortie chpo aux noeuds scalaire *
  8590. * IDI = 3 sortie chamelem au CDG *
  8591. * MODIFIEE FEVRIER 92 POUR P2 *
  8592. ***********************************************************************
  8593. IMET = 2 ;
  8594. SI ( EGA IMET 1 ) ;
  8595. * estimation de mu au noeuds en trichant sur l axe
  8596. RGEO = COOR 1 GEO ;
  8597. AXE= GEO POINTS DROITE (0. 0) (0. 10.) .05 ;
  8598. MUPO = (((RGEO + ((COOR 1 AXE) + 1.E-8)) ** -1. ) / MU ) NOMC 'K';
  8599. MATT= CHAMELEM GEO MUPO 'CARACTERISTIQUE' ;
  8600. FINSI ;
  8601. SI ( EGA IMET 2 ) ;
  8602. * estimation de mu aux cdg sans tricher sur l axe
  8603. OBMOD = MODE GEO THERMIQUE ISOTROPE ;
  8604. cp_rpoa = (coor 1 GEO ) ;
  8605. * chamelem des rayons aux cdg
  8606. ce_rpoa = CHAN 'CHAM' CP_RPOA OBMOD 'GRAVITE';
  8607. * chamelem des cdg reportes aux noeuds
  8608. RGEO = (CHAN CHPO OBMOD (CHAN 'NOEUD' OBMOD ce_rpoa )) ** -1.;
  8609. SI ( EGA IDI 1 ) ;
  8610. CHPMUGEO= ( (1./ MU ) * RGEO )NOMC 'K' ;
  8611. MATT= CHAMELEM GEO CHPMUGEO 'CARACTERISTIQUE' ;
  8612. * MESS ' 1/MU CHAMP ELEM TYPE CARACTERISTIQUE K ';
  8613. FINSI ;
  8614. SI (EGA IDI 2 ) ;
  8615. MESS ' 1/R AUX CDG REPORTES AUX NOEUDS SCALAIRE ';
  8616. MATT = RGEO ;
  8617. FINSI ;
  8618. SI (EGA IDI 3 ) ;
  8619. MESS ' 1/R CHAMP ELEM AUX CDG ';
  8620. MATT = CE_RPOA ;
  8621. FINSI ;
  8622. FINSI ;
  8623. FINPROC MATT ;
  8624. **** REMONT derniere modif 14 08 91
  8625. DEBPROC REMONT ETAB*TABLE POT*CHPOINT GEON*MAILLAGE FE/CHPOINT GEOMAIT*MAILLAGE ;
  8626. * POT SOLUTION
  8627. * GEON MAILLAGE AUTRE QUE LE SUPER
  8628. * GEOMAIT POINTS MAITRES
  8629. SI ( EXISTE ETAB 'SUPER' ) ;
  8630. SUPP= ETAB.'SUPER' ;
  8631. DSUP = SUPER 'DEPLA' SUPP POT ;
  8632. * ATTENTION SI IL Y AVAIT DES CHARGES DANS LE SUPER
  8633. RIGS = EXTRAI SUPP 'RIGT' ;
  8634. SI ( EXISTE FE ) ;
  8635. SOLSUP = RESOU RIGS ( DSUP ET FE ) ;
  8636. SINON ;
  8637.  
  8638. SOLSUP = RESOU RIGS DSUP ;
  8639. FINSI ;
  8640. GEOSUP = EXTR SOLSUP MAILLAGE 'NOMU' ;
  8641. SINON ;
  8642. ********************************************************
  8643. * autre methode eventuelle
  8644. ********************************************************
  8645. * TAIR2 = REDU SOL1 CAIR1 ;
  8646. * NN= CAIR1 NBNO ;CAIR1 = CHAN CAIR1 POI1 ;
  8647. * IP = 0 ;
  8648. * REPETER BBBB NN ;
  8649. * IP = IP + 1 ;PP = CAIR1 POINT IP ;
  8650. * CLIM = BLOQUER 'T' PP ; FP = DEPIMP CLIM ( EXTR TAIR2 'T' PP ) ;
  8651. * SI ( EGA IP 1 ); CLIMT = CLIM ;FPT = FP ;
  8652. * SINON ; CLIMT = CLIMT ET CLIM ; FPT = FPT ET FP ;FINSI ;
  8653. * FIN BBBB ;
  8654. * TIAIR2 = RESOU (RIGA ET CLIMT) ( FPT ET FE ) ;
  8655. FINSI ;
  8656. *
  8657. POIS= CHAN GEOSUP POI1 ;
  8658. AAA= DIFF POIS (CHAN GEOMAIT POI1 ) ;
  8659. SOLSU = REDU SOLSUP AAA ;
  8660. SOLT= ( POT + SOLSU ) ;
  8661. FINPROC SOLT ;
  8662. **** F_S2PI derniere modif 30/3/92
  8663. DEBPROC F_S2PI CHARM*MAILLAGE SCIRC*CHPOINT NN*ENTIER OO*POINT ;
  8664. VALIN = REDU SCIRC ( CHARM POINT INITIAL ) ;
  8665. VALFI = REDU SCIRC ( CHARM POINT FINAL ) ;
  8666. V1 = MAXI VALIN ;V2 = MAXI VALFI ;
  8667. K = -1 ;
  8668. SI (( V1 < V2 ) ET ( NUM NEG 1 )) ;
  8669. CHARM = INVE CHARM ;K = 1 ;
  8670. FINSI ;
  8671. 1P = CHARM POINT INITIAL ;2P = CHARM POINT FINAL ;
  8672. IP = 0 ;
  8673. REPETER BOUC (NN - 1 );
  8674. IP = IP + 1 ;
  8675. SI ( EGA IP 1 ) ;
  8676. SOL2 = (SCIRC PLUS (0. 0.)) * K ;
  8677. SINON ;
  8678. SOL2 = (SOL2 PLUS (0. 0.)) * K ;
  8679. FINSI ;
  8680. MAI2 = EXTR SOL2 MAILLAGE ;
  8681. PDOU = CHARM POINT FINAL ;
  8682. VALDOU = REDU SCIRC PDOU ;
  8683.  
  8684. MAI2 = DEPLACER MAI2 SYME DROITE OO PDOU ;
  8685. SI ( EGA IP 1 ) ;
  8686. CHARM2= ( INVE (CHARM SYME DROITE OO PDOU )) ;
  8687. SINON ;
  8688. CHARM2= ( INVE (CHARM2 SYME DROITE OO PDOU )) ;
  8689. FINSI ;
  8690. ELIM .0001 CHARM2 MAI2 ;
  8691. CONFONDRE ( CHARM POINT FINAL) ( CHARM2 POINT INITIAL ) ;
  8692. CHARM = CHARM ET CHARM2 ;
  8693. SCIRC = SCIRC + SOL2 - VALDOU ;
  8694. K = K * -1 ;
  8695. FIN BOUC ;
  8696. *
  8697. SUPO = CHARM ;
  8698. * TITRE ' SOLUTION SUR 2PI ';
  8699. * EVV1 = EVOL ROUG CHPO SCIRC 'T' CHARM ;
  8700. * titre ' evo '( dime evv1 ) 'supp ' ( supo nbno ) ;
  8701. * trac supo ;
  8702. * dess evv1 ;
  8703. FINPROC SCIRC SUPO ;
  8704. **** DDFOUR derniere modif 30/3/92
  8705. DEBPROC DDFOUR GEO*MAILLAGE CHARM*MAILLAGE NHARM*ENTIER SOL*CHPOINT RHARM*FLOTTANT ORIG/POINT LIS*LOGIQUE ;
  8706. *********************************************************************
  8707. * ANALYSE HARMONIQUE DU POTENTIEL VECTEUR
  8708. * GEO MAILLAGE SUPPORT SOLUTION GENERALE *
  8709. * CHARM ARC DE CERCLE SUR LEQUEL ON A LE POTENTIEL *
  8710. * NHARM NOMBRE D HARMONIQUES A CALCULER *
  8711. * SOL SOLUTION EN POTENTIEL *
  8712. * RHARM RAYON DE NORMALISATION *
  8713. * ORIG ORIGINE CERCLE D ANALYSE
  8714. * LIS LOGIQUE FAUX SI PAS DE LISSAGE POLYNOMIAL *
  8715. *********************************************************************
  8716. 1P = CHARM POINT INITIAL ;2P= CHARM POINT FINAL ;
  8717. SI ( EXISTE ORIG ) ;
  8718. RCIRC = NORM ( 1P MOINS ORIG ) ;
  8719. SINON ;
  8720. RCIRC = NORM 1P ;ORIG = 0. 0. ;
  8721. FINSI ;
  8722. X1 Y1 = COOR ( 1P MOINS ORIG );X2 Y2 = COOR 2P ;
  8723. PT = 2P PROJETER (( Y1 * -1. ) X1 ) DROITE ORIG 1P ;
  8724. H = NORM ( 2P MOINS PT ) ;
  8725. SI ( (X1 + X2 ) < 1.E-3 ) ;
  8726. NUM = 2 ;
  8727. MESS 'SOLUTION DONNEE SUR 180 DEGRES ' ;
  8728. SINON ;
  8729. ANG = ATG H ( NORM ( PT MOINS ORIG)) ;
  8730. NUM = ( ENTI ( 360.1 / ANG )) ;
  8731. MESS 'SOLUTION DONNEE SUR ' ANG ' DEGRES ' ;
  8732. FINSI ;
  8733. SI ( NON ( LIS )) ;
  8734. SCIRC = INT_COMP GEO SOL CHARM ;
  8735. SCIRC = SCIRC NOMC 'T' ;
  8736. SINON ;
  8737. * lissage polynomial
  8738. CHLI = LISS GEO CHARM SOL 2 PLAN ;
  8739. SCIRC = (EXCO CHLI 'A' ) NOMC 'T' ;
  8740. FINSI ;
  8741. RRAP = RHARM / RCIRC ;
  8742. CQTT RTOT = F_S2PI CHARM SCIRC NUM ORIG ;
  8743. EQTT = EVOL ROUG CHPO CQTT 'T' RTOT ;
  8744. AAAA= EXTR EQTT 'ABSC' ;
  8745. * QTOT= EXTR EQTT 'ORDO' ;
  8746. * LIST QTOT ;
  8747. * NI1= (DIME AAAA ) - 1 ;
  8748. * IVAL = VALE ELEM ;
  8749. * OPTION ELEM SEG2 ;I1 = 0. 0. ; I2 = 360. 0. ;
  8750. * RTOT = DROI NI1 I1 I2 ;
  8751. OBA_RMA= AFFECTE RTOT (MODELE STANDARD) COQ2;
  8752. PERIOD= MAXI AAAA ;
  8753. MULT= 360. / PERIOD ;
  8754. ANGVEC= AAAA * MULT ;
  8755. * MESS ' PERIODE ' PERIOD ;
  8756. N=0;
  8757. MESS ' ANALYSE CONFORME A POISSON HARMON ';
  8758. MESS ' HARMONIQUE POTENTIEL CHAMP ';
  8759. MESS ' NOMBRE DE SEGMENTS DE DR ' NI1 ;
  8760. MESS ' DIME DE ANGVEC ' ( DIME ANGVEC ) ;
  8761. CHPA= MANU CHPO RTOT 1 SCAL ANGVEC ;
  8762. * CQTT = MANU CHPO RTOT 1 'POT' QTOT ;
  8763. REPETER BLOCIT NHARM ;
  8764. N= N + 1 ;
  8765. RAN= RRAP ** N ;
  8766. ANGLEN= CHPA * N ;
  8767. CNX= COS ANGLEN ;
  8768. SNX= SIN ANGLEN ;
  8769. EVREL= CQTT * CNX ;EVIMA= CQTT * SNX ;
  8770. CEVREL = PRCH EVREL OBA_RMA 'RIGIDITE' ;
  8771. CEVIMA = PRCH EVIMA OBA_RMA 'RIGIDITE' ;
  8772. AK= (( INTG CEVREL ) / PERIOD ) * 2. * RAN ;
  8773. BK= (( INTG CEVIMA ) / PERIOD ) * 2. * RAN ;
  8774. CK= (( AK * AK ) + ( BK * BK ) ) ** .5 ;
  8775. FF= ( FLOT N) / RHARM ;
  8776. AKK= AK * FF ;
  8777. BKK= BK * FF ;
  8778. CKK= CK * FF ;
  8779. SI (N EGA 1 );AKN= PROG AKK ; SINON ;AKN = AKN ET (PROG AKK ) ; FINSI ;
  8780. SAUTER 1 LIGNE ;
  8781. * MESS N AK BK CK AKK BKK CKK ;
  8782. MESS N AK BK CK ;
  8783. MESS N AKK BKK CKK ;
  8784. FIN BLOCIT ;
  8785. * OPTION ELEM IVAL ;
  8786. FINPROC AKN ANGVEC ;
  8787. *****
  8788.  
  8789. **** @DEFMAT
  8790. DEBPROC @DEFMAT TAB1*TABLE ;
  8791. *23456789012345678901234567890123456789012345678901234567890123456789012
  8792. * 1 2 3 4 5 6 7
  8793. ************************************************************************
  8794. MESS '---------------------------------> Entree dans DEFMAT ' ;
  8795.  
  8796. * on initialise des evol nuls
  8797. EVMA1 = EVOL MANU ( PROG 0. 500.) ( PROG 0. 0. ) ;
  8798. EVMA2 = EVOL MANU ( PROG 0. 500.) ( PROG 0. 0. ) ;
  8799. EVMA3 = EVOL MANU ( PROG 0. 500.) ( PROG 0. 0. ) ;
  8800. EVMA4 = EVOL MANU ( PROG 0. 500.) ( PROG 0. 0. ) ;
  8801. EVMA5 = EVOL MANU ( PROG 0. 500.) ( PROG 0. 0. ) ;
  8802. CHP_TM1 = TAB1.>CHP_TM1 ;
  8803. TAB1.TETMAT = TABLE ;
  8804. TAB1.MODL_MAT = TABLE ;
  8805. TAB1.MAT_MAT = TABLE ;
  8806.  
  8807. I1 = 0 ;
  8808. REPETER BOMA11 ;
  8809. I1 = I1 + 1 ;
  8810. *>1
  8811. SI ( EXISTE (TAB1.ZONE_MAT) I1 ) ;
  8812. NOM_MAT1 = TAB1.NOM_MAT.I1 ;
  8813. MESS '>>>> MATERIAU ' I1 NOM_MAT1 ;
  8814. TMECA_I1 = TEXT TAB1.TEXTMECA.I1 ;
  8815. MO1 = MODE TAB1.ZONE_MAT.I1 TMECA_I1 ;
  8816. TAB1.MODL_MAT. I1 = MO1 ;
  8817. TITRE NOM_MAT1 ' YOUN MODULUS ' ;
  8818. TAB1.TETMAT.MO1 = TABLE ;
  8819.  
  8820. *>>2*************** orthotropie
  8821.  
  8822. SI ( EGA TAB1.TEXTMECA.I1 ' MECANIQUE ELASTIQUE ORTHOTROPE') ;
  8823. CHAYGI= CHAINE TAB1 . TEXTMECA .(I1 + 100) ;
  8824. MESS '>>> ORTHOTROPIE' TAB1.TEXTMECA.I1 ;
  8825. MESS '>>> DIRECTIONS D ORTHOTROPIE' CHAYGI ;
  8826.  
  8827. * P1 = TAB1.DIRECT1 ;
  8828. * P2 = TAB1.DIRECT2 ;
  8829. * CHAYGI = 'DIRECTION P1 P2 ' ;
  8830. * CHADIR = 'DIRECTION TAB1.DIRECT1 TAB1.DIRECT2' ;
  8831.  
  8832. SI ( NON ( EXISTE TAB1 'MOMATR')) ;
  8833. TAB1.'MOMATR' = TABLE ;
  8834. FINSI ;
  8835. TAB1.'MOMATR'.MO1 = TAB1.TEXTMECA.(I1 + 100) ;
  8836.  
  8837. * CHAYG1 = CHAINE CHADIR ' YG1 ' ;
  8838. * CHAYG2 = CHAINE CHADIR ' YG2 ' ;
  8839. * CHAYG3 = CHAINE CHADIR ' YG3 ' ;
  8840. * CHAG12 = CHAINE CHADIR ' G12 ' ;
  8841. * CHAG23 = CHAINE CHADIR ' G23 ' ;
  8842. * CHAG13 = CHAINE CHADIR ' G13 ' ;
  8843. * CHANU12 = CHAINE CHADIR ' NU12 ' ;
  8844. * CHANU23 = CHAINE CHADIR ' NU23 ' ;
  8845. * CHANU13 = CHAINE CHADIR ' NU13 ' ;
  8846. * CHAALP12 = CHAINE CHADIR ' ALP1 ' ;
  8847. * CHAALP23 = CHAINE CHADIR ' ALP2 ' ;
  8848. * CHAALP13 = CHAINE CHADIR ' ALP3 ' ;
  8849.  
  8850. *>>3*************** orthotropie 333333333333333DDDDDDDDDD
  8851.  
  8852. SI (EGA (VALEUR DIMENSION) 3 ) ;
  8853. TAB1.TETMAT.MO1.YG1 = @EVMAT TAB1.NOM_MAT.I1 'YG1' TAB1 ;
  8854. TAB1.TETMAT.MO1.YG2 = @EVMAT TAB1.NOM_MAT.I1 'YG2' TAB1 ;
  8855. TAB1.TETMAT.MO1.YG3 = @EVMAT TAB1.NOM_MAT.I1 'YG3' TAB1 ;
  8856. EVMA1 = EVMA1 ET TAB1.TETMAT.MO1.YG1 ET TAB1.TETMAT.MO1.YG2 ET TAB1.TETMAT.MO1.YG3 ;
  8857. TITRE NOM_MAT1 ' POISSON COEFFICIENT ' ;
  8858. TAB1.TETMAT.MO1.NU12 = @EVMAT TAB1.NOM_MAT.I1 'NU12' TAB1 ;
  8859. TAB1.TETMAT.MO1.NU23 = @EVMAT TAB1.NOM_MAT.I1 'NU23' TAB1 ;
  8860. TAB1.TETMAT.MO1.NU13 = @EVMAT TAB1.NOM_MAT.I1 'NU13' TAB1 ;
  8861. EVMA2 = EVMA2 ET TAB1.TETMAT.MO1.NU12 ET TAB1.TETMAT.MO1.NU23 ET TAB1.TETMAT.MO1.NU13 ;
  8862. TITRE NOM_MAT1 ' THERMAL EXPANSION ' ;
  8863. TAB1.TETMAT.MO1.ALP1 = @EVMAT TAB1.NOM_MAT.I1 'ALP1' TAB1 ;
  8864. TAB1.TETMAT.MO1.ALP2 = @EVMAT TAB1.NOM_MAT.I1 'ALP2' TAB1 ;
  8865. TAB1.TETMAT.MO1.ALP3 = @EVMAT TAB1.NOM_MAT.I1 'ALP3' TAB1 ;
  8866. EVMA3 = EVMA3 ET TAB1.TETMAT.MO1.ALP1 ET TAB1.TETMAT.MO1.ALP2 ET TAB1.TETMAT.MO1.ALP3;
  8867. TAB1.TETMAT.MO1.G12 = @EVMAT TAB1.NOM_MAT.I1 'G12' TAB1 ;
  8868. TAB1.TETMAT.MO1.G23 = @EVMAT TAB1.NOM_MAT.I1 'G23' TAB1 ;
  8869. TAB1.TETMAT.MO1.G13 = @EVMAT TAB1.NOM_MAT.I1 'G13' TAB1 ;
  8870. TM_1 = ( REDU CHP_TM1 TAB1.ZONE_MAT.I1 ) ;
  8871. *
  8872. *** DIRECTION 1
  8873. *
  8874. Y_1 = VARI TM_1 TAB1.TETMAT.MO1.YG1 YG1 ;
  8875. G_1 = VARI TM_1 TAB1.TETMAT.MO1.G12 G12 ;
  8876. N_1 = VARI TM_1 TAB1.TETMAT.MO1.NU12 NU12 ;
  8877. A_1 = VARI TM_1 TAB1.TETMAT.MO1.ALP1 ALP1 ;
  8878. *
  8879. N_1 = CHANGER CHAM N_1 MO1 'RIGIDITE' ;
  8880. Y_1 = CHANGER CHAM Y_1 MO1 'RIGIDITE' ;
  8881. G_1 = CHANGER CHAM G_1 MO1 'RIGIDITE' ;
  8882. A_1 = CHANGER CHAM A_1 MO1 'RIGIDITE' ;
  8883. *
  8884. *** DIRECTION 2
  8885. *
  8886. Y_2 = VARI TM_1 TAB1.TETMAT.MO1.YG2 YG2 ;
  8887. G_2 = VARI TM_1 TAB1.TETMAT.MO1.G23 G23 ;
  8888. N_2 = VARI TM_1 TAB1.TETMAT.MO1.NU23 NU23 ;
  8889. A_2 = VARI TM_1 TAB1.TETMAT.MO1.ALP2 ALP2 ;
  8890. *
  8891. N_2 = CHANGER CHAM N_2 MO1 'RIGIDITE' ;
  8892. Y_2 = CHANGER CHAM Y_2 MO1 'RIGIDITE' ;
  8893. G_2 = CHANGER CHAM G_2 MO1 'RIGIDITE' ;
  8894. A_2 = CHANGER CHAM A_2 MO1 'RIGIDITE' ;
  8895. *
  8896. *** DIRECTION 3
  8897. *
  8898. Y_3 = VARI TM_1 TAB1.TETMAT.MO1.YG3 YG3 ;
  8899. G_3 = VARI TM_1 TAB1.TETMAT.MO1.G13 G13 ;
  8900. N_3 = VARI TM_1 TAB1.TETMAT.MO1.NU13 NU13 ;
  8901. A_3 = VARI TM_1 TAB1.TETMAT.MO1.ALP3 ALP3 ;
  8902. *
  8903. N_3 = CHANGER CHAM N_3 MO1 'RIGIDITE' ;
  8904. Y_3 = CHANGER CHAM Y_3 MO1 'RIGIDITE' ;
  8905. G_3 = CHANGER CHAM G_3 MO1 'RIGIDITE' ;
  8906. A_3 = CHANGER CHAM A_3 MO1 'RIGIDITE' ;
  8907. *
  8908. TEX1 = TEXT CHAYGI ' YG1 Y_1 YG2 Y_2 YG3 Y_3' ;
  8909. TEX2 = TEXT CHAYGI ' G12 G_1 G23 G_2 G13 G_3' ;
  8910. TEX3 = TEXT CHAYGI ' NU12 N_1 NU23 N_2 NU13 N_3' ;
  8911. TEX4 = TEXT CHAYGI ' ALP1 A_1 ALP2 A_2 ALP3 A_3' ;
  8912. SINON ;
  8913.  
  8914. *>>3*************** orthotropie 222222222222222 DDDDDDDDDD
  8915.  
  8916. TAB1.TETMAT.MO1.YG1 = @EVMAT TAB1.NOM_MAT.I1 'YG1' TAB1 ;
  8917. TAB1.TETMAT.MO1.YG2 = @EVMAT TAB1.NOM_MAT.I1 'YG2' TAB1 ;
  8918. EVMA1 = EVMA1 ET TAB1.TETMAT.MO1.YG1 ET TAB1.TETMAT.MO1.YG2 ;
  8919.  
  8920. TITRE NOM_MAT1 ' POISSON COEFFICIENT ' ;
  8921. TAB1.TETMAT.MO1.NU12 = @EVMAT TAB1.NOM_MAT.I1 'NU12' TAB1 ;
  8922.  
  8923. EVMA2 = EVMA2 ET TAB1.TETMAT.MO1.NU12 ;
  8924.  
  8925. TITRE NOM_MAT1 ' THERMAL EXPANSION ' ;
  8926. TAB1.TETMAT.MO1.ALP1 = @EVMAT TAB1.NOM_MAT.I1 'ALP1' TAB1 ;
  8927. TAB1.TETMAT.MO1.ALP2 = @EVMAT TAB1.NOM_MAT.I1 'ALP2' TAB1 ;
  8928. EVMA3 = EVMA3 ET TAB1.TETMAT.MO1.ALP1 ET TAB1.TETMAT.MO1.ALP2 ;
  8929. TAB1.TETMAT.MO1.G12 = @EVMAT TAB1.NOM_MAT.I1 'G12' TAB1 ;
  8930. TM_1 = ( REDU CHP_TM1 TAB1.ZONE_MAT.I1 ) ;
  8931. *
  8932. *** DIRECTION 1
  8933. *
  8934. Y_1 = VARI TM_1 TAB1.TETMAT.MO1.YG1 YG1 ;
  8935. G_1 = VARI TM_1 TAB1.TETMAT.MO1.G12 G12 ;
  8936. N_1 = VARI TM_1 TAB1.TETMAT.MO1.NU12 NU12 ;
  8937. A_1 = VARI TM_1 TAB1.TETMAT.MO1.ALP1 ALP1 ;
  8938. *
  8939. N_1 = CHANGER CHAM N_1 MO1 'RIGIDITE' ;
  8940. Y_1 = CHANGER CHAM Y_1 MO1 'RIGIDITE' ;
  8941. G_1 = CHANGER CHAM G_1 MO1 'RIGIDITE' ;
  8942. A_1 = CHANGER CHAM A_1 MO1 'RIGIDITE' ;
  8943. *
  8944. *** DIRECTION 2
  8945. *
  8946. Y_2 = VARI TM_1 TAB1.TETMAT.MO1.YG2 YG2 ;
  8947. A_2 = VARI TM_1 TAB1.TETMAT.MO1.ALP2 ALP2 ;
  8948. Y_2 = CHANGER CHAM Y_2 MO1 'RIGIDITE' ;
  8949. A_2 = CHANGER CHAM A_2 MO1 'RIGIDITE' ;
  8950.  
  8951. TEX1 = TEXT CHAYGI ' YG1 Y_1 YG2 Y_2 ' ;
  8952. TEX2 = TEXT CHAYGI ' G12 G_1 ' ;
  8953. TEX3 = TEXT CHAYGI ' NU12 N_1 ' ;
  8954. TEX4 = TEXT CHAYGI ' ALP1 A_1 ALP2 A_2 ' ;
  8955. FINSI ;
  8956. ** MA1 = MATE MO1 (TEXT CHAYG1 ' Y_1 ' ) ;
  8957. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYG2 ' Y_2 ')) ;
  8958. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYG3 ' Y_3 ')) ;
  8959. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYG12 ' G_1' )) ;
  8960. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYG23 ' G_2' )) ;
  8961. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYG13 ' G_3' )) ;
  8962. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYNU12 ' N_1' )) ;
  8963. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYNU23 ' N_2' )) ;
  8964. ** MA1 = MA1 ET (MATE MO1 (TEXT CHAYNU13 ' N_3' )) ;
  8965. ;
  8966. MA1 = MATE MO1 TEX1 (TEXT TAB1 . TEXTMECA . 101 ) ;
  8967. MA2 = MATE MO1 TEX2 (TEXT TAB1 . TEXTMECA . 101 ) ;
  8968. MA3 = MATE MO1 TEX3 (TEXT TAB1 . TEXTMECA . 101 ) ;
  8969. MA4 = MATE MO1 TEX4 (TEXT TAB1 . TEXTMECA . 101 ) ;
  8970. MA1 = MA1 ET MA2 ET MA3 ET MA4 ;
  8971.  
  8972. *>>2 ************* Isotropie
  8973.  
  8974.  
  8975. SINON ;
  8976. MESS '>>> NON ORTHO' TAB1.TEXTMECA.I1 ;
  8977. TITRE NOM_MAT1 ' YOUNG MODULUS ' ;
  8978. TAB1.TETMAT.MO1.YOUN = @EVMAT TAB1.NOM_MAT.I1 'YOUN' TAB1 ;
  8979. EVMA1 = EVMA1 ET TAB1.TETMAT.MO1.YOUN ;
  8980. TITRE NOM_MAT1 ' POISSON COEFFICIENT ' ;
  8981. TAB1.TETMAT.MO1.NU = @EVMAT TAB1.NOM_MAT.I1 'NU' TAB1;
  8982. EVMA2 = EVMA2 ET TAB1.TETMAT.MO1.NU ;
  8983. TITRE NOM_MAT1 ' THERMAL EXPANSION ' ;
  8984. TAB1.TETMAT.MO1.ALPH = @EVMAT TAB1.NOM_MAT.I1 'ALPH' TAB1;
  8985. EVMA3 = EVMA3 ET TAB1.TETMAT.MO1.ALPH ;
  8986. TM_1 = ( REDU CHP_TM1 TAB1.ZONE_MAT.I1 ) ;
  8987. Y_1 = VARI TM_1 TAB1.TETMAT.MO1.YOUN YOUN ;
  8988. NU_1 = VARI TM_1 TAB1.TETMAT.MO1.NU NU ;
  8989. AL_1 = VARI TM_1 TAB1.TETMAT.MO1.ALPH ALPH ;
  8990. NU_1 = CHANGER CHAM NU_1 MO1 'RIGIDITE' ;
  8991. Y_1 = CHANGER CHAM Y_1 MO1 'RIGIDITE' ;
  8992. AL_1 = CHANGER CHAM AL_1 MO1 'RIGIDITE' ;
  8993. TEX1 = TEXTE ' YOUN Y_1 NU NU_1 ALPH AL_1 ' ;
  8994. MA1 = MATE MO1 TEX1 ;
  8995. FINSI ;
  8996. *>>2
  8997. IMOTM1 = DIME (MOTS TMECA_I1) ;
  8998. SI ( IMOTM1 EGA 5 ) ;
  8999. TITRE NOM_MAT1 ' YIELD STRESS ' ;
  9000. TAB1.TETMAT.MO1.SIGY = @EVMAT TAB1.NOM_MAT.I1 'SIGY' TAB1 ;
  9001. EVMA4 = EVMA4 ET TAB1.TETMAT.MO1.SIGY ;
  9002. TEX1 = TEXTE TEX1 ' SIGY YM_1 ' ;
  9003. TITRE NOM_MAT1 ' YIELD MODULUS' ;
  9004. YM_1 = VARI TM_1 TAB1.TETMAT.MO1.SIGY SIGY ;
  9005. YM_1 = CHANGER CHAM YM_1 MO1 'RIGIDITE' ;
  9006. TAB1.TETMAT.MO1.H = @EVMAT TAB1.NOM_MAT.I1 'H' TAB1 ;
  9007. EVMA5 = EVMA5 ET TAB1.TETMAT.MO1.H ;
  9008. H_1 = VARI TM_1 TAB1.TETMAT.MO1.H H ;
  9009. H_1 = CHANGER CHAM H_1 MO1 'RIGIDITE' ;
  9010. TEX1 = TEXTE TEX1 'H H_1 ' ;
  9011. MA1 = MATE MO1 TEX1 ;
  9012. * TEMP IMPR PLACE ;
  9013. * MENAGE ;
  9014.  
  9015. @TRCPLAS TAB1 MO1 I1 ;
  9016. TEX5 = TEXT ' MA1 = MATE MO1 ' ;
  9017. * TEX5 TEX1 TEX2 TEX3 TEX4 ;
  9018. FINSI;
  9019. *>1
  9020. SINON ;
  9021. QUITTER BOMA11 ;
  9022. FINSI ;
  9023. *>1
  9024. SI ( I1 EGA 1 ) ;
  9025. MOD_1 = MO1 ;
  9026. MAT_1 = MA1 ;
  9027. SINON ;
  9028. MOD_1 = MOD_1 ET MO1 ;
  9029. MAT_1 = MAT_1 ET MA1 ;
  9030. FINSI ;
  9031. TAB1.MAT_MAT.I1 = MA1 ;
  9032. FIN BOMA11 ;
  9033. TAB1.MATTOT = MAT_1 ;
  9034. TAB1.MODTOT = MOD_1 ;
  9035. TAC8 = TABLE ;
  9036. TAC8.1 = ' NOLI ' ;
  9037. TAC8.2 = 'MARQ PLUS REGU' ;
  9038. TAC8.3 = 'MARQ ETOI REGU' ;
  9039. TAC8.4 = 'MARQ LOSA REGU' ;
  9040. TAC8.5 = 'MARQ CARR REGU' ;
  9041. TAC8.6 = 'MARQ TRIA REGU' ;
  9042. TAC8.7 = 'MARQ TRIB REGU' ;
  9043. TAC8.8 = 'MARQ PLUS REGU' ;
  9044. TAC8.9 = 'MARQ ETOI REGU' ;
  9045. TAC8.10 = 'MARQ CROI REGU' ;
  9046. DESS EVMA1 XBOR 0. 2000. LEGE MIMA DATE TAC8 ;
  9047. DESS EVMA2 XBOR 0. 2000. LEGE MIMA DATE TAC8 ;
  9048. DESS EVMA3 XBOR 0. 2000. LEGE MIMA DATE TAC8 ;
  9049. DESS EVMA4 XBOR 0. 2000. LEGE MIMA DATE TAC8 ;
  9050. DESS EVMA5 XBOR 0. 2000. LEGE MIMA DATE TAC8 ;
  9051. MESS ' >>>>>>> fin materiaux' ;
  9052. MO1 = TAB1.MODL_MAT.1 ;
  9053. MA1 = TAB1.MAT_MAT.1 ;
  9054. CHAEPXX = MANU 'CHML' MO1 EPXX 0.001 EPYY 0. EPZZ 0. GAXY 0. GAXZ 0. GAYZ 0. TYPE 'DEFORMATIONS' 'STRESSES' ;
  9055. HO11 = HOOK MO1 MA1 ;
  9056. CHASIXX = MO1 HO11 * CHAEPXX ;
  9057. MESS ' >>>****** MAXI MINI CONT ' (MAXI CHASIXX AVEC (MOTS SMXX)) (MINI CHASIXX AVEC (MOTS SMXX));
  9058. CHAEEXX = MO1 HO11 * CHASIXX ;
  9059. MESS ' >>>****** MAXI MINI CONT ' (MAXI CHAEEXX AVEC (MOTS EPXX)) (MINI CHAEEXX AVEC (MOTS EPXX));
  9060. MESS '---------------------------------> sortie de DEFMAT';
  9061. FINPROC ;
  9062. * *
  9063. * *
  9064. * *
  9065. * *
  9066. DEBPROC DEFORAPH LIGN_1*MAILLAGE INSTEVOL*FLOTTANT MOD1*MMODEL TAB1*TABLE SM1/EVOLUTION EM1/EVOLUTION VAL1/FLOTTANT VAL2/FLOTTANT;
  9067.  
  9068. MESS '-----------------------------------> entree dans DEFORAPH ' ;
  9069. *
  9070. * !!! NON ENCORE OPERATIONNEL !!!
  9071. *
  9072. MESS ' !!! NON ENCORE OPERATIONNEL !!! ' ;
  9073.  
  9074. DIM1 = VALEUR DIME ;
  9075.  
  9076. * test sur la dimension
  9077. SI (EGA DIM1 2);
  9078. MESS ' attention contraph ne tourne pas en 3D';
  9079. QUITTER CONTRAPH ;
  9080. * malgre le probleme de PROI en 3D, qui n a pas ete regle
  9081. * mais qu on accepte faute de mieux
  9082. FINSI;
  9083.  
  9084.  
  9085. SI (NON (EXISTE TAB1 RESUCONT)) ;
  9086. MESS ' TAB1 NE CONTIENT PAS DE CONTRAINTES ' ;
  9087. MESS ' SORTIE DE CONTRAPH ' ;
  9088. QUITTER CONTRAPH ;
  9089. FINSI ;
  9090.  
  9091. * test sur la dimension de LIGN_1*MAILLAGE : a faire
  9092.  
  9093. LCONFON = FAUX ;
  9094. MAIL_1 = MOD1 EXTR 'MAIL' ;
  9095. N_1 = NBNO MAIL_1 ;
  9096. N_2 = NBNO (MAIL_1 ET LIGN_1 ) ;
  9097.  
  9098. SI ( EGA N_1 N_2 ) ;
  9099. LCONFON = VRAI ;
  9100. FINSI ;
  9101.  
  9102. SI (NON(EXISTE TAB1 TETMAT)) ;
  9103. MESS ' TAB1 NE CONTIENT PAS DE TETMAT ' ;
  9104. MESS ' SORTIE DE CONTRAPH ' ;
  9105. QUITTER CONTRAPH ;
  9106. FINSI ;
  9107.  
  9108. SI (NON(EXISTE (TAB1.TETMAT) MOD1)) ;
  9109. MESS ' TAB1.TETMAT NE CONTIENT PAS DE MODELE ' ;
  9110. MESS ' SORTIE DE CONTRAPH ' ;
  9111. QUITTER CONTRAPH ;
  9112. FINSI ;
  9113.  
  9114. SI (NON(EXISTE (TAB1.TETMAT.MOD1) SIGY)) ;
  9115. MESS ' LE MATERIAU DEMANDE N EST PAS PLASTIQUE ' ;
  9116. MESS ' SORTIE DE CONTRAPH ' ;
  9117. QUITTER CONTRAPH ;
  9118. FINSI ;
  9119.  
  9120. TITR ' DEPOUILLEMENT LE LONG DE LA LIGNE ' ;
  9121. *
  9122. * --- Depouillement en deformation
  9123. *
  9124. DEPL1 = TAB1.RESUDEPL.INSTEVOL ;
  9125. TOTA1 = EPSI MOD1 (REDU DEPL1 (EXTR MOD1 MAIL)) ;
  9126. PLAS1 = EXCO ( TAB1.RESUVARI. INSTEVOL) EPSE ;
  9127.  
  9128. * --- METHODE 1
  9129. * evaluation de la deformation ELASTIQUE PAR ELAS
  9130. * caract pris contant egal a sa moyenne sur l'intervalle de T considere
  9131. * deduction de EPStherm
  9132. CONT1 = REDU (TAB1.RESUCONT.INSTEVOL) MOD1 ;
  9133. ELAS1_1 = ELAS MOD1 CONT1 (TAB1.MAT_MAT.3) ;
  9134.  
  9135.  
  9136.  
  9137. * --- METHODE 2
  9138. * evaluation de la deformation du a la thermique
  9139. * alpha pris contant egal a sa moyenne sur l'intervalle de T considere
  9140. * deduction de EPS elas
  9141. ID1 = INDE (TAB1.'CHPOTHETA') ;
  9142. CHT1 = TAB1.CHPOTHETA . INSTEVOL - (TAB1.CHPOTHETA. (ID1 . 1)) ;
  9143. CHT2 = (TAB1.CHPOTHETA. (ID1 . 1)) + (CHT1 / 2.) ;
  9144. ALPHA1 = VARI CHT2 TAB1.TETMAT.MOD1.'ALPH' ;
  9145. THER2_1 = ALPHA1 * (EXCO CHT1 'T') ;
  9146. THER2_2 = (CHAN CHAM THER2_1 (EXTR MOD1 MAIL) NOEUD) * -1. ;
  9147. THER2_2 = (CHAN CHAM THER2_1 (EXTR MOD1 MAIL) NOEUD) ;
  9148.  
  9149.  
  9150.  
  9151. * evaluation de la limite elastique exprimee en epsilon
  9152. * cette limite est egale a Re/E c'est a dire SIGY / YOUN en langage CASTEM
  9153. * le tout dependant de la temperature du point considere
  9154.  
  9155. CHYOUN1 = VARI TAB1.CHPOTHETA.INSTEVOL TAB1.TETMAT.MOD1.'YOUN' ;
  9156. CHSIGY1 = VARI TAB1.CHPOTHETA.INSTEVOL TAB1.TETMAT.MOD1.'SIGY' ;
  9157.  
  9158. CHYOUN2 = CHYOUN1 ** (-1) ;
  9159. CHSIGY2 = CHAN CHAM CHSIGY1 (EXTR MOD1 MAIL) NOEUD ;
  9160.  
  9161. CHYOUN3 = CHAN CHAM CHYOUN2 (EXTR MOD1 MAIL) NOEUD ;
  9162. CHSIGY3 = CHSIGY2 ;
  9163.  
  9164. LIMELAS1 = CHSIGY3 * CHYOUN3 ;
  9165.  
  9166.  
  9167. SI LCONFON ;
  9168. TOTA2 = CHAN 'CHPO' MOD1 TOTA1 ;
  9169. PLAS2 = CHAN 'CHPO' MOD1 (REDU PLAS1 MOD1) ;
  9170. LIMELAS2 = CHAN 'CHPO' MOD1 LIMELAS1 ;
  9171. THER2_3 = CHAN 'CHPO' MOD1 THER2_2;
  9172. ELAS1_2 = CHAN 'CHPO' MOD1 ELAS1_1 ;
  9173. SI (EXISTE EM1 ) ;
  9174. FINSI ;
  9175. SINON ;
  9176. TOTA2 = PROI LIGN_1 (CHAN NOEUD MOD1 TOTA1) ;
  9177. PLAS2 = PROI LIGN_1 (CHAN NOEUD MOD1 (REDU PLAS1 MOD1)) ;
  9178. LIMELAS2 = PROI LIGN_1 LIMELAS1 ;
  9179. ELAS1_2 = PROI LIGN_1 (CHAN NOEUD MOD1 ELAS1_1) ;
  9180. THER2_3 = PROI LIGN_1 THER2_2;
  9181. SI (EXISTE EM1) ;
  9182. FINSI ;
  9183. FINSI ;
  9184.  
  9185.  
  9186.  
  9187. SI (EGA DIM1 2) ;
  9188. EXX1 = EXCO EPSETOT2 EPXX ;
  9189. EYY1 = EXCO EPSETOT2 EPYY ;
  9190. GXY1 = EXCO EPSETOT2 GAXY ;
  9191. EPSETOT2 = ((2. ** .5 ) / 3.) * (( ((EXX1 - EYY1 ) ** 2) + 6 * ((GXY1 * 2. ) ** 2) ) ** .5);
  9192.  
  9193.  
  9194.  
  9195. SINON ;
  9196. EXX1 = EXCO TOTA2 EPXX ;
  9197. EYY1 = EXCO TOTA2 EPYY ;
  9198. EZZ1 = EXCO TOTA2 EPZZ ;
  9199. GXY1 = EXCO TOTA2 GAXY ;
  9200. GXZ1 = EXCO TOTA2 GAXZ ;
  9201. GYZ1 = EXCO TOTA2 GAYZ ;
  9202. TOTA3 = ((2. ** .5 ) / 3.) * ( ( ((EXX1 - EYY1 ) ** 2) + ((EXX1 - EZZ1 ) ** 2) + ((EYY1 - EZZ1 ) ** 2) + 6. * ( ((GXY1 / 2.) ** 2) + ((GXZ1 / 2.) ** 2) + ((GYZ1 / 2.)** 2) ) ) ** .5);
  9203. EXX1 = EXCO ELAS1_2 EPXX ;
  9204. EYY1 = EXCO ELAS1_2 EPYY ;
  9205. EZZ1 = EXCO ELAS1_2 EPZZ ;
  9206. GXY1 = EXCO ELAS1_2 GAXY ;
  9207. GXZ1 = EXCO ELAS1_2 GAXZ ;
  9208. GYZ1 = EXCO ELAS1_2 GAYZ ;
  9209. ELAS1_3 = ((2. ** .5 ) / 3.) * ( ( ((EXX1 - EYY1 ) ** 2) + ((EXX1 - EZZ1 ) ** 2) + ((EYY1 - EZZ1 ) ** 2) + 6. * (( (GXY1 / 2.) ** 2) + ((GXZ1 / 2.)** 2) + ((GYZ1 / 2.)** 2)) ) ** .5);
  9210.  
  9211.  
  9212. FINSI ;
  9213.  
  9214. THER1_1 = (EXCO TOTA3 SCAL) - (EXCO PLAS2 EPSE) - (EXCO ELAS1_3 SCAL) ;
  9215. ELAS2_1 = (EXCO TOTA3 SCAL) - (EXCO PLAS2 EPSE) - (EXCO THER2_3 (EXTR (EXTR THER2_3 COMP) 1)) ;
  9216.  
  9217. EVEL1 = EVOL CHPO ELAS1_3 LIGN_1 ;
  9218. EVEL2 = EVOL CHPO ELAS2_1 LIGN_1 ;
  9219. TAC1 = TABLE ;
  9220. TAC1.1 = 'MARQ LOSA REGU TITR METH1';
  9221. TAC1.3 = 'MARQ CROI REGU TITR METH2';
  9222. EVELL = EVEL1 ET EVEL2 ;
  9223. DESS EVELL LEGE TAC1 ;
  9224.  
  9225. EVET1 = EVOL CHPO THER1_1 LIGN_1 ;
  9226. EVET2 = EVOL CHPO THER2_3 LIGN_1 ;
  9227. TAC1 = TABLE ;
  9228. TAC1.1 = 'MARQ LOSA REGU TITR METH1';
  9229. TAC1.3 = 'MARQ CROI REGU TITR METH2';
  9230. EVETT = EVET1 ET EVET2 ;
  9231. DESS EVETT LEGE TAC1 ;
  9232.  
  9233.  
  9234.  
  9235. TITRE 'EPS_TOT' ;
  9236. EVTOT1 = EVOL CHPO EPSETOT2 LIGN_1 ;
  9237. TITRE 'EPS_PLAS' ;
  9238. EVPLAS1 = EVOL CHPO EPSPLAS2 LIGN_1 ;
  9239. TITRE 'EPS_THER' ;
  9240. EVTHER1 = EVOL CHPO EPSTHER3 LIGN_1 ;
  9241. TITRE 'LIM_ELAS' ;
  9242. EVLIEL1 = EVOL CHPO LIMELAS2 LIGN_1 ;
  9243.  
  9244. TAD1 = TABLE ;
  9245. TAD1.1 = CHAI 'MARQ CROI REGU TITR EPS_TOT' ;
  9246. TAD1.3 = CHAI 'MARQ ETOI REGU TITR EPS_PLAS ' ;
  9247. TAD1.5 = CHAI 'MARQ LOSA REGU TITR EPS_THER ' ;
  9248. TAD1.7 = CHAI 'MARQ TRIA REGU TITR LIM_ELAS ' ;
  9249. EVEPS1 = EVTOT1 ET EVPLAS1 ET EVTHER1 ET EVLIEL1 ;
  9250. DESS EVEPS1 LEGE MIMA TAD1 ;
  9251.  
  9252.  
  9253. MESS '-----------------------------------> sortie de DEFORAPH ' ;
  9254.  
  9255. FINPROC ;
  9256.  
  9257. **** @DEFO_EQ
  9258. DEBPROC @DEFO_EQ EPSE1*MCHAML MOD1*MMODEL ;
  9259. MESS '----------------------------> calling @DEFO_EQ';
  9260.  
  9261. EX1 = EXCO EPSE1 EPXX NOID SCAL ;
  9262. EY1 = EXCO EPSE1 EPYY NOID SCAL ;
  9263. EZ1 = EXCO EPSE1 EPZZ NOID SCAL ;
  9264. EG1 = EXCO EPSE1 GAXY NOID SCAL ;
  9265. EG2 = EXCO EPSE1 GAXZ NOID SCAL ;
  9266. EG3 = EXCO EPSE1 GAYZ NOID SCAL ;
  9267.  
  9268. TERM1 = (EX1 - EY1 ) ** 2 ;
  9269. TERM2 = (EY1 - EZ1 ) ** 2 ;
  9270. TERM3 = (EZ1 - EX1 ) ** 2 ;
  9271. TERM4 = 6. *( ((ABS (EG1/2.) ) ** 2.) + ((ABS (EG2/2.) ) ** 2.) + ((ABS (EG3/2.) ) ** 2.) );
  9272.  
  9273. EPS_ETOI = ((2. ** .5 )/3.) * ((TERM1 + TERM2 + TERM3 + TERM4 ) ** .5 );
  9274.  
  9275. * MIN1 = MINI EPS_ETOI ;
  9276. * MAX1 = MAXI EPS_ETOI ;
  9277.  
  9278. * RM 30/08/95 suppression du trace du champ
  9279. *
  9280. * SI (EGA MIN1 MAX1 1.E-6) ;
  9281. * MESS ' epsilon equivalent constant egal a ' MAX1;
  9282. * SINON ;
  9283. * TITR1 = CHAIN 'mini maxi epsilon equivalent : 'MIN1 MAX1;
  9284. * TITR TITR1 ;
  9285. * TRAC EPS_ETOI MOD1 (EXTR MOD1 'MAIL');
  9286. * FINSI ;
  9287. *
  9288. MESS '----------------------------> exiting @DEFO_EQ';
  9289. FINPROC EPS_ETOI;
  9290. **** @DEMATH1
  9291. DEBPROC @DEMATH1 TAB1*TABLE ;
  9292.  
  9293. MESS ' ';
  9294. NIVEAU = TAB1.'NIVEAU' ;
  9295. V1 = VALE DIME ;
  9296.  
  9297. * modification RMITTEAU le 6 juin 96 pour avoir les bonnes legendes
  9298. * dans lestraces
  9299. * avec la version 96
  9300.  
  9301. SI (NIVEAU >EG 4) ;
  9302. MESS '---------------------------------> calling @DEMATH1';
  9303. FINSI ;
  9304.  
  9305. TACC1 = TABLE ;
  9306. TACC1.TITRE = TABLE ;
  9307. TAB1.DEF_MO = TABLE;
  9308. IC1 = 0 ;
  9309.  
  9310. SI ( EXISTE (TAB1.ZONE_MAT) 1 ) ;
  9311. MESS '>@DEMATH1> Materiau ----> 1 ';
  9312. MESS '>@DEMATH1> Definition of the conductivity of ' TAB1.NOM_MAT.1 ;
  9313. TITRE 'MATERIAL CONDUCTIVITY OR CAPACITY' ;
  9314. TAB1.'MAILLAG1' = TAB1. ZONE_MAT.1 ;
  9315. TAB1.'MAILLAGE' = TAB1. ZONE_MAT.1 ;
  9316.  
  9317. SI ( EXISTE (TAB1.NOM_MAT) 1.1 ) ;
  9318.  
  9319. MESS '>@DEMATH1> ' TAB1.NOM_MAT.1 ' est orthotrope';
  9320. SI ( NON ( EXISTE (TAB1.NOM_MAT) 1) ) ;
  9321. TAB1. NOM_MAT . 1 = TEXT '_ORTHOTROPE' ;
  9322. FINSI ;
  9323.  
  9324. TAB1.'EVOKX1' = @EVMAT (TAB1.NOM_MAT. 1.1) 'CONDUCTIVITE' TAB1 ;
  9325. TAB1.'EVOKY1' = @EVMAT (TAB1.NOM_MAT. 1.2) 'CONDUCTIVITE' TAB1 ;
  9326. TAB1.'EVOKZ1' = @EVMAT (TAB1.NOM_MAT. 1.3) 'CONDUCTIVITE' TAB1 ;
  9327.  
  9328. TAB1.'CONDUCT1' = @EVMAT (TAB1.NOM_MAT. 1.1) 'CONDUCTIVITE' TIN TAB1;
  9329. si (ega v1 2) ;
  9330. EVMA1 = ( TAB1.'EVOKX1') ET ( TAB1.'EVOKY1') ;
  9331. IC1 = IC1 + 1;
  9332. TACC1.IC1 = 'MARQ CARR ' ;
  9333. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1.1 ;
  9334. IC1 = IC1 + 1 ;
  9335. TACC1.IC1 = 'MARQ TRIA ' ;
  9336. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1.2 ;
  9337. sinon ;
  9338. EVMA1 = ( TAB1.'EVOKX1') ET ( TAB1.'EVOKY1') ET TAB1.'EVOKZ1' ;
  9339. IC1 = IC1 + 1;
  9340. TACC1.IC1 = 'MARQ CARR ' ;
  9341. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1.1 ;
  9342. IC1 = IC1 + 1 ;
  9343. TACC1.IC1 = 'MARQ TRIA ' ;
  9344. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1.2 ;
  9345. IC1 = IC1 + 1 ;
  9346. TACC1.IC1 = 'MARQ TRIA ' ;
  9347. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1.3 ;
  9348.  
  9349. finsi ;
  9350. TAB1.DEF_MO.1 = MODE TAB1.ZONE_MAT.1 'THERMIQUE' 'ORTHOTROPE' ;
  9351.  
  9352. SINON ;
  9353. MESS '>@DEMATH1> ' TAB1.NOM_MAT.1 ' est isotrope';
  9354. TAB1.'EVOCON1' = @EVMAT (TAB1.NOM_MAT.1) 'CONDUCTIVITE' TAB1;
  9355. TAB1.'CONDUCT1' = @EVMAT (TAB1.NOM_MAT.1) 'CONDUCTIVITE' TIN TAB1;
  9356. TAB1.'EVOCOND' = @EVMAT (TAB1.NOM_MAT.1) 'CONDUCTIVITE' TAB1 ;
  9357. EVMA1 = TAB1.'EVOCON1' ;
  9358. TAB1.DEF_MO.1 = MODE TAB1.ZONE_MAT.1 'THERMIQUE' 'ISOTROPE' ;
  9359. IC1 = IC1 + 1 ;
  9360. TACC1.IC1 = 'MARQ TRIA ' ;
  9361. TACC1.TITRE.IC1 = TAB1.NOM_MAT.1;
  9362. MESS TACC1.IC1 ;
  9363. FINSI ;
  9364. SI ( TAB1.TRANSITOIRE ) ;
  9365. MESS '>@DEMATH1> Definition of the capacity of ' TAB1.NOM_MAT.1 ;
  9366. TAB1.'EVOCAPA' = @EVMAT (TAB1. NOM_MAT.1) 'CAPACITE' TAB1;
  9367. EVCA1 = TAB1.'EVOCAPA' ;
  9368. FINSI ;
  9369. FINSI ;
  9370. SI ( EXISTE (TAB1.ZONE_MAT) 2 ) ;
  9371. MESS '>@DEMATH1> Materiau ----> 2 ';
  9372. MESS '>@DEMATH1> Definition of the conductivity of ' TAB1.NOM_MAT.2 ;
  9373. TAB1.'MAILLAG2' = TAB1. ZONE_MAT.2 ;
  9374. * TAB1.'EVOCON2' = @EVMAT (TAB1. NOM_MAT.2) 'CONDUCTIVITE' TAB1 ;
  9375. * TAB1.'CONDUCT2' = @EVMAT (TAB1. NOM_MAT.2) 'CONDUCTIVITE' TIN TAB1 ;
  9376. * EVMA1 = EVMA1 ET ( TAB1.'EVOCON2') ;
  9377. * IC1 = IC1 + 1 ;
  9378. * TACC1.IC1 = ET 'MARQ CARR TITRE' ' ' TAB1.NOM_MAT.2;
  9379. * TAB1.DEF_MO.2 = MODE TAB1.ZONE_MAT.2 'THERMIQUE' 'ISOTROPE' ;
  9380. *> js 050296
  9381. SI ( EXISTE (TAB1.NOM_MAT) 2.1 ) ;
  9382. MESS '>@DEMATH1> ' TAB1.NOM_MAT.2 ' est orthotrope';
  9383. SI ( NON ( EXISTE (TAB1.NOM_MAT) 2) ) ;
  9384. TAB1. NOM_MAT . 2 = TEXT '_ORTHOTROPE' ;
  9385. FINSI ;
  9386. TAB1.'EVOKX2' = @EVMAT (TAB1.NOM_MAT. 2.1) 'CONDUCTIVITE' TAB1 ;
  9387. TAB1.'EVOKY2' = @EVMAT (TAB1.NOM_MAT. 2.2) 'CONDUCTIVITE' TAB1 ;
  9388. TAB1.'EVOKZ2' = @EVMAT (TAB1.NOM_MAT. 2.3) 'CONDUCTIVITE' TAB1 ;
  9389. TAB1.'CONDUCT2' =@EVMAT (TAB1.NOM_MAT. 2.1) 'CONDUCTIVITE' TIN TAB1;
  9390. EVMA1 = EVMA1 ET ( TAB1.'EVOKX2') ET ( TAB1.'EVOKY2');
  9391. IC1 = IC1 + 1;
  9392. TACC1.IC1 = 'MARQ CROI ' ;
  9393. TACC1.TITRE.IC1 = (TAB1.NOM_MAT.2.1);
  9394. * MESS TACC1.IC1 ;
  9395. IC1 = IC1 + 1 ;
  9396. TACC1.IC1 = 'MARQ TRIA ' ;
  9397. TACC1.TITRE.IC1 = (TAB1.NOM_MAT.2.2);
  9398. * MESS TACC1.IC1 ;
  9399. TAB1.DEF_MO.2 = MODE TAB1.ZONE_MAT.2 'THERMIQUE' 'ORTHOTROPE' ;
  9400. SINON ;
  9401. TAB1.'EVOCON2' = @EVMAT (TAB1.NOM_MAT.2) 'CONDUCTIVITE' TAB1;
  9402. TAB1.'CONDUCT2' = @EVMAT (TAB1.NOM_MAT.2) 'CONDUCTIVITE' TIN TAB1;
  9403. TAB1.'EVOCON2' = @EVMAT (TAB1.NOM_MAT.2) 'CONDUCTIVITE' TAB1 ;
  9404. EVMA1 = EVMA1 ET TAB1.'EVOCON2' ;
  9405. TAB1.DEF_MO.2 = MODE TAB1.ZONE_MAT.2 'THERMIQUE' 'ISOTROPE' ;
  9406. IC1 = IC1 + 1 ;
  9407. TACC1.IC1 = 'MARQ TRIB ' ;
  9408. TACC1.TITRE.IC1 = (TAB1.NOM_MAT.2);
  9409. * MESS TACC1.IC1 ;
  9410. FINSI ;
  9411. *>
  9412. SI ( TAB1.TRANSITOIRE ) ;
  9413. MESS '>@DEMATH1> Definition of the capacity of ' TAB1.NOM_MAT.2 ;
  9414. TAB1.'EVOCAP2' = @EVMAT (TAB1. NOM_MAT.2) 'CAPACITE' TAB1 ;
  9415. EVCA1 = EVCA1 ET ( TAB1.'EVOCAP2') ;
  9416. FINSI ;
  9417. FINSI ;
  9418. SI ( EXISTE (TAB1.ZONE_MAT) 3 ) ;
  9419. MESS '>@DEMATH1> Materiau ----> 3 ';
  9420. MESS '>@DEMATH1> Definition of the conductivity of ' TAB1.NOM_MAT.3 ;
  9421. TAB1.'MAILLAG3' = TAB1. ZONE_MAT.3 ;
  9422. TAB1.'EVOCON3' = @EVMAT (TAB1. NOM_MAT.3) 'CONDUCTIVITE' TAB1 ;
  9423. TAB1.'CONDUCT3' = @EVMAT (TAB1. NOM_MAT.3) 'CONDUCTIVITE' TIN TAB1 ;
  9424. EVMA1 = EVMA1 ET ( TAB1.'EVOCON3') ;
  9425. IC1 = IC1 + 1 ;
  9426. TACC1.IC1 = 'MARQ ETOI ' ;
  9427. TACC1.TITRE.IC1=TAB1.NOM_MAT.3;
  9428. TAB1.DEF_MO.3 = MODE TAB1.ZONE_MAT.3 'THERMIQUE' 'ISOTROPE' ;
  9429. SI ( TAB1.TRANSITOIRE ) ;
  9430. MESS '>@DEMATH1> Definition of the capacity of ' TAB1.NOM_MAT.3 ;
  9431. TAB1.'EVOCAP3' = @EVMAT (TAB1. NOM_MAT.3) 'CAPACITE' TAB1 ;
  9432. EVCA1 = EVCA1 ET ( TAB1.'EVOCAP3') ;
  9433. FINSI ;
  9434. FINSI ;
  9435. SI ( EXISTE (TAB1.ZONE_MAT) 4 ) ;
  9436. MESS '>@DEMATH1> Material ----> 4 ';
  9437. MESS '>@DEMATH1> Definition of the conductivity of ' TAB1.NOM_MAT.4 ;
  9438. TAB1.'MAILLAG4' = TAB1. ZONE_MAT.4 ;
  9439. TAB1.'EVOCON4' = @EVMAT (TAB1. NOM_MAT.4) 'CONDUCTIVITE' TAB1 ;
  9440. TAB1.'CONDUCT4' = @EVMAT (TAB1. NOM_MAT.4) 'CONDUCTIVITE' TIN TAB1 ;
  9441. EVMA1 = EVMA1 ET ( TAB1.'EVOCON4') ;
  9442. IC1 = IC1 + 1 ;
  9443. TACC1.IC1 = 'MARQ LOSA ' ;
  9444. TACC1.TITRE.IC1 = TAB1.NOM_MAT.4 ;
  9445. TAB1.DEF_MO.4 = MODE TAB1.ZONE_MAT.4 'THERMIQUE' 'ISOTROPE' ;
  9446. SI ( TAB1.TRANSITOIRE ) ;
  9447. MESS '>@DEMATH1> Definition of the capacity of ' TAB1.NOM_MAT.4 ;
  9448. TAB1.'EVOCAP4' = @EVMAT (TAB1. NOM_MAT.4) 'CAPACITE' TAB1 ;
  9449. EVCA1 = EVCA1 ET ( TAB1.'EVOCAP4') ;
  9450. FINSI ;
  9451. FINSI ;
  9452. SI (NIVEAU >EG 4) ;
  9453. MESS '---------------------------------> exiting @DEMATH1';
  9454. FINSI ;
  9455. FINPROC EVMA1 EVCA1 TACC1 ;
  9456.  
  9457.  
  9458. **** @DEMATH2
  9459. DEBPROC @DEMATH2 TAB1*TABLE ;
  9460. TAB1.TABCON = TABLE ;
  9461. IPP1 = 0 ;
  9462. REPETER BOUCM7 ;
  9463. IPP1 = IPP1 + 1 ;
  9464. SI ( EXISTE (TAB1.ZONE_MAT) IPP1 ) ;
  9465. * MO_1 = MODE TAB1.ZONE_MAT.IPP1 'THERMIQUE' 'ISOTROPE';
  9466. MO_1 = TAB1.DEF_MO.IPP1 ;
  9467. TAB1.ZONE_MAT.IPP1 = EXTR 'MAIL' TAB1.DEF_MO.IPP1 ;
  9468. TAB1.TABCON.MO_1 =@EVMAT (TAB1.NOM_MAT.IPP1) 'CONDUCTIVITE' TAB1;
  9469. SINON ;
  9470. QUITTER BOUCM7 ;
  9471. FINSI ;
  9472. FIN BOUCM7 ;
  9473. FINPROC EVMA1 EVCA1 TACC1 ;
  9474.  
  9475.  
  9476. DEBPROC DEPOMIMA TAB1*TABLE ;
  9477. OPTION ECHO 1 IMPR 99 TRAC BENS ;
  9478. MOD_1 = TAB1.MODTOT ;
  9479. MAT_1 = TAB1.MATTOT ;
  9480. SI (EXISTE TAB1 L_ADEPOU ) ;
  9481. L_1 = TAB1.L_ADEPOU ;
  9482. FINSI ;
  9483. SI ( NON (EXISTE TAB1 MO_ADEPOU )) ;
  9484. MOTOT1 = MOD_1 ;
  9485. SINON ;
  9486. MOTOT1 = TAB1.MO_ADEPOU ;
  9487. FINSI ;
  9488. N_MAIL = EXTR 'MAIL' MOTOT1 ;
  9489. *SI ( NON (EXISTE TAB1 NMAIL_ADEPOU )) ;
  9490. * N_MAIL = 'MAIL TOT' ;
  9491. *SINON ;
  9492. * N_MAIL = TAB1.NMAIL_ADEPOU ;
  9493. *FINSI ;
  9494. I1 = 0 ;
  9495. MESS ' >>>>>>>> ' N_MAIL ' :' ;
  9496. MESS ' ====================================' ;
  9497. SAUT 2 LIGNE ;
  9498. MESS '******************************' ;
  9499. MESS '*** CONTRAINTES **' ;
  9500. MESS '******************************' ;
  9501. REPETER BDEPO1 ( DIME TAB1.L_CASADEPOU ) ;
  9502. I1 = I1 + 1 ;
  9503. XIT1 = EXTR I1 TAB1.L_CASADEPOU ;
  9504. VMI1 = VMIS MOD_1 TAB1.RESUCONT.XIT1 ;
  9505. SIRESU1 = TAB1.RESUCONT.XIT1 ET VMI1 ;
  9506. SIRESUA = TAB1.RESUVARI.XIT1 ET VMI1 ;
  9507. I2 = 0 ;
  9508. SAUT 2 LIGNE ;
  9509. MESS 'TIME' XIT1 ;
  9510. SAUT LIGNE ;
  9511. MESS ' MINI * MAXI';
  9512. SAUT LIGNE ;
  9513. REPETER BDEPO2 ( DIME TAB1.LM_SIGCOMP) ;
  9514. I2 = I2 + 1 ;
  9515. MOCOMP = EXTR TAB1.LM_SIGCOMP I2 ;
  9516. TMOCOMP = TEXT MOCOMP ;
  9517. SI (( EGA MOCOMP 'VMIS') OU ( EGA MOCOMP 'VONM') ) ;
  9518. MOCOMP = 'SCAL' ;
  9519. FINSI ;
  9520. SBID1 = REDU ( EXCO SIRESU1 MOCOMP ) MOTOT1 ;
  9521. MAXSB1 = ((MAXI SBID1)/1.E6) ;
  9522. MINSB1 = ((MINI SBID1)/1.E6) ;
  9523. MESS TMOCOMP ' (MPa) : ' MINSB1 ' * ' MAXSB1 ;
  9524. FIN BDEPO2 ;
  9525. SI (EXISTE TAB1 L_ADEPOU ) ;
  9526. DEPOULI L_1 'CONTRAINTES' MOD_1 TAB1.RESUCONT.XIT1 GLOBAL MASSIF ;
  9527. FINSI ;
  9528. FIN BDEPO1 ;
  9529. I3 = 0 ;
  9530. SAUT 2 LIGNE ;
  9531. MESS '******************************' ;
  9532. MESS '*** DEFORMATIONS **' ;
  9533. MESS '******************************' ;
  9534. SAUT 2 LIGNE ;
  9535. REPETER BDEPO3 ( DIME TAB1.L_CASADEPOU ) ;
  9536. I3 = I3 + 1 ;
  9537. XIT1 = EXTR I3 TAB1.L_CASADEPOU ;
  9538. DEPL_1 = TAB1.RESUDEPL.XIT1 ;
  9539. SI_1 = TAB1.RESUCONT.XIT1 ;
  9540. EPS_0 = EPSI MOD_1 DEPL_1 ;
  9541. EPS_1 = EPS_0 ET ( EXCO EPSE TAB1.RESUVARI.XIT1) ;
  9542. I4 = 0 ;
  9543. SAUT 2 LIGNE ;
  9544. MESS 'TIME' XIT1 ;
  9545. SAUT LIGNE ;
  9546. MESS ' MINI * MAXI DU MCHAM PTS GAUSS';
  9547. SAUT LIGNE ;
  9548. REPETER BDEPO4 ( DIME TAB1.LM_EPSCOMP) ;
  9549. I4 = I4 + 1 ;
  9550. MOCOMP = EXTR TAB1.LM_EPSCOMP I4 ;
  9551. TMOCOMP = TEXT MOCOMP ;
  9552. SI (( EGA MOCOMP 'EPZZ' ) ET ( EGA (VALE MODE) 'PLANCONT')) ;
  9553. EPS_2 = TAB1.RESUDEFI.XIT1 + (EPSCHL MOD_1 SI_1 (TAB1.CHPOTHETA. 0.) (TAB1.CHPOTHETA.XIT1) TAB1 ) ;
  9554. EPSB2 = REDU ( EXCO EPS_2 MOCOMP ) MOTOT1 ;
  9555. MAXEB2 = ((MAXI EPSB2) * 1.E2) ;
  9556. MINEB2 = ((MINI EPSB2) * 1.E2) ;
  9557. MESS TMOCOMP ' ( % ) : ' MINEB2 ' * ' MAXEB2 ;
  9558. SINON ;
  9559. EPSB1 = REDU ( EXCO EPS_1 MOCOMP ) MOTOT1 ;
  9560. MAXEB1 = ((MAXI EPSB1) * 1.E2) ;
  9561. MINEB1 = ((MINI EPSB1) * 1.E2) ;
  9562. MESS TMOCOMP ' ( % ) : ' MINEB1 ' * ' MAXEB1 ;
  9563. FINSI ;
  9564. FIN BDEPO4 ;
  9565. SI (EXISTE TAB1 L_ADEPOU ) ;
  9566. DEPOULI L_1 'DEFORMATIONS' MOD_1 EPS_0 GLOBAL MASSIF ;
  9567. FINSI ;
  9568. FIN BDEPO3 ;
  9569. SAUT PAGE ;
  9570. OPTI ECHO 1 IMPR 6;
  9571. FINPROC ;
  9572. *****************************************************************
  9573. * *
  9574. * Procedure DEPOULI : trace des contraintes ou des deformations *
  9575. * le long d'un ligne quelconque *
  9576. * *
  9577. *****************************************************************
  9578. 'DEBPROC' FRENETT LIGN_1*MAILLAGE ;
  9579. MESS '----------------------> entree dans FRENETT ';
  9580. V1 = VALEUR DIME ;
  9581. SI( V1 EGA 2 ) ;
  9582. CHT CHN CHB = FRENET LIGN_1 'TRACE' ;
  9583. CHPP = CHT ET CHN ;
  9584. SINON ;
  9585. CHT CHN CHB = FRENET LIGN_1 'TRACE' (0. 0. 1000.);
  9586. CHPP = CHT ET CHN ET CHB ;
  9587. FINSI ;
  9588. MESS '----------------------> sortie de FRENETT ';
  9589. 'FINPROC' CHPP;
  9590.  
  9591.  
  9592.  
  9593. 'DEBPROC' DEPOULI LIGN_1*MAILLAGE M_IND1*MOT MOD_L*MMODEL MCHA_E2*MCHAML M_REP2*MOT M_ELEM*MOT VECT1/POINT VECT2/POINT MCHA_E3/MCHAML ;
  9594.  
  9595. MESS '----------------------> entree dans DEPOULI';
  9596.  
  9597. TAB1 = TABLE;
  9598. TAC1 = TABLE ;
  9599.  
  9600. SI (( NON (EGA M_ELEM 'MASSIF')) ET (NON (EGA M_ELEM 'INFE')) ET (NON (EGA M_ELEM 'MOYE')) ET (NON (EGA M_ELEM 'SUPE')));
  9601. MESS '>>>DEPOULI>>>> OPTION NON PREVU :' M_ELEM ;
  9602. MESS '>>>DEPOULI>>>> ON STOPPE ICI ....' ;
  9603. ERREUR 'MAUVAIS_INDIC_ELEMENT_DANS_DEPOULI';
  9604. FINSI ;
  9605.  
  9606.  
  9607. SI (( NON (EGA M_REP2 'FIXE')) ET (NON (EGA M_REP2 'GLOBAL')) ET (NON (EGA M_REP2 'LOCAL')));
  9608. MESS '>>>DEPOULI>>>> OPTION NON PREVU :' M_REP2 ;
  9609. MESS '>>>DEPOULI>>>> ON STOPPE ICI ....' ;
  9610. ERREUR 'MAUVAIS_INDIC_REPERE_DANS_DEPOULI';
  9611. SINON;
  9612. M_REPE = M_REP2 ;
  9613. FINSI ;
  9614.  
  9615.  
  9616. SI (( NON (EGA M_IND1 'CONTRAINTES')) ET ( NON (EGA M_IND1 'DEFORMATIONS')) );
  9617. MESS '>>>DEPOULI>>>> OPTION NON PREVU :' M_IND1 ;
  9618. MESS '>>>DEPOULI>>>> ON STOPPE ICI ....' ;
  9619. ERREUR 'MAUVAIS_INDIC_DANS_DEPOULI';
  9620. FINSI ;
  9621.  
  9622. LCONFON = FAUX ;
  9623. MAIL_1 = MOD_L EXTR 'MAIL';
  9624. N_1 = NBNO MAIL_1 ;
  9625. N_2 = NBNO (MAIL_1 ET LIGN_1 );
  9626.  
  9627. SI ( EGA N_1 N_2 ) ;
  9628. LCONFON = VRAI;
  9629. FINSI ;
  9630.  
  9631. SI (EXISTE MCHA_E3);
  9632. SI (EGA M_IND1 'CONTRAINTES');
  9633. CAR1 = MCHA_E3;
  9634. FINSI ;
  9635. SI (EGA M_IND1 'DEFORMATIONS');
  9636. MCHA_EP = MCHA_E3;
  9637. FINSI ;
  9638. FINSI;
  9639.  
  9640.  
  9641. SI (EGA M_IND1 'CONTRAINTES');
  9642. MO_TI1 = MOT 'STRESSES ALONG THE LINE ' ;
  9643. FINSI ;
  9644. SI (EGA M_IND1 'DEFORMATIONS');
  9645. MO_TI1 = MOT 'STRAINS ALONG THE LINE ' ;
  9646. FINSI ;
  9647.  
  9648. SI (EGA M_REPE 'FIXE');
  9649. MO_TI2 = MOT ' (REPERE FIXE DONNE)';
  9650. SINON;
  9651. SI (EGA M_REPE 'GLOBAL');
  9652. MO_TI2 = MOT ' (REPERE GLOBAL)';
  9653. SINON;
  9654. MO_TI2 = MOT ' (REPERE LOCAL DE FRENET)';
  9655. FINSI;
  9656. FINSI;
  9657.  
  9658.  
  9659. SI(NON (EXISTE L_COQ2 ));
  9660. L_COQ1 = FAUX ;
  9661. SINON ;
  9662. L_COQ1 = L_COQ2 ;
  9663. FINSI;
  9664.  
  9665.  
  9666. SI (EGA M_REPE 'FIXE');
  9667. SI ((VALEUR DIME) EGA 3);
  9668. MCHA_E11 = RTENS MCHA_E2 MOD_L VECT1 VECT2;
  9669. MCHA_E1 = MCHA_E11;
  9670. SINON;
  9671. TYP1 = TYPE MCHA_E2; MESS TYP1;
  9672. MCHA_E11 = RTENS MCHA_E2 MOD_L VECT1;
  9673. MCHA_E1 = MCHA_E11;
  9674. FINSI;
  9675. SINON;
  9676. MCHA_E1 = MCHA_E2;
  9677. FINSI;
  9678.  
  9679.  
  9680. ***CHTT1 CHPOINT sur la ligne
  9681. ***EV_OTT evolution globale
  9682.  
  9683. CHM1 = REDU MCHA_E1 MOD_L ;
  9684. TC1 = EXTR CHM1 'COMP' ;
  9685. LIST1 = MOTS CROI TRIA PLUS LOSA CARR TRIB ETOI TRIB CARR LOSA;
  9686.  
  9687.  
  9688. SI ( (EGA M_REPE 'FIXE') OU (EGA M_REPE 'GLOBAL') );
  9689.  
  9690. SI (EGA M_IND1 'CONTRAINTES');
  9691. SI (EGA (VALEUR DIME) 2);
  9692. LIST2 = MOTS SMXX SMYY SMZZ SMXY VMIS TRES TREI TREE ;
  9693. SINON;
  9694. LIST2 = MOTS SMXX SMYY SMZZ SMXY SMXZ SMYZ VMIS TRES TREI TREE;
  9695. FINSI;
  9696. SINON;
  9697. SI (EGA (VALEUR DIME) 2);
  9698. LIST2 = MOTS EPXX EPYY EPZZ GAXY PLAS;
  9699. SINON;
  9700. LIST2 = MOTS EPXX EPYY EPZZ GAXY GAXZ GAYZ PLAS;
  9701. FINSI;
  9702. FINSI;
  9703.  
  9704. I1 = 1;
  9705. REPETER BOUC1 (DIME TC1 );
  9706. MOC1 = ( EXTR TC1 I1 );
  9707. SSI1 = EXCO MOC1 CHM1 'SCAL';
  9708. SI LCONFON;
  9709. CHI1 = CHAN 'CHPO' MOD_L ( CHAN NOEUD MOD_L SSI1 );
  9710. SINON ;
  9711. CHI1 = PROI LIGN_1 ( CHAN NOEUD MOD_L SSI1 );
  9712. FINSI;
  9713. CHI1 = NOMC MOC1 CHI1;
  9714. EV_I1 = EVOL CHPO CHI1 MOC1 LIGN_1;
  9715. TAB1.MOC1 = EV_I1;
  9716. TITRE MO_TI1 MO_TI2;
  9717. SI ( I1 EGA 1 );
  9718. MARQ1 = TEXT (EXTR 1 LIST1);
  9719. COMP1 = TEXT (EXTR 1 LIST2);
  9720. * TAC1.1 = CHAINE ' MARQ' ' ' MARQ1 ' REGU ' ' TITR' ' ' COMP1;
  9721. EV_OTT = EV_I1;
  9722. CHTT1 = CHI1;
  9723. SINON ;
  9724. DIM1 = DIME EV_OTT;
  9725. MARQ1 = TEXT (EXTR I1 LIST1);
  9726. COMP1 = TEXT (EXTR I1 LIST2);
  9727. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU ' ' TITR' ' ' COMP1;
  9728. EV_OTT = EV_OTT ET EV_I1 ;
  9729. CHTT1 = CHTT1 ET CHI1;
  9730. FINSI ;
  9731. I1 = I1 + 1;
  9732. FIN BOUC1;
  9733. FINSI ;
  9734.  
  9735. SI (EGA M_REPE 'LOCAL');
  9736. SI (EGA M_IND1 'CONTRAINTES');
  9737. SI (EGA (VALEUR DIME) 2);
  9738. LIST2 = MOTS SMTT SMNN SMBB SMTN VMIS TRES TREI TREE;
  9739. SINON;
  9740. LIST2 = MOTS SMTT SMNN SMBB SMTN SMTB SMNB VMIS TRES TREI TREE;
  9741. FINSI;
  9742. SINON;
  9743. SI (EGA (VALEUR DIME) 2);
  9744. LIST2 = MOTS EPTT EPNN EPBB GATN PLAS;
  9745. SINON;
  9746. LIST2 = MOTS EPTT EPNN EPBB GATN GATB GANB PLAS;
  9747. FINSI;
  9748. FINSI;
  9749. I1 = 1;
  9750.  
  9751. REPETER BOUC3 (DIME TC1 );
  9752. MOC1 = ( EXTR TC1 I1 );
  9753. SSI1 = EXCO MOC1 CHM1 'SCAL';
  9754. SI LCONFON;
  9755. CHI1 = CHAN 'CHPO' MOD_L ( CHAN NOEUD MOD_L SSI1 );
  9756. SINON ;
  9757. CHI1 = PROI LIGN_1 ( CHAN NOEUD MOD_L SSI1 );
  9758. FINSI;
  9759. CHI1 = NOMC MOC1 CHI1;
  9760. TAB1.MOC1 = EV_I1;
  9761. SI ( I1 EGA 1 );
  9762. CHTT1 = CHI1;
  9763. SINON ;
  9764. CHTT1 = CHTT1 ET CHI1;
  9765. FINSI ;
  9766. I1 = I1 + 1;
  9767. FIN BOUC3;
  9768. CHPP = FRENETT LIGN_1 ;
  9769. CHTT2 = CHREP M_IND1 CHTT1 CHPP ;
  9770. TC1 = EXTR CHTT2 'COMP' ;
  9771. MENAGE ;
  9772. I1 = 1 ;
  9773. REPETER BOUC2 (DIME TC1 ) ;
  9774. MOC1 = ( EXTR TC1 I1 ) ;
  9775. EV_I1 = EVOL CHPO CHTT2 MOC1 LIGN_1 ;
  9776. TITRE MO_TI1 MO_TI2 ;
  9777. MENAGE ;
  9778. SI ( I1 EGA 1 ) ;
  9779. MARQ1 = TEXT (EXTR 1 LIST1) ;
  9780. COMP1 = TEXT (EXTR 1 LIST2) ;
  9781. * TAC1.1 = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9782. EV_OTT = EV_I1;
  9783. SINON;
  9784. DIM1 = DIME EV_OTT;
  9785. MARQ1 = TEXT (EXTR I1 LIST1);
  9786. COMP1 = TEXT (EXTR I1 LIST2);
  9787. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9788. EV_OTT = EV_OTT ET EV_I1;
  9789. FINSI;
  9790. I1 = I1 + 1;
  9791. TAB1.MOC1 = EV_I1;
  9792. FIN BOUC2;
  9793. FINSI;
  9794.  
  9795. SI (EGA M_IND1 'CONTRAINTES');
  9796.  
  9797. SI ((EGA M_ELEM 'MASSIF') OU (EGA M_ELEM 'MOYE'));
  9798.  
  9799. DIM1 = DIME EV_OTT;
  9800. MARQ1 = TEXT (EXTR I1 LIST1);
  9801. COMP1 = TEXT (EXTR I1 LIST2);
  9802. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9803. I1 = I1 + 1;
  9804.  
  9805. SI (EXISTE MCHA_E3);
  9806. VMI1 = VMIS MOD_L CHM1 CAR1;
  9807. SINON ;
  9808. VMI1 = VMIS MOD_L CHM1 ;
  9809. FINSI;
  9810. SI LCONFON;
  9811. CHVM = CHAN 'CHPO' MOD_L ( CHAN NOEUD MOD_L VMI1 );
  9812. SINON ;
  9813. CHVM = PROI LIGN_1 ( CHAN NOEUD MOD_L VMI1 );
  9814. FINSI;
  9815. EVVM = EVOL ROUGE CHPO CHVM SCAL LIGN_1;
  9816. EV_OTT = EV_OTT ET EVVM ;
  9817. TAB1.VMIS = EVVM;
  9818.  
  9819. DIM1 = DIME EV_OTT;
  9820. MARQ1 = TEXT (EXTR I1 LIST1);
  9821. COMP1 = TEXT (EXTR I1 LIST2);
  9822. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9823. I1 = I1 + 1;
  9824.  
  9825. SI (EXISTE MCHA_E3);
  9826. TRE1 = TRESCA MOD_L CHM1 CAR1 MOYE;
  9827. SINON ;
  9828. SI (EGA M_ELEM 'MASSIF');
  9829. TRE1 = TRESCA MOD_L CHM1 ;
  9830. SINON ;
  9831. TRE1 = TRESCA MOD_L CHM1 MOYE;
  9832. FINSI ;
  9833. FINSI;
  9834. SI LCONFON;
  9835. CHTR1 = CHAN 'CHPO' MOD_L ( CHAN NOEUD MOD_L TRE1 );
  9836. SINON ;
  9837. CHTR1 = PROI LIGN_1 ( CHAN NOEUD MOD_L TRE1 );
  9838. FINSI;
  9839. EVTR1 = EVOL VERT CHPO CHTR1 SCAL LIGN_1;
  9840. EV_OTT = EV_OTT ET EVTR1 ;
  9841. TAB1.TRES1 = EVTR1;
  9842.  
  9843. FINSI;
  9844.  
  9845.  
  9846. SI (EGA M_ELEM 'MOYE') ;
  9847.  
  9848. DIM1 = DIME EV_OTT;
  9849. MARQ1 = TEXT (EXTR I1 LIST1);
  9850. COMP1 = TEXT (EXTR I1 LIST2);
  9851. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9852. I1 = I1 + 1;
  9853.  
  9854. TRE2 = TRESCA MOD_L CHM1 CAR1 INFE;
  9855. SI LCONFON;
  9856. CHTR2 = CHAN 'CHPO' MOD_L ( CHAN NOEUD MOD_L TRE2);
  9857. SINON ;
  9858. CHTR2 = PROI LIGN_1 ( CHAN NOEUD MOD_L TRE2 );
  9859. FINSI;
  9860. EVTR2 = EVOL ROUGE CHPO CHTR2 SCAL LIGN_1;
  9861. EV_OTT = EV_OTT ET EVTR2 ;
  9862. TAB1.TRES2 = EVTR2;
  9863.  
  9864.  
  9865. DIM1 = DIME EV_OTT;
  9866. MARQ1 = TEXT (EXTR I1 LIST1);
  9867. COMP1 = TEXT (EXTR I1 LIST2);
  9868. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9869.  
  9870. TRE3 = TRESCA MOD_L CHM1 CAR1 SUPE;
  9871. SI LCONFON;
  9872. CHTR3 = CHAN 'CHPO' MOD_L (CHAN NOEUD MOD_L TRE3 );
  9873. SINON ;
  9874. CHTR3 = PROI LIGN_1 (CHAN NOEUD MOD_L TRE3 );
  9875. FINSI;
  9876. EVTR3 = EVOL ROSE CHPO CHTR3 SCAL LIGN_1;
  9877. EV_OTT = EV_OTT ET EVTR3 ;
  9878. TAB1.TRES = EVTR3;
  9879.  
  9880. FINSI;
  9881. FINSI;
  9882.  
  9883. SI (EGA M_IND1 'DEFORMATIONS');
  9884. SI ( EXISTE MCHA_E3 );
  9885. * I2 = I1 * 2 - 1;
  9886. * TAC1.I2 = 'MARQ ETOI TITR EPSE_PLAS';
  9887. EPSE1 = EXCO EPSE (REDU MCHA_EP MOD_L) ;
  9888. SI LCONFON;
  9889. EPSEL1 = CHAN 'CHPO' MOD_L (CHAN NOEUD MOD_L EPSE1) ;
  9890. SINON ;
  9891. EPSEL1 = PROI LIGN_1 (CHAN NOEUD MOD_L EPSE1) ;
  9892. FINSI;
  9893. EVOSE = EVOL ROUGE CHPO EPSEL1 EPSE LIGN_1 ;
  9894.  
  9895. DIM1 = DIME EV_OTT;
  9896. MARQ1 = TEXT (EXTR I1 LIST1);
  9897. COMP1 = TEXT (EXTR I1 LIST2);
  9898. * TAC1.(DIM1+1) = CHAINE ' MARQ' ' ' MARQ1 ' REGU TITR' ' ' COMP1 ' ';
  9899. EV_OTT = EV_OTT ET EVOSE ;
  9900. TAB1.PLAS = EVOSE;
  9901. FINSI;
  9902. FINSI;
  9903.  
  9904.  
  9905. DESS EV_OTT TAC1 MIMA LEGE ;
  9906.  
  9907. TAB1.MARC = TAC1;
  9908. TAB1.EVOL = EV_OTT;
  9909.  
  9910. MESS '----------------------> sortie de DEPOULI ';
  9911. FINPROC TAB1;
  9912.  
  9913.  
  9914.  
  9915.  
  9916.  
  9917.  
  9918.  
  9919.  
  9920.  
  9921.  
  9922.  
  9923.  
  9924.  
  9925.  
  9926.  
  9927.  
  9928.  
  9929.  
  9930.  
  9931.  
  9932.  
  9933. 'DEBPROC' DEPT LIGN_1*MAILLAGE MOD_L*MMODEL MCHA_E2*CHPOINT;
  9934.  
  9935. MESS '----------------------> entree dans DEPT';
  9936.  
  9937. LCONFON = FAUX ;
  9938. MAIL_1 = MOD_L EXTR 'MAIL';
  9939. N_1 = NBNO MAIL_1 ;
  9940. N_2 = NBNO (MAIL_1 ET LIGN_1 );
  9941.  
  9942. SI ( EGA N_1 N_2 ) ;
  9943. LCONFON = VRAI;
  9944. FINSI ;
  9945.  
  9946. MAIL1 = (extr MOD_L 'MAIL' ) ;
  9947. LEV1 = REDU MCHA_E2 MAIL1;
  9948.  
  9949. SI LCONFON ;
  9950. LEV2 = REDU LEV1 LIGN_1 ;
  9951. LEV3 = EVOL CHPO LEV2 LIGN_1 ;
  9952. SINON ;
  9953. LEV2 = PROI (CHAN CHAM LEV1 MAIL1 NOEUD ) LIGN_1 ;
  9954. LEV3 = EVOL CHPO LEV2 LIGN_1 ;
  9955. FINSI ;
  9956.  
  9957. DESS LEV3 ;
  9958.  
  9959.  
  9960.  
  9961.  
  9962. MESS '----------------------> sortie de DEPT ';
  9963. FINPROC ;
  9964.  
  9965.  
  9966.  
  9967.  
  9968.  
  9969.  
  9970.  
  9971.  
  9972.  
  9973.  
  9974.  
  9975.  
  9976.  
  9977.  
  9978.  
  9979.  
  9980.  
  9981.  
  9982.  
  9983.  
  9984.  
  9985. **** @DESCEND
  9986.  
  9987. DEBPROC @DESCEND CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT CHSIGN0*CHPOINT TAB1*TABLE ;
  9988. *
  9989. *****************************************************
  9990. * Procedure de descente des lignes de champ par une *
  9991. * methode explicite. Alain MOAL (Fevrier 2001) *
  9992. *****************************************************
  9993. *
  9994. *MESS '---------------------------------> calling @descend';
  9995. *
  9996. *--------------- VARIABLES D'ENTREE :
  9997. MAIL0 = TAB1.<MAILLAGE_B ;
  9998. *-----------------------------------
  9999. *
  10000. *---- Calcul du champ et de sa norme
  10001. BR BZ BPHI = @MAGNB TAB1 ;
  10002. *
  10003. *---- Descente dans le plan (R,Z)
  10004. BPHI = BPHI * 0. ;
  10005. PHI = ATG (COOR 2 MAIL0) (COOR 1 MAIL0) ;
  10006. *AM*11/09/01*BX = BR * (COS PHI) + (BPHI * (SIN PHI));
  10007. *AM*11/09/01*BY = BR * (SIN PHI) - (BPHI * (COS PHI));
  10008. BX = BR * (COS PHI) - (BPHI * (SIN PHI));
  10009. BY = BR * (SIN PHI) + (BPHI * (COS PHI));
  10010. NORM_B = ((BX*BX) + (BY*BY) + (BZ*BZ))**0.5 ;
  10011. *
  10012. *---- Deplacements (methode explicite) affectes du signe
  10013. *---- donnant le sens de descente dans le plan (R,Z)
  10014. DEPX0 = CHSIGN0 * BX * PASB0 / NORM_B ;
  10015. DEPY0 = CHSIGN0 * BY * PASB0 / NORM_B ;
  10016. DEPZ0 = CHSIGN0 * BZ * PASB0 / NORM_B ;
  10017. *
  10018. *---- Nouvelles coordonnees
  10019. X_NEW = CHP_X + DEPX0 ;
  10020. Y_NEW = CHP_Y + DEPY0 ;
  10021. Z_NEW = CHP_Z + DEPZ0 ;
  10022. *
  10023. *---- actualisation de la position des points de la ligne
  10024. DEPX0 = NOMC UX DEPX0 NATURE DIFFUS ;
  10025. DEPY0 = NOMC UY DEPY0 NATURE DIFFUS ;
  10026. DEPZ0 = NOMC UZ DEPZ0 NATURE DIFFUS ;
  10027. DEP0 = DEPX0 ET DEPY0 ET DEPZ0 ;
  10028. *
  10029. *MESS '---------------------------------> exiting @descend';
  10030. FINPROC X_NEW Y_NEW Z_NEW DEP0 ;
  10031.  
  10032. **** @DEXPJET
  10033.  
  10034. DEBPROC @DEXPJET CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT TAB1*TABLE;
  10035.  
  10036. *MESS '---------------------------------> calling @DEXPJET';
  10037. *
  10038. *--------------- VARIABLES D'ENTREE :
  10039. MAIL0 = TAB1.<MAILLAGE_B ;
  10040. *-----------------------------------
  10041. *
  10042. *---- Calcul du champ et de sa norme
  10043. BR BZ BPHI = @MAGNB TAB1 ;
  10044. *
  10045. PHI = ATG (COOR 2 MAIL0) (COOR 1 MAIL0) ;
  10046. *AM*11/09/01*BX = BR * (COS PHI) + (BPHI * (SIN PHI));
  10047. *AM*11/09/01*BY = BR * (SIN PHI) - (BPHI * (COS PHI));
  10048. BX = BR * (COS PHI) - (BPHI * (SIN PHI));
  10049. BY = BR * (SIN PHI) + (BPHI * (COS PHI));
  10050. NORM_B = ((BX*BX) + (BY*BY) + (BZ*BZ))**0.5 ;
  10051. *
  10052. *---- Deplacements (methode explicite)
  10053. DEPX0 = BX * PASB0 / NORM_B ;
  10054. DEPY0 = BY * PASB0 / NORM_B ;
  10055. DEPZ0 = BZ * PASB0 / NORM_B ;
  10056.  
  10057. *MESS '---------------------------------> exiting @DEXPJET';
  10058. FINPROC DEPX0 DEPY0 DEPZ0 ;
  10059.  
  10060. **** @DEXPLI
  10061.  
  10062. DEBPROC @DEXPLI CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT TAB1*TABLE;
  10063.  
  10064. *MESS '---------------------------------> calling @DEXPLI';
  10065.  
  10066. *--------------- VARIABLES D'ENTREE :
  10067. TYPCAL = TAB1.<TYPE_CALCUL ;
  10068. *------------------------------------
  10069. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  10070. ISHIFT = VRAI ;
  10071. IRIPPLE = VRAI ;
  10072. FINSI ;
  10073. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  10074. ISHIFT = VRAI ;
  10075. IRIPPLE = FAUX ;
  10076. FINSI ;
  10077. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  10078. ISHIFT = FAUX ;
  10079. IRIPPLE = VRAI ;
  10080. FINSI ;
  10081. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  10082. ISHIFT = FAUX ;
  10083. IRIPPLE = FAUX ;
  10084. FINSI ;
  10085. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  10086. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  10087. FINSI ;
  10088.  
  10089. * ---- Calcul du champ dans le repere global
  10090. BXG BYG BZG FSECU = @CHAMB TAB1 CHP_X CHP_Y CHP_Z ISHIFT IRIPPLE ;
  10091.  
  10092. * ---- Calcul de la norme du champ
  10093.  
  10094. NORM_B = ((BXG*BXG) + (BYG*BYG) + (BZG*BZG))**0.5 ;
  10095.  
  10096. * ---- Calcul des deplacements
  10097.  
  10098. DEPX0 = BXG * PASB0 / NORM_B ;
  10099. DEPY0 = BYG * PASB0 / NORM_B ;
  10100. DEPZ0 = BZG * PASB0 / NORM_B ;
  10101.  
  10102. *MESS '---------------------------------> exiting @DEXPLI';
  10103. FINPROC DEPX0 DEPY0 DEPZ0 ;
  10104. **** @DMILIEU
  10105.  
  10106. DEBPROC @DMILIEU CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT CHSIGN/CHPOINT TAB1*TABLE;
  10107.  
  10108. *MESS '---------------------------------> calling @DMILIEU';
  10109.  
  10110. *--------------- VARIABLES D'ENTREE :
  10111. TYPCAL = TAB1.<TYPE_CALCUL ;
  10112. RP = TAB1.<RP ;
  10113. HP = TAB1.<HP ;
  10114. *------------------------------------
  10115. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  10116. ISHIFT = VRAI ;
  10117. IRIPPLE = VRAI ;
  10118. FINSI ;
  10119. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  10120. ISHIFT = VRAI ;
  10121. IRIPPLE = FAUX ;
  10122. FINSI ;
  10123. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  10124. ISHIFT = FAUX ;
  10125. IRIPPLE = VRAI ;
  10126. FINSI ;
  10127. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  10128. ISHIFT = FAUX ;
  10129. IRIPPLE = FAUX ;
  10130. FINSI ;
  10131. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  10132. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  10133. FINSI ;
  10134. *
  10135. SI (EGA (TYPE CHSIGN) MOT) ;
  10136. * --- Cas ou l'appel vient d'une proc qui n'a pas calcule CHSIGN
  10137. CHSIGN = 1. ;
  10138. FINSI ;
  10139. *BR01/10/98 SI (EXISTE TAB1 <CHSIGN) ;
  10140. * CHSIGN = TAB1.<CHSIGN ;
  10141. * --- Cas ou l'appel vient d'une proc qui n'a pas calcule TAB1.<CHSIGN
  10142. *SINON ;
  10143. * CHSIGN = 1. ;
  10144. *FINSI ;
  10145.  
  10146. * ---- Lors du premier pas, calcul des points milieux
  10147. SI (NON (EXIS TAB1 <CHP_X1)) ;
  10148.  
  10149.  
  10150. DEPX0 DEPY0 DEPZ0 = @DEXPLI CHP_X CHP_Y CHP_Z PASB0 TAB1;
  10151. CHP_X1 = CHP_X + (CHSIGN * DEPX0) ;
  10152. CHP_Y1 = CHP_Y + (CHSIGN * DEPY0) ;
  10153. CHP_Z1 = CHP_Z + (CHSIGN * DEPZ0) ;
  10154. SINON ;
  10155. CHP_X1 = TAB1.<CHP_X1 ;
  10156. CHP_Y1 = TAB1.<CHP_Y1 ;
  10157. CHP_Z1 = TAB1.<CHP_Z1 ;
  10158. MAILR = EXTR CHP_X MAIL ;
  10159. CHP_X1 = REDU CHP_X1 MAILR ;
  10160. CHP_Y1 = REDU CHP_Y1 MAILR ;
  10161. CHP_Z1 = REDU CHP_Z1 MAILR ;
  10162. FINSI ;
  10163.  
  10164. * ---- Calcul du deplacement dans le repere global
  10165. * ---- (aux points milieux)
  10166.  
  10167. DEPX0 DEPY0 DEPZ0 = @DEXPLI CHP_X1 CHP_Y1 CHP_Z1 PASB0 TAB1 ;
  10168.  
  10169. * ---- Actualisation des points initiaux
  10170.  
  10171. X_NEW = CHP_X + (CHSIGN * DEPX0) ;
  10172. Y_NEW = CHP_Y + (CHSIGN * DEPY0) ;
  10173. Z_NEW = CHP_Z + (CHSIGN * DEPZ0) ;
  10174.  
  10175.  
  10176. * ---- Calcul du deplacement aux points initiaux remontes
  10177.  
  10178.  
  10179. DEPXI DEPYI DEPZI = @DEXPLI X_NEW Y_NEW Z_NEW PASB0 TAB1;
  10180.  
  10181. * ---- Calcul des nouveaux points milieux
  10182.  
  10183. CHP_X1 = CHP_X1 + (CHSIGN * DEPXI) ;
  10184. CHP_Y1 = CHP_Y1 + (CHSIGN * DEPYI) ;
  10185. CHP_Z1 = CHP_Z1 + (CHSIGN * DEPZI) ;
  10186.  
  10187. * ---- Actualisation des points milieux
  10188.  
  10189. TAB1.<CHP_X1 = CHP_X1 ;
  10190. TAB1.<CHP_Y1 = CHP_Y1 ;
  10191. TAB1.<CHP_Z1 = CHP_Z1 ;
  10192.  
  10193. *MESS '---------------------------------> exiting @DMILIEU';
  10194. FINPROC DEPX0 DEPY0 DEPZ0 ;
  10195. **** @DMOYEN
  10196.  
  10197. DEBPROC @DMOYEN CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT CHSIGN/CHPOINT TAB1*TABLE;
  10198.  
  10199.  
  10200. *MESS '---------------------------------> calling @DMOYEN';
  10201.  
  10202. *--------------- VARIABLES D'ENTREE :
  10203. TYPCAL = TAB1.<TYPE_CALCUL ;
  10204. *------------------------------------
  10205. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  10206. ISHIFT = VRAI ;
  10207. IRIPPLE = VRAI ;
  10208. FINSI ;
  10209. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  10210. ISHIFT = VRAI ;
  10211. IRIPPLE = FAUX ;
  10212. FINSI ;
  10213. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  10214. ISHIFT = FAUX ;
  10215. IRIPPLE = VRAI ;
  10216. FINSI ;
  10217. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  10218. ISHIFT = FAUX ;
  10219. IRIPPLE = FAUX ;
  10220. FINSI ;
  10221. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  10222. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  10223. FINSI ;
  10224. *
  10225. SI (EGA (TYPE CHSIGN) MOT) ;
  10226. * --- Cas ou l'appel vient d'une proc qui n'a pas calcule CHSIGN
  10227. CHSIGN = 1. ;
  10228. FINSI ;
  10229.  
  10230. * ---- Calcul du champ dans le repere global
  10231. BXG BYG BZG FSECU = @CHAMB TAB1 CHP_X CHP_Y CHP_Z ISHIFT IRIPPLE ;
  10232.  
  10233. * ---- Calcul de la norme du champ
  10234.  
  10235. NORM_B = ((BXG*BXG) + (BYG*BYG) + (BZG*BZG))**0.5 ;
  10236.  
  10237. * ---- Calcul du point extremite par la methode des tangentes
  10238.  
  10239. XG_NEW0 = CHP_X + (CHSIGN * BXG * PASB0 / NORM_B) ;
  10240. YG_NEW0 = CHP_Y + (CHSIGN * BYG * PASB0 / NORM_B) ;
  10241. ZG_NEW0 = CHP_Z + (CHSIGN * BZG * PASB0 / NORM_B) ;
  10242.  
  10243.  
  10244.  
  10245. * ---- Calcul du champ magnetique dans le repere global
  10246. * ---- sur le point extremite
  10247.  
  10248.  
  10249. BXG0 BYG0 BZG0 FSECU = @CHAMB TAB1 XG_NEW0 YG_NEW0 ZG_NEW0 ISHIFT IRIPPLE ;
  10250.  
  10251.  
  10252. * ---- Moyenne des champs magnetiques
  10253.  
  10254. BXG1 = (BXG + BXG0)/2. ;
  10255. BYG1 = (BYG + BYG0)/2. ;
  10256. BZG1 = (BZG + BZG0)/2. ;
  10257.  
  10258.  
  10259. * ---- Calcul de la norme du champ moyenne
  10260.  
  10261. NORM_B1 = ((BXG1*BXG1) + (BYG1*BYG1) + (BZG1*BZG1))**0.5 ;
  10262.  
  10263. * ---- Calcul des deplacements
  10264.  
  10265. DEPX0 = BXG1 * PASB0 / NORM_B1 ;
  10266. DEPY0 = BYG1 * PASB0 / NORM_B1 ;
  10267. DEPZ0 = BZG1 * PASB0 / NORM_B1 ;
  10268.  
  10269. *MESS '---------------------------------> exiting @DMOYEN';
  10270. FINPROC DEPX0 DEPY0 DEPZ0 ;
  10271. **** @DPSI
  10272.  
  10273. DEBPROC @DPSI TAB1*TABLE ;
  10274.  
  10275. *************************************************************
  10276. * Procedure de calcul de dpsi en chaque point d'un maillage *
  10277. * donne. Alain MOAL (Novembre 2001) *
  10278. *************************************************************
  10279. *
  10280. MESS '---------------------------------> calling @DPSI';
  10281. *
  10282. *--------------- VARIABLES D'ENTREE :
  10283. CHB0 = TAB1.<CARTE_B ;
  10284. GRILB0 = TAB1.<GRILLE_B ;
  10285. MAIL1 = TAB1.<MAILLAGE_B ;
  10286. *------------------------------------
  10287. *TRAC (MAIL1 ET GRILB0) ;
  10288. CHEL1 = CHAN CHAM CHB0 GRILB0 ;
  10289. CHPO1 = PROI MAIL1 CHEL1 1.E-4;
  10290. CHDPSI = EXCO 'DPSI' CHPO1 ;
  10291. *
  10292. MESS '---------------------------------> exiting @DPSI';
  10293. FINPROC CHDPSI ;
  10294.  
  10295. **** @DREPROJ
  10296.  
  10297. DEBPROC @DREPROJ CHP_X*CHPOINT CHP_Y*CHPOINT CHP_Z*CHPOINT PASB0*FLOTTANT CHSIGN/CHPOINT TAB1*TABLE ;
  10298.  
  10299. ****************************************************************
  10300. * Procedure de calcul du deplacement pour remonter des lignes *
  10301. * de champ magnetique, a partir des CHPOINT de coordonnees *
  10302. * methode utilisant une reprojection sur la SMF *
  10303. * ---> construit un chpoint appuye sur l'objet etudie et *
  10304. * contenant pour chaque point le deplacement sur un pas pour *
  10305. * remonter les lignes de champ *
  10306. ****************************************************************
  10307.  
  10308. *MESS '---------------------------------> calling @DREPROJ';
  10309.  
  10310. *--------------- VARIABLES D'ENTREE :
  10311. TYPCAL = TAB1.<TYPE_CALCUL ;
  10312. RR = TAB1.<RR ;
  10313. EPS0 = TAB1.<EPS ;
  10314. NBOB = TAB1.<NBOB ;
  10315. COEFA = TAB1.<COEFA ;
  10316. COEFB = TAB1.<COEFB ;
  10317. COEFC = TAB1.<COEFC ;
  10318. * (pour info) TAB1.<CHSIGN ;
  10319. *------------------------------------
  10320. SI (EGA TYPCAL 'AVEC_SHIFT_AVEC_RIPPLE') ;
  10321. ISHIFT = VRAI ;
  10322. IRIPPLE = VRAI ;
  10323. FINSI ;
  10324. SI (EGA TYPCAL 'AVEC_SHIFT_SANS_RIPPLE') ;
  10325. ISHIFT = VRAI ;
  10326. IRIPPLE = FAUX ;
  10327. FINSI ;
  10328. SI (EGA TYPCAL 'SANS_SHIFT_AVEC_RIPPLE') ;
  10329. ISHIFT = FAUX ;
  10330. IRIPPLE = VRAI ;
  10331. FINSI ;
  10332. SI (EGA TYPCAL 'SANS_SHIFT_SANS_RIPPLE') ;
  10333. ISHIFT = FAUX ;
  10334. IRIPPLE = FAUX ;
  10335. FINSI ;
  10336. SI ((NON (EXISTE ISHIFT)) OU (NON (EXISTE IRIPPLE))) ;
  10337. ERRE ' >>>> @CLIGB : check the value of TAB1.<TYPE_CALCUL';
  10338. FINSI ;
  10339. *
  10340. SI (EGA (TYPE CHSIGN) MOT) ;
  10341. * --- Cas ou l'appel vient d'une proc qui n'a pas calcule CHSIGN
  10342. CHSIGN = 1. ;
  10343. FINSI ;
  10344.  
  10345.  
  10346. * ---- Calcul du champ dans le repere global
  10347. BXG BYG BZG FSECU = @CHAMB TAB1 CHP_X CHP_Y CHP_Z ISHIFT IRIPPLE ;
  10348.  
  10349.  
  10350. * ---- Calcul de la norme du champ
  10351.  
  10352. NORM_B = ((BXG*BXG) + (BYG*BYG) + (BZG*BZG))**0.5 ;
  10353.  
  10354.  
  10355. *
  10356. XG_NEW0 = CHP_X + (CHSIGN * BXG * PASB0 / NORM_B) ;
  10357. YG_NEW0 = CHP_Y + (CHSIGN * BYG * PASB0 / NORM_B) ;
  10358. ZG_NEW0 = CHP_Z + (CHSIGN * BZG * PASB0 / NORM_B) ;
  10359.  
  10360. * ---- Coordonnees dans le repere
  10361. * ---- pseudo-toroidal du ripple
  10362. RHOR THER PHIR = @CRGTC CHP_X CHP_Y CHP_Z RR 0. ;
  10363. RHOR_OLD = RHOR ;
  10364. KAUX = (EXP (THER ** 2 * -1. * COEFC))* ((COS (PHIR * NBOB)) * -1. + 1.) * COEFA ;
  10365. I3 = 0 ;
  10366. REPETER BOUCLE3 50 ;
  10367. * I3 =I3 + 1 ; MESS ' I3 =' I3 ;
  10368. RHOR_NEW = RHOR + (KAUX * (EXP(RHOR_OLD * COEFB)));
  10369. SI ((MAXI (ABS((RHOR_NEW - RHOR_OLD)/RHOR_NEW))) &lt;EG EPS0) ;
  10370. QUITTER BOUCLE3 ;
  10371. FINSI ;
  10372. RHOR_OLD = RHOR_NEW ;
  10373. FIN BOUCLE3 ;
  10374.  
  10375. RHOMER = RHOR_NEW ;
  10376.  
  10377. I2 = 0 ;
  10378. REPETER BOUCLE2 2 ;
  10379. I2 =I2 + 1 ;
  10380. * MESS ' I2 =' I2 ;
  10381. * ---- point sur la surface magnetique
  10382. RHORN THERN PHIRN = @CRGTC XG_NEW0 YG_NEW0 ZG_NEW0 RR 0. ;
  10383. DRHOMERN = (EXP (RHOMER*COEFB))*(EXP(THERN**2 *COEFC * -1.)) * COEFA ;
  10384. RHORIP = DRHOMERN * ((COS(PHIRN * NBOB)) - 1.) + RHOMER ;
  10385.  
  10386. XG_NEW1 YG_NEW1 ZG_NEW1 = @CRTGC RHORIP THERN PHIRN RR 0. ;
  10387. *
  10388. * ---- Calcul du champ dans le repere global
  10389. BXG0 BYG0 BZG0 FSECU0 = @CHAMB TAB1 XG_NEW1 YG_NEW1 ZG_NEW1 ISHIFT IRIPPLE ;
  10390.  
  10391. * ---- Moyenne des tangentes
  10392. BXG1 = (BXG + BXG0)/2. ;
  10393. BYG1 = (BYG + BYG0)/2. ;
  10394. BZG1 = (BZG + BZG0)/2. ;
  10395.  
  10396. NORM_B1 = ((BXG1*BXG1) + (BYG1*BYG1) + (BZG1*BZG1))**0.5 ;
  10397.  
  10398. XG_NEW0 = CHP_X + (CHSIGN * BXG1 * PASB0 / NORM_B1) ;
  10399. YG_NEW0 = CHP_Y + (CHSIGN * BYG1 * PASB0 / NORM_B1) ;
  10400. ZG_NEW0 = CHP_Z + (CHSIGN * BZG1 * PASB0 / NORM_B1) ;
  10401.  
  10402. SI (I2 EGA 2);
  10403. XG_NEW = XG_NEW0 ;
  10404. YG_NEW = YG_NEW0 ;
  10405. ZG_NEW = ZG_NEW0 ;
  10406. FINSI ;
  10407.  
  10408. FIN BOUCLE2 ;
  10409.  
  10410. * ---- Calcul des deplacements
  10411.  
  10412. DEPX0 = BXG1 * PASB0 / NORM_B1 ;
  10413. DEPY0 = BYG1 * PASB0 / NORM_B1 ;
  10414. DEPZ0 = BZG1 * PASB0 / NORM_B1 ;
  10415.  
  10416.  
  10417.  
  10418. *MESS '---------------------------------> exiting @DREPROJ';
  10419. FINPROC DEPX0 DEPY0 DEPZ0 ;
  10420. 'DEBPROC' EPSCHL MOD_1*MMODEL SI_13*MCHAM TE0*CHPOINT TE1*CHPOINT TAB1/'TABLE ' ;
  10421. SI (( NON ( EXISTE MAT_1)) ET ( EXISTE TAB1)) ;
  10422. I1 = 0 ;
  10423. REPETER BOMA11 ;
  10424. I1 = I1 + 1 ;
  10425. SI ( EXISTE (TAB1.ZONE_MAT) I1 ) ;
  10426. MO1 = TAB1.MODL_MAT. I1 ;
  10427. TM_1 = ( REDU TE1 TAB1.ZONE_MAT.I1 ) ;
  10428. Y_1 = VARI TM_1 TAB1.TETMAT.MO1.YOUN YOUN ;
  10429. NU_1 = VARI TM_1 TAB1.TETMAT.MO1.NU NU ;
  10430. AL_1 = VARI TM_1 TAB1.TETMAT.MO1.ALPH ALPH ;
  10431. NU_1 = CHANGER CHAM NU_1 MO1 'RIGIDITE' ;
  10432. Y_1 = CHANGER CHAM Y_1 MO1 'RIGIDITE' ;
  10433. AL_1 = CHANGER CHAM AL_1 MO1 'RIGIDITE' ;
  10434. TEX1 = TEXTE 'YOUN Y_1 NU NU_1 ALPH AL_1' ;
  10435. IMOTM1 = DIME (MOTS TAB1.TEXTMECA.I1) ;
  10436. SI ( IMOTM1 EGA 5 ) ;
  10437. TEX1 = TEXTE TEX1 'SIGY YM_1 ' ;
  10438. TITRE 'MAT' I1 ' YIELD MODULUS' ;
  10439. YM_1 = VARI TM_1 TAB1.TETMAT.MO1.SIGY SIGY ;
  10440. YM_1 = CHANGER CHAM YM_1 MO1 'RIGIDITE' ;
  10441. TEX1 = TEXTE TEX1 'H H_1 ' ;
  10442. H_1 = VARI TM_1 TAB1.TETMAT.MO1.H H ;
  10443. H_1 = CHANGER CHAM H_1 MO1 'RIGIDITE' ;
  10444. FINSI ;
  10445. MA1 = MATE MO1 TEX1 ;
  10446. SINON ;
  10447. QUITTER BOMA11 ;
  10448. FINSI ;
  10449. SI ( I1 EGA 1 ) ;
  10450. MOD_1 = MO1 ;
  10451. MAT_1 = MA1 ;
  10452. SINON ;
  10453. MOD_1 = MOD_1 ET MO1 ;
  10454. MAT_1 = MAT_1 ET MA1 ;
  10455. FINSI ;
  10456. FIN BOMA11 ;
  10457. FINSI ;
  10458. TAB1.MATTOT = MAT_1 ;
  10459. SI_11 = THETA MAT_1 ( TE1 - TE0 ) ;
  10460. FO1 = BSIGMA SI_11 ;
  10461. SI_12 = SI_13 + SI_11 ;
  10462. EPS_1 = ELAS MOD_1 SI_12 MAT_1 FINPROC EPS_1 ;**** @EPTH DEBPROC @EPTH CHT1*CHPOINT EV1*EVOLUTION MOD1*MMODEL;
  10463.  
  10464. CHT2 = REDU CHT1 ( EXTR MOD1 'MAIL');
  10465. ALP1 = VARI MOD1 CHT2 EV1;
  10466. ALP2 = CHAN CHPO ALP1 MOD1 ;
  10467. ALP3 = NOMC ALP2 'SCAL' ;
  10468.  
  10469.  
  10470. EPS1 = ALP3 * CHT2;
  10471.  
  10472. EPX1 = NOMC EPS1 'EPXX';
  10473. EPY1 = NOMC EPS1 'EPYY';
  10474. EPZ1 = NOMC EPS1 'EPZZ';
  10475. GAXY1 = NOMC (0. * EPS1) 'GAXY';
  10476. GAXZ1 = NOMC (0. * EPS1) 'GAXZ';
  10477. GAYZ1 = NOMC (0. * EPS1) 'GAYZ';
  10478.  
  10479. EPX2 = CHAN CHAM EPX1 MOD1 'STRESSES';
  10480. EPY2 = CHAN CHAM EPY1 MOD1 'STRESSES';
  10481. EPZ2 = CHAN CHAM EPZ1 MOD1 'STRESSES';
  10482. GAXY2 = CHAN CHAM GAXY1 MOD1 'STRESSES';
  10483. GAXZ2 = CHAN CHAM GAXZ1 MOD1 'STRESSES';
  10484. GAYZ2 = CHAN CHAM GAYZ1 MOD1 'STRESSES';
  10485.  
  10486. EPS_THER = EPX2 ET EPY2 ET EPZ2 ET GAXY2 ET GAXZ2 ET GAYZ2;
  10487.  
  10488.  
  10489. FINPROC EPS_THER ;
  10490.  
  10491.  
  10492. **** @ET
  10493. DEBPROC @ET CH1*CHPOINT CH2*CHPOINT ;
  10494. CHA1 = CHAN 'ATTRIBUT ' CH1 'NATURE' 'DISCRET' ;
  10495. CHA2 = CHAN 'ATTRIBUT ' CH2 'NATURE' 'DISCRET' ;
  10496. CHR = CHA1 ET CHA2;
  10497. FINPROC CHR ;
  10498. **** @EVMAA
  10499. DEBPROC @EVMAA NOMM*MOT TIN1*FLOTTANT ;
  10500.  
  10501. EVE2 = @EVMAT NOMM 'ALPHA' ;
  10502. LLTE1 = EXTR EVE2 'ABSC' ;
  10503. KK1 = MINI ( ABS ( LLTE1 - (PROG (DIME LLTE1) * TIN1)));
  10504.  
  10505. SI (KK1 EGA 0. 1. ) ;
  10506. LLTE1 = LLTE1 + (PROG (DIME LLTE1) * 10.) ;
  10507. PP1 = @IPOE LLTE1 EVE2 FIXE ;
  10508. EVE2 = EVOL MANU 'TEMPERATURE' LLTE1 'ALPH' PP1 ;
  10509. FINSI ;
  10510.  
  10511. EVOC700 = EVOL MANU 'TEMPERATURE' LLTE1 'ALPH' ( PROG (DIME LLTE1) * (TIN1 - 20.)) ;
  10512.  
  10513. EVOCT1 = EVOL MANU 'TEMPERATURE' LLTE1 'ALPH' (LLTE1 - (PROG (DIME LLTE1) * 20.)) ;
  10514.  
  10515. EVOCTY1 = EVOL MANU 'TEMPERATURE' LLTE1 'ALPH' (PROG (DIME LLTE1) * ((TIN1 - 20.) * (EVMAT NOMM 'ALPHA' TIN1)));
  10516.  
  10517. BETA1 = ((EVOCTY1 - (EVE2 * EVOCT1))/(EVOC700 - EVOCT1)) ;
  10518.  
  10519. FINPROC BETA1 ;
  10520. **** @EVMAT
  10521. 'DEBPROC' @EVMAT MOT1*'MOT ' MOT2*'MOT ' VAL1/FLOTTANT CHP1/CHPOINT TABTT/TABLE ;
  10522. *23456789012345678901234567890123456789012345678901234567890123456789012
  10523. * 1 2 3 4 5 6 7
  10524. * version créee 19.12.96 par R. Mitteau pour fonctionner avec PASAPAS
  10525. *modification des noms de composantes :
  10526. * 'TEMPERATURE' -> 'T'
  10527. * 'CONDUCTIVITE' -> 'K'
  10528. * 'CAPACITE' -> 'CapaVolu'
  10529.  
  10530. SI ( EXISTE TABTT) ;
  10531. TABT = TABLE TABTT ;
  10532. SINON ;
  10533. TABT = TABLE ;
  10534. FINSI ;
  10535. TT1 = TABLE ;
  10536. REPETER BLOC1 1 ;
  10537.  
  10538. SI ( EGA MOT1 'DUNLOP' ) ;
  10539. * donnees bonnal 19 avril 93
  10540. TT1.'DUNLOP' = TABLE ;
  10541. TT1.'DUNLOP' . 'K' 'T' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'K'(PROG 459. 459. 446. 418. 390. 364. 341. 320. 302. 286. 273. 261. 250. 241. 233. 227. 220. 215. 190. 150. 110 51.) ;
  10542. *TITRE ' DUNLOP SPECIF HEAT' ;
  10543. TT1.'DUNLOP' . 'C' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'C' (PROG 708. 708. 789. 937. 1066. 1178. 1274. 1357. 1431. 1495.4 1552.4 1603.2 1648.7 1689.7 1726.8 1760.5 1791.3 1819.6 1820. 2000. 2050. 2100.) ;
  10544.  
  10545. *TITRE ' DUNLOP DENSITY' ;
  10546. TT1.'DUNLOP' . 'RHO' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'RHO' (PROG 1903. 1903. 1902. 1902. 1901. 1901. 1900. 1900. 1899. 1899. 1898. 1898. 1897. 1897. 1897. 1896. 1896. 1895. 1894. 1890. 1890. 1890. );
  10547.  
  10548. EVRHOC = (TT1.'DUNLOP' . 'RHO') * ( TT1.'DUNLOP' . 'C') ;
  10549. TT1.'DUNLOP' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10550. QUITTER BLOC1 ;
  10551. FINSI ;
  10552. ***********************************************************************
  10553. * N11 redensifie direction P
  10554. * materiau rentre par Raphael Mitteau le 6 juin 1996
  10555. * Source SEP lineaire entre 20 et 1000 C
  10556. SI ( EGA MOT1 'N11P_DENSE1' ) ;
  10557. *
  10558. * --- definition de la table
  10559. *
  10560. TT1.'N11P_DENSE1' = TABLE ;
  10561. *
  10562. * --- definition de la conductivite thermique
  10563. *
  10564. TT1.'N11P_DENSE1' . 'K' = EVOL MANU 'T' (PROG -200. 20. 1000. ) 'K' (PROG 250. 250. 100.) ;
  10565. *
  10566. * --- tout est defini, on quitte les bloc de definition des materiaux
  10567. *
  10568. QUITTER BLOC1 ;
  10569. FINSI ;
  10570. * N11 redensifie direction P
  10571. * materiau rentre par Raphael Mitteau le 6 juin 1996
  10572. * Source SEP a 20 et 1000 C copie variation N11
  10573. SI ( EGA MOT1 'N11P_DENSE2' ) ;
  10574. *
  10575. * --- definition de la table
  10576. *
  10577. TT1.'N11P_DENSE2' = TABLE ;
  10578. *
  10579. * --- definition de la conductivite thermique
  10580. *
  10581. TT1.'N11P_DENSE2' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(150.)) + (PROG 23. * 100.));
  10582. *
  10583. * --- tout est defini, on quitte les bloc de definition des materiaux
  10584. *
  10585. QUITTER BLOC1 ;
  10586. FINSI ;
  10587. ***********************************************************************
  10588. * Dunlop concept 1 conductivite dana la direction X mesure par CEA
  10589. * materiau rentre par Raphael Mitteau le 5 juin 1996
  10590. * source CEA/DRN/DMT 95-495 rapport de J.P. Bonal
  10591. SI ( EGA MOT1 'DUN_C1_BONAL_X' ) ;
  10592. *
  10593. * --- definition de la table
  10594. *
  10595. TT1.'DUN_C1_BONAL_X' = TABLE ;
  10596. *
  10597. * --- definition de la conductivite thermique
  10598. *
  10599. TT1.'DUN_C1_BONAL_X' . 'K' = EVOL MANU 'T' (PROG -200. 25 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. ) 'K' (PROG 430.6 430.6 425.7 406.5 382.4 358.0 335.1 314.4 295.9 279.5 264.9 252. 240.5 230.2 221.0 212.7 205.3 198.5 ) ;
  10600. *
  10601. * --- tout est defini, on quitte les bloc de definition des materiaux
  10602. *
  10603. QUITTER BLOC1 ;
  10604. FINSI ;
  10605. ***********************************************************************
  10606. * Dunlop concept 1 conductivite dana la direction X mesure par CEA
  10607. * materiau rentre par Raphael Mitteau le 5 juin 1996
  10608. * source CEA/DRN/DMT 95-495 rapport de J.P. Bonal
  10609. SI ( EGA MOT1 'DUN_C1_BONAL_Y' ) ;
  10610. *
  10611. * --- definition de la table
  10612. *
  10613. TT1.'DUN_C1_BONAL_Y' = TABLE ;
  10614. *
  10615. * --- definition de la conductivite thermique
  10616. *
  10617. TT1.'DUN_C1_BONAL_Y' . 'K' = EVOL MANU 'T' (PROG -200. 25 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. ) 'K'(PROG 102.4 102.4 102.4 99.9 95.6 90.8 86.0 81.4 77.2 73.4 69.9 66.8 63.9 61.3 58.9 56.7 54.7 52.9 ) ;
  10618. *
  10619. * --- tout est defini, on quitte les bloc de definition des materiaux
  10620. *
  10621. QUITTER BLOC1 ;
  10622. FINSI ;
  10623. ***********************************************************************
  10624. * Sepcarb NB31 Version C conductivite dana la direction X
  10625. * materiau rentre par Raphael Mitteau le 5 juin 1996
  10626. * source SEP
  10627. SI ( EGA MOT1 'NB31CX' ) ;
  10628. *
  10629. * --- definition de la table
  10630. *
  10631. TT1.'NB31CX' = TABLE ;
  10632. *
  10633. * --- definition de la conductivite thermique
  10634. *
  10635. * --- approximation lineaire
  10636. TT1.'NB31CX' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K' (PROG 323. 323. 154. 145. 145. ) ;
  10637.  
  10638. * --- variation copiee sur celle du N11
  10639. TT1.'NB31CX' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(323. - 154.)) + (PROG 23. * 154.));
  10640. *
  10641. * --- tout est defini, on quitte les bloc de definition des materiaux
  10642. *
  10643. QUITTER BLOC1 ;
  10644. FINSI ;
  10645. ***********************************************************************
  10646. * Sepcarb NB31 Version C conductivite dans la direction Y
  10647. * materiau rentre par Raphael Mitteau le 5 juin 1996
  10648. * source SEP
  10649. SI ( EGA MOT1 'NB31CY' ) ;
  10650. *
  10651. * --- definition de la table
  10652. *
  10653. TT1.'NB31CY' = TABLE ;
  10654. *
  10655. * --- definition de la conductivite thermique
  10656. *
  10657.  
  10658. * --- approximation lineaire
  10659.  
  10660. TT1.'NB31CY' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K'(PROG 117. 117. 58. 56. 56. ) ;
  10661.  
  10662. * --- variation copiee sur celle du N11
  10663.  
  10664. TT1.'NB31CY' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(117. - 58. )) + (PROG 23. * 58.));
  10665. *
  10666. * --- tout est defini, on quitte les bloc de definition des materiaux
  10667. *
  10668. QUITTER BLOC1 ;
  10669. FINSI ;
  10670. ***********************************************************************
  10671. * Sepcarb NB31 Version C conductivite dans la direction Z
  10672. * materiau rentre par Raphael Mitteau le 5 juin 1996
  10673. * source SEP
  10674. SI ( EGA MOT1 'NB31CZ' ) ;
  10675. *
  10676. * --- definition de la table
  10677. *
  10678. TT1.'NB31CZ' = TABLE ;
  10679. *
  10680. * --- definition de la conductivite thermique
  10681. *
  10682. TT1.'NB31CZ' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K'(PROG 115. 115. 55. 52. 52. ) ;
  10683. *
  10684. * --- tout est defini, on quitte les bloc de definition des materiaux
  10685. *
  10686. QUITTER BLOC1 ;
  10687. FINSI ;
  10688.  
  10689. ***********************************************************************
  10690. * Sepcarb NS31 Version C conductivite dans la direction X
  10691. * materiau rentre par Raphael Mitteau le 10 septembre 1996
  10692. * source SEP
  10693. SI ( EGA MOT1 'NS31CX' ) ;
  10694. *
  10695. * --- definition de la table
  10696. *
  10697. TT1.'NS31CX' = TABLE ;
  10698. *
  10699. * --- definition de la conductivite thermique
  10700. *
  10701. * --- approximation lineaire
  10702. TT1.'NS31CX' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K' (PROG 304. 304. 149. 141. 141. ) ;
  10703.  
  10704. * --- variation copiee sur celle du N11
  10705. TT1.'NS31CX' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(304. - 149.)) + (PROG 23. * 149.));
  10706. *
  10707. * --- tout est defini, on quitte les bloc de definition des materiaux
  10708. *
  10709. QUITTER BLOC1 ;
  10710. FINSI ;
  10711. ***********************************************************************
  10712. * Sepcarb NS31 Version C conductivite dans la direction Y
  10713. * materiau rentre par Raphael Mitteau le 10 septembre 1996
  10714. * source SEP
  10715. SI ( EGA MOT1 'NS31CY' ) ;
  10716. *
  10717. * --- definition de la table
  10718. *
  10719. TT1.'NS31CY' = TABLE ;
  10720. *
  10721. * --- definition de la conductivite thermique
  10722. *
  10723.  
  10724. * --- approximation lineaire
  10725.  
  10726. TT1.'NS31CY' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K'(PROG 100. 100. 55. 54. 54. ) ;
  10727.  
  10728. * --- variation copiee sur celle du N11
  10729.  
  10730. TT1.'NS31CY' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(100. - 55. )) + (PROG 23. * 55.));
  10731. *
  10732. * --- tout est defini, on quitte les bloc de definition des materiaux
  10733. *
  10734. QUITTER BLOC1 ;
  10735. FINSI ;
  10736. ***********************************************************************
  10737. * Sepcarb NB31 Version C conductivite dans la direction Z
  10738. * materiau rentre par Raphael Mitteau le 10 septembre 1996
  10739. * source SEP
  10740. SI ( EGA MOT1 'NS31CZ' ) ;
  10741. *
  10742. * --- definition de la table
  10743. *
  10744. TT1.'NS31CZ' = TABLE ;
  10745. *
  10746. * --- definition de la conductivite thermique
  10747. *
  10748. TT1.'NS31CZ' . 'K' = EVOL MANU 'T' (PROG -200. 20. 800. 1000. 2000.) 'K'(PROG 91. 91. 48. 43. 43. ) ;
  10749. *
  10750. * --- variation copiee sur celle du N11
  10751. *
  10752.  
  10753. TT1.'NS31CZ' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' (((((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) - (PROG 23. * 102.6 ))/ (247.8 - 102.6))*(91. - 48. )) + (PROG 23. * 48.));
  10754. *
  10755. * --- tout est defini, on quitte les bloc de definition des materiaux
  10756. *
  10757. QUITTER BLOC1 ;
  10758. FINSI ;
  10759.  
  10760. ***********************************************************************
  10761. * stands for DUNLOP CONCEPT 1
  10762. * valeurs rentrees le 04 mai 95 par J.F. Salavy
  10763.  
  10764. * source : DUNLOP LIMITED AVIATION DIVISION (net supply contract
  10765. * no 92-825A) envoyees par Ivi Smid le 29/03/95
  10766. * donnees entre 25 et 1200 C
  10767. * Pour cond_Z, les valeurs sont celles de la courbe et non du tableau
  10768.  
  10769. SI ( EGA MOT1 'DUN_CONCEPT1_X' ) ;
  10770.  
  10771. TT1.'DUN_CONCEPT1_X' = TABLE ;
  10772.  
  10773. TT1.'DUN_CONCEPT1_X' . 'K' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 2000. 5000.) 'K'(PROG 112. 112. 106. 92. 84. 74. 67. 64. 57. 56. 50. 49. 45. 42. 30. 10. ) ;
  10774.  
  10775. TT1.'DUN_CONCEPT1_X' . 'C' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'C' (PROG 710. 710. 934. 1171. 1363. 1506. 1621. 1706. 1779. 1835. 1884. 1924. 1960. 1990. 1990. ) ;
  10776.  
  10777. TT1.'DUN_CONCEPT1_X' . 'RHO' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'RHO' (PROG 1910. 1910. 1907. 1905. 1903. 1900. 1896. 1893. 1890. 1887. 1885. 1883. 1880. 1880. 1880. );
  10778.  
  10779. EVRHOC = ( TT1.'DUN_CONCEPT1_X' . 'RHO') * ( TT1.'DUN_CONCEPT1_X' . 'C');
  10780.  
  10781. TT1.'DUN_CONCEPT1_X' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10782.  
  10783. QUITTER BLOC1 ;
  10784. FINSI ;
  10785.  
  10786. SI ( EGA MOT1 'DUN_CONCEPT1_Y' ) ;
  10787.  
  10788. TT1.'DUN_CONCEPT1_Y' = TABLE ;
  10789.  
  10790. TT1.'DUN_CONCEPT1_Y' . 'K' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 2000. 5000. ) 'K'(PROG 78. 78. 73. 66. 59. 53. 48. 45. 40. 39. 37. 33. 33. 31. 30. 20. ) ;
  10791.  
  10792. TT1.'DUN_CONCEPT1_Y' . 'C' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'C' (PROG 719. 719. 923. 1182. 1368. 1507. 1623. 1706. 1776. 1834. 1883. 1924. 1959. 1990. 1990. );
  10793.  
  10794. TT1.'DUN_CONCEPT1_Y' . 'RHO' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'RHO' (PROG 1940. 1940. 1937. 1935. 1933. 1930. 1926. 1923. 1920. 1917. 1915. 1913. 1910. 1910. 1910. );
  10795.  
  10796. EVRHOC = ( TT1.'DUN_CONCEPT1_Y' . 'RHO') * ( TT1.'DUN_CONCEPT1_Y' . 'C');
  10797.  
  10798. TT1.'DUN_CONCEPT1_Y' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10799.  
  10800. QUITTER BLOC1 ;
  10801. FINSI ;
  10802.  
  10803. SI ( EGA MOT1 'DUN_CONCEPT1_Z' ) ;
  10804.  
  10805. TT1.'DUN_CONCEPT1_Z' = TABLE ;
  10806.  
  10807. TT1.'DUN_CONCEPT1_Z' . 'K' = EVOL MANU 'T' (PROG -5000. 20. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 2000. 5000. ) 'K'(PROG 351. 351. 330. 300. 275. 248. 225. 211. 190. 170. 150. 140. 125. 115. 100. 100. ) ;
  10808.  
  10809. TT1.'DUN_CONCEPT1_Z' . 'C' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'C' (PROG 695. 695. 923. 1173. 1362. 1508. 1620. 1706. 1777. 1837. 1883. 1925. 1960. 1989. 1989. );
  10810.  
  10811. TT1.'DUN_CONCEPT1_Z' . 'RHO' = EVOL MANU 'T' (PROG -5000. 25. 100. 200. 300. 400. 500. 600. 700. 800. 900. 1000. 1100. 1200. 5000. ) 'RHO' (PROG 1800. 1800. 1797. 1795. 1793. 1790. 1786. 1783. 1780. 1777. 1775. 1773. 1770. 1770. 1770. );
  10812.  
  10813. EVRHOC = ( TT1.'DUN_CONCEPT1_Z' . 'RHO') * ( TT1.'DUN_CONCEPT1_Z' . 'C');
  10814.  
  10815. TT1.'DUN_CONCEPT1_Z' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10816.  
  10817. QUITTER BLOC1 ;
  10818. FINSI ;
  10819. **********************************************************************
  10820.  
  10821. LL1 = (( EGA MOT1 'DUNX' ) OU ( EGA MOT1 'I1DUNX' ) OU ( EGA MOT1 'DUNY' ) OU ( EGA MOT1 'I1DUNY' ));
  10822. SI LL1 ;
  10823. * Valeurs fournies par Deschamps le 12/02/93 a 20. et 1000. degres C
  10824. TT1.'DUNX' = TABLE ;
  10825. *
  10826. TT1.'DUNX' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'K'(PROG 459. 459. 446. 418. 390. 364. 341. 320. 302. 286. 273. 261. 250. 241. 233. 227. 220. 215. 190. 150. 110 51.) ;
  10827. *
  10828.  
  10829. TT1.'DUNY' = TABLE ;
  10830. *
  10831. TT1.'DUNY' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'K'(PROG 92. 92. 91.3 89. 85.8 82.2 78.5 74.9 71.6 68.5 65.6 63 60.6 58.4 56.4 54.5 52.8 51.2 45. 35. 22. 51.) ;
  10832. *
  10833. *
  10834. * Valeurs fournies par Deschamps le 12/02/93 a 20. et 1000. degres C
  10835. TT1.'I1DUNX' = TABLE ;
  10836. *
  10837.  
  10838. P_COEF = prog .21 .21 .23 .26 .29 .33 .36 .39 .41 .44 .46 .48 .5 .52 .52 .52 .52 .52 .515 .51 .5 .5 ;
  10839. TT1.'I1DUNX' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'K'((PROG 459. 459. 446. 418. 390. 364. 341. 320. 302. 286. 273. 261. 250. 241. 233. 227. 220. 215. 190. 150. 110 51.)*P_COEF) ;
  10840. *
  10841. TT1.'I1DUNY' = TABLE ;
  10842. *
  10843. P_COEF = prog .21 .21 .23 .26 .29 .33 .36 .39 .41 .44 .46 .48 .5 .52 .52 .52 .52 .52 .515 .51 .5 .5 ;
  10844. TT1.'I1DUNY' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 3.5E3) 'K' ((PROG 92. 92. 91.3 89. 85.8 82.2 78.5 74.9 71.6 68.5 65.6 63 60.6 58.4 56.4 54.5 52.8 51.2 45. 35. 22. 51.)*P_COEF) ;
  10845. *
  10846. *
  10847. QUITTER BLOC1 ;
  10848. FINSI ;
  10849.  
  10850. ****************************************************************&*****
  10851. SI ( EGA MOT1 'N112X' ) ;
  10852. * Valeurs fournies par Deschamps le 12/02/93 a 20. et 1000. degres C
  10853. TT1.'N112X' = TABLE ;
  10854. *
  10855. TT1.'N112X' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 210. 210. 125. 111. 80. 69. 51. 51.) ;
  10856. *
  10857. TT1.'N112X' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 2.7E-6 2.7E-6 2.9E-6 3.3E-6 4.0E-6 4.0E-6 );
  10858. QUITTER BLOC1 ;
  10859. FINSI ;
  10860. ***********************************************************************
  10861. SI ( EGA MOT1 'N112Y' ) ;
  10862. TT1.'N112Y' = TABLE ;
  10863. *
  10864. TT1.'N112Y' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 200. 200. 120. 102. 76. 62. 49. 49.) ;
  10865. *
  10866. TT1.'N112Y' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 2.4E-6 2.4E-6 2.6E-6 3.0E-6 3.7E-6 3.7E-6 );
  10867. *
  10868. QUITTER BLOC1 ;
  10869. FINSI ;
  10870. SI ( EGA MOT1 'N112Z' ) ;
  10871. TT1.'N112Z' = TABLE ;
  10872. *
  10873. TT1.'N112Z' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 174. 174. 92. 72. 60. 50. 45. 45.) ;
  10874. *
  10875. TT1.'N112Z' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 2.2E-6 2.2E-6 2.4E-6 2.8E-6 3.5E-6 3.5E-6 );
  10876. QUITTER BLOC1 ;
  10877. FINSI ;
  10878. ***********************************************************************
  10879. SI ( EGA MOT1 'N112P' ) ;
  10880. * donnees bonnal 19 avril 93
  10881. TT1.'N112P' = TABLE ;
  10882. TT1.'N112P' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 5.5E3) 'K'(PROG 220.3 220.3 222.4 214.7 201. 186.9 173.4 161.3 150.7 141.3 133.1 125.9 119.6 114. 109. 104.6 100.6 97. 90. 70. 60. 58.) ;
  10883. *TITRE ' N112P SPECIF HEAT' ;
  10884. TT1.'N112P' . 'C' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 5.5E3) 'C' (PROG 669. 669. 770.3 935. 1063.2 1165.8 1249.7 1319.6 1378.8 1429.4 1473.4 1511.8 1545.7 1575.8 1602.7 1627.0 1648.9 1668.8 1748. 1950. 1950. 1950.) ;
  10885.  
  10886. *TITRE ' N112P DENSITY' ;
  10887. TT1.'N112P' . 'RHO' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 5.5E3) 'RHO' (PROG 2010. 2010. 2010. 2010. 2010. 2009. 2009. 2009. 2009. 2009. 2008. 2008. 2008. 2008. 2008. 2007. 2007. 2007. 2007. 2007. 2007. 2007. );
  10888.  
  10889. EVRHOC = (TT1.'N112P' . 'RHO') * ( TT1.'N112P' . 'C') ;
  10890. TT1.'N112P' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10891. QUITTER BLOC1 ;
  10892. FINSI ;
  10893. ***********************************************************************
  10894. SI ( EGA MOT1 'N112H' ) ;
  10895.  
  10896. TT1.'N112H' = TABLE ;
  10897. *
  10898. * TITRE ' N112 H CONDUCTIVITY' ;
  10899. TT1.'N112H' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 210. 210. 123. 105. 76. 62. 52. 52.) ;
  10900. QUITTER BLOC1 ;
  10901. FINSI ;
  10902. ***********************************************************************
  10903. SI ( EGA MOT1 'N112' ) ;
  10904. TT1.'N112' = TABLE ;
  10905. *
  10906. TT1.'N112' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 210. 210. 123. 105. 76. 62. 52. 52.) ;
  10907.  
  10908. *TITRE ' N112 SPECIF HEAT' ;
  10909. TT1.'N112' . 'C' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'C' (PROG 780. 780. 1430. 1580. 1890. 2030. 2060. 2060.) ;
  10910.  
  10911. *TITRE ' N112 DENSITY' ;
  10912. TT1.'N112' . 'RHO' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'RHO' (PROG 1820. 1820. 1820. 1820. 1820. 1820. 1820. 1820.);
  10913.  
  10914. EVRHOC = (TT1.'N112' . 'RHO') * ( TT1.'N112' . 'C') ;
  10915. TT1.'N112' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10916. * valeurs donnee par Deschamps 28 le 16.02.93
  10917. TT1.'N112' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (PROG 28.E9 28.E9 31.E9 34.E9 37.E9 37.E9);
  10918. *
  10919. QUITTER BLOC1 ;
  10920. FINSI ;
  10921. ***********************************************************************
  10922. SI ( EGA MOT1 'N11' ) ;
  10923. TT1.'N11' = TABLE ;
  10924. *
  10925. *js 190296 TT1.'N11' . 'K' = EVOL MANU
  10926. *js 190296 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3)
  10927. *js 190296 'K'(PROG 210. 210. 123. 105. 76. 62. 52. 52.) ;
  10928. TT1.'N11' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K'((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) * ( 210./247.) );
  10929.  
  10930. *TITRE ' N11 SPECIF HEAT' ;
  10931. TT1.'N11' . 'C' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'C' (PROG 780. 780. 1430. 1580. 1890. 2030. 2060. 2060.) ;
  10932.  
  10933. *TITRE ' N11 DENSITY' ;
  10934. TT1.'N11' . 'RHO' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'RHO' (PROG 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720.);
  10935.  
  10936. EVRHOC = (TT1.'N11' . 'RHO') * ( TT1.'N11' . 'C') ;
  10937. TT1.'N11' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10938.  
  10939. * valeurs donnee par Deschamps 28 le 16.02.93
  10940. TT1.'N11' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (PROG 28.E9 28.E9 31.E9 34.E9 37.E9 37.E9);
  10941. *
  10942. QUITTER BLOC1 ;
  10943. FINSI ;
  10944.  
  10945. ***************************************************************************
  10946. SI ( EGA MOT1 'N11_PPI' ) ;
  10947. TT1.'N11_PPI' = TABLE ;
  10948.  
  10949. * ....Lipa...actualise les valeurs le 28.3.95..suivant mesures PPI.
  10950.  
  10951. TT1.'N11_PPI' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 246. 246. 165. 141. 94. 72. 52. 52.) ;
  10952.  
  10953. *TITRE ' N11_PPI SPECIF HEAT' ;
  10954. TT1.'N11_PPI' . 'C' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'C' (PROG 780. 780. 1430. 1580. 1890. 2030. 2060. 2060.) ;
  10955.  
  10956. *TITRE ' N11_PPI DENSITY' ;
  10957. TT1.'N11_PPI' . 'RHO' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'RHO' (PROG 1750. 1750. 1750. 1750. 1750. 1750. 1750. 1750.);
  10958.  
  10959. EVRHOC = (TT1.'N11_PPI' . 'RHO') * ( TT1.'N11_PPI' . 'C') ;
  10960. TT1.'N11_PPI' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10961. * valeurs donnee par Deschamps 28 le 16.02.93
  10962.  
  10963. TT1.'N11_PPI' . 'YOUN' = EVOL MANU 'T' (PROG -500. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (PROG 28.E9 28.E9 31.E9 34.E9 37.E9 37.E9);
  10964.  
  10965. TT1.'N11_PPI' . 'ALPH' = EVOL MANU 'T'(PROG -500. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 1.5E-6 1.5E-6 1.6E-6 1.7E-6 1.8E-6 1.9E-6 );
  10966.  
  10967. TT1.'N11_PPI' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 3500.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  10968. *
  10969. QUITTER BLOC1 ;
  10970. FINSI ;
  10971. ***********************************************************************
  10972. SI ( EGA MOT1 'I1N112P' ) ;
  10973. * creation de ce materiau par J. SCHLOS le 22/09/94
  10974. * valeurs dans le plan, moyenne des directions x et y
  10975. * N112 // irradie at 640 deg C / 1.25 dpa.g
  10976. TT1.'I1N112P' = TABLE ;
  10977. *
  10978. TT1.'I1N112P' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 3500.) 'K'((PROG 45.6 45.6 48.7 53.1 55.8 57.2 57.9 58. 57.8 57.4 56.8 56.1 55.4 54.7 54. 53.6 52.9 51.3 37.2 21. 11.3 6.2 1.9) );
  10979. * Source :Bonnal telecopie a Deschamps le 21 09 94
  10980. * extrapole au dessus de 600.
  10981.  
  10982. *TITRE ' I1N112P SPECIF HEAT' ;
  10983. TT1.'I1N112P' . 'C' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 3500.) 'C' ((PROG 666. 666. 750. 901. 1031. 1142. 1237. 1320. 1391.8 1455. 1511. 1561. 1605. 1645. 1651.4 1680.6 1707.1 1731.3 1865.8 2098.4 2281. 2433.4 2682.6 ) );
  10984.  
  10985.  
  10986. *TITRE ' I1N112P DENSITY' ;
  10987. TT1.'I1N112P' . 'RHO' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 3500. ) 'RHO' (PROG 2026. 2026. 2026. 2026. 2025. 2025. 2025. 2024. 2024. 2024. 2023. 2023. 2023. 2023. 2022. 2022. 2022. 2022. 2022. 2022. 2022. 2022. 2022.);
  10988. EVRHOC = (TT1.'I1N112P' . 'RHO') * ( TT1.'I1N112P' . 'C') ;
  10989. TT1.'I1N112P' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  10990. QUITTER BLOC1 ;
  10991. FINSI ;
  10992. **************************************************************************************
  10993. SI ( EGA MOT1 'N11P' ) ;
  10994. * creation de ce materiau par R. MITTEAU le 20/01/94
  10995. * valeurs dans le plan, moyenne des directions x et y
  10996. * MODIF Fred.ESC. le 28/10/95 *****
  10997. * But de la manoeuvre :ameliorer la conductivite a haute temperature
  10998. * MODIF 1 : otpimisation au dela de 800 degC
  10999.  
  11000. TT1.'N11P' = TABLE ;
  11001. TT1.'N11P' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K'((PROG 247.8 247.8 243.4 228.0 210.2 193.2 178.1 165. 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 91.69 75.17 65.28 58.52 43.95) * ( 240./247.) );
  11002.  
  11003. *ESC 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 74.5 41.
  11004. *ESC 41. 41. 41.) * ( 240./247.) );
  11005.  
  11006. * MODIF 2 : MODIF 1 * ( 240./247.)
  11007. * 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 94.36 77.36
  11008. * 67.19 60.23 45.23) * ( 240./247.) );
  11009. * MODIF 3 : MODIF 2 * ( 1.05 )
  11010. * 153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 99.08 81.23
  11011. * 70.54 63.25 47.5) * ( 240./247.) );
  11012. * MODIF 4 : ORIGINAL * ( 1.1 )
  11013. *153.8 144.2 136. 129. 122.9 117.7 113.2 109.2 105.7 102.6 74.5 41.
  11014. * 41. 41. 41.) * ( 240./247.*1.1) );
  11015. * FIN MODIF Fred. ESC le 28/10/95 *****
  11016. * Source : Valeur a 25 C donnee par Chappuis selon mesures SEP
  11017. * (registre de controle individuel)2129043
  11018. * extrapolees pour les temperatures superieures selon valeurs
  11019. * du rapport DMT/93-265, J.P. BONAL, Elements pour la constitution
  11020. * d'une base de donnee sur les composites carbone-carboneA05 A035
  11021. * N11 N112 envisages pour la fusion thermonucleaire
  11022. * Aout 1993, extrapollee exponentiellement au dela de 800 C
  11023.  
  11024. *TITRE ' N11P SPECIF HEAT' ;
  11025. TT1.'N11P' . 'C' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'C' (PROG 672.8 672.8 763.9 920.5 1049.4 1156.6 1247. 1324. 1390.4 1448.2 1498.8 1543.6 1583.5 1619.2 1651.4 1680.6 1707.1 1731.3 1865.8 2098.4 2281. 2433.4 2682.6 ) ;
  11026. * source: rapport DMT/93-265, J.P. BONAL, Elements pour la constitution
  11027. * d'une base de donnee sur les composites carbone-carboneA05 A035
  11028. * N11 N112 envisages pour la fusion thermonucleaire
  11029. * Aout 1993, extrapollee exponentiellement au dela de 800 C
  11030.  
  11031. *TITRE ' N11P DENSITY' ;
  11032. TT1.'N11P' . 'RHO' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500. ) 'RHO' (PROG 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720.);
  11033.  
  11034. EVRHOC = (TT1.'N11P' . 'RHO') * ( TT1.'N11P' . 'C') ;
  11035. TT1.'N11P' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11036.  
  11037. TT1.'N11P' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'ALPH' ((1.42/6.)*(PROG 6.E-6 6.E-6 6.6E-6 7.8E-6 9.E-6 9.0E-6 ));
  11038. * Source : Valeur a 20 C donnee par Chappuis selon mesures SEP
  11039. * extrapolees pour les temperatures superieures selon lois precedentes
  11040.  
  11041. TT1.'N11P' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' ((24.5/22.)*(PROG 22.E9 22.E9 24.3E9 26.7E9 29.E9 29.E9));
  11042. * Source : Valeur a 20 C donnee par Chappuis selon mesures SEP
  11043. * extrapolees pour les temperatures superieures selon lois precedentes
  11044. *
  11045. TT1.'N11P' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11046. * Pris egal a celui de A05 par defaut d'autre valeur
  11047. QUITTER BLOC1 ;
  11048. FINSI ;
  11049. ***********************************************************************
  11050. SI ( EGA MOT1 'N11H' ) ;
  11051. * creation de ce materiau par R. MITTEAU le 20/01/94
  11052.  
  11053. TT1.'N11H' = TABLE ;
  11054. *
  11055. TT1.'N11H' . 'K' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500.) 'K' ((PROG 170.1 170.1 168.1 159. 147.9 137.0 127.2 118.5 111. 104.5 98.9 94.1 89.9 86.2 82.9 80.1 77.6 75.3 56.3 32.3 18.6 10.7 3.5 ) * (149.4/170.1));
  11056. * Source : Valeur a 25 C donnee par Chappuis selon mesures SEP
  11057. * (registre de controle individuel) 2129043
  11058. * extrapolees pour les temperatures superieures selon valeurs
  11059. * du rapport DMT/93-265, J.P. BONAL, Elements pour la constitution
  11060. * d'une base de donnee sur les composites carbone-carbone A05 A035
  11061. * N11 N112 envisages pour la fusion thermonucleaire
  11062. * Aout 1993, extrapollee exponentiellement au dela de 800 C
  11063.  
  11064. *TITRE ' N11H SPECIF HEAT' ;
  11065. TT1.'N11H' . 'C' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500. ) 'C' (PROG 672.8 672.8 763.9 920.5 1049.4 1156.6 1247. 1324. 1390.4 1448.2 1498.8 1543.6 1583.5 1619.2 1651.4 1680.6 1707.1 1731.3 1865.8 2098.4 2281. 2433.4 2682.6 ) ;
  11066. * source rapport DMT/93-265, J.P. BONAL, Elements pour la constitution
  11067. * d'une base de donnee sur les composites carbone-carbone A05 A035
  11068. * N11 N112 envisages pour la fusion thermonucleaire
  11069. * Aout 1993, extrapollee y=a*(x**b) au dela de 800 C
  11070.  
  11071. *TITRE ' N11H DENSITY' ;
  11072. TT1.'N11H' . 'RHO' = EVOL MANU 'T' (PROG -500. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 1000. 1500. 2000. 2500. 4500. ) 'RHO' (PROG 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720. 1720.);
  11073.  
  11074. EVRHOC = (TT1.'N11H' . 'RHO') * ( TT1.'N11H' . 'C') ;
  11075. TT1.'N11H' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11076.  
  11077. TT1.'N11H' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'ALPH' ((PROG 6.E-6 6.E-6 6.6E-6 7.8E-6 9.E-6 9.0E-6 ) * (2.67/6));
  11078. * Source : Valeur a 25 C donnee par Chappuis selon mesures SEP
  11079. * (registre de controle individuel)2129043
  11080. * extrapolee en T suivant loi ?
  11081.  
  11082. TT1.'N11H' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (PROG 28.E9 28.E9 31.E9 34.E9 37.E9 37.E9);
  11083. * source : valeurs donnees par Deschamps le 16.02.93
  11084.  
  11085.  
  11086. TT1.'N11H' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11087. * Pris egal a celui de A05 par defaut d'autre valeur
  11088. QUITTER BLOC1 ;
  11089. FINSI ;
  11090. ***********************************************************************
  11091. SI ( EGA MOT1 '5890PT' ) ;
  11092. TT1.'5890PT' = TABLE ;
  11093. *
  11094. *TITRE ' 5890PT CONDUCTIVITY' ;
  11095. TT1.'5890PT' . 'K' = EVOL MANU 'T' (PROG -200. 27. 200. 600. 800. 1000. 1500. 2000. 9.5E3) 'K'( PROG 76. 76. 73.5 54.7 49.0 44.0 36.5 31.7 31.7);
  11096.  
  11097. TT1.'5890PT' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'RHO'(PROG 1820. 1820. 1820. 1820. 1820. 1820. 1820. );
  11098.  
  11099. TT1.'5890PT' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'C'(PROG 880. 880. 1520. 1940. 2110. 2280. 2280.);
  11100.  
  11101. EVRHOC = (TT1.'5890PT' . 'RHO') * ( TT1.'5890PT' . 'C');
  11102.  
  11103. TT1.'5890PT' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11104. *
  11105. * caracteristiques mecaniques ajoutees par R. MITTEAU le 30 mars 1994
  11106.  
  11107. TT1.'5890PT' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 700. 1200. 1700. 2200. 9.5E3 ) 'YOUN' (PROG 12.E9 12.E9 13.E9 14.E9 15.E9 15.5E9 14.4E9 14.4E9);
  11108. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11109. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11110.  
  11111. TT1.'5890PT' . 'ALPH' = EVOL MANU 'T' (PROG 0. 20. 100. 700. 1200. 1700. 2200. 9.5E3 ) 'ALPH' (PROG 4.2E-6 4.2E-6 4.3E-6 4.8E-6 5.2E-6 5.6E-6 6.E-6 6.E-6);
  11112. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11113. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11114.  
  11115. TT1.'5890PT' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 200. 700. 1200. 1700. 2200. 9.5E3 ) 'NU' (PROG .09 .09 .09 .1 .11 .12 .12 .12 );
  11116. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11117. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11118. QUITTER BLOC1 ;
  11119. FINSI ;
  11120. *********************************************************************
  11121. SI ( EGA MOT1 'PYRO_GP' ) ;
  11122. TT1.'PYRO_GP' = TABLE ;
  11123. *
  11124. *TITRE ' PYRO_GP CONDUCTIVITY' ;
  11125. TT1.'PYRO_GP' . 'K' = EVOL MANU 'T' (PROG -200. 27. 200. 400. 600. 800. 1000. 1200. 1400. 1600. 2000. 9.5E3) 'K'( PROG 500. 500. 408. 350. 294. 260. 238. 220. 203. 190. 190. 190. );
  11126.  
  11127. TT1.'PYRO_GP' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'RHO'(PROG 2200. 2200. 2200. 2200. 2200. 2200. 2200. );
  11128.  
  11129. TT1.'PYRO_GP' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'C'(PROG 880. 880. 1520. 1940. 2110. 2280. 2280.);
  11130.  
  11131. EVRHOC = (TT1.'PYRO_GP' . 'RHO') * ( TT1.'PYRO_GP' . 'C');
  11132.  
  11133. TT1.'PYRO_GP' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11134. QUITTER BLOC1 ;
  11135. FINSI ;
  11136. **********************************************************************
  11137. SI ( EGA MOT1 'PYRO_GH' ) ;
  11138. *
  11139. TT1.'PYRO_GH' = TABLE ;
  11140. *
  11141. *TITRE ' PYRO_GH CONDUCTIVITY' ;
  11142. TT1.'PYRO_GH' . 'K' = EVOL MANU 'T' (PROG -200. 27. 200. 400. 600. 800. 1000. 1200. 1400. 1600. 2000. 9.5E3) 'K'( PROG 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. );
  11143.  
  11144. TT1.'PYRO_GH' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'RHO'(PROG 2200. 2200. 2200. 2200. 2200. 2200. 2200. );
  11145.  
  11146. TT1.'PYRO_GH' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 9.5E3) 'C'(PROG 880. 880. 1520. 1940. 2110. 2280. 2280.);
  11147.  
  11148. EVRHOC = (TT1.'PYRO_GP' . 'RHO') * ( TT1.'PYRO_GP' . 'C');
  11149.  
  11150. TT1.'PYRO_GH' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11151. *
  11152. QUITTER BLOC1 ;
  11153. FINSI ;
  11154. **********************************************************************
  11155. SI ( EGA MOT1 'TOYOTANSO' ) ;
  11156. TT1.'TOYOTANSO' = TABLE ;
  11157. *
  11158. LR1 = PROG 0. 20. 25. 50. 100. 150. 200. 250. 300. 350. 400. 450. 500. 550. 600. 650. 700. 750. 800. 4500. ;
  11159. LR2 = PROG 149.6 149.6 150.1 150.5 145.7 137.9 129.4 121.3 113.8 107.0 100.8 95.3 90.4 86.0 82.0 78.5 75.2 72.2 69.5 69.5 ;
  11160. *TITRE ' TOYOTANSO CONDUCTIVITY' ;
  11161. TT1.'TOYOTANSO' . 'K' = EVOL MANU 'T' LR1 'K' LR2 ;
  11162.  
  11163. LD = PROG 1838 1838 1838 1837 1836 1835 1833 1832 1831 1829 1828 1827 1825 1824 1823 1821 1820 1819 1817 1817 ;
  11164. TT1.'TOYOTANSO' . 'RHO' = EVOL MANU 'T' LR1 'RHO' LD ;
  11165.  
  11166. LR4 = PROG 666.8 666.8 686.4 778.0 933.3 1059.2 1162.9 1249.7 1323.3 1386.5 1441.2 1489.1 1531.4 1568.9 1602.5 1632.6 1659.9 1684.7 1707.3 1707.3 ;
  11167. TT1.'TOYOTANSO' . 'C' = EVOL MANU 'T' LR1 'C'LR4;
  11168.  
  11169. EVRHOC = (TT1.'TOYOTANSO' . 'RHO') * ( TT1.'TOYOTANSO' . 'C');
  11170.  
  11171. TT1.'TOYOTANSO' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11172. QUITTER BLOC1 ;
  11173. FINSI ;
  11174. **********************************************************************
  11175. SI ( EGA MOT1 'A05P' ) ;
  11176.  
  11177. TT1.'A05P' = TABLE ;
  11178.  
  11179. * 31/7/92 diminution de la conduc A05
  11180.  
  11181. *TITRE ' A05 // CONDUCTIVITY' ;
  11182. TT1.'A05P' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 9.5E3) 'K'(PROG 200. 200. 117. 97. 68. 55. 45. 45.) ;
  11183.  
  11184. *
  11185. TT1.'A05P' . 'C' = EVOL MANU 'T' (PROG -5000. 20. 500. 1000. 2000. 9.5E3) 'C' ( PROG 880. 880. 1500. 1900. 2070. 2070.);
  11186.  
  11187. TT1.'A05P' . 'RHO' = EVOL MANU 'T' (PROG -5000. 20. 500. 1000. 2000. 9.5E3) 'RHO' (PROG 1770. 1770. 1770. 1770. 1770. 1770.);
  11188.  
  11189. EVRHOC = (TT1.'A05P' . 'RHO') * ( TT1.'A05P' . 'C');
  11190.  
  11191. TT1.'A05P' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11192.  
  11193. TT1.'A05P' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9);
  11194.  
  11195. TT1.'A05P' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'ALPH' (PROG 1.E-6 1.E-6 1.1E-6 1.3E-6 1.5E-6 1.5E-6 );
  11196.  
  11197. TT1.'A05P' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11198. QUITTER BLOC1 ;
  11199. FINSI ;
  11200. **********************************************************************
  11201. SI ( EGA MOT1 'A05H' ) ;
  11202. TT1.'A05H' = TABLE ;
  11203. *
  11204. *TITRE ' A05 H CONDUCTIVITY' ;
  11205. TT1.'A05H' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 9.5E3) 'K'(PROG 95. 95. 60. 47. 30. 28. 26. 26.) ;
  11206.  
  11207. * alpha pris egal a 6 * alpha de A05P le 3 decembre 1993
  11208. * R.MITTEAU - J. SCHLOSSER
  11209. TT1.'A05H' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'ALPH' (PROG 6.E-6 6.E-6 6.6E-6 7.8E-6 9.E-6 9.0E-6 );
  11210.  
  11211. * toutes evolutions suivantes de A05 H prises egales a celle
  11212. * de A05P le 3 decembre 1993 R.MITTEAU - J. SCHLOSSER
  11213. TT1.'A05H' . 'C' = EVOL MANU 'T' (PROG -5000. 20. 500. 1000. 2000. 9.5E3) 'C' ( PROG 880. 880. 1500. 1900. 2070. 2070.);
  11214.  
  11215. TT1.'A05H' . 'RHO' = EVOL MANU 'T' (PROG -5000. 20. 500. 1000. 2000. 9.5E3) 'RHO' (PROG 1770. 1770. 1770. 1770. 1770. 1770.);
  11216.  
  11217. EVRHOC = (TT1.'A05H' . 'RHO') * ( TT1.'A05H' . 'C');
  11218.  
  11219. TT1.'A05H' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11220.  
  11221.  
  11222. TT1.'A05H' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 9.5E3 ) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9);
  11223.  
  11224. TT1.'A05H' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11225. QUITTER BLOC1 ;
  11226. FINSI ;
  11227. ********************************************************************************
  11228. SI ( EGA MOT1 'A05ORT3D' ) ;
  11229. * ce materiau est de l A05 orthotrope en 3 dimensions
  11230. * plans conducteurs dans la direction 2 - 3
  11231. * mis a jour le 22/12/93 par R. MITTEAU
  11232.  
  11233. TT1.'A05ORT3D' = TABLE ;
  11234.  
  11235. *------------------------ Donnees thermiques
  11236.  
  11237. TT1.'A05ORT3D' . 'K1' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 9.5E3) 'K'(PROG 95. 95. 60. 47. 30. 28. 26. 26.) ;
  11238. * ref : inconnue
  11239.  
  11240.  
  11241. TT1.'A05ORT3D' . 'K2' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 200. 200. 117. 97. 68. 55. 45. 45.) ;
  11242. * ref Le Carbone Lorraine
  11243.  
  11244. TT1.'A05ORT3D' . 'K3' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 200. 200. 117. 97. 68. 55. 45. 45.) ;
  11245. * reference Le Carbone Lorraine
  11246.  
  11247.  
  11248. TT1.'A05ORT3D' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 2000. 4.5E3) 'C' ( PROG 880. 880. 1500. 1900. 2070. 2070.);
  11249. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11250.  
  11251.  
  11252. TT1.'A05ORT3D' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 2000. 4.5E3) 'RHO' (PROG 1770. 1770. 1770. 1770. 1770. 1770.);
  11253. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11254.  
  11255. EVRHOC = (TT1.'A05ORT3D' . 'RHO') * ( TT1.'A05ORT3D' . 'C');
  11256.  
  11257. TT1.'A05ORT3D' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11258.  
  11259. *------------------------ Donnees mecaniques
  11260.  
  11261. TT1.'A05ORT3D' . 'YG1' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9 26.E9);
  11262. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11263.  
  11264. TT1.'A05ORT3D' . 'YG2' = EVOL MANU 'T' (PROG 0. 20. 300. 500. 700. 900. 4000.) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9 26.E9) ;
  11265. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11266.  
  11267. TT1.'A05ORT3D' . 'YG3' = EVOL MANU 'T' (PROG 0. 20. 300. 500. 700. 900. 4000.) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9 26.E9);
  11268. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11269.  
  11270. TT1.'A05ORT3D' . 'NU12' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11271. * ref : Le Carbone Lorraine, generalise pour toutes les T et directions
  11272.  
  11273. TT1.'A05ORT3D' . 'NU23' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11274. * ref : Le Carbone Lorraine, generalise pour toutes les T et directions
  11275.  
  11276. TT1.'A05ORT3D' . 'NU13' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11277. * ref : Le Carbone Lorraine, generalise pour toutes les T et directions
  11278.  
  11279.  
  11280. 1PLUS = EVOL MANU 'T' (PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 1. 1. 1. 1. 1. 1. 1.);
  11281.  
  11282. TT1.'A05ORT3D' . 'G12' = TT1.'A05ORT3D' . 'YG3' /(2* (1PLUS + TT1.'A05ORT3D' . 'NU12' ));
  11283. * ref : formule G = E / (2 * (1 + nu)), a verifier en orthotrope
  11284.  
  11285. TT1.'A05ORT3D' . 'G23' = TT1.'A05ORT3D' . 'YG1' /(2* (1PLUS + TT1.'A05ORT3D' . 'NU23' ));
  11286. * ref : formule G = E / (2 * (1 + nu)), a verifier en orthotrope
  11287.  
  11288.  
  11289. TT1.'A05ORT3D' . 'G13' = TT1.'A05ORT3D' . 'YG2' /(2* (1PLUS + TT1.'A05ORT3D' . 'NU13' ));
  11290. * ref : formule G = E / (2 * (1 + nu)), a verifier en orthotrope
  11291.  
  11292.  
  11293. * TT1.'A05ORT3D' . 'G12' = EVOL MANU
  11294. *'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 )
  11295. * 'COULOMB' (1.6*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11296. * TT1.'A05ORT3D' . 'G23' = EVOL MANU
  11297. *'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 )
  11298. * 'COULOMB' (1.7*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11299. * TT1.'A05ORT3D' . 'G13' = EVOL MANU
  11300. *'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 )
  11301. * 'COULOMB' (1.8*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11302.  
  11303. TT1.'A05ORT3D' . 'ALP1' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 7.E-6 7.E-6 7.5E-6 8.0E-6 9.0E-6 10.0E-6 ) ;
  11304. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11305. * interpole a partir des valeurs a 20 C et 2000 C
  11306.  
  11307. TT1.'A05ORT3D' . 'ALP2' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 0.7E-6 0.7E-6 0.9E-6 1.1E-6 1.5E-6 2.3E-6 );
  11308. * interpole a partir des valeurs a 20 C et 2000 C
  11309. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11310.  
  11311. TT1.'A05ORT3D' . 'ALP3' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 0.7E-6 0.7E-6 0.9E-6 1.1E-6 1.5E-6 2.3E-6 );
  11312. * ref : Principales caracteristiques des materiaux NET NT TS 51-90-06
  11313. * interpole a partir des valeurs a 20 C et 2000 C
  11314.  
  11315. QUITTER BLOC1 ;
  11316. FINSI ;
  11317. **********************************************************************
  11318.  
  11319. SI ( EGA MOT1 'A05ORT2D' ) ;
  11320. * ce materiau est de l A05 orthotrope en 2 dimensions
  11321. * plans conducteurs dans la direction
  11322. TT1.'A05ORT2D' = TABLE ;
  11323.  
  11324. *------------------------ Donnees thermiques
  11325.  
  11326. TT1.'A05ORT2D' . 'K' = EVOL MANU 'T' (PROG -500. 23. 350. 500. 1000. 1500. 2000. 4.5E3) 'K'(PROG 200. 200. 117. 97. 68. 55. 45. 45.) ;
  11327.  
  11328.  
  11329. TT1.'A05ORT2D' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 2000. 4.5E3) 'C' ( PROG 880. 880. 1500. 1900. 2070. 2070.);
  11330.  
  11331. TT1.'A05ORT2D' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 2000. 4.5E3) 'RHO' (PROG 1770. 1770. 1770. 1770. 1770. 1770.);
  11332.  
  11333. EVRHOC = (TT1.'A05ORT2D' . 'RHO') * ( TT1.'A05ORT2D' . 'C');
  11334.  
  11335. TT1.'A05ORT2D' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11336.  
  11337. *------------------------ Donnees mecaniques
  11338. * le 6/12/93, tout est bidon et ne sert qu a verifier
  11339. * que l orthotropie passe
  11340.  
  11341. TT1.'A05ORT2D' . 'YG1' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9);
  11342.  
  11343. TT1.'A05ORT2D' . 'YG2' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (1.3*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11344.  
  11345. TT1.'A05ORT2D' . 'YG3' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'YOUN' (1.5*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11346.  
  11347.  
  11348. TT1.'A05ORT2D' . 'G12' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'COULOMB' (1.6*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11349.  
  11350. TT1.'A05ORT2D' . 'G23' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'COULOMB' (1.7*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11351.  
  11352. TT1.'A05ORT2D' . 'G13' = EVOL MANU 'T' (PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'COULOMB' (1.8*(PROG 20.E9 20.E9 22.E9 24.E9 26.E9 26.E9));
  11353.  
  11354. TT1.'A05ORT2D' . 'ALP1' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (PROG 1.E-6 1.E-6 1.1E-6 1.3E-6 1.5E-6 1.5E-6 );
  11355. *
  11356. TT1.'A05ORT2D' . 'ALP2' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (1.3*(PROG 1.E-6 1.E-6 1.1E-6 1.3E-6 1.5E-6 1.5E-6 ));
  11357.  
  11358. TT1.'A05ORT2D' . 'ALP3' = EVOL MANU 'T'(PROG 0. 20. 500. 1000. 2000. 4.5E3 ) 'ALPH' (1.5*(PROG 1.E-6 1.E-6 1.1E-6 1.3E-6 1.5E-6 1.5E-6 ));
  11359.  
  11360. TT1.'A05ORT2D' . 'NU12' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11361. *
  11362. TT1.'A05ORT2D' . 'NU23' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11363. *
  11364. TT1.'A05ORT2D' . 'NU13' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 4000.) 'NU' (PROG 0.4 0.4 0.4 0.4 0.4 0.4 0.4 );
  11365.  
  11366. QUITTER BLOC1 ;
  11367. FINSI ;
  11368. ******************************************************************************
  11369. SI ( EGA MOT1 'B4C' ) ;
  11370. TT1.'B4C' = TABLE ;
  11371.  
  11372. TT1.'B4C' . 'K' =EVOL MANU 'T' (PROG -200. 0. 50. 75. 100. 150. 200. 300. 400. 500. 600. 650. 700. 750. 1000. 2000. 2.5E3 ) 'K' (PROG 0.5 .5 1. 1.1 1.15 1.1 1. 0.8 0.78 0.87 1.12 1.4 1.75 2.2 4.45 13.45 18.);
  11373.  
  11374. * Valeurs rentrees le 30.01.1995 par R. Mitteau, d'apres le rapport
  11375. *'Determination de la conductivite thermique d'un depot de B4C sur
  11376. * un substrat cuivre' par D. Gosset, Rapport LEMA.DG.AD/95-003
  11377. * du 06.01.1995, valeurs extrapolees lineairement au dessus de 800C
  11378. * Valeurs representatives d'echantillons SNMI
  11379.  
  11380.  
  11381. TT1.'B4C' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 100. 200. 300. 400. 500. 600. 800. 1000. 1500. 2000. 2.5E3) 'RHO'(PROG 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 1.3E3 );
  11382.  
  11383. * Valeurs rentrees le 30.01.1995 par R. Mitteau, d'apres le rapport
  11384. *'Determination de la conductivite thermique d'un depot de B4C sur
  11385. * un substrat cuivre' par D. Gosset, Rapport LEMA.DG.AD/95-003
  11386. * du 06.01.1995, valeurs extrapolees lineairement au dessus de 800C
  11387. * Valeurs representatives d'echantillons SNMI
  11388.  
  11389.  
  11390. TT1.'B4C' . 'C' = EVOL MANU 'T' (PROG -200. 20. 100. 200. 300. 400. 500. 600. 800. 1000. 1500. 2000. 2.5E3) 'C' (PROG .5E3 .85E3 1.15E3 1.35E3 1.5E3 1.6E3 1.65E3 1.65E3 1.63E3 1.58E3 1.5E3 1.5E3 1.5E3) ;
  11391.  
  11392. * Valeurs rentrees le 30.01.1995 par R. Mitteau, d'apres le rapport
  11393. *'Determination de la conductivite thermique d'un depot de B4C sur
  11394. * un substrat cuivre' par D. Gosset, Rapport LEMA.DG.AD/95-003
  11395. * du 06.01.1995, valeurs extrapolees lineairement au dessus de 800C
  11396. * Valeurs representatives d'echantillons SNMI
  11397.  
  11398. EVRHOC = (TT1.'B4C' . 'RHO') * ( TT1.'B4C' . 'C');
  11399.  
  11400. TT1.'B4C' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11401.  
  11402.  
  11403. *
  11404. TT1.'B4C' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 600. 2000.) 'YOUN' (PROG 450.E9 450.E9 450.E9 450.E9 450.E9 450.E9);
  11405.  
  11406. TT1.'B4C' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 2000.) 'ALPH' (PROG 5.E-6 5.E-6 5.E-6 5.E-6 5.E-6 5.E-6 5.E-6 );
  11407.  
  11408. TT1.'B4C' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11409.  
  11410. * valeurs non connues prises identiques AU CUCRZR
  11411.  
  11412. TT1.'B4C' . 'SIGY' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 2000.) 'SIGY' (PROG 10.E6 10.E6 10.E6 10.E6 10.E6 10.E6 2.E6 0. );
  11413.  
  11414. * TT1.'B4C' . 'H' = EVOL MANU
  11415. *'T'(PROG 0. 20. 200. 400. 500. 600.
  11416. * 800. 1000.)
  11417. * 'H' (PROG 1190.5E6 1190.5E6 1041.7E6 875.E6 729.2E6 500.E6
  11418. * 312.5E6 10.E6 );
  11419. QUITTER BLOC1 ;
  11420. FINSI ;
  11421. **********************************************************************
  11422. SI ( EGA MOT1 'BEHP' ) ;
  11423. * stands for BEryllium Hot Pressed
  11424. * valeurs rentrees le 18 mars 1994 par raphael MITTEAU
  11425. TT1.'BEHP' = TABLE ;
  11426.  
  11427. TT1.'BEHP' . 'K' = EVOL MANU 'T' (PROG -200. 20. 100. 300. 500. 600. 800. 1000. 2000. 4000.) 'K'(PROG 187. 187. 149. 130. 108. 103. 99. 93. 77. 60. ) ;
  11428. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11429. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11430. * valeurs pour 20 300 500 600, Best Fit pour les autres (log)
  11431. * donnee en Watt/ metre * Kelvin
  11432.  
  11433. TT1.'BEHP' . 'ALPH' = EVOL MANU 'T'(PROG -200. 20. 100. 500. 1000. 4000. ) 'ALPH' (PROG 11.3E-6 11.3E-6 13.5E-6 19.E-6 22.7E-6 27.9E-6);
  11434. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11435. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11436. * valeurs pour 20 100 500 1000, Best Fit pour les autres (puiss)
  11437. * donnee en [.]
  11438.  
  11439. TT1.'BEHP' . 'C' = EVOL MANU 'T' (PROG -200. 20. 100. 500. 1000. 1500. 4000. ) 'C' (PROG 1700. 1700. 2090. 2250. 2920. 3590. 3590. );
  11440. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11441. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11442. * valeurs pour 20 100 500 1000 1500 C
  11443. * donnee en Joule par Kelvin et par Kilo
  11444. * ce jeu de valeurs montre sans doute un PB vers 100 C
  11445.  
  11446. TT1.'BEHP' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 100. 500. 1000. 1500. 4000. ) 'RHO' (PROG 1850. 1850. 1826. 1711. 1565. 1420. 1420. );
  11447. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11448. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11449. * valeurs pour 20 et 1500 C, linearise pour les autres valeurs
  11450. * donnee en Kilo par metre cube
  11451.  
  11452. EVRHOC = (TT1.'BEHP' . 'RHO') * ( TT1.'BEHP' . 'C');
  11453.  
  11454. TT1.'BEHP' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11455.  
  11456.  
  11457. TT1.'BEHP' . 'YOUN' = EVOL MANU 'T' (PROG -200. 20. 300. 500. 800. 4000. ) 'YOUN' (PROG 297.E9 297.E9 281.E9 270.E9 253.E9 72.E9 );
  11458. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11459. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11460. * valeurs pour 20 600 et 800 C, Best Fit pour les autres (lineaire)
  11461. * donnee Pascal
  11462.  
  11463.  
  11464. TT1.'BEHP' . 'NU' = EVOL MANU 'T'(PROG -200. 20. 300. 500. 700. 900. 4000. ) 'NU' (PROG .08 .08 .08 .08 .08 .08 .08 );
  11465. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11466. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11467.  
  11468.  
  11469. TT1.'BEHP' . 'SIGY' = EVOL MANU 'T'(PROG -200. 20. 200. 400. 600. 800. 1100. ) 'SIGY' (PROG 275.E6 275.E6 245.E6 210.E6 150.E6 25.E6 1.E6 );
  11470. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11471. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11472. * valeurs pour 20 a 800 C corrigees,
  11473. * extrapolees a vue au dessus en fonction de Temp Fusion
  11474. * donnees exprimees en Pascal
  11475.  
  11476. TT1.'BEHP' . 'H' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 500. 600. 800. 4000.) 'H' (PROG 8. * 400.E6 );
  11477. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11478. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11479. * valeur moyenne prise cste pour tout T
  11480. * donnees exprimees en Pascal
  11481.  
  11482. QUITTER BLOC1 ;
  11483. FINSI ;
  11484. **********************************************************************
  11485. SI ( EGA MOT1 'BE_ITER' ) ;
  11486. * stands for BEryllium hot pressed and sintered, fitted values
  11487. * valeurs rentrees le 29 mars 95 par J.F. Salavy
  11488.  
  11489. * source : ITER MATERIAL PROPERTIES HANDBOOK
  11490. * (draft, file code ITER-AL01-2101)
  11491. * envoyees par Ivi Schmid le 29/03/95 (excepte pour H)
  11492. * Pour Young, Poisson et yield, les polynomes donnent des valeurs
  11493. * de 0 a 800C. Les valeurs suivantes sont intuitees mais
  11494. * non exactes.
  11495.  
  11496. TT1.'BE_ITER' = TABLE ;
  11497.  
  11498. LTEMC1 = (PROG 20. PAS 39. 800.) ;
  11499.  
  11500. LCON1 = PROG ;
  11501. LRHO1 = PROG ;
  11502. LCSP1 = PROG ;
  11503. LALP1 = PROG ;
  11504. LYOU1 = PROG ;
  11505. LPOI1 = PROG ;
  11506. LYIE1 = PROG ;
  11507.  
  11508. I1 = 0 ;
  11509. REPE BOUC1 (DIME LTEMC1) ;
  11510. I1 = I1 + 1 ;
  11511. TEMPC1 = EXTR LTEMC1 I1 ;
  11512. VALCON1 = (-1.0104E-07 * (TEMPC1 ** 3.)) + ( 2.5429E-04 * (TEMPC1 ** 2.)) + (-2.6939E-01 * TEMPC1 ) + ( 1.8980E+02 ) ;
  11513. LCON1 = LCON1 ET (PROG VALCON1) ;
  11514.  
  11515. VALCSP1 = ( 1.2748E-06 * (TEMPC1 ** 3.)) + (-3.1125E-03 * (TEMPC1 ** 2.)) + ( 3.3358E+00 * TEMPC1 ) + ( 1.7418E+03 ) ;
  11516. LCSP1 = LCSP1 ET (PROG VALCSP1) ;
  11517.  
  11518. VALRHO1 = (-1.5139E-05 * (TEMPC1 ** 2.)) + (-6.9336E-02 * TEMPC1 ) + ( 1.8230E+03 ) ;
  11519. LRHO1 = LRHO1 ET (PROG VALRHO1) ;
  11520.  
  11521. VALALP1 = ( 3.4457E-15 * (TEMPC1 ** 3.)) + (-1.3462E-11 * (TEMPC1 ** 2.)) + ( 2.1892E-08 * TEMPC1 ) + ( 1.0822E-05 ) ;
  11522. LALP1 = LALP1 ET (PROG VALALP1) ;
  11523.  
  11524. VALYOU1 = (-7.6042E+02 * (TEMPC1 ** 3.)) + ( 3.8393E+05 * (TEMPC1 ** 2.)) + (-8.6726E+07 * TEMPC1 ) + ( 3.0961E+11 ) ;
  11525. LYOU1 = LYOU1 ET (PROG VALYOU1) ;
  11526.  
  11527. VALPOI1 = (-2.5E-05 * TEMPC1 ) + ( 0.0715 ) ;
  11528. LPOI1 = LPOI1 ET (PROG VALPOI1) ;
  11529.  
  11530. VALYIE1 = ( 8.5157E-02 * (TEMPC1 ** 3.)) + (-4.1428E+02 * (TEMPC1 ** 2.)) + ( 4.4811E+04 * TEMPC1 ) + ( 2.2464E+08 ) ;
  11531. LYIE1 = LYIE1 ET (PROG VALYIE1) ;
  11532.  
  11533. FIN BOUC1 ;
  11534.  
  11535. LTEMPT = (PROG -200.) ET LTEMC1 ET (PROG 1250. 10000.) ;
  11536.  
  11537. LCON1T = (PROG (EXTR LCON1 1)) ET LCON1 ET (PROG 60. 60.) ;
  11538. LCSP1T = (PROG (EXTR LCSP1 1)) ET LCSP1 ET (PROG 3540. 3540.) ;
  11539. LRHO1T = (PROG (EXTR LRHO1 1)) ET LRHO1 ET (PROG 1713. 1713.) ;
  11540. LALP1T = (PROG (EXTR LALP1 1)) ET LALP1 ET (PROG 2.4E-5 2.4E-5) ;
  11541. LYOU1T = (PROG (EXTR LYOU1 1)) ET LYOU1 ET (PROG 98.E+9 98.E+9) ;
  11542. LPOI1T = (PROG (EXTR LPOI1 1)) ET LPOI1 ET (PROG 0.0517 0.0517) ;
  11543. LYIE1T = (PROG (EXTR LYIE1 1)) ET LYIE1 ET (PROG 35.E+6 35.E+6) ;
  11544.  
  11545.  
  11546. TT1.'BE_ITER' . 'K' = EVOL MANU 'T' (LTEMPT) 'K'(LCON1T) ;
  11547.  
  11548. TT1.'BE_ITER' . 'C' = EVOL MANU 'T' (LTEMPT) 'C' (LCSP1T) ;
  11549.  
  11550. TT1.'BE_ITER' . 'RHO' = EVOL MANU 'T' (LTEMPT) 'RHO' (LRHO1T) ;
  11551.  
  11552. TT1.'BE_ITER' . 'ALPH' = EVOL MANU 'T' (LTEMPT) 'ALPH' (LALP1T) ;
  11553.  
  11554. TT1.'BE_ITER' . 'YOUN' = EVOL MANU 'T' (LTEMPT) 'YOUN' (LYOU1T) ;
  11555.  
  11556. TT1.'BE_ITER' . 'NU' = EVOL MANU 'T' (LTEMPT) 'NU' (LPOI1T) ;
  11557.  
  11558. TT1.'BE_ITER' . 'SIGY' = EVOL MANU 'T' (LTEMPT) 'SIGY' (LYIE1T) ;
  11559.  
  11560.  
  11561. EVRHOC = (TT1.'BE_ITER' . 'RHO') * ( TT1.'BE_ITER' . 'C');
  11562.  
  11563. TT1.'BE_ITER' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11564.  
  11565.  
  11566. TT1.'BE_ITER' . 'H' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 500. 600. 800. 4000.) 'H' (PROG 8. * 400.E6 );
  11567. * source : MATERIAL DATA for predesign Analysis of In Vessel Components
  11568. * compiled by E. Zolti The NET TEAM, internal Note, Revised 14.9.90
  11569. * valeur moyenne prise cste pour tout T
  11570. * donnees exprimees en Pascal
  11571.  
  11572. QUITTER BLOC1 ;
  11573. FINSI ;
  11574.  
  11575. **********************************************************************
  11576. SI ( EGA MOT1 'MOLY' ) ;
  11577. TT1.'MOLY' = TABLE ;
  11578. *
  11579. TT1.'MOLY' . 'K' = EVOL MANU 'T' (PROG -100. 20. 500. 1000. 1500. 2000. 2500. 2.5E3 ) 'K'(PROG 60. 60. 50. 35. 22. 10. 2. 2. ) ;
  11580. *
  11581. QUITTER BLOC1 ;
  11582. FINSI ;
  11583. **********************************************************************
  11584. SI ( EGA MOT1 'TZM' ) ;
  11585. TT1.'TZM' = TABLE ;
  11586. *
  11587. TT1.'TZM'.'K' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 2.5E3 ) 'K'(PROG 125. 125. 115. 100. 87. 75. 67. 67. ) ;
  11588. TT1.'TZM' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 2.5E3) 'C' ( PROG 240. 240. 250. 290. 330. 400. 500. 500. );
  11589.  
  11590. TT1.'TZM' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 2.5E3) 'RHO' (PROG 10200. 10200. 10200. 10200. 10200. 10200. 10200. 10200.);
  11591.  
  11592. EVRHOC = (TT1.'TZM'.'RHO') * ( TT1.'TZM'.'C');
  11593.  
  11594. TT1.'TZM' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11595.  
  11596. TT1.'TZM' . 'YOUN' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2.5E3) 'YOUN' (PROG 300.E9 300.E9 260.E9 220.E9 140.E9 40.E9 40.E9);
  11597.  
  11598. TT1.'TZM' . 'ALPH' = EVOL MANU 'T'(PROG -200. 20. 500. 1000. 1500. 2000. 2500. 2.5E3 ) 'ALPH'(PROG 5.3E-6 5.3E-6 5.6E-6 6.0E-6 6.5E-6 7.2E-6 8.0E-6 8.0E-6 );
  11599.  
  11600. TT1.'TZM' . 'NU' = EVOL MANU 'T'(PROG -200. 20. 300. 500. 700. 900. 2000. 2.5E3) 'NU' (PROG 0.32 0.32 0.32 0.32 0.32 0.32 0.32 0.32 );
  11601.  
  11602. TT1.'TZM' . 'SIGY' = EVOL MANU 'T'(PROG -200. 20. 200. 400. 600. 800. 1000. 2.5E3 ) 'SIGY' (PROG 6.E8 6.E8 4.5E8 4.25E8 3.5E8 3.E8 2.5E8 2.5E8 );
  11603.  
  11604. TT1.'TZM' . 'H' = EVOL MANU 'T' (PROG -200. 20. 200. 400. 600. 800. 1000. 2.5E3 ) 'H' (PROG 1.1E9 1.1E9 1.1E9 1.1E9 1.1E9 1.1E9 1.1E9 1.1E9 );
  11605. *
  11606. QUITTER BLOC1 ;
  11607. FINSI ;
  11608. **********************************************************************
  11609. SI ( EGA MOT1 'TUNGSTEN' ) ;
  11610. TT1.'TUNGSTEN' = TABLE ;
  11611. *
  11612. TT1.'TUNGSTEN'.'K' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 3000. 3500. 4000. ) 'K'(PROG 130. 130. 120. 114. 105. 99. 95. 90. 85. 80.) ;
  11613. *Valeurs The NET TEAM, Valeurs de references ITER au dela
  11614.  
  11615. TT1.'TUNGSTEN' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 3000. 3500. 4000.) 'C' ( PROG 140. 140. 150. 170. 180. 200. 220. 240. 260. 280. );
  11616. *Valeurs The NET TEAM, extrapolation lineaire au dela
  11617.  
  11618.  
  11619. TT1.'TUNGSTEN' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 1000. 1500. 2000. 2500. 3000. 3500. 4000.) 'RHO' (PROG 19200. 19200. 19200. 19200. 19200. 19200. 19200. 19200. 19200. 19200.);
  11620. *Valeurs The NET TEAM, extrapolation lineaire au dela
  11621.  
  11622. EVRHOC = (TT1.'TUNGSTEN'.'RHO') * ( TT1.'TUNGSTEN'.'C');
  11623.  
  11624. TT1.'TUNGSTEN' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11625. QUITTER BLOC1 ;
  11626. FINSI ;
  11627. **********************************************************************
  11628. SI ( EGA MOT1 'OFHC' ) ;
  11629. TT1.'OFHC' = TABLE ;
  11630. *
  11631. TT1.'OFHC' . 'K' = EVOL MANU 'T' (PROG -5000. 20. 200. 300. 400. 600. 800. 1000. 2.5E3 ) 'K'(PROG 387. 387. 365. 351.5 338. 312. 291. 273. 273. ) ;
  11632. * 'T' (PROG -500. 20. 200. 300. 400. 600. 2.5E3 )
  11633. * 'K'(PROG 387. 387. 365. 351.5 338. 312. 312.) ;
  11634. *
  11635.  
  11636. TT1.'OFHC' . 'C' = EVOL MANU 'T' (PROG -5000. 20. 200. 400. 600. 2.5E3) 'C'( PROG 380. 380. 390. 400. 415. 415.);
  11637.  
  11638. TT1.'OFHC' . 'RHO' = EVOL MANU 'T' (PROG -5000. 20. 200. 400. 600. 2.5E3) 'RHO'(PROG 8750. 8750. 8650. 8560. 8480. 8480.);
  11639.  
  11640. EVRHOC = (TT1.'OFHC' . 'RHO') * ( TT1.'OFHC' . 'C');
  11641.  
  11642. TT1.'OFHC' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11643.  
  11644. TT1.'OFHC' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 600. 2000.) 'YOUN' (PROG 132.E9 132.E9 120.E9 103.E9 90.E9 29.E9);
  11645.  
  11646. TT1.'OFHC' . 'ALPH' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 500. 600. 2000.) 'ALPH' (PROG 16.6E-6 16.7E-6 17.3E-6 18.1E-6 18.45E-6 18.7E-6 20.0E-6 );
  11647.  
  11648. TT1.'OFHC' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11649.  
  11650. TT1.'OFHC' . 'SIGY' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 2000.) 'SIGY' (PROG 60.E6 60.E6 40.E6 20.E6 15.E6 10.E6 2.E6 0. );
  11651.  
  11652. TT1.'OFHC' . 'H' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 500. 600. 800. 1000.) 'H' (PROG 1190.5E6 1190.5E6 1041.7E6 875.E6 729.2E6 500.E6 312.5E6 10.E6 );
  11653. QUITTER BLOC1 ;
  11654. FINSI ;
  11655. **********************************************************************
  11656. SI ( EGA MOT1 'OFHCCYCL' ) ;
  11657. *
  11658. * Materiau entre le 19 septembre 1995 par R. Mitteau
  11659. *
  11660. * designation : Cuivre OFHC, proprietes mecaniques correspondant
  11661. * aux courbes d'ecrouissage cyclique
  11662. *
  11663. * Conductivite, rho, capacite calorifiques
  11664. * coefficient de Poisson prises identiques a OFHC
  11665. *
  11666. * Module d'young, SIGY et H d'apres
  11667. *
  11668. * High Temperature Torsional Low Cycle Fatigue of OFHC Copper
  11669. * Ahmet Aran and Dogan Erdun Gucer, Material Research Division,
  11670. * Marmara Research Institute...
  11671. * in Z. Metallkunde
  11672. *
  11673. * retravaille suivant CFP ...
  11674. *
  11675. *
  11676. *
  11677. TT1.'OFHCCYCL' = TABLE ;
  11678. *
  11679. TT1.'OFHCCYCL' . 'K' = EVOL MANU 'T' (PROG -5000. 20. 200. 300. 400. 600. 800. 1000. 2.5E3 ) 'K'(PROG 387. 387. 365. 351.5 338. 312. 291. 273. 273. ) ;
  11680.  
  11681. TT1.'OFHCCYCL' . 'C' = EVOL MANU 'T' (PROG -5000. 20. 200. 400. 600. 2.5E3) 'C'( PROG 380. 380. 390. 400. 415. 415.);
  11682.  
  11683. TT1.'OFHCCYCL' . 'RHO' = EVOL MANU 'T' (PROG -5000. 20. 200. 400. 600. 2.5E3) 'RHO'(PROG 8750. 8750. 8650. 8560. 8480. 8480.);
  11684.  
  11685. EVRHOC = (TT1.'OFHCCYCL' . 'RHO') * ( TT1.'OFHCCYCL' . 'C');
  11686.  
  11687. TT1.'OFHCCYCL' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11688.  
  11689. TT1.'OFHCCYCL' . 'YOUN' = EVOL MANU 'T' (PROG -150. 20. 100. 200. 300. 400. 450. 500. 600.) 'YOUN' (1.E9*(PROG 5. 5. 5. 5. 4.6 4. 2.5 1.2 .5 ));
  11690.  
  11691. TT1.'OFHCCYCL' . 'ALPH' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 500. 600. 2000.) 'ALPH' (PROG 16.6E-6 16.7E-6 17.3E-6 18.1E-6 18.45E-6 18.7E-6 20.0E-6 );
  11692.  
  11693. TT1.'OFHCCYCL' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11694.  
  11695. TT1.'OFHCCYCL' . 'SIGY' = EVOL MANU 'T'(PROG -150. 20. 100. 200. 300. 400. 450. 500. 600.) 'SIGY' (1.E6 *(PROG 116. 116. 112. 100. 86. 65. 33. 14. 5. ));
  11696.  
  11697. TT1.'OFHCCYCL' . 'H' = EVOL MANU 'T' (PROG -150. 20. 100. 200. 300. 400. 450. 500. 600. ) 'H' (1.E6 *(PROG 190. 190. 176. 154. 132. 110. 86. 62. 16. ));
  11698. QUITTER BLOC1 ;
  11699. FINSI ;
  11700. **********************************************************************
  11701. SI ( EGA MOT1 'INOX316L' ) ;
  11702. TT1.'INOX316L' = TABLE ;
  11703. *
  11704. TT1.'INOX316L' . 'K' = EVOL MANU 'T' (PROG -200. 20. 500. 800. 1000. 4.5E3 ) 'K'(PROG 15. 15. 21. 26. 28. 28.) ;
  11705.  
  11706. TT1.'INOX316L' . 'C' = EVOL MANU 'T' (PROG -200. 20. 500. 800. 1000. 2.5E3) 'C' ( PROG 480. 480. 560. 610. 650. 650.);
  11707.  
  11708. TT1.'INOX316L' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 500. 800. 1000. 2.5E3) 'RHO' (PROG 7850. 7850. 7850. 7850. 7850. 7850. );
  11709.  
  11710. EVRHOC = (TT1.'INOX316L' . 'RHO') * ( TT1.'INOX316L' . 'C');
  11711.  
  11712. TT1.'INOX316L' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11713.  
  11714. TT1.'INOX316L' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 300. 500. 650. 2000. ) 'YOUN' (PROG 190.E9 190.E9 170.E9 155.E9 145.E9 145.E9 );
  11715.  
  11716. TT1.'INOX316L' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 400. 500. 700. 2000.) 'ALPH' (PROG 16.2E-6 16.2E-6 17.8E-6 18.1E-6 18.7E-6 20.5E-6 );
  11717.  
  11718. TT1.'INOX316L' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11719.  
  11720. TT1.'INOX316L' . 'SIGY' = EVOL MANU *'T'(PROG 0. 20. 300. 500. 700. 2000. ) * 'SIGY' (PROG 250.E6 250.E6 160.E6 140.E6 120.E6 120.E6 );
  11721. 'T'(PROG 0. 20. 100. 200. 300. 400. 500. 600. 900. 2000. ) 'SIGY' (PROG 200.E6 200.E6 165.E6 132.5E6 112.5E6 100.E6 93.8E6 85.E6 65.E6 65.E6);
  11722. TT1.'INOX316L' . 'H' = EVOL MANU 'T'(PROG 0. 20. 100. 200. 300. 400. 500. 600. 900. 2000. ) 'H' (PROG 10.E9 10.E9 8.25E9 7.0E9 6.E9 4.5E9 4.5E9 4.5E9 4.5E9 4.5E9 );
  11723. QUITTER BLOC1 ;
  11724. FINSI ;
  11725. **********************************************************************
  11726. SI ( EGA MOT1 'GLIDCOP' ) ;
  11727. TT1.'GLIDCOP' = TABLE ;
  11728. *
  11729. TT1.'GLIDCOP' . 'K' = EVOL MANU 'T' (PROG -5000. 20. 200. 300. 500. 2.5E3 ) 'K'(PROG 348. 348. 325. 310.0 290. 290.) ;
  11730. * 'K'(PROG 391. 391. 385. 381. 377. 338. 312.) ;
  11731.  
  11732. TT1.'GLIDCOP' . 'C' = EVOL MANU 'T' (PROG -5000. 20. 200. 300. 400. 500. 600. 2.5E3) 'C' ( PROG 380. 380. 400. 410. 413. 413. 413. 413.);
  11733.  
  11734. TT1.'GLIDCOP' . 'RHO' = EVOL MANU 'T' (PROG -5000. 20. 200. 300. 400. 500. 600. 2.5E3) 'RHO' (PROG 8860. 8860. 8760. 8715. 8670. 8630. 8590. 8590.);
  11735.  
  11736. EVRHOC = (TT1.'GLIDCOP' . 'RHO') * ( TT1.'GLIDCOP' . 'C');
  11737.  
  11738. TT1.'GLIDCOP' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11739.  
  11740. TT1.'GLIDCOP' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 500. 800. 2000.) 'YOUN' (PROG 130.E9 130.E9 120.E9 98.E9 75.E9 75.E9);
  11741.  
  11742. TT1.'GLIDCOP' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 2000.) 'ALPH' (PROG 17.E-6 17.E-6 17.5E-6 18.5E-6 19.5E-6 19.5E-6 );
  11743.  
  11744. TT1.'GLIDCOP' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11745.  
  11746. TT1.'GLIDCOP' . 'SIGY' = EVOL MANU 'T'(PROG 0. 20. 200. 300. 500. 2000. ) 'SIGY' (PROG 424.E6 424.E6 313.E6 259.E6 169.E6 169.E6 );
  11747. * VALeurs prises egales au OFHC a controler
  11748.  
  11749. TT1.'GLIDCOP' . 'H' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 1000.) 'H' (PROG 1190.5E6 1190.5E6 1041.7E6 875.E6 729.2E6 500.E6 312.5E6 10.E6 );
  11750. QUITTER BLOC1 ;
  11751. FINSI ;
  11752. **********************************************************************
  11753. SI ( EGA MOT1 'OUTOKUMPU' ) ;
  11754. ***********************************************************************
  11755. TT1.'OUTOKUMPU' = TABLE ;
  11756. *
  11757. * seul valeur connue a 20 deg le reste pris proportionnellement a OFHC
  11758. TT1.'OUTOKUMPU' . 'K' = EVOL MANU 'T' (PROG -500. 20. 200. 300. 400. 600. 2.5E3 ) 'K'(PROG 355. 355. 335. 322.4 310. 286. 286.) ;
  11759. *OFHC
  11760. * 'T' (PROG -500. 20. 200. 300. 400. 600. 2.5E3 )
  11761. * 'K'(PROG 387. 387. 365. 351.5 338. 312. 312.) ;
  11762. QUITTER BLOC1 ;
  11763. FINSI ;
  11764. **********************************************************************
  11765. SI ( EGA MOT1 'CUCRZR' ) ;
  11766. TT1.'CUCRZR' = TABLE ;
  11767. *
  11768. *TITRE 'CUCRZR CONDUCTIVITY' ;
  11769. TT1.'CUCRZR' . 'K' = EVOL MANU 'T' (PROG -500. 20. 200. 300. 400. 600. 2.5E3 ) 'K'(PROG 343. 343. 351. 359. 359. 359. 312.) ;
  11770. TT1.'CUCRZR' . 'C' = EVOL MANU 'T' (PROG -200. 20. 200. 400. 600. 2.5E3) 'C' ( PROG 376. 376. 376. 376. 376. 376.);
  11771.  
  11772. TT1.'CUCRZR' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 200. 400. 600. 2.5E3) 'RHO'(PROG 8890. 8890. 8890. 8890. 8890. 8890.);
  11773.  
  11774. EVRHOC = (TT1.'CUCRZR' . 'RHO') * ( TT1.'CUCRZR' . 'C');
  11775.  
  11776. TT1.'CUCRZR' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11777.  
  11778. * valeurs non connues prises identiques CU dependent de l'etat du metal
  11779. TT1.'CUCRZR' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 600. 2000.) 'YOUN' (PROG 132.E9 132.E9 120.E9 103.E9 90.E9 29.E9);
  11780.  
  11781. TT1.'CUCRZR' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 1000. 2000.) 'ALPH' (PROG 16.6E-6 16.7E-6 17.3E-6 18.1E-6 18.45E-6 18.7E-6 19.1E-6 19.5E-6 20.0E-6);
  11782.  
  11783. TT1.'CUCRZR' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11784.  
  11785. TT1.'CUCRZR' . 'SIGY' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 2000.) 'SIGY' (PROG 210.E6 210.E6 200.E6 140.E6 100.E6 10.E6 2.E6 0. );
  11786.  
  11787. TT1.'CUCRZR' . 'H' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 1000.) 'H' (PROG 1190.5E6 1190.5E6 1041.7E6 875.E6 729.2E6 500.E6 312.5E6 10.E6 );
  11788. *
  11789. QUITTER BLOC1 ;
  11790. FINSI ;
  11791. **********************************************************************
  11792. SI ( EGA MOT1 'CUZR' ) ;
  11793. TT1.'CUZR' = TABLE ;
  11794. *valeurs non connues prises -10% au OFHC
  11795.  
  11796. TT1.'CUZR' . 'K' =EVOL MANU 'T' (PROG -200. 20. 200. 600. 1200. 2500. 2.5E3 ) 'K' (PROG 335. 335. 314. 270. 270. 270. 270.);
  11797.  
  11798. * valeurs non connues prises identiques au OFHC
  11799. TT1.'CUZR' . 'C' = EVOL MANU 'T' (PROG -200. 20. 200. 400. 600. 2.5E3) 'C'( PROG 380. 380. 390. 400. 415. 415.);
  11800.  
  11801. TT1.'CUZR' . 'RHO' = EVOL MANU 'T' (PROG -200. 20. 200. 400. 600. 2.5E3) 'RHO'(PROG 8750. 8750. 8650. 8560. 8480. 8480.);
  11802.  
  11803. EVRHOC = (TT1.'CUZR' . 'RHO') * ( TT1.'CUZR' . 'C');
  11804.  
  11805. TT1.'CUZR' . 'CapaVolu' = EVOL MANU 'T' ( EXTR EVRHOC ABSC 1 ) 'CapaVolu' ( EXTR EVRHOC ORDO 1 ) ;
  11806. * valeurs non connues prises identiques AU CU
  11807. TT1.'CUZR' . 'YOUN' = EVOL MANU 'T' (PROG 0. 20. 200. 400. 600. 2000.) 'YOUN' (PROG 132.E9 132.E9 120.E9 103.E9 90.E9 29.E9);
  11808.  
  11809. TT1.'CUZR' . 'ALPH' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 2000.) 'ALPH' (PROG 16.6E-6 16.7E-6 17.3E-6 18.1E-6 18.45E-6 18.7E-6 20.0E-6);
  11810.  
  11811. TT1.'CUZR' . 'NU' = EVOL MANU 'T'(PROG 0. 20. 300. 500. 700. 900. 2000.) 'NU' (PROG 0.3 0.3 0.3 0.3 0.3 0.3 0.3 );
  11812.  
  11813. * valeurs non connues prises identiques AU CUCRZR
  11814.  
  11815. TT1.'CUZR' . 'SIGY' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 2000.) 'SIGY' (PROG 210.E6 210.E6 200.E6 140.E6 100.E6 10.E6 2.E6 0. );
  11816.  
  11817. TT1.'CUZR' . 'H' = EVOL MANU 'T'(PROG 0. 20. 200. 400. 500. 600. 800. 1000.) 'H' (PROG 1190.5E6 1190.5E6 1041.7E6 875.E6 729.2E6 500.E6 312.5E6 10.E6 );
  11818. QUITTER BLOC1 ;
  11819. FINSI ;
  11820. **********************************************************************
  11821. SI ( EGA MOT1 'AL25' ) ;
  11822. TT1.'AL25' = TABLE ;
  11823. *
  11824. *TITRE ' AL25 CONDUCTIVITY' ;
  11825. TT1.'AL25'. 'K' = EVOL MANU 'T' (PROG -500. 20. 100. 200. 300. 400. 600. 2.5E3 ) 'K'(PROG 350. 350. 340. 327. 317. 300. 280. 280.) ;
  11826. QUITTER BLOC1 ;
  11827. FINSI ;
  11828. **********************************************************************
  11829. FIN BLOC1 ;
  11830. **********************************************************************
  11831. *
  11832. * Fin de la table de materiaux standarts
  11833. *
  11834. * Debut de la partie de la procedure qui retourne les donnees
  11835. *
  11836. **********************************************************************
  11837.  
  11838. SI (EXISTE TABT MOT1 ) ;
  11839. SI ( EXISTE (TABT. MOT1) MOT2 ) ;
  11840. EV1 = TABT . MOT1 . MOT2 ;
  11841. SINON ;
  11842. SI ( EXISTE TT1 MOT1 ) ;
  11843. SI ( EXISTE (TT1. MOT1) MOT2 ) ;
  11844. EV1 = TT1 . MOT1 . MOT2 ;
  11845. SINON ;
  11846. MESS '>>> Material ' MOT1 ' exists by you and in standard' ;
  11847. MESS '>>> the property ' MOT2 ' of the material ' MOT1 ' is not defined in your data' ' nor is it in satandard' ;
  11848. MESS '>>> Execution break-down by lack of data ' ;
  11849. ERRE 'MATERIAL' ;
  11850. FINSI ;
  11851. SINON ;
  11852. MESS '>>> MAT ' MOT1 ' exists by you but not in standard' ;
  11853. MESS '>>> the property ' MOT2 ' of the material ' MOT1 ' is not defined in your data' ;
  11854. MESS '>>> Execution break-down by lack of data ' ;
  11855. ERRE ' MATERIAL' ;
  11856. FINSI ;
  11857. FINSI ;
  11858. SINON ;
  11859. SI ( EXISTE TT1 MOT1 ) ;
  11860. SI ( EXISTE (TT1. MOT1) MOT2 ) ;
  11861. EV1 = TT1 . MOT1 . MOT2 ;
  11862. SINON ;
  11863. MESS '>>> The property ' MOT2 ' of the material ' MOT1 ' is not defined in standard' ;
  11864. ERRE 'MATERIAL' ;
  11865. FINSI ;
  11866. SINON ;
  11867. MESS '>>>> The material ' MOT1 ' is not defined in standard' ;
  11868. ERRE 'MATERIAL' ;
  11869. FINSI ;
  11870. FINSI ;
  11871.  
  11872. SI ( EXISTE VAL1 ) ;
  11873. EV1 = IPOL VAL1 (EXTR EV1 'ABSC' ) (EXTR EV1 'ORDO') ;
  11874. FINSI ;
  11875.  
  11876. SI ( EXISTE CHP1 ) ;
  11877. EV1 = IPOL CHP1 (EXTR EV1 'ABSC' ) (EXTR EV1 'ORDO') ;
  11878. FINSI ;
  11879. *
  11880. *
  11881. * Organisation :
  11882. * --------------
  11883. *
  11884. * La procedure est organisee en deux parties.
  11885. *
  11886. * La premiere partie est une table standart contenant les
  11887. * caracteristiques des materiaux usuels du groupe premiere paroi.
  11888. * Les donnees sont regroupes dans le bloc BLOC1.
  11889. *
  11890. * d'abord : materiaux de surface
  11891. * puis : materiaux intercalaires
  11892. * enfin : materiaux de structure
  11893. *
  11894. *
  11895.  
  11896. * Afin de ne pas surcharger la memoire de choses inutiles, un test
  11897. * permet de ne lire les donnees du materiau que s'il est effectivement
  11898. * appelle.
  11899. * Des que le materiau a ete lu, on sort du bloc, car il n'est pas
  11900. * necessaire de passer par tout les tests qui seront negatifs.
  11901. *
  11902. * Les caracteristiques sont definies sous forme d'evolutions.
  11903. *
  11904. * La deuxieme partie est la procedure proprement dite.
  11905. * Elle est organisee sous forme de tests SI-SINON-FINSI.
  11906.  
  11907. *-------------------------------------------------------------------*
  11908. FINPROC EV1 ;
  11909.  
  11910.  
  11911. 'DEBPROC' TELIGNSC MAIL_1*MAILLAGE CHP_1*CHPOINT P_DEB*POINT P_FIN*POINT CRIT*FLOTTANT ;
  11912. ********************************************************
  11913. *
  11914. * CETTE PROC. PERMET de reduire les valeurs du chpoint
  11915. *CHP_1 aux points les plus proche de la droite P_DEB P_FIN
  11916. * les points sont reperes suivant la distance a P_DEB
  11917. *la proc. rend une evolution donnant la valeur
  11918. *en fonction de la distance
  11919. *
  11920. * j. schlosser 8 4 92
  11921. *
  11922. ********************************************************
  11923. LBRI1 = MAIL_1 POIN 'DROIT' P_DEB P_FIN CRIT ;
  11924. i1 = 0 ;
  11925. opti elem seg2 ;
  11926. repeter bou4 (( NBNO LBRI1) - 1 ) ;
  11927. i1 = i1 + 1 ;
  11928. po1 = LBRI1 poin i1 ;
  11929. po2 = LBRI1 poin ( i1 + 1 ) ;
  11930. si ( i1 ega 1 ) ;
  11931. lbri2 = po1 d 1 po2 ;
  11932. sinon ;
  11933. lbri2 = lbri2 d 1 po2 ;
  11934. finsi ;
  11935. fin bou4 ;
  11936. XLBRI1 = COOR 1 LBRI2 ;
  11937. YLBRI1 = COOR 2 LBRI2 ;
  11938. NI1 = ( (( XLBRI1 - ( COOR 1 P_DEB )) ** 2 ) + (( YLBRI1 - ( COOR 2 P_DEB )) ** 2 ) ) ** 0.5 ;
  11939. EVI1 = evol chpo (REDU CHP_1 LBRI2 ) scal LBRI2 ;
  11940. EVI2 = evol chpo NI1 scal LBRI2 ;
  11941. EVIT1 = evol manu (EVI2 extr 'ORDO' 1 ) (EVI1 extr 'ORDO'1 ) ;
  11942. dess ( evI1 et evI2 ) ;
  11943. FINPROC EVIT1 ;
  11944.  
  11945. *EVIT1 = TELIGNSC VBRIQT CHT1 P01 O67 1.E-3 ;
  11946. **** @FLNORM
  11947.  
  11948. DEBPROC @FLNORM TAB1*TABLE ;
  11949. *
  11950. **************************************************
  11951. * Procedure (inspiree de @OMBRAGE) permettant de *
  11952. * recuperer les valeurs du flux normalise en *
  11953. * descendant les lignes de champ et en calculant *
  11954. * leur intersection avec le plan sur lequel la *
  11955. * valeur du flux normalise est connue. *
  11956. * Alain MOAL (Fevrier 2001) *
  11957. **************************************************
  11958. *
  11959. MESS '---------------------------------> calling @FLNORM';
  11960. *
  11961. *--------------- VARIABLES D'ENTREE :
  11962. MAIL1 = TAB1.LFLUX_EXTE ;
  11963. MAIL2 = TAB1.<MAILLAGE_FN ;
  11964. PASB1 = TAB1.<LONGUEUR_PAS_SANS_TEST ;
  11965. PASB2 = TAB1.<LONGUEUR_PAS_AVEC_TEST ;
  11966. *------------------------------------
  11967. *
  11968. *---- Champ magnetique sur le maillage "ombre"
  11969. TAB1.<MAILLAGE_B = MAIL1 ;
  11970. BR BZ BPHI = @MAGNB TAB1 ;
  11971. *
  11972. *---- signe pour descente de la ligne (+ si bz < 0)
  11973. TAB1.<CHAMP_SIGNE = BZ * (-1.) / (ABS BZ) ;
  11974. *
  11975. *---- distance a parcourir sans test d'intersection
  11976. CHZ = COOR 3 MAIL1 ;
  11977. Z0 = COOR 3 (MAIL2 POIN 1) ;
  11978. DMAX1 = (MINI (CHZ - Z0) 'ABS') * 0.9 ;
  11979. NBPAS1 = ENTIER ((DMAX1 + (PASB1/1000.))/PASB1) ;
  11980. *
  11981. *---- distance a parcourir avec test d'intersection
  11982. DMAX2 = (MAXI (CHZ - Z0) 'ABS') * 2. - DMAX1 ;
  11983. NBPAS2 = ENTIER ((DMAX2 + (PASB2/1000.))/PASB2) ;
  11984. *
  11985. *---- distance a parcourir
  11986. DMAX0 = (NBPAS1 * PASB1) + (NBPAS2 * PASB2) ;
  11987. *
  11988. *---- calcul exp(-delta/lambdaQ).ABS(b.n) aux points
  11989. *---- d'intersection avec une methode analytique
  11990. TAB1.<NOMBRE_PAS_SANS_TEST = NBPAS1 ;
  11991. TAB1.<NOMBRE_PAS_AVEC_TEST = NBPAS2 ;
  11992. TAB1.<DISTANCE_SANS_TEST = DMAX1;
  11993. TAB1.<DISTANCE_AVEC_TEST = DMAX2 ;
  11994. *
  11995. CHFNORM = @ANADES TAB1 ;
  11996. *
  11997. *---- Champ magnetique sur les points d'intersection
  11998. TAB1.<MAILLAGE_B = EXTR CHFNORM 'MAIL' ;
  11999. TITRE 'TEST : MAILLAGE INITIAL DEFORME ';
  12000. TRAC ((TAB1.<MAILLAGE_B) ET MAIL1 ET (TAB1.<GRILLE_B) ET (TAB1.<MAILLAGE_FN));
  12001. *
  12002. BR BZ BPHI = @MAGNB TAB1 ;
  12003. *
  12004. PHI = ATG (COOR 2 TAB1.<MAILLAGE_B) (COOR 1 TAB1.<MAILLAGE_B) ;
  12005. BX = BR * (COS PHI) - (BPHI * (SIN PHI));
  12006. BY = BR * (SIN PHI) + (BPHI * (COS PHI));
  12007. *AM*11/09/01*BX = BR * (COS PHI) + (BPHI * (SIN PHI));
  12008. *AM*11/09/01*BY = BR * (SIN PHI) - (BPHI * (COS PHI));
  12009. *
  12010. *---- Calcul de b.n sur le maillage "ombrant"
  12011. B_NORM = ((BX*BX) + (BY*BY) + (BZ*BZ))**0.5 ;
  12012. VBVN = (ABS BZ) / B_NORM ;
  12013. *
  12014. *---- calcul de exp (-delta/lambdaQ)
  12015. VAR1 = CHFNORM / VBVN ;
  12016. *
  12017. *---- on retrouve la forme initiale de TAB1.<S_OMBRE
  12018. FORM (TAB1.<DEPLACEMENT * (-1.)) ;
  12019. TITRE 'TEST : RETOUR FORME INITIALE' ;
  12020. TRAC ((TAB1.<MAILLAGE_B) ET MAIL1 ET (TAB1.<GRILLE_B) ET (TAB1.<MAILLAGE_FN));
  12021.  
  12022. MESS '>@FLNORM> distance covered :' TAB1.<LONGUEUR_PARCOURUE;
  12023.  
  12024. SI (EGA (TAB1.<LONGUEUR_CONNEXION_MAX) 0.) ;
  12025. MESS '>@FLNORM> no interception found';
  12026. SINON;
  12027. MESS '>@FLNORM> mini - maxi connection length' (mini TAB1.<CHAMP_DISTANCE) TAB1.<LONGUEUR_CONNEXION_MAX ;
  12028. FINSI;
  12029. *
  12030. MESS '---------------------------------> exiting @FLNORM';
  12031. FINPROC VAR1 ;
  12032.  
  12033. **** @FLUCRIT
  12034. DEBPROC @FLUCRIT TAB1*TABLE ;
  12035. *
  12036. * --- entrees
  12037. *
  12038. CHOIX = TAB1.'CHFCORRELATION';
  12039. NIVEAU = TAB1.'NIVEAU' ;
  12040. *
  12041. * --- racine
  12042. *
  12043. SI (NIVEAU >EG 4 ) ;
  12044. MESS '-----------------------------------> calling @FLUCRIT' ;
  12045. FINSI ;
  12046. * Calculs thermohydrauliques et bilans thermiques
  12047. * en attendant de les passer dans thersch1
  12048.  
  12049.  
  12050. *
  12051. * --- traitement
  12052. *
  12053. I1 = 1 ;
  12054. REPETER BOUC1 (DIME CHOIX) ;
  12055. ICHOIX = EXTR CHOIX I1 ;
  12056. LOGI1 = EGA ICHOIX 'BOWR' ;
  12057. LOGI2 = EGA ICHOIX 'TONG' ;
  12058. LOGI3 = EGA ICHOIX 'CELA' ;
  12059. LOGITOT1 = LOGI1 OU LOGI2 OU LOGI3 ;
  12060. SI (NON LOGITOT1) ;
  12061. ERRE '@FLUCRIT mot cle different de BOWR,TONG ou CELA' ;
  12062. FINSI ;
  12063. *
  12064. * --- Bowring72
  12065. *
  12066. SI (EGA ICHOIX 'BOWR') ;
  12067. TIN1 = TAB1.'T_IN' ;
  12068. PRESS1 = TAB1.'P_IN' ;
  12069. VITESS1 = TAB1.'V_IN' ;
  12070. EL = TAB1.'L_HEATED' ;
  12071. XL1 = TAB1.'WE_HEATED' ;
  12072. D1 = TAB1.'D_MAQUETTE' ;
  12073. YTWIST = TAB1.'TWIST_RATIO' ;
  12074. TTAPE = TAB1.'T_TAPE' ;
  12075. PI = 3.14159 ;
  12076. SI ( YTWIST EGA 0. ) ;
  12077. TAB1.DHC = D1 ;
  12078. S1 = PI * D1 * D1 / 4. ;
  12079. TAB1.DH = D1 ;
  12080. FACV = 1. ;
  12081. FACS = 1. ;
  12082. SINON ;
  12083. SI ( NON ( EXISTE TAB1 'N_CANAUX' )) ;
  12084. TAB1 . N_CANAUX = 2. ;
  12085. FINSI ;
  12086. SS2 = ( ( PI * D1 * D1 / 8.) - ( TTAPE * D1 / 2. ) ) ;
  12087. S1 = SS2 * TAB1 . N_CANAUX ;
  12088. QUAS = 4. * SS2 ;
  12089. PERI = ( ( PI * D1 / 2.) - TTAPE + D1 ) ;
  12090. TAB1.DH = QUAS / PERI ;
  12091. FINSI ;
  12092. TAB1.T_IN = TIN1;
  12093. TAB1.P_IN = PRESS1;
  12094. TAB1.V_IN = VITESS1;
  12095. @BOWRI72 TAB1 ;
  12096. QCHFW = TAB1.CHF ;
  12097. FINSI ;
  12098. *
  12099. * --- Tong75
  12100. *
  12101. SI (EGA ICHOIX 'TONG') ;
  12102. @TABEAU TAB1 ;
  12103. VIN = TAB1.V_IN ;
  12104. TIN = TAB1.T_IN ;
  12105. PRES1 = TAB1.P_LOCAL ;
  12106. D1 = TAB1.D_MAQUETTE ;
  12107. EL = TAB1.L_HEATED ;
  12108. XL1 = TAB1.WE_HEATED ;
  12109. TAB1.V_LOCAL = VIN ;
  12110. SI ( NON ( EXISTE TAB1 TWIST_RATIO ) ) ;
  12111. TAB1 . TWIST_RATIO = 0. ;
  12112. FINSI ;
  12113. YTWIST = TAB1 . TWIST_RATIO ;
  12114. SI ( NON ( EXISTE TAB1 T_TAPE ) ) ;
  12115. TAB1 . T_TAPE = 0. ;
  12116. FINSI ;
  12117. TTAPE = TAB1 . T_TAPE ;
  12118. QSURFE = TAB1.V_FLUMOY1 ;
  12119. TSAT = @IPOE PRES1 TAB1.EPTSAT ;
  12120. RHOIN = @IPOE TIN TAB1.ETRHOF ;
  12121. GIN = RHOIN * VIN ;
  12122. HIN = @IPOE TIN TAB1.ETHF ;
  12123. HSAT = @IPOE TSAT TAB1.ETHF ;
  12124. PI = 3.14159 ;
  12125. SI ( ( YTWIST EGA 0. ) ET ( EGA TAB1.HYPERVAP FAUX ) ) ;
  12126. TAB1.DHC = D1 ;
  12127. S1 = PI * D1 * D1 / 4. ;
  12128. TAB1.DH = D1 ;
  12129. FACV = 1. ;
  12130. FACS = 1. ;
  12131. TAB1.M_TONG = MOT 'TONG75' ;
  12132. * FACF = 1. ;
  12133. FINSI ;
  12134. SI ( NON ( EXISTE TAB1 HELI_WIRE ) ) ;
  12135. TAB1.HELI_WIRE = FAUX ;
  12136. FINSI ;
  12137. SI ( NON ( EXISTE TAB1 HYPERVAP ) ) ;
  12138. TAB1.HYPERVAP = FAUX ;
  12139. FINSI ;
  12140. SI ( ( YTWIST EGA 0. ) ET ( EGA TAB1.HELI_WIRE VRAI )) ;
  12141. S1 = PI * D1 * D1 / 4. ;
  12142. SM = PI * TAB1.WIRE_D * TAB1.WIRE_D / 4. ;
  12143. P1 = PI * D1 ;
  12144. PM = PI * TAB1.WIRE_D ;
  12145. TAB1.DH = 4. * ( S1 - SM ) / ( P1 + PM ) ;
  12146. PIS2Y = PI / ( 2 * TAB1.PITCH_WIRE ) ;
  12147. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  12148. * FACV = 1. ;
  12149. FACF = 1. ;
  12150. TAB1.M_TONG = MOT 'TONG75' ;
  12151. FINSI ;
  12152. *
  12153. SI ( NON ( EXISTE TAB1 HYPERVAP ) ) ;
  12154. TAB1.HYPERVAP = FAUX ;
  12155. FINSI ;
  12156. SI ( ( YTWIST EGA 0. ) ET ( EGA TAB1.HYPERVAP VRAI ) ) ;
  12157. SM = ( TAB1 . LARG_CANAL * TAB1 . HMIN_CANAL ) + ( 2. * ( TAB1 . LARG_ESP * TAB1 . HFIN ) ) ;
  12158. PM = TAB1 . LARG_CANAL + ( 2.* TAB1 . HMAX_CANAL ) + ( 2. * TAB1 . LARG_ESP ) + ( 2. * TAB1 . HFIN ) + TAB1 . LFIN ;
  12159. TAB1.DH = 4. * SM / PM ;
  12160. FACV = 1. ;
  12161. FACF = 1. ;
  12162. TAB1.HYP_SM = SM ;
  12163. FINSI ;
  12164. *
  12165. SI ( YTWIST > 0. ) ;
  12166. SI ( NON ( EXISTE TAB1 'N_CANAUX' )) ;
  12167. TAB1 . N_CANAUX = 2. ;
  12168. FINSI ;
  12169. SS2 = ( ( PI * D1 * D1 / 8.) - ( TTAPE * D1 / 2. ) ) ;
  12170. S1 = SS2 * TAB1 . N_CANAUX ;
  12171. QUAS = 4. * SS2 ;
  12172. PERI = ( ( PI * D1 / 2.) - TTAPE + D1 ) ;
  12173. TAB1.DH = QUAS / PERI ;
  12174. TAB1.DHC = 4. * ( ( PI * D1 * D1 / 4.) - ( TTAPE * D1 ) ) / ( ( PI * D1 ) - ( TTAPE * 2.) ) ;
  12175. PIS2Y = PI / ( 2. * YTWIST ) ;
  12176. FACV = ( 1. + ( PIS2Y ** 2 ) ) ** 0.5 ;
  12177. FACF = 1.15 ;
  12178. FACS = 1.67 ;
  12179. TAB1.M_TONG = MOT '1.67*TONG75' ;
  12180. FINSI ;
  12181. SI ( EGA TAB1.HYPERVAP VRAI ) ;
  12182. HLOCAL = HIN + ( QSURFE * XL1 * EL / ( GIN * TAB1.HYP_SM ) ) ;
  12183. SINON ;
  12184. HLOCAL = HIN + ( QSURFE * XL1 * EL / ( GIN * S1 ) ) ;
  12185. FINSI ;
  12186. SI ( HLOCAL < HSAT ) ;
  12187. SI ( HLOCAL >EG HIN ) ;
  12188. TLOCAL = @IPOE HLOCAL TAB1.EHFT ;
  12189. SINON ;
  12190. MESS '>@FLUCRIT> HLOCAL < HIN ?????====== ' ;
  12191. ERREUR '>@FLUCRIT> HLOCAL < HIN' ;
  12192. FINSI ;
  12193. SINON ;
  12194. TLOCAL = TSAT ;
  12195. * HLOCAL = HSAT ;
  12196. FINSI ;
  12197. TAB1.'HLOCAL' = HLOCAL ;
  12198. @TONG75 TAB1 ;
  12199. QCHFW = TAB1.CHF ;
  12200. FINSI ;
  12201. *
  12202. * --- Celata94
  12203. *
  12204. SI (EGA ICHOIX 'CELA') ;
  12205. @CELAT94 TAB1 ;
  12206. QCHFW = TAB1.CHF ;
  12207. FINSI ;
  12208. *
  12209. * --- fin des appels
  12210. *
  12211. SI (EGA I1 1) ;
  12212. L_QCHFW = PROG QCHFW ;
  12213. SINON ;
  12214. L_QCHFW = L_QCHFW ET (PROG QCHFW) ;
  12215. FINSI ;
  12216. I1 = I1 + 1 ;
  12217. FIN BOUC1 ;
  12218.  
  12219. MESS '>@FLUCRIT> Critical Heat Flux output';
  12220. LIST L_QCHFW ;
  12221. *
  12222. * --- sorties
  12223. *
  12224. TAB1.'L_QCHFW' = L_QCHFW ;
  12225.  
  12226. SI (NIVEAU >EG 4 ) ;
  12227. MESS '-----------------------------------> exiting @FLUCRIT' ;
  12228. FINSI ;
  12229.  
  12230. FINPROC ;
  12231. **** @FLUXH
  12232. DEBPROC @FLUXH TAB1*TABLE ;
  12233. *---------------------------------------------------------------------
  12234. * Procedure @FLUXH
  12235. *---------------------------------------------------------------------
  12236. MESS '---------------------------------> calling @FLUXH';
  12237. V_DIM1 = VALEUR 'DIME' ;
  12238. S_TOT1 = TAB1.M_ILLAGE_TOT ;
  12239. COSDIR1 COSDIR2 COSDIR3 = @VNORM3D (EXTR TAB1.'MODELF' 'MAIL') (TAB1.LFLUX_EXTE) TAB1.'NIVEAU';
  12240. COTETF1 = COSDIR1 ;
  12241. SITETF1 = COSDIR2;
  12242. TETF1 = ATG SITETF1 ( COTETF1 + 1.E-12) ;
  12243.  
  12244. SI (EXISTE TAB1 'VAL_ANGLEI1');
  12245. MESS '>>>>@FLUXH Le flux d electrons est forcement selon OY ';
  12246. MESS '>>>>@FLUXH a l axe y, si autre angle tournez avec DEPL';
  12247. ERRE '>>>>@FLUXH TAB1 VAL_ANGLEI1 inoperant ici';
  12248. FINSI ;
  12249.  
  12250. *1 DDDDDDDDDD SI de niveau 1 : cas DIMENSION 2
  12251.  
  12252. SI ( V_DIM1 EGA 2) ;
  12253. MESS '>@FLUXH> 2D ';
  12254. VFON1 = TAB1.VPROFIL_W;
  12255. XFON1 = TAB1.XPROFIL_W;
  12256. LPAT1 = TAB1.LFLUX_EXTE;
  12257. LPAT1D = TAB1.LFLUX_EXTE_DESS ;
  12258. XLPAT1 = COOR 1 LPAT1;
  12259. XLPAT1D = COOR 1 LPAT1D;
  12260. XL_LPAT1 = ABS (( MAXI XLPAT1 ) - ( MINI XLPAT1 ));
  12261. VFON2 = ( IPOL XLPAT1 XFON1 VFON1 ) ;
  12262. EVV1 = EVOL CHPO XLPAT1 SCAL LPAT1D ;
  12263. *dess EVV1 ;
  12264. EVV2 = EVOL CHPO VFON2 SCAL LPAT1D ;
  12265. *dess EVV2 ;
  12266. VVFON2 = EXTR EVV2 ORDO 1 ;
  12267. XXPAT1 = EXTR EVV1 ORDO 1 ;
  12268. TITRE ' INCIDENT GUN FLUX PROFILE ' ;
  12269. dess ( EVOL MANU XXPAT1 VVFON2 ) ;
  12270. SOM1 = INTG ( EVOL MANU XXPAT1 VVFON2 ) ;
  12271. SOM1 = ABS ( MAXI SOM1 ) ;
  12272.  
  12273. * ajout RM le 27 10 95
  12274. SI (EGA (VALE MODE) 'AXIS') ;
  12275. MESS '>@FLUXH> mode axisymetrique' ;
  12276. SOM1 =(2. * 3.14159 * (INTG ( EVOL MANU XXPAT1 (VVFON2 * XXPAT1)))) ;
  12277. SOM1 = ABS ( MAXI SOM1 ) ;
  12278. FINSI ;
  12279. * fin locale de l ajout RM le 27 10 95
  12280.  
  12281. FACFM1 = SOM1 / XL_LPAT1 ;
  12282. MESS '>@FLUXH> VALEUR integrale DU PROFIL' SOM1;
  12283. MESS '>@FLUXH> LARGEUR MAQ. CHAUFFEE' (TAB1 . W_HEATED);
  12284. MESS '>@FLUXH> VALEUR moyenne DU PROFIL' FACFM1;
  12285. VPAT1 = VFON2 * SITETF1;
  12286. (MINI VPAT1) (MAXI VPAT1);
  12287. TAB1.'WE_HEATED_N'= XL_LPAT1 * (TAB1 . FSYM_X );
  12288. TAB1.'WE_HEATED'= XL_LPAT1 * (TAB1 . FSYM_X );
  12289. VPUI_1 = FACFM1 * XL_LPAT1;
  12290. TAB1.'V_FACFM1' = FACFM1;
  12291. MESS '>@FLUXH> direct integration' VPUI_1 ;
  12292.  
  12293. *
  12294. * --- test puissance incidente
  12295. *
  12296.  
  12297. * calcul apres utilisation de l operateur flux
  12298.  
  12299. FPAT1 = FLUX TAB1.'MODELF' VPAT1;
  12300. VPUI_2 = (MAXI (RESU FPAT1));
  12301. MESS '>@FLUXH> nodal intergration ' VPUI_2;
  12302.  
  12303. ERR_1 = VPUI_2 * 0.05;
  12304. SI( NON ( EGA VPUI_1 VPUI_2 ERR_1));
  12305. MESS '>@FLUXH> call the CONCEPTEUR ';
  12306. ERREUR 'POWER BALANCE';
  12307. SINON;
  12308. MESS '>@FLUXH> Ok Power Balance';
  12309. FINSI;
  12310.  
  12311. SOM1 = SOM1 * (EXTR TAB1.LIS_FLUX (DIME TAB1.LIS_FLUX));
  12312. SI (NON (EXISTE TAB1 'V_SOM1'));
  12313. TAB1.'V_SOM1' = SOM1;
  12314. SINON;
  12315. TAB1.'V_SOM1' = TAB1.'V_SOM1' + SOM1;
  12316. FINSI;
  12317. * 1 MMMMMMMM SINON de niveau 1 : cas DIMENSION 3
  12318. SINON ;
  12319.  
  12320. EXFLUX1 = TAB1.E_XPROFIL_W ;
  12321. EZFLUX1 = TAB1.E_ZPROFIL_W ;
  12322.  
  12323. SFLUX1 = TAB1.LFLUX_EXTE ;
  12324.  
  12325. XSFLUX1 = COOR 1 SFLUX1 ;
  12326. ZSFLUX1 = COOR 3 SFLUX1 ;
  12327.  
  12328. VXFLUX2 = ( @IPOE XSFLUX1 EXFLUX1 FIXE ) ;
  12329. VZFLUX2 = ( @IPOE ZSFLUX1 EZFLUX1 FIXE ) ;
  12330.  
  12331. VXZFLUX2 = VXFLUX2 * VZFLUX2 * COSDIR2 ;
  12332. PHFLUX1 = FLUX (TAB1.'MODELF') VXZFLUX2 ;
  12333. VMOY1 = MAXI ( ( RESU PHFLUX1) / ( MESU SFLUX1 ) ) ;
  12334. TAB1.'V_FACFM1'= VMOY1;
  12335. SOM1 = (MAXI (RESU PHFLUX1)) * (EXTR TAB1.LIS_FLUX (DIME TAB1.LIS_FLUX));
  12336. SI (NON (EXISTE TAB1 'V_SOM1'));
  12337. TAB1.'V_SOM1' = SOM1;
  12338. SINON;
  12339. TAB1.'V_SOM1' = TAB1.'V_SOM1' + SOM1;
  12340. FINSI;
  12341. VPAT1 = VXZFLUX2 / VMOY1 ;
  12342. *1 FFFFFFFFFF FINSI de niveau 1 : fin du test sur la dimension
  12343. FINSI ;
  12344. MESS '---------------------------------> exiting @FLUXH';
  12345. FINPROC VPAT1 ;
  12346.  
  12347. **** @FLUXQP
  12348. * Procedure @FLUXQP
  12349. *
  12350. *-----------------------------------------------------------------------
  12351. DEBPROC @FLUXQP TAB1*TABLE;
  12352. MESS '---------------------------------> calling @FLUXQP';
  12353. *
  12354. ****** ATTENTION --> Cette procedure ne tourne pour l'instant qu'en 2D
  12355.  
  12356. V_DIM1 = VALEUR 'DIME' ;
  12357. SI ( V_DIM1 EGA 3) ;
  12358. MESS '@FLUXQP ne tourne pas en 3D';
  12359. ERRE 'Dimension';
  12360. FINSI;
  12361.  
  12362. TAC1 = TABLE;
  12363. TAC1.1 = 'MARQ TRIA ';
  12364. TAC1.2 = 'MARQ TRIB ';
  12365. TAC1.3 = 'MARQ ETOI ';
  12366. TAC1.4 = 'MARQ LOSA ';
  12367. TAC1.5 = 'MARQ CROI ';
  12368. TAC1.6 = 'MARQ PLUS ';
  12369. S_TOT1 = TAB1.M_ILLAGE_TOT ;
  12370. LPAT1 = TAB1.LFLUX_EXTE ;
  12371. LPAT1D = TAB1.LFLUX_EXTE_DESS ;
  12372. COSDIR1 COSDIR2 COSDIR3 = @VNORM3D (EXTR TAB1.'MODELF' 'MAIL') LPAT1 TAB1.'NIVEAU';
  12373. COTETF1 = COSDIR1;
  12374. SITETF1 = COSDIR2;
  12375. TETF1 = ATG SITETF1 ( COTETF1 + 1.E-12) ;
  12376. SI (EXISTE TAB1 'VAL_ANGLEI1');
  12377. SI (EXISTE TAB1 'CENTRE_PLASMA');
  12378. ERREUR 'on ne peut avoir VAL_ANGLEI1 et CENTRE_PLASMA ' ;
  12379. SINON;
  12380. SINPA1 = COS ( (TETF1 * -1.) + (TAB1.'VAL_ANGLEI1'));
  12381. SIALPHA1 = ABS ( COS (TAB1.'VAL_ANGLEI1'));
  12382. COALPHA1 = ABS ( SIN (TAB1.'VAL_ANGLEI1'));
  12383. XXPAT1 = ABS ((COOR 1 LPAT1) - (COOR 1 TAB1.'PT_TGPLASMA'));
  12384. YYPAT1 = ABS ((COOR 2 LPAT1) - (COOR 2 TAB1.'PT_TGPLASMA'));
  12385. XLPAT1 = (XXPAT1*COALPHA1) + (YYPAT1*SIALPHA1);
  12386. XLPAT3 = XLPAT1;
  12387. FINSI;
  12388. SINON;
  12389. SI (NON (EXISTE TAB1 'CENTRE_PLASMA'));
  12390. ERREUR 'vous n avez pas donne TAB1.VAL_ANGLEI1';
  12391. SINON;
  12392. LOG1 = EGA (COOR 1 TAB1.'CENTRE_PLASMA') (COOR 1 TAB1.'PT_TGPLASMA') 1.E-6;
  12393. SI ( NON LOG1);
  12394. ERREUR ' COOR 1 CENTRE_PLASMA ET PT_TGPLASMA DIFFERENTS ' ;
  12395. FINSI;
  12396. R0 = (COOR 2 TAB1.'CENTRE_PLASMA') - (COOR 2 TAB1.'PT_TGPLASMA');
  12397. XXPAT1 = ((COOR 1 LPAT1) - (COOR 1 TAB1.'CENTRE_PLASMA')) ;
  12398. YYPAT1 = -1. * ((COOR 2 LPAT1) - (COOR 2 TAB1.'CENTRE_PLASMA')) ;
  12399. RXY = ((XXPAT1 * XXPAT1)+(YYPAT1 * YYPAT1))** 0.5 ;
  12400. ALPH1 = ATG XXPAT1 (YYPAT1 + 1.E-6) ;
  12401. XLPAT1 = RXY - R0 ;
  12402. SINPA1 = SIN ( ALPH1 + 90. - TETF1 ) ;
  12403. MASP1 = XXPAT1 MASQUE 'EGSUPE' 0. ;
  12404. MASM1 = XXPAT1 MASQUE 'INFERIEUR' 0. ;
  12405. XLPAT3 = (XLPAT1 * MASP1) - (XLPAT1 * MASM1) ;
  12406. FINSI;
  12407. FINSI;
  12408. MLAMB1 = ( TAB1 . 'LAMDAQ' ) * -1. ;
  12409. ELPAT1 = EXP ( XLPAT1 / MLAMB1 ) ; ;
  12410. VPAT1 = ELPAT1 * (ABS SINPA1) ;
  12411. *********** cas LAMBDAQ VPAT1 = exp*sinus
  12412. TAC1.TITRE = TABLE ;
  12413.  
  12414. *TITRE 'SIN(teta)' ;
  12415. EV1 = EVOL CHPO SINPA1 SCAL LPAT1D ;
  12416. *TITRE 'EXP(-DL/LAMB)' ;
  12417. EV2 = EVOL CHPO ELPAT1 SCAL LPAT1D ;
  12418. *TITRE 'SIN(teta)*EXP(-DL/LAMB)' ;
  12419. EV3 = EVOL CHPO VPAT1 SCAL LPAT1D ;
  12420. TAC1.1 = 'MARQ TRIA REGU ' ;
  12421. TAC1.TITRE.1 = 'SIN(teta)';
  12422. TAC1.2 = 'MARQ TRIB REGU TITR SIN(teta)' ;
  12423. TAC1.TITRE.2 = 'EXP(-DL/LAMB)';
  12424. TAC1.3 = 'MARQ ETOI REGU TITR EXP(-DL/LAMB)' ;
  12425. TAC1.TITRE.3 = 'SIN(teta)*EXP(-DL/LAMB)' ;
  12426. *TAC1.4 = 'MARQ LOSA REGU TITR EXP(-DL/LAMB)' ;
  12427. *TAC1.5 = 'MARQ CROI REGU TITR SIN(teta)*EXP(-DL/LAMB)' ;
  12428. *TAC1.6 = 'MARQ PLUS REGU TITR SIN(teta)*EXP(-DL/LAMB)' ;
  12429. TITRE 'SIN,EXP,SIN*EXP' ;
  12430. DESS ( EV1 ET EV2 ET EV3 ) LEGE TAC1;
  12431. MESS ' MIN MAX DE EXP*SINa ' (MINI VPAT1) (MAXI VPAT1);
  12432. TITRE 'EXP(-DL/LAMB) fonction de DL ' ;
  12433. EV4 = EVOL CHPO XLPAT3 SCAL LPAT1D ;
  12434. EV5 = ( EVOL MANU (EXTR EV4 ORDO 1) (EXTR EV2 ORDO 1));
  12435. TITRE 'EXP(-DL/LAMB) fonction de DL ';
  12436. DESS EV5 LEGE;
  12437. SOM1 = INTG EV5 ;
  12438. *********** cas LAMBDAQ VPAT1 = exp*sinus
  12439. *********** cas LAMBDAQ SOM1 = somme ( exp*sinus)
  12440. *********** cas LAMBDAQ FACFM1 = SOM1 / largeur
  12441. SOM1 = ABS (MAXI SOM1);
  12442. MESS '>@FLUXQP> VALEUR integrale DU PROFIL' SOM1;
  12443. MESS '>@FLUXQP> LARGEUR MAQ. CHAUFFEE' (TAB1 . W_HEATED );
  12444. XL_LPAT1 = ( ABS (( MAXI XLPAT1 ) - ( MINI XLPAT1 )));
  12445. FACFM1 = SOM1 / XL_LPAT1;
  12446. MESS '>@FLUXQP> LARGEUR vue du plasma' XL_LPAT1;
  12447. MESS '>@FLUXQP> VALEUR moyenne DU PROFIL' FACFM1;
  12448.  
  12449. SI (EXISTE TAB1 'LAMDAQ2');
  12450. LPAT2 = TAB1.LFLUX_EXT2 ;
  12451. LPAT2D = TAB1.LFLUX_EXT2 ;
  12452. COSDIR1 COSDIR2 COSDIR3 = @VNORM3D S_TOT1 LPAT2 TAB1.'NIVEAU';
  12453. COTETF2 = COSDIR1 * 1. ;
  12454. SITETF2 = COSDIR2 * 1. ;
  12455. COTETF1 = @ET COTETF1 COTETF2 ;
  12456. SITETF1 = @ET SITETF1 SITETF2 ;
  12457. TETF2 = ATG SITETF2 ( COTETF2 + 1.E-12) ;
  12458. MESS '>>>>> 3B>>>>>>' ;
  12459. SINPA2 = COS ( (TETF2 * -1.) + (TAB1.'VAL_ANGLEI2'));
  12460. SIALPHA2 = ABS ( COS (TAB1.'VAL_ANGLEI2')) ;
  12461. COALPHA2 = ABS ( SIN (TAB1.'VAL_ANGLEI2'));
  12462. XXPAT2 = ABS ((COOR 1 LPAT2) - (COOR 1 TAB1.'PT_TGPLASMA'));
  12463. YYPAT2 = ABS ((COOR 2 LPAT2) - (COOR 2 TAB1.'PT_TGPLASMA'));
  12464. XLPAT2 = (XXPAT2*COALPHA2) + (YYPAT2*SIALPHA2);
  12465. MLAMB2 = ( TAB1 . 'LAMDAQ2' ) * -1.;
  12466. ELPAT2 = EXP ( XLPAT2 / MLAMB2 );
  12467. VPAT2 = ELPAT2 * SINPA2;
  12468. VPAT2 = VPAT2 + (( REDU VPAT2 TAB1.'PT_TGPLASMA') * -1.);
  12469. VPAT1 = VPAT2 + VPAT1;
  12470. * VPAT1 = VPAT2;
  12471. TITRE 'SIN(teta)*EXP(-DL/LAMB)';
  12472. TAC1 = TABLE ;
  12473. TAC1.1 = 'MARQ TRIA ' ;
  12474. TAC1.2 = 'MARQ TRIB ' ;
  12475. TAC1.3 = 'MARQ ETOI ' ;
  12476. TAC1.4 = 'MARQ LOSA ' ;
  12477. TITRE 'SIN(teta)';
  12478. EV1 = EVOL CHPO SINPA2 SCAL LPAT2D;
  12479. TITRE 'EXP(-DL/LAMB)' ;
  12480. EV2 = EVOL CHPO ELPAT2 SCAL LPAT2D ;
  12481. TITRE 'SIN(teta)*EXP(-DL/LAMB)';
  12482. EV3 = EVOL CHPO VPAT2 SCAL LPAT2D ;
  12483. EV4 = EVOL CHPO XLPAT2 SCAL LPAT2D ;
  12484. DESS ( EV1 ET EV2 ET EV3 ) ;
  12485. MESS ' MIN MAX DE EXP*SIN22 ' (MINI VPAT2) (MAXI VPAT2);
  12486. TITRE 'EXP(-DL/LAMB) fonction de DL, ligne 2 ';
  12487. EV5 = (EVOL MANU (EXTR EV4 ORDO 1) (EXTR EV2 ORDO 1));
  12488. TAC1.1 = 'MARQ TRIA TITRE EXP(-DL/LAMB)' ;
  12489. TAC1.2 = 'MARQ TRIB TITRE EXP(-DL/LAMB)' ;
  12490. DESS EV5 LEGE TAC1;
  12491. SOM1 = SOM1 + (ABS ( MAXI (INTG EV5) )) ;
  12492. MESS '>CFLUX_TO> VALEUR integrale DU PROFIL' SOM1;
  12493. MESS '>CFLUX_TO>