Télécharger latw.dgibi

Retour à la liste

Numérotation des lignes :

  1. * fichier : latw.dgibi
  2. *$$$$ EXEC
  3. * EXEC PROCEDUR MAGN 03/03/31 21:15:04 4631
  4. *X EXEC (Procedure)
  5. * Procedure EXEC
  6. *
  7. * Objet : Execute un algorithme décrit dans une table RV
  8. * de type EQEX.
  9. * Cette table est créée par l'opérateur EQEX
  10. *
  11. * Syntaxe : EXEC RV ;
  12. *
  13. ***********************************************************************
  14. * VERSION : ????
  15. * HISTORIQUE : 20/12/99: gounand
  16. * Rajout de la gestion de la matrice servant à l'assemblage
  17. * (rv . 'METHINV' . 'MATASS')
  18. *
  19. * HISTORIQUE : 10/11/00: magnaud
  20. * Reecriture de exec pour tirer parti du // (operateur ASSI et RESO)
  21. * Pour l'instant cette procedure est testee experimentalement dans
  22. * la directive EQUA de EXEC
  23. *
  24. * HISTORIQUE : 04/04/01: magnaud
  25. * Calcul et impression tout les FIDT cycles de la norme Linf du residu
  26. *
  27. * HISTORIQUE :
  28. * HISTORIQUE :
  29. ************************************************************************
  30. * DISCPRES = (d'apres KMIC)
  31. * KPRE=3 pression P0 KPRE=4 pression P1 KPRE=2 cas macro 1ère génération
  32. * KPRE=5 pression MSOMMET
  33. ************************************************************************
  34. 'DEBPROC' EXEC ;
  35. 'ARGUMENT' rv*'TABLE ' ;
  36.  
  37. * Logique pilotant le recalcul de la matrice de pression
  38. CALPRE=FAUX ;
  39. Si ('EXIST' rv 'CALPRE') ;
  40. vertytab rv 'CALPRE' 'LOGIQUE' ;
  41. CALPRE=rv.'CALPRE' ;
  42. Finsi ;
  43.  
  44. Si(NON('EXIST' rv 'XEQUA'));
  45. rv.'XEQUA'= FAUX ;
  46. Finsi ;
  47.  
  48. ********************************************************************************
  49. ********************************************************************************
  50. ****** Directive EQUA **********************************************************
  51. ********************************************************************************
  52. ********************************************************************************
  53.  
  54. Si (rv.'XEQUA');
  55.  
  56. IMPKRES=0 ;
  57. Si ('EXIST' rv 'NUMASSI'); numassi=rv.'NUMASSI';
  58. Sinon; numassi=1 ;
  59. Finsi;
  60.  
  61.  
  62. Xdfdt = FAUX ;
  63.  
  64. ITMA=rv . 'ITMA';
  65. 'SI' ('<EG' ITMA 1) ;
  66. ITMA=1 ;
  67. 'FINSI' ;
  68.  
  69. NITER=rv . 'NITER';
  70. 'SI' ('<EG' NITER 1) ;
  71. NITER=1 ;
  72. 'FINSI' ;
  73.  
  74. OMEGA=rv . 'OMEGA';
  75. 'SI' ('<EG' NITER 1) ;
  76. OMEGA=1.;
  77. 'FINSI' ;
  78.  
  79. NUPDT=rv.'PASDETPS'.'NUPASDT';
  80.  
  81. 'SI'((NON (rv.'TRAN')) et ('>' ITMA 1) );
  82. Mess ' Incoherence : Algorithme Permanent et ITMA >1';
  83. QUITTER EXEC ;
  84. 'FINSI' ;
  85.  
  86. 'SI'((rv.'TRAN') et (NON (rv.'PROJ')) et ('EGA' NUPDT 1));
  87. Mess ' Algorithme transitoire standard implicite ou explicite ';
  88. mess '========================================================';
  89. 'FINSI' ;
  90.  
  91. 'SI'((rv.'PROJ') et ('EGA' NUPDT 1));
  92. mess 'Algorithme de Projection';
  93. mess '========================';
  94. 'FINSI' ;
  95.  
  96. 'SI' ( non (rv.'TRAN'));
  97. mess 'Algorithme de recherche d un permanent ';
  98. mess '=======================================';
  99. 'FINSI' ;
  100.  
  101.  
  102. 'REPETER' BCLTPS ITMA ;
  103. si (rv.'PROJ');
  104. testp1 = non ( exist rv 'MATC') ;
  105. sinon ;
  106. testp1 = FAUX ;
  107. finsi ;
  108. 'REPETER' BCLINT NITER ;
  109. Si (non (rv.'TRAN'));
  110. mess 'ITERATION ' &BCLINT;
  111. Finsi ;
  112.  
  113. Si (rv.'XRIG');
  114. MRIG='RGDT ';
  115. sf mau = assi numassi 'KOPS' 'RIGIDITE' ;
  116. sp map = assi numassi 'KOPS' 'RIGIDITE' ;
  117. sr mar = assi numassi 'KOPS' 'RIGIDITE' ;
  118. Sinon ;
  119. MRIG=TEXT ' ';
  120. sf mau = assi numassi 'KOPS' 'MATRIK' ;
  121. sp map = assi numassi 'KOPS' 'MATRIK' ;
  122. sr mar = assi numassi 'KOPS' 'MATRIK' ;
  123. Finsi ;
  124.  
  125. NRES=0 ;
  126.  
  127. *****************************************************
  128. * ._._. \|/
  129. * ._._. CALCUL MATRICES ELEMENTAIRES
  130. * ._._. /|\
  131. *****************************************************
  132.  
  133.  
  134. 'REPETER' bloc2 ('DIME' (rv . 'LISTOPER')) ;
  135. nomper = 'EXTRAIRE' &bloc2 (rv . 'LISTOPER') ;
  136. * mess ' Début BLOC2 nomper=' nomper ;
  137. notable= 'MOT' ('TEXTE' ('CHAINE' &bloc2 nomper)) ;
  138. Si('>EG' (rv.'IMPR') 2); mess 'Operateur ' nomper ; Finsi ;
  139. td=rv.notable ;
  140. tdk=td.'KOPT' ;
  141. iarg= rv.notable.'IARG' ;
  142. arg1 = TEXT ' ' ; arg2 = TEXT ' ' ; arg3 = TEXT ' ' ;
  143. arg4 = TEXT ' ' ; arg5 = TEXT ' ' ; arg6 = TEXT ' ' ;
  144. arg7 = TEXT ' ' ; arg8 = TEXT ' ' ; arg9 = TEXT ' ' ;
  145.  
  146. Si ('>EG' iarg 1 );
  147. Si ( EGA ('TYPE' (td.'ARG1')) 'MOT ' ) ;
  148. arg1=rv.'INCO'.(td.'ARG1') ;
  149. Sinon ;
  150. arg1=(td.'ARG1') ;
  151. Finsi ;
  152. Finsi ;
  153.  
  154. Si ('>EG' iarg 2 );
  155. Si ( EGA ('TYPE' (td.'ARG2')) 'MOT ' ) ;
  156. arg2=rv.'INCO'.(td.'ARG2') ;
  157. Sinon ;
  158. arg2=(td.'ARG2') ;
  159. Finsi ;
  160. Finsi ;
  161.  
  162. Si ('>EG' iarg 3 );
  163. Si ( EGA ('TYPE' (td.'ARG3')) 'MOT ' ) ;
  164. arg3=rv.'INCO'.(td.'ARG3') ;
  165. Sinon ;
  166. arg3=(td.'ARG3') ;
  167. Finsi ;
  168. Finsi ;
  169.  
  170. Si ('>EG' iarg 4 );
  171. Si ( EGA ('TYPE' (td.'ARG4')) 'MOT ' ) ;
  172. arg4=rv.'INCO'.(td.'ARG4') ;
  173. Sinon ;
  174. arg4=(td.'ARG4') ;
  175. Finsi ;
  176. Finsi ;
  177.  
  178. * Traitement du cas transitoire
  179. XTRA =CHAI 'PERM' ; DT = TEXT ' ' ; SCHE=TEXT ' ' ;
  180. inc1 = TEXT ' ' ; inc2 = TEXT ' ' ;
  181. imc1 = TEXT ' ' ; imc2 = TEXT ' ' ;
  182. BETAT= TEXT ' ' ;
  183. XBDF2 = FAUX ;
  184.  
  185. XOT=(('EGA' nomper 'NS ') ou ('EGA' nomper 'TSCA ')
  186. ou ('EGA' nomper 'DFDT ') ou ('EGA' nomper 'TSCAL '));
  187.  
  188. Si (rv.'PROJ' et ('EGA' nomper 'KBBT ')) ;
  189. XTRA=CHAI 'PROJ' ;
  190. Finsi ;
  191.  
  192. Si (rv.'TRAN') ;
  193. Xdfdt = VRAI ;
  194. XTRA=CHAI 'TRANS' ;
  195. Si (rv.'PROJ') ; XTRA=CHAI 'PROJ' ; Finsi ;
  196. DT=(rv.'DELTAT') ;
  197. Si ( EGA ('TYPE' DT) 'MOT ' ) ;
  198. DT=rv.'INCO'.DT ;
  199. Finsi ;
  200. SCHE = rv.'SCHEMAT';
  201. Si (EGA SCHE 'SEMI');
  202. BETAT=(rv.'Betat') ;
  203. Finsi ;
  204. Si (EGA SCHE 'BDF2');
  205. XBDF2 = VRAI ;
  206. Finsi ;
  207. Finsi ;
  208.  
  209. nbic=dime td.'LISTINCO';
  210.  
  211. Si ('>EG' nbic 1 );
  212. ninc1=extr td.'NUMEINCO' 1 ;
  213. a= chai 'FORMAT' '(A3,I1)' 'INC' ninc1 ;
  214. inc1=rv.'INCO'.(rv.a);
  215. Si (XBDF2) ;
  216. a= chai 'FORMAT' '(A3,I1)' 'IMC' ninc1 ;
  217. imc1=rv.'INCO'.(rv.a);
  218. Finsi;
  219. Finsi ;
  220.  
  221. Si ('>EG' nbic 2 );
  222. ninc2=extr td.'NUMEINCO' 2 ;
  223. a= chai 'FORMAT' '(A3,I1)' 'INC' ninc2 ;
  224. inc2=rv.'INCO'.(rv.a);
  225. Si (XBDF2) ;
  226. a= chai 'FORMAT' '(A3,I1)' 'IMC' ninc2 ;
  227. imc2=rv.'INCO'.(rv.a);
  228. Finsi;
  229. Finsi ;
  230.  
  231.  
  232. MM=TEXT ' ';
  233. DCEN='????' ;
  234. Si(EGA (tdk.'MTRMASS') 2 );MM='MMDIAGO';Finsi;
  235. Si(EGA (tdk.'IDCEN') 1 );DCEN='CENTREE';Finsi;
  236. Si(EGA (tdk.'IDCEN') 2 );DCEN='SUPGDC ';Finsi;
  237. Si(EGA (tdk.'IDCEN') 3 );DCEN='SUPG ';Finsi;
  238. Si(EGA (tdk.'IKOMP') 0 );MC=TEXT ' ';Finsi;
  239. Si(EGA (tdk.'IKOMP') 1 );MC='CONS';Finsi;
  240.  
  241. INEFMD= tdk.'INEFMD' ;
  242. tdz=TEXT ' ' ;
  243. Si (EGA nomper 'VNIMP ');
  244. tdz=CHAI 'V' ;
  245. nomper= text 'NS';
  246. Finsi ;
  247.  
  248. * temp place ;
  249. * mess ' Avant ' nomper ' tdz ' tdz ' DT=' DT ' XTRA=' ; list xtra ;
  250. * mess SCHE ; mess BETAT;
  251. msi mai =assi numassi nomper tdz
  252. (td.'DOMZ') (td.'LISTINCO') (td.'TYPEINCO') (rv.'TYPPRESS')
  253. INEFMD MRIG MM 'CONS' 'STABP' (tdk.'STABP') 'CMD' (tdk.'CMD') DCEN
  254. XTRA DT SCHE BETAT
  255. 'INCO' inc1 imc1 inc2 imc2
  256. (td.'IARG') arg1 arg2 arg3 arg4 ;
  257. * temp place ;
  258. * mess ' Apres ' nomper;
  259.  
  260. Si ((rv.'PROJ') et ('EGA' nomper 'KBBT '));
  261. msp =assi numassi msi ;
  262. mac =assi numassi mai ;
  263. 'ITER' bloc2 ;
  264. Finsi ;
  265.  
  266. Si ((rv.'PROJ') et ('EGA' nomper 'DFDT '));
  267. mam =assi numassi mai ;
  268. Finsi ;
  269.  
  270. * Si ((rv.'PROJ') et ('EGA' nomper 'TOIMP '));
  271. * list msi ;
  272. * Finsi ;
  273.  
  274. Si ((rv.'PROJ') et ('EGA' nomper 'NS '));
  275. XTRA=CHAI 'TRANS' ;
  276. DT=(rv.'DELTAT') ;
  277. Si ( EGA ('TYPE' DT) 'MOT ' ) ;
  278. DT=rv.'INCO'.DT ;
  279. Finsi ;
  280. SCHE = rv.'SCHEMAT';
  281. Si (EGA SCHE 'SEMI');
  282. BETAT=(rv.'Betat') ;
  283. Finsi ;
  284. Si (EGA SCHE 'BDF2');
  285. XBDF2 = VRAI ;
  286. Finsi ;
  287. * mess ' Appel DFDT DT=' DT ' XTRA=' ; list xtra ;
  288. msm mam =assi numassi DFDT
  289. (td.'DOMZ') (td.'LISTINCO') (td.'TYPEINCO') (rv.'TYPPRESS')
  290. INEFMD MRIG MM 'CONS' 'CMD' (tdk.'CMD') DCEN
  291. XTRA DT SCHE BETAT
  292. 'INCO' inc1 imc1 inc2 imc2
  293. 1 arg1 ;
  294. oubli msm;
  295. Finsi ;
  296.  
  297. mau = assi numassi mau 'ET' mai ;
  298. sf = assi numassi sf 'ET' msi ;
  299.  
  300.  
  301. rv.'TVNP'=FAUX;
  302. rv.'TVNPC'=FAUX;
  303.  
  304. Si ('EGA' nomper 'VNIMP '); *
  305. mess ' Cas oper VNIMP' ;
  306. Si (ega (rv.'TYPPRESS') 'MSOMMET');
  307. rv.'TVNPC'=VRAI;
  308. mvnpc=mai ;
  309. svnpc=msi ;
  310. Sinon ;
  311. rv.'TVNP'=VRAI ;
  312. mar = assi numassi mar 'ET' mai ;
  313. sr = assi numassi sr 'ET' msi ;
  314. Finsi ;
  315. Sinon ;
  316.  
  317. Finsi ;
  318.  
  319. 'FIN' bloc2 ;
  320. *mess 'Fin Bloc2 ' ;
  321.  
  322. 'SI'((rv.'TRAN') et (NON Xdfdt));
  323. Mess ' Incoherence : Algorithme Transitoire '
  324. ' et pas d increment en temps';
  325. Mess ' Il manque un operateur DFDT NS ou TSCA ';
  326. QUITTER EXEC ;
  327. 'FINSI' ;
  328.  
  329. NRES=NRES+1;
  330. *mess 'NRES=' NRES;
  331. TABRES=chai 'FORMAT' '(A6,I1)' 'TABRES' NRES;
  332. Si (NON('EXIST' rv TABRES)); rv.TABRES=TABLE ; Finsi ;
  333. Si (NON ('EGA' ('TYPE' rv.TABRES) 'TABLE '));
  334. rv.TABRES=TABLE ;
  335. Finsi ;
  336.  
  337. rv.TABRES.'mau' =mau ;
  338. rv.TABRES.'sf' =sf ;
  339. rv.TABRES.'clim'=rv.'CLIM' ;
  340. rv.TABRES.'METHINV'=rv.'METHINV' ;
  341.  
  342. *****************************************************
  343. * __ |\
  344. * \ /_/o | | \|/
  345. * \=> \_\/ \| --O-- PROJECTION
  346. * /|\ /\ /|\
  347. *************/*|*\***********************************
  348.  
  349. 'SI' (rv.'PROJ');
  350. SCHE = rv.'SCHEMAT';
  351. cnvi1=chai 'FORMAT' '(I1,A3)' 1 (extr rv.'LISTINCO' 1) ;
  352. cnvi2=chai 'FORMAT' '(I1,A3)' 2 (extr rv.'LISTINCO' 1) ;
  353. cnvi3=chai 'FORMAT' '(I1,A3)' 3 (extr rv.'LISTINCO' 1) ;
  354. cnppp=chai 'FORMAT' '(I1,A3)' 3 (extr rv.'LISTINCO' 2) ;
  355. 'SI' (testp1) ;
  356. mess ' CALCUL de CMCT ' ;
  357. Diag = doma (rv.'MODELE') 'XXDIAGSI' ;
  358. Digv= (nomc Diag cnvi1) et (nomc Diag cnvi2) ;
  359. Si ('EGA' (VALE DIME) 3);
  360. Digv= Digv et (nomc Diag cnvi3);
  361. Finsi ;
  362.  
  363. * Diag : Matrice diagonale de base ('SCAL')
  364. * Digv : Matrice diagonale de base ('1U' '2U' '3U')
  365. * Digvl: Matrice diagonale contenant les conditions aux limites
  366.  
  367. IDiag = 'INVERSE' Digv ;
  368.  
  369. Digvl= 'KOPS' Digv 'CLIM' (rv . 'CLIM') -1;
  370. IDigvl= 'INVERSE' Digvl ;
  371.  
  372. *
  373. * Calcul matrices MD-1
  374. *
  375. MDM1='KMF' mam IDiag ;
  376. Si ('EGA' SCHE 'BDF2'); MDM1=MDM1 * (((rv.'DELTAT')*2.)/3.) ;
  377. Sinon ; MDM1=MDM1 * (rv.'DELTAT') ;
  378. Finsi ;
  379. *
  380. * Calcul matrices C
  381. *
  382. * msp mac =assi numassi 'KBBT'
  383. * (rv.'MODELE') (rv.'LISTINCO') (rv.'TYPEINCO') (rv.'TYPPRESS')
  384. * MRIG (1) (1.) ;
  385.  
  386. matpc mac = kops 'CMCTSPLT' mac ;
  387.  
  388. Si ('EGA' (rv.'TYPPRESS') 'MSOMMET');
  389. mess ' Cas des pressions continues' ;
  390. incp= mots (extr rv.'LISTINCO' 2) ;
  391. msp matpr =assi numassi 'LAPN'
  392. (rv.'MODELE') incp (mots 'TEMPERAT')
  393. MRIG 'LINE' (1) (1.) ;
  394.  
  395. Sinon ;
  396. mess ' Cas des pressions discontinues' ;
  397.  
  398. Si (rv.'TVNPC'); mac=mac et mvnpc; Finsi;
  399. rv . 'MATC' = mac ;
  400. * list mac 4 ;
  401. scr mcr = 'KOPS' 'MATRIK' ;
  402. Si (rv.'TVNP') ;
  403. rv . 'MBTR' = mar ;
  404. Dunit=Idigv;
  405. crt= kops 'CMCT' mac mar (Dunit) ;
  406. ctr= kops 'CMCT' mar mac (Dunit) ;
  407. rrt= kops 'CMCT' mar mar (Dunit) ;
  408. mcr= mcr et crt et ctr et rrt ;
  409. Finsi ;
  410.  
  411. * list mac 3 ;list IDigvl;
  412. matpr = kops 'CMCT' mac mac IDigvl;
  413. * mess 'APRES CMCT' ; list matpr 3 ;
  414. matpr = matpc et matpr et mcr ;
  415.  
  416. Finsi ;
  417.  
  418. rv.'IDigvl'= IDigvl ;
  419. rv.'MATP' = matpr ;
  420. rv.'MATC' = mac ;
  421. rv.'MDM1' = MDM1 ;
  422.  
  423. 'FINSI' ;
  424.  
  425. IDigvl= rv.'IDigvl';
  426. matpr = rv.'MATP' ;
  427. mac = rv.'MATC' ;
  428. MDM1 = rv.'MDM1' ;
  429.  
  430.  
  431. 'SI' ('EXIST' (rv.'INCO') 'PINM1') ;
  432. **
  433. ** mess ' t n-1' ;
  434. ** mess 'Calcul de C P' ;
  435. **
  436.  
  437. pinm1= rv.'INCO'.'PINM1';
  438. * cpi2=(extr rv.'LISTINCO' 2) ;
  439. * pinm1= nomc (rv.'INCO'.(rv.'INC2')) cpi2;
  440. cpre = 'KMF' (rv . 'MATC') pinm1 'TRAN' ;
  441. Si (rv.'TVNP') ;
  442. cxre = 'KMF' (rv . 'MBTR') pinm1 'TRAN' ;
  443. cpre = cpre et cxre ;
  444. Finsi ;
  445.  
  446. Si ('EGA' (rv.'TYPPRESS') 'MSOMMET');
  447. gradpres = 'KOPS' MDM1 '*' cpre ;
  448. Sinon ;
  449. gradpres = 'KOPS' MDM1 '*' cpre ;
  450. Finsi ;
  451. gradpres = nomc (mots 'UX' 'UY' 'UZ')
  452. (mots cnvi1 cnvi2 cnvi3) gradpres;
  453.  
  454. oublier cpre ;
  455. rv.'INCO'.'GRADPRES' = gradpres ;
  456. sf = sf - (rv.'INCO'.'GRADPRES') ;
  457. rv.'TABRES1'.'sf'=sf ;
  458.  
  459. 'FINSI' ;
  460. clim = exco rv.'CLIM' (mots cnvi1 cnvi2 cnvi3) 'NOID' ;
  461. rv.'TABRES1'.'clim'=clim ;
  462.  
  463. ********** FIN Traitement PRESSION ************************
  464. * mess ' FIN Traitement PRESSION' ;
  465.  
  466. 'FINSI' ;
  467. *******************************************************
  468.  
  469.  
  470. *****************************************************
  471. * \___\ /
  472. * \/ RESOLUTION
  473. * \ \|/
  474. *************************--O--***********************
  475. res mau = assi numassi 'KOPS' 'MATRIK' ;
  476. Si (rv.XRIG);
  477. res = chan res 'ATTRIBUT' 'NATURE' 'DIFFUS' ;
  478. Finsi ;
  479. Repeter Bclres NRES ;
  480. * mess ' Resolution ' NRES ;
  481. TABRES=rv.(chai 'FORMAT' '(A6,I1)' 'TABRES' &Bclres);
  482. MTIV = TABRES.'METHINV';
  483. mau = TABRES.'mau' ;
  484. sf = TABRES.'sf' ;
  485. clim = TABRES.'clim';
  486. *........................................................
  487. Si (rv.'XRIG') ;
  488. gclim=extr clim 'MAILLAGE' ;
  489. rclim=bloq 'T' gclim ;
  490. dclim=depi rclim (nomc 'Q' clim);
  491. mau = mau et rclim ;
  492. sf = sf et dclim ;
  493. * list mau; list sf ;
  494. res1 = 'RESO' mau sf ;
  495. res = ASSI numassi res1 et res ;
  496. Sinon ;
  497. MATASS= mau ;
  498. TYRENU=MTIV.'TYRENU';PCMLAG=MTIV.'PCMLAG';KTYPI =MTIV.'TYPINV';
  499. XINIT=TEXT ' ' ;DI2 = TEXT ' ' ;DI3 = TEXT ' ' ;
  500. DI4 = TEXT ' ' ;DI5 = TEXT ' ' ;
  501. MAPREC=TEXT ' ';KPREC =TEXT ' ';PR3 = TEXT ' ' ;
  502. PR4 = TEXT ' ' ;PR5 = TEXT ' ' ;
  503. Si (('>EG' KTYPI 2) ET ('<EG' KTYPI 5));
  504. XINIT mar = assi numassi 'KOPS' 'MATRIK' ;
  505. DI2=MTIV.'NITMAX';DI3=MTIV.'RESID';DI4=MTIV.'BCGSBTOL';
  506. Si ('EGA' KTYPI 5);DI5=MTIV.'GMRESTRT';Finsi ;
  507. MAPREC= mau ;
  508. KPREC=MTIV.'PRECOND';
  509. Si ('EGA' KPREC 4);PR3=MTIV.'MILURELX';Finsi ;
  510. Si (('EGA' KPREC 5) OU ('EGA' KPREC 6));
  511. PR4=MTIV.'ILUTLFIL';PR5=MTIV.'ILUTDTOL';
  512. Finsi ;
  513. Finsi ;
  514. * list mau 3 ;
  515. * list sf ;
  516. res1 = ASSI numassi 'KRES' 'LL' mau
  517. 'TYPI' MTIV KTYPI 'CLIM' clim 'SMBR' sf
  518. 'IMPR' IMPKRES MATASS TYRENU PCMLAG
  519. XINIT DI2 DI3 DI4 DI5
  520. MAPREC KPREC PR3 PR4 PR5;
  521. res = ASSI numassi res1 et res ;
  522. Finsi;
  523. *........................................................
  524. Fin Bclres ;
  525.  
  526. rv.inco.'Res'=res ;
  527.  
  528. 'SI' (rv.'PROJ');
  529. **
  530. * mess 'RESOLUTION : ETAPE DE PROJECTION ' ;
  531. ** _n
  532. ** C U
  533. cun = ('KMF' (rv . 'MATC') res)*(1./(rv.'DELTAT')) ;
  534. Si (rv.'TVNP');
  535. cxn = ('KMF' (rv . 'MBTR') res)*(1./(rv.'DELTAT')) ;
  536. cun = cun et cxn ;
  537. Finsi ;
  538. clim=exco (rv.'CLIM') (mots (extr rv.'LISTINCO' 2)) 'NOID';
  539. MTIV=rv.'METHINV2' ;
  540.  
  541. *........................................................
  542. Si (rv.'XRIG') ;
  543. gclim=extr clim 'MAILLAGE' ;
  544. rclim=bloq 'T' gclim ;
  545. dclim=depi rclim (nomc 'Q' clim);
  546. matpr = matpr et rclim ;
  547. cun = cun et dclim ;
  548. sl = 'RESO' matpr cun ;
  549. Sinon ;
  550. MATASS= matpr ;
  551. TYRENU=MTIV.'TYRENU';PCMLAG=MTIV.'PCMLAG';KTYPI =MTIV.'TYPINV';
  552. XINIT=TEXT ' ' ;DI2 = TEXT ' ' ;DI3 = TEXT ' ' ;
  553. DI4 = TEXT ' ' ;DI5 = TEXT ' ' ;
  554. MAPREC=TEXT ' ';KPREC =TEXT ' ';PR3 = TEXT ' ' ;
  555. PR4 = TEXT ' ' ;PR5 = TEXT ' ' ;
  556. Si (('>EG' KTYPI 2) ET ('<EG' KTYPI 5));
  557. XINIT mar = assi numassi 'KOPS' 'MATRIK' ;
  558. DI2=MTIV.'NITMAX';DI3=MTIV.'RESID';DI4=MTIV.'BCGSBTOL';
  559. Si ('EGA' KTYPI 5);DI5=MTIV.'GMRESTRT';Finsi ;
  560. MAPREC= matpr;
  561. KPREC=MTIV.'PRECOND';
  562. Si ('EGA' KPREC 4);PR3=MTIV.'MILURELX';Finsi ;
  563. Si (('EGA' KPREC 5) OU ('EGA' KPREC 6));
  564. PR4=MTIV.'ILUTLFIL';PR5=MTIV.'ILUTDTOL';
  565. Finsi ;
  566. Finsi ;
  567. sl = ASSI numassi 'KRES' 'LL' matpr
  568. 'TYPI' MTIV KTYPI 'CLIM' clim 'SMBR' cun
  569. 'IMPR' IMPKRES MATASS TYRENU PCMLAG
  570. XINIT DI2 DI3 DI4 DI5
  571. MAPREC KPREC PR3 PR4 PR5;
  572. Finsi;
  573. *........................................................
  574. ctl = 'KMF' (rv . 'MATC') sl 'TRAN' ;
  575. Si(rv.'TVNP') ;
  576. cxl = 'KMF' (rv . 'MBTR') sl 'TRAN' ;
  577. ctl = ctl + cxl ;
  578. Finsi ;
  579. a=KOPS IDigvl '*' ctl ;
  580. au = nomc (mots 'UX' 'UY' 'UZ')(mots cnvi1 cnvi2 cnvi3) a ;
  581. oublier ctl ;
  582. res = res - (au*(rv.'DELTAT')) ;
  583. 'FINSI' ;
  584.  
  585.  
  586. *************************--O--***********************
  587. * \ /|\
  588. * /\____ RELAXATION
  589. * / \ \
  590. *****************************************************
  591. nbic=dime rv.'LISTINCO';
  592. omega=rv.'OMEGA';
  593. NUPDT=rv.'PASDETPS'.'NUPASDT';
  594. LRA= CHAI 'Pas de temps ' NUPDT ' ERREUR LINF : ' ;
  595. 'SI' ('MULT' NUPDT (rv.'FIDT'));
  596. Si('EXIST' rv.'PASDETPS' 'NUPDT');
  597. rv.'PASDETPS'.'NUPDT'=rv.'PASDETPS'.'NUPDT' et (PROG NUPDT) ;
  598. Sinon ;
  599. rv.'PASDETPS'.'NUPDT'= (PROG NUPDT) ;
  600. Finsi ;
  601. 'FINSI' ;
  602. Repeter Relax nbic;
  603.  
  604. a= chai 'FORMAT' '(A3,I1)' 'INC' &relax ;
  605.  
  606. Si (XBDF2) ;
  607. b= chai 'FORMAT' '(A3,I1)' 'IMC' &relax ;
  608. rv.'INCO'.(rv.b)=rv.'INCO'.(rv.a);
  609. * mess ' On fait ' (rv.a) ' -> ' (rv.b) ;
  610. Finsi ;
  611.  
  612. nc =extr rv.'LISTINCO' &relax;
  613. nc1=mots nc ;
  614. nc2=mots 'SCAL' ;
  615. ty=extr rv.'TYPEINCO' &relax;
  616. * mess ' Composante ' nc ' Type inco ' ty ;
  617. Si (('EGA' ty 'VITESSE ') et ('EGA' ('VALEUR' 'DIME') 2));
  618. nc2=mots 'UX' 'UY' ;
  619. a1= chai 'FORMAT' '(I1,A3)' 1 nc ;
  620. a2= chai 'FORMAT' '(I1,A3)' 2 nc ;
  621. nc1=mots a1 a2 ;
  622. Finsi ;
  623. Si (('EGA' ty 'VITESSE ') et ('EGA' ('VALEUR' 'DIME') 3));
  624. nc2=mots 'UX' 'UY' 'UZ' ;
  625. a1= chai 'FORMAT' '(I1,A3)' 1 nc ;
  626. a2= chai 'FORMAT' '(I1,A3)' 2 nc ;
  627. a3= chai 'FORMAT' '(I1,A3)' 3 nc ;
  628. nc1=mots a1 a2 a3 ;
  629. Finsi ;
  630. ri= exco nc1 res nc2 'NOID';
  631. nbc=dime (extr ri 'COMP') ;
  632. Si('EGA' nbc 0);
  633. Si('EGA' NUPDT 1);
  634. Mess ' ATTENTION La (ou les) composante(s) suivantes ne sont pas'
  635. ' calculees' ;
  636. list nc1 ;
  637. Finsi ;
  638. Sinon ;
  639. 'SI' ('MULT' NUPDT (rv.'FIDT'));
  640. eri=ri - rv.'INCO'.(rv.a);
  641. ELI=MAXI ERI 'ABS';
  642. ELI=(LOG (ELI + 1.0E-10))/(LOG 10.);
  643. LRA= CHAI LRA ' ' (rv.a) ' ' ELI ;
  644. ER = PROG ELI;
  645. ERA=CHAI 'ERLI' (rv.a);
  646. Si('EXIST' rv.'PASDETPS' ERA);
  647. rv.'PASDETPS'.ERA=rv.'PASDETPS'.ERA et ER ;
  648. Sinon ;
  649. rv.'PASDETPS'.ERA= ER ;
  650. Finsi ;
  651. 'FINSI' ;
  652.  
  653. rv.'INCO'.(rv.a)=(omega*ri) + ((1. - omega)*rv.'INCO'.(rv.a)) ;
  654. Finsi ;
  655.  
  656. Fin Relax ;
  657.  
  658. 'SI' ('MULT' NUPDT (rv.'FIDT'));
  659. MESS LRA ;
  660. 'FINSI' ;
  661.  
  662. Fin BCLINT ;
  663.  
  664. ***** Avancement en temps
  665. rv.inco.'Resnm'=res ;
  666. rv.'PASDETPS'.'NUPASDT'=rv.'PASDETPS'.'NUPASDT' + 1 ;
  667. * Algorithme de projection P(n+1) = P(n) + (sl / dt)
  668. 'SI' (rv.'PROJ');
  669.  
  670. 'SI' ('EXIST' (rv.'INCO') 'PINM1') ;
  671.  
  672. * PNM1=(-1.)*rv.'INCO'.'PRESSION' ;
  673. PNM1=(-1.)*rv.'INCO'.(rv.'INC2') ;
  674. si (XBDF2) ;
  675. PN=PNM1 + (1.5*sl) ;
  676. sinon ;
  677. PN=PNM1 + (sl) ;
  678. finsi ;
  679.  
  680. * rv.'INCO'.'PRESSION'=(-1.)*PN ;
  681. rv.'INCO'.(rv.'INC2')=(-1.)*PN ;
  682. rv.'INCO'.'PINM1'=PN ;
  683. 'SINON' ;
  684. * rv.'INCO'.'PRESSION' = (-1.)*(sl) ;
  685. rv.'INCO'.(rv.'INC2')= (-1.)*(sl) ;
  686. rv.'INCO'.'PINM1'=(2.*sl);
  687. 'FINSI' ;
  688. 'OUBLIER' sl ;
  689. 'FINSI' ;
  690. ***** Avancement en temps FIN
  691. Fin BCLTPS ;
  692.  
  693. QUITTER EXEC ;
  694. Finsi ;
  695. ********************************************************************************
  696. ********************************************************************************
  697. ****** Fin directive EQUA ******************************************************
  698. ********************************************************************************
  699. ********************************************************************************
  700.  
  701. 'SI' ('EGA' (rv . 'NAVISTOK') 0) ;
  702. EXAC rv ;
  703. 'QUITTER' EXEC ;
  704. 'FINSI' ;
  705.  
  706. *******PROJ*************************************************************
  707. *******PROJ Trois possibilités *****************************************
  708. *******PROJ TMDM1 (vrai)_> Correction Gresho NON
  709. *******PROJ TGRAD (vrai)-> Formulation Gradient NON
  710. *******PROJ TPNM2 (vrai)-> elimination end of step velocity OUI
  711. *******PROJ TMDM1 = VRAI TGRAD = FAUX TPNM2 = FAUX ancien algo
  712. TYPROJ='VPI1' ;
  713. 'SI' ('EXIST' RV 'TYPROJ') ;
  714. TYPROJ=RV.'TYPROJ' ;
  715. 'SI' (non (exist (MOTS 'PSCT' 'VPI1' 'VPI2') TYPROJ));
  716. Mess '*********************************************************' ;
  717. Mess ' ERREUR ERREUR ERREUR ERREUR ERREUR ERREUR ' ;
  718. Mess ' ' ;
  719. Mess 'Le mot ' TYPROJ ' n existe pas dans la liste.';
  720. Mess 'Les méthodes de projection autorisées sont :';
  721. Mess 'VPI1 et VPI2 ' ;
  722. Mess '*********************************************************' ;
  723. erreur 21 ;
  724. quitter EXEC ;
  725. 'FINSI' ;
  726. 'FINSI' ;
  727.  
  728. 'SI' ('EGA' TYPROJ 'PSCT') ;
  729. TGRAD = FAUX ;
  730. TMDM1 = FAUX ;
  731. TPNM2 = FAUX ;
  732. 'FINSI' ;
  733. 'SI' ('EGA' TYPROJ 'VPI1') ;
  734. TGRAD = FAUX ;
  735. TMDM1 = VRAI ;
  736. TPNM2 = FAUX ;
  737. 'FINSI' ;
  738. 'SI' ('EGA' TYPROJ 'VPI2') ;
  739. TGRAD = FAUX ;
  740. TMDM1 = FAUX ;
  741. TPNM2 = VRAI ;
  742. 'FINSI' ;
  743.  
  744. *******PROJ Trois possibilités *****************************************
  745. *******PROJ*************************************************************
  746.  
  747. nomvi=rv . 'NOMVI' ;
  748.  
  749. 'SI' ('EGA' ('VALEUR' 'DIME') 2) ;
  750. vnul=0.D0 0.D0 ;
  751. vuni=1.D0 1.D0 ;
  752. cnvi1= 'MOT' ('TEXTE' ('CHAINE' 1 nomvi)) ;
  753. cnvi2= 'MOT' ('TEXTE' ('CHAINE' 2 nomvi)) ;
  754. lc= mots cnvi1 cnvi2 ;
  755. lcu=mots 'UX' 'UY' ;
  756. 'SINON' ;
  757. vnul=0.D0 0.D0 0.D0 ;
  758. vuni=1.D0 1.D0 1.D0 ;
  759. cnvi1= 'MOT' ('TEXTE' ('CHAINE' 1 nomvi)) ;
  760. cnvi2= 'MOT' ('TEXTE' ('CHAINE' 2 nomvi)) ;
  761. cnvi3= 'MOT' ('TEXTE' ('CHAINE' 3 nomvi)) ;
  762. lc= mots cnvi1 cnvi2 cnvi3 ;
  763. lcu=mots 'UX' 'UY' 'UZ' ;
  764. 'FINSI' ;
  765. 'SI' ('NON' ('EXISTE' rv 'OMEGA')) ;
  766. omeg=1.D0 ;
  767. 'SINON' ;
  768. omeg=rv . 'OMEGA' ;
  769. 'FINSI' ;
  770.  
  771. testpr ='EXISTE' rv 'PRESSION' ;
  772. testprj ='EXISTE' rv 'PROJ' ;
  773. testran=testpr 'ET' ('EXISTE' rv 'CO') ;
  774.  
  775. si testpr ; rvp = rv.'PRESSION' ;
  776. achp matpr= 'KOPS' 'MATRIK' ;
  777. rvp.'MATP'= matpr;
  778. finsi ;
  779. si testprj; rvp = rv.'PROJ' ; Finsi ;
  780.  
  781. 'SI' (rv.'IMPR' >EG 1) ;
  782. si testpr ;
  783. mess 'Algorithme semi explicite (ANCIEN)';
  784. mess '==================================';
  785. Finsi ;
  786. si testprj;
  787. mess 'Algorithme de Projection';
  788. mess '========================';
  789. finsi ;
  790. si ( non (testpr ou testprj)) ;
  791. mess 'Algorithme standard implicite ou explicite ';
  792. mess '===========================================';
  793. finsi ;
  794. 'FINSI' ;
  795.  
  796. 'SI' ('NON' ('EXISTE' rv 'HIST')) ;
  797. rv . 'HIST' = 'TABLE' ;
  798. 'FINSI' ;
  799.  
  800.  
  801. ITMA=(rv . 'ITMA') ;
  802. IMPTCRR=0 ;
  803. IMPKRES=0 ;
  804. 'SI' ('<EG' ITMA 1) ;
  805. ITMA=1 ;
  806. IMPTCRR=1 ;
  807. 'FINSI' ;
  808. Si (testprj ) ; IMPTCRR=1 ; finsi ;
  809. Si ( non (testpr ou testprj)) ; IMPTCRR=1 ; finsi ;
  810.  
  811.  
  812. * Gestion de la matrice de préconditionnement
  813. *
  814. * calass : doit-on recalculer l'assemblage
  815. * calprec : doit-on recalculer le préconditionneur
  816. * calassp : idem pour la matrice de pression
  817. * calprecp: idem pour la matrice de pression
  818. * fcprect : fréquence de recalcul du préc. en fn du pas de temps
  819. * fcpreci : fréquence de recalcul du préc. dans la boucle
  820. * d'itérations internes pour les non-linéarités
  821. * resmn : le résidu au pas de temps ou à l'itération interne précédente
  822. *
  823. calprec = VRAI ;
  824. fcprect = rv. 'METHINV' . 'FCPRECT' ;
  825. fcpreci = rv. 'METHINV' . 'FCPRECI' ;
  826. resmn maprec = 'KOPS' 'MATRIK' ;
  827. resmn1 maprec1 = 'KOPS' 'MATRIK' ;
  828. resmn2 maprec2 = 'KOPS' 'MATRIK' ;
  829. 'SI'(exist rv 'resmn');resmn=rv.'resmn' ; finsi ;
  830. 'SI'(non (exist rv 'calprec'));rv.'calprec'=VRAI;finsi;
  831. 'SI'(non (exist rv 'calass' ));rv.'calass' =VRAI;calass =VRAI;finsi;
  832. 'REPETER' bloc1 ITMA ;
  833. * mess ' DEBUT BLOC1 ';
  834.  
  835. testp1 = FAUX ;
  836. si (testpr ou testprj) ;
  837. Si CALPRE ; testp1=VRAI ; Finsi ;
  838. Si (non (exist rvp 'MATC')) ; testp1=VRAI ; Finsi ;
  839. finsi ;
  840.  
  841. 'SI' ('MULT' (&bloc1 '+' 1) fcprect) ;
  842. rv.'calprec' = VRAI ;
  843. 'FINSI' ;
  844. 'REPETER' bloci (rv . 'NITER') ;
  845. 'SI' ('MULT' (&bloci '+' 1) fcpreci) ;
  846. rv.'calprec' = VRAI ;
  847. 'FINSI' ;
  848.  
  849. 'SI' (testprj) ;
  850. calprecp=VRAI ;
  851. calassp =VRAI ;
  852. si (exist rvp 'calprecp' ) ; calprecp=rvp.'calprecp';
  853. maprec1=rvp.'maprec1' ;finsi ;
  854. si (exist rvp 'calassp' ) ; calassp=rvp.'calassp';
  855. matass1=rvp.'matass1' ;finsi ;
  856. fcprectp = rvp . 'METHINV' . 'FCPRECT' ;
  857. 'SI' ('MULT' (&bloc1 '+' 1) fcprectp) ;
  858. calprecp= VRAI ;
  859. 'FINSI' ;
  860. 'FINSI' ;
  861.  
  862.  
  863.  
  864. st mat = 'KOPS' 'MATRIK' ;
  865. sf mau = 'KOPS' 'MATRIK' ;
  866.  
  867.  
  868. mdfdt = 0 ;
  869. 'REPETER' bloc2 ('DIME' (rv . 'LISTOPER')) ;
  870. nomper = 'EXTRAIRE' &bloc2 (rv . 'LISTOPER') ;
  871. notable= 'MOT' ('TEXTE' ('CHAINE' &bloc2 nomper)) ;
  872. * mess 'Operateur Bloc2 mdfdt ? ' nomper ;
  873. mdfdt = mdfdt + rv. notable . 'KOPT' . 'KFORM' ;
  874.  
  875. si (ega nomper 'DFDT ');
  876. ISCHT= (rv . notable.kopt.'ISCHT') ;
  877. msi mai=('TEXTE' nomper) (rv . notable) ;
  878. mat = mat 'ET' mai ;
  879. st = st 'ET' msi ;
  880.  
  881. sinon ;
  882.  
  883. * mess ' 1OPER =' nomper;
  884. msi mai=('TEXTE' nomper) (rv . notable) ;
  885. mau = mau 'ET' mai ;
  886. sf = sf 'ET' msi ;
  887.  
  888. finsi ;
  889.  
  890. 'FIN' bloc2 ;
  891.  
  892. s2 = sf et st ;
  893. ma1 = mau 'ET' mat ;
  894.  
  895. ********** Traitement PRESSION ****************************
  896. *mess 'Traitement PRESSION';
  897.  
  898. 'SI' (exist rv 'rvpd') ;
  899. rvpd = rv.'rvpd' ;
  900. IDigv=rv.'IDigv';
  901. Digv=rv.'Digv';
  902. matpr= rvp.'MATP' ;
  903. 'FINSI' ;
  904.  
  905. */1 CALCUL de CMCT pour PRESSION
  906. 'SI' (testpr et testp1) ;
  907.  
  908. rvpd = (rvp.'DOMAINE') ;
  909. Diago = doma rvpd 'XXDIAGSI' ;
  910. si ( ega ('VALEUR' 'DIME') 2) ;
  911. Digv= ( exco Diago 'SCAL' cnvi1 ) et ( exco Diago 'SCAL' cnvi2 ) ;
  912. sinon ;
  913. Digv= ( exco Diago 'SCAL' cnvi1 ) et ( exco Diago 'SCAL' cnvi2 ) et
  914. ( exco Diago 'SCAL' cnvi3 ) ;
  915. finsi ;
  916. Digv = kcht rvpd vect sommet comp lc Digv ;
  917.  
  918. 'SI' ('EXISTE' rv 'CLIM') ;
  919. rvp . 'CLIM' = rv . 'CLIM' ;
  920. Digv = 'KOPS' Digv 'CLIM' (rv . 'CLIM') -1;
  921. 'FINSI' ;
  922.  
  923. IDigv= 'INVERSE' digv ;
  924.  
  925. 'SI' ('NON' ('EXISTE' rvp 'DIAGV')) ;
  926. rvp . 'DIAGV' = digv ;
  927. 'FINSI' ;
  928.  
  929. rvp . 'MATC' = 'KMAB' rvp ;
  930. rvp . 'PRESSION' = 'KCHT' rvpd 'SCAL'
  931. 'CENTRE' 0.D0 ;
  932. rvp . 'GRADP' = 'KCHT' rvpd 'VECT'
  933. 'SOMMET' vnul ;
  934.  
  935. achp matpr= 'KOPS' 'MATRIK' ;
  936. rvp . 'MATP' = matpr ;
  937. rv.'rvpd'=rvpd;
  938. rv.'IDigv'=IDigv;
  939. rv.'Digv'=Digv;
  940.  
  941. 'FINSI' ;
  942.  
  943. */3 CALCUL de CMCT pour PROJ
  944. 'SI' (testprj et testp1) ;
  945.  
  946. Diago mma = 'KOPS' 'MATRIK' ;
  947.  
  948. idfdt = 0 ;
  949. 'REPETER' blocj ('DIME' (rv . 'LISTOPER')) ;
  950. nomper = 'EXTRAIRE' &blocj (rv . 'LISTOPER') ;
  951. notable= 'MOT' ('TEXTE' ('CHAINE' &blocj nomper)) ;
  952. *? mess 'Operateur ' nomper ;
  953. si (ega nomper 'DFDT ');
  954. idfdt=idfdt + 1 ;
  955. Diago = Diago et (doma (rv. notable . 'DOMZ') 'XXDIAGSI') ;
  956. rvpd=rv. notable . 'DOMZ';
  957. finsi ;
  958. 'FIN' blocj ;
  959. si (ega idfdt 0) ; mess ' Pas de DFDT ?? ' ; erreur 21 ; finsi ;
  960.  
  961. si ( ega ('VALEUR' 'DIME') 2) ;
  962. Digv= ( exco Diago 'SCAL' cnvi1 ) et ( exco Diago 'SCAL' cnvi2 ) ;
  963. sinon ;
  964. Digv= ( exco Diago 'SCAL' cnvi1 ) et ( exco Diago 'SCAL' cnvi2 ) et
  965. ( exco Diago 'SCAL' cnvi3 ) ;
  966. finsi ;
  967. Digv = kcht rvpd vect sommet comp lc Digv ;
  968. * Matrice diagonale ne contenant pas les conditions aux limites : Diag
  969. Diag = copier Digv;
  970. IDiag = 'INVERSE' Diag ;
  971.  
  972. Digv = 'KOPS' Digv 'CLIM' (rv . 'CLIM') -1;
  973.  
  974. IDigv= 'INVERSE' digv ;
  975.  
  976. 'SI' ('NON' ('EXISTE' rvp 'DIAGV')) ;
  977. rvp . 'DIAGV' = digv ;
  978. 'FINSI' ;
  979.  
  980. rvp.'INCO'=rv.'INCO' ;
  981.  
  982. sp map = 'KOPS' 'MATRIK' ;
  983. sr mar = 'KOPS' 'MATRIK' ;
  984. svnpc mvnpc = 'KOPS' 'MATRIK' ;
  985. 'REPETER' blocpj ('DIME' (rvp . 'LISTOPER')) ;
  986. nomper = 'EXTRAIRE' &blocpj (rvp . 'LISTOPER') ;
  987. notable= 'MOT' ('TEXTE' ('CHAINE' &blocpj nomper)) ;
  988. mess 'Procedure PROJ Operateur : ' nomper ;
  989.  
  990. si (EGA nomper 'KBBT');
  991. rvp . notable . 'KOPT' . 'IKOMP' = 1 ;
  992. finsi ;
  993.  
  994. msi mai=('TEXTE' nomper) (rvp . notable) ;
  995.  
  996. *******PROJ*************************************************************
  997. *******PROJ TGRAD calcul maig (Formulation en Gradient) DEBUT*** *******
  998. Si TGRAD ;
  999. mess 'Procedure PROJCT (Gradient) Operateur : ' nomper ;
  1000. rvp . notable . 'KOPT' . 'IKOMP' = 0 ;
  1001. msig maig=('TEXTE' nomper) (rvp . notable) ;
  1002. Finsi ;
  1003. *******PROJ -> MATG FIN*****
  1004. *******PROJ/////////////////////////////////////////////////////////////
  1005.  
  1006. TVNP=FAUX;
  1007. TVNPC=FAUX;
  1008. Si (('EGA' nomper 'VNIMP ') et (non (ega (rvp.'DISCPRES') 5)));
  1009. TVNP=VRAI ;
  1010. mar = mar 'ET' mai ;
  1011. sr = sr 'ET' msi ;
  1012. Finsi ;
  1013.  
  1014. * mess 'nomper=' nomper (rvp.'DISCPRES');
  1015. Si (('EGA' nomper 'VNIMP ') et (ega (rvp.'DISCPRES') 5));
  1016. TVNPC=VRAI;
  1017. mvnpc=mvnpc et mai ;
  1018. svnpc=svnpc et msi ;
  1019. Finsi ;
  1020.  
  1021. Si (non ('EGA' nomper 'VNIMP '));
  1022. map = map 'ET' mai ;
  1023. sp = sp 'ET' msi ;
  1024. Finsi ;
  1025.  
  1026. 'FIN' blocpj ;
  1027.  
  1028. matpc mac = kops 'CMCTSPLT' map ;
  1029. *******PROJ*************************************************************
  1030. *******PROJ TGRAD (vrai Formulation en Gradient) CMCTSPLT DEBUT*** *******
  1031. Si TGRAD ;
  1032. matpcg macg = kops 'CMCTSPLT' maig ;
  1033. Finsi ;
  1034. *******PROJ -> MATG FIN*****
  1035. *******PROJ/////////////////////////////////////////////////////////////
  1036.  
  1037. Si TVNPC; mac=mac et mvnpc; Finsi;
  1038. rvp . 'MATC' = mac ;
  1039.  
  1040. *******PROJ*************************************************************
  1041. *******PROJ TGRAD (vrai Formulation en Gradient) -> MATG DEBUT*** *******
  1042. SI TGRAD ; rvp . 'MATG' = macg; FINSI ;
  1043. *******PROJ -> MATG FIN*****
  1044. *******PROJ/////////////////////////////////////////////////////////////
  1045.  
  1046. scr mcr = 'KOPS' 'MATRIK' ;
  1047. Si TVNP ;
  1048. rvp . 'MBTR' = mar ;
  1049. Dunit=Idigv;
  1050. crt= kops 'CMCT' mac mar (Dunit) ;
  1051. ctr= kops 'CMCT' mar mac (Dunit) ;
  1052. rrt= kops 'CMCT' mar mar (Dunit) ;
  1053. mcr= mcr et crt et ctr et rrt ;
  1054. Finsi ;
  1055. rvp . 'TVNP' = TVNP ;
  1056.  
  1057. Si( ega (rvp.'DISCPRES') 5 ) ;
  1058. mess ' Cas des pressions continues' ;
  1059. matpr = matpc et mcr ;
  1060. Sinon ;
  1061. mess ' Cas des pressions discontinues' ;
  1062.  
  1063. matpr = kops 'CMCT' mac mac IDigv ;
  1064. matpr = matpc et matpr et mcr ;
  1065.  
  1066. Finsi ;
  1067.  
  1068.  
  1069. rvp . 'MATP' = matpr ;
  1070. rv.'rvpd'=rvpd;
  1071. rv.'IDigv'=IDigv;
  1072. rv.'Digv'=Digv;
  1073. 'FINSI' ;
  1074. *************
  1075. ** Fin calcul CMCT pour testp1 et testprj
  1076. ******************************************
  1077. * t
  1078. *************** Calcul de C p Pression
  1079. 'SI' testpr ;
  1080.  
  1081. dt = (rv . 'PASDETPS' . 'DELTAT') '*' (rv . 'ALFA') ;
  1082. rvp . 'DELTAT' = dt ;
  1083. f = 'COPIER' s2 ;
  1084. u = rv . 'INCO' . nomvi ;
  1085.  
  1086. lc = 'EXTRAIRE' digv 'COMP' ;
  1087. fu = 'KCHT' rvpd 'VECT' 'SOMMET'
  1088. 'COMP' lc ('EXCO' f lc) ;
  1089.  
  1090. 'SI' ('EXISTE' rv 'CLIM') ;
  1091. dti = -1.D0 '/' dt ;
  1092. dm1f= 'KOPS' (dt '*' ('KOPS' fu '*' IDigv))
  1093. 'CLIM' (rv . 'CLIM') 3 ;
  1094. dm1f= dti * dm1f ;
  1095. 'SINON' ;
  1096. dm1f= (-1.D0) '*' ('KOPS' fu '*' IDigv) ;
  1097. 'FINSI' ;
  1098.  
  1099. rvp . 'PRESSION' = 'KMF' (rvp . 'MATC') dm1f ;
  1100.  
  1101. 'KRES' rvp (rvp . 'PRESSION')
  1102. 'BETA' (rvp . 'KBETA') (rvp . 'BETA')
  1103. 'PIMP' (rvp . 'KPIMP') (rvp . 'PIMP') ;
  1104. rvp . 'GRADP' = 'KMTP' 1 (rvp . 'MATC')
  1105. (rvp . 'PRESSION') lc ;
  1106. s2 = s2 + (rvp . 'GRADP') ;
  1107. rv.'INCO'.'PRESSION'=rvp . 'PRESSION';
  1108.  
  1109. 'FINSI' ;
  1110.  
  1111. *******PROJ*************************************************************
  1112. *******PROJ MDM1 Ici on calcule M D-1 pour ensuite calculer Ctp DEBUT*** *******
  1113. *******PROJ on ne calcule M D-1 que si (rv 'MDM1') n'existe pas DEBUT*** *******
  1114. *******PROJ ou CALPRE VRAI DEBUT*** *******
  1115. 'SI' testprj ;
  1116.  
  1117. dt = (rv . 'PASDETPS' . 'DELTAT') '*' (rv . 'ALFA') ;
  1118. rvp . 'DELTAT' = dt ;
  1119.  
  1120. ** Produit M D-1
  1121. 'SI' TMDM1 ;
  1122. 'SI' (('EXIST' rv 'MDM1') et (NON CALPRE)) ;
  1123. MDM1=rv.'MDM1' ;
  1124. 'SINON' ;
  1125. mess ' On calcule MD-1 ' ;
  1126. stn matn= 'KOPS' 'MATRIK' ;
  1127.  
  1128. 'REPETER' blocpj1 ('DIME' (rvp . 'LISTOPER')) ;
  1129. nomper1 = 'EXTRAIRE' &blocpj1 (rvp . 'LISTOPER') ;
  1130. notable1= 'MOT' ('TEXTE' ('CHAINE' &blocpj1 nomper1)) ;
  1131. * mess 'Operateur ' nomper1 ;
  1132.  
  1133. si (ega nomper1 'KBBT ');
  1134. nomiv1= extr (rvp . notable1 . 'LISTINCO') 1 ;
  1135.  
  1136. 'REPETER' blocpj2 ('DIME' (rv . 'LISTOPER')) ;
  1137. nomper2 = 'EXTRAIRE' &blocpj2 (rv . 'LISTOPER') ;
  1138. notable2= 'MOT' ('TEXTE' ('CHAINE' &blocpj2 nomper2)) ;
  1139. * mess 'Operateur ' nomper2 ;
  1140.  
  1141. si (ega nomper2 'DFDT ');
  1142. nomiv2= extr (rv . notable2 . 'LISTINCO') 1 ;
  1143. si ('EGA' nomiv2 nomiv1) ;
  1144.  
  1145. domzp=rv . notable2 . 'DOMZ' ;
  1146. msi mai='DFDT' (rv . notable2) ;
  1147. matn = matn et mai ;
  1148. sti = kcht domzp vect sommet comp lc vuni;
  1149. finsi ;
  1150. finsi ;
  1151. 'FIN' blocpj2 ;
  1152. finsi ;
  1153. 'FIN' blocpj1 ;
  1154.  
  1155. MDM1='KMF' matn IDiag ;
  1156.  
  1157. Si(EGA ISCHT 1);
  1158. MDM1=MDM1 * ((dt*2.)/3.) ;
  1159. Sinon ;
  1160. MDM1=MDM1 * dt ;
  1161. Finsi ;
  1162.  
  1163. rv.'MDM1' = MDM1 ;
  1164.  
  1165. *******PROJ MDM1 -> rv.'MDM1' FIN*****
  1166. *******PROJ/////////////////////////////////////////////////////////////
  1167. 'FINSI';
  1168. 'FINSI';
  1169. *******PROJ*************************************************************
  1170. *******PROJ t n-1 DEBUT*** *******
  1171. *******PROJ Calcul de C P DEBUT*** *******
  1172.  
  1173. TVNP=rvp.'TVNP' ;
  1174.  
  1175. 'SI' ('EXIST' (rv.'INCO') 'PRESSION') ;
  1176. PPI = rv.'INCO'.'PRESSION' ;
  1177. 'SI' ('EXIST' (rv.'INCO') 'PNM2') ;
  1178. * TPNM2 elimination of end of step velocity (2 Pn - Pn-1)
  1179. PPI = 2*(PPI) - rv.'INCO'.'PNM2' ;
  1180. 'FINSI' ;
  1181.  
  1182. *Formulation en u grad p
  1183. Si (Exist rvp 'MATG');
  1184. cpre = 'KMF' (rvp . 'MATG') PPI 'TRAN' ;
  1185. *Formulation en p div u
  1186. Sinon;
  1187. cpre = 'KMF' (rvp . 'MATC') PPI 'TRAN' ;
  1188. Finsi ;
  1189.  
  1190. Si TVNP ;
  1191. cxre = 'KMF' (rvp . 'MBTR') PPI 'TRAN' ;
  1192. cpre = cpre et cxre ;
  1193. Finsi ;
  1194.  
  1195. *******PROJ MDM1
  1196. Si TMDM1 ;
  1197. * consistence selon (Gresho)
  1198. gradpres = 'KOPS' MDM1 '*' cpre ;
  1199. Sinon ;
  1200. * consistence selon (Guermond)
  1201. gradpres = cpre ;
  1202. Finsi ;
  1203.  
  1204. oublier cpre ;
  1205. rv.'INCO'.'GRADPRES' = 'NOMC' lcu lc gradpres;
  1206.  
  1207. *Formulation en u grad p
  1208. Si (Exist rvp 'MATG');
  1209. s2 = sf - (rv.'INCO'.'GRADPRES') + st ;
  1210. Sinon ;
  1211. *Formulation en p div u
  1212. s2 = sf + (rv.'INCO'.'GRADPRES') + st ;
  1213. Finsi ;
  1214.  
  1215. 'FINSI' ;
  1216.  
  1217. *******PROJ t n-1 FIN*****
  1218. *******PROJ MDM1 '*' C P -> rv.'INCO'.'GRADPRES' FIN*****
  1219. *******PROJ t n-1 FIN*****
  1220. *******PROJ si (p div u) -> S2 = F + C P + st FIN*****
  1221. *******PROJ t n-1 FIN*****
  1222. *******PROJ si (u grad p) -> S2 = F - C P + st FIN*****
  1223. *******PROJ/////////////////////////////////////////////////////////////
  1224. 'FINSI' ;
  1225.  
  1226. ********** FIN Traitement PRESSION ************************
  1227. * mess ' FIN Traitement PRESSION' ;
  1228.  
  1229. 'SI' ('EXISTE' rv 'CLIM') ;
  1230. s1 = rv . 'CLIM' ;
  1231. 'SINON' ;
  1232. s1=' ' ;
  1233. 'FINSI' ;
  1234. rv . 'S2' = s2 ;
  1235.  
  1236. *******************************************************************
  1237. * Résolution hors QDM méthode de projection
  1238. 'SI'((NON testprj) ou (EGA mdfdt 0));
  1239. *mess '* Résolution hors QDM méthode de projection ';
  1240.  
  1241. * mess ' ====================> calprec '; list calprec ;
  1242. 'SI' rv.'calass' ;
  1243. rv . 'METHINV' . 'MATASS' =ma1 ;
  1244. rv.'calass'=FAUX ;
  1245. 'FINSI' ;
  1246.  
  1247. 'SI' rv.'calprec' ;
  1248. rv . 'METHINV' . 'MAPREC' = ma1 ;
  1249. rv.'calprec'=FAUX ;
  1250. 'FINSI' ;
  1251.  
  1252. rv . 'METHINV' . 'XINIT' = resmn ;
  1253.  
  1254. res = 'KRES' ma1 'TYPI' (rv . 'METHINV')
  1255. 'CLIM' s1
  1256. 'SMBR' s2
  1257. 'IMPR' IMPKRES ;
  1258.  
  1259. 'FINSI' ;
  1260.  
  1261. 'SI' (testprj et (non(EGA mdfdt 0)));
  1262. *******PROJ*************************************************************
  1263. *******PROJ Résolution QDM DEBUT*** *******
  1264. *******PROJ (On éclate les résolutions) DEBUT*** *******
  1265.  
  1266. * Résolution QDM méthode de projection (On éclate les résolutions)
  1267. *mess ' Résolution QDM méthode de projection';
  1268. res mm1= kops 'MATRIK' ;
  1269. liscom=extr s1 'COMP';
  1270. nbcom=dime liscom ;
  1271. * MEss ' NBCOM=' nbcom ;
  1272.  
  1273. Si(NON(EXIST RV 'TABRES')); RV.'TABRES'=TABLE ; Finsi ;
  1274. Si(NON(EGA ('TYPE' RV.'TABRES') 'TABLE')); RV.'TABRES'=TABLE;Finsi;
  1275.  
  1276. repeter Bclcom nbcom ;
  1277. nmc=extr liscom &Bclcom;
  1278. * Mess ' Composante : ' nmc ;
  1279. ma1i=kops 'EXTRCOMP' nmc 'SCAL' ma1;
  1280. s1i = exco s1 nmc 'NOID' ;
  1281. s2i = exco s2 nmc 'NOID' ;
  1282. resmni = exco resmn nmc 'NOID' ;
  1283.  
  1284. MATASSI =chai 'FORMAT' '(A6,I1)' 'MATASS' &Bclcom;
  1285. MAPRECI =chai 'FORMAT' '(A6,I1)' 'MAPREC' &Bclcom;
  1286.  
  1287. 'SI' (rv.'calass' ou (NON ('EXIST' (RV.'TABRES') MATASSI))) ;
  1288. rv . 'TABRES' . MATASSI = ma1i;
  1289. rv.'calass'=FAUX ;
  1290. 'FINSI' ;
  1291.  
  1292. 'SI' (rv.'calprec' ou (NON ('EXIST' (RV.'TABRES') MAPRECI)));
  1293. mess 'On recalcule le preconditionneur ';
  1294. rv . 'TABRES' . MAPRECI = ma1i;
  1295. rv.'calprec'=FAUX ;
  1296. 'FINSI' ;
  1297.  
  1298. rv . 'METHINV' . 'MATASS' = rv . 'TABRES' . MATASSI ;
  1299. rv . 'METHINV' . 'MAPREC' = rv . 'TABRES' . MAPRECI ;
  1300. rv . 'METHINV' . 'XINIT' = resmni ;
  1301.  
  1302.  
  1303. resi = 'KRES' ma1i 'TYPI' (rv . 'METHINV')
  1304. 'CLIM' s1i
  1305. 'SMBR' s2i
  1306. 'IMPR' IMPKRES ;
  1307. resi = nomc resi nmc ;
  1308. res=res et resi ;
  1309. Fin Bclcom ;
  1310. oubli ma1 ;
  1311. *mess ' Fin Résolution QDM méthode de projection';
  1312. * Fin Résolution QDM méthode de projection
  1313. *******PROJ Résolution QDM -> res FIN*****
  1314. *******PROJ (On éclate les résolutions) FIN*****
  1315. *******PROJ/////////////////////////////////////////////////////////////
  1316. 'FINSI' ;
  1317.  
  1318. 'SI' testprj ;
  1319. *******PROJ*************************************************************
  1320. *******PROJ ETAPE DE PROJECTION DEBUT*** *******
  1321. *******PROJ on calcul cun (alias c U tilde) DEBUT*** *******
  1322. * mess 'ETAPE DE PROJECTION ' ;
  1323. * _n
  1324. * C U
  1325. cun = ('KMF' (rvp . 'MATC') res) ;
  1326. Si TVNP ;
  1327. cxn = ('KMF' (rvp . 'MBTR') res) ;
  1328. cun = cun et cxn ;
  1329. Finsi ;
  1330.  
  1331. * mess ' On calcule les seconds membres de l équation de pression ' ;
  1332. * mess ' s ils existent (opérateurs FIMP) ' ;
  1333.  
  1334. 'REPETER' blocpj ('DIME' (rvp . 'LISTOPER')) ;
  1335. nomper = 'EXTRAIRE' &blocpj (rvp . 'LISTOPER') ;
  1336. notable= 'MOT' ('TEXTE' ('CHAINE' &blocpj nomper)) ;
  1337. si (ega nomper 'FIMP ');
  1338. * mess 'Seconds membres de l équation de pression Opérateur ' nomper ;
  1339. msi mai=('TEXTE' nomper) (rvp . notable) ;
  1340. cun = cun et msi ;
  1341. finsi ;
  1342. 'FIN' blocpj ;
  1343.  
  1344. cun = cun * (-1./dt) ;
  1345.  
  1346. * mess ' ====================> calprecp '; list calprecp ;
  1347. 'SI' calassp;
  1348. matass1=matpr ;
  1349. rvp.'matass1'=matass1 ;
  1350. 'FINSI' ;
  1351.  
  1352. 'SI' calprecp ;
  1353. 'SI' (RV.IMPR >EG 1) ;
  1354. 'MESS' ' On preconditionne CMCT ' ;
  1355. 'FINSI' ;
  1356. maprec1 = matpr ;
  1357. rvp.'maprec1'=maprec1 ;
  1358. 'FINSI' ;
  1359. rvp . 'METHINV' . 'MATASS' = matass1 ;
  1360. rvp . 'METHINV' . 'MAPREC' = maprec1 ;
  1361. rvp . 'METHINV' . 'XINIT' = resmn2 ;
  1362.  
  1363. sl= 'KRES' matpr 'TYPI' (rvp . 'METHINV')
  1364. 'CLIM' (rvp . CLIM )
  1365. 'SMBR' cun
  1366. 'IMPR' IMPKRES ; oublier cun ;
  1367.  
  1368. oublier resmn2 ; resmn2 = sl ;
  1369. ctl = 'KMF' (rvp . 'MATC') sl 'TRAN' ;
  1370. Si TVNP ;
  1371. cxl = 'KMF' (rvp . 'MBTR') sl 'TRAN' ;
  1372. ctl = ctl + cxl ;
  1373. Finsi ;
  1374.  
  1375. * elimination of end of step velocity (Si exist PNM2) (on ne corrige pas)
  1376. 'SI'(NON(TPNM2));
  1377. 'SI' (NON ('EXIST' (rv.'INCO') 'PNM2')) ;
  1378. a=nomc lcu lc ('KOPS' IDigv '*' ctl) ;
  1379. res = res + (a*dt) ;
  1380. 'FINSI' ;
  1381. 'FINSI' ;
  1382.  
  1383. oublier ctl ;
  1384.  
  1385. *******PROJ -> (alias c U tilde) FIN*****
  1386. *******PROJ -> sl (alias lambda) FIN*****
  1387. *******PROJ -> on corrige u FIN*****
  1388. *******PROJ/////////////////////////////////////////////////////////////
  1389. 'FINSI' ;
  1390.  
  1391. ***** Avancement en temps
  1392. *? Si (testprj et ('EGA' mdfdt 0)) ; IMPTCRR=RV.'IMPR' ; finsi ;
  1393. Si ('EGA' mdfdt 0) ; IMPTCRR=RV.'IMPR' ; finsi ;
  1394. IMPKRES=0 ;
  1395. * mess 'On passe dans TCRR ' ;
  1396. eps = 'TCRR' res omeg (rv . 'INCO') 'IMPR' IMPTCRR ;
  1397.  
  1398. 'OUBLIER' resmn ;
  1399. resmn = res ;
  1400. 'MENAGE' ;
  1401. 'FIN' bloci ;
  1402. irt=0 ;
  1403.  
  1404. * mess ' ITMA= ' (rv . 'ITMA') ' mdfdt= ' mdfdt ;
  1405. 'SI' ('EGA' (rv . 'ITMA') 0) ;
  1406. * mess ' ON PASSE PLUS DS TCNM>>>>>>>>>>>>>>' ;
  1407. irt = 'TCNM' rv 'NOUP';
  1408. 'SINON' ;
  1409. * mess ' ON PASSE DS TCNM>>>>' (rv . 'ITMA') mdfdt;
  1410. irt = 'TCNM' rv ;
  1411. 'FINSI' ;
  1412.  
  1413. ***** Avancement en temps algorithme de projection
  1414.  
  1415. 'SI' (testprj) ;
  1416. 'SI' calprecp;
  1417. calprecp= FAUX ;
  1418. 'SINON' ;
  1419. 'SI' ('NON' calassp) ;
  1420. 'OUBLIER' matpr ;
  1421. 'FINSI' ;
  1422. 'FINSI' ;
  1423. calassp=FAUX ;
  1424. rvp.'calassp'=calassp ;
  1425. rvp.'calprecp'=calprecp ;
  1426. 'FINSI' ;
  1427.  
  1428. *******PROJ*************************************************************
  1429. *******PROJ P(n+1) = P(n) + sl DEBUT*** *******
  1430. * Algorithme de projection P(n+1) = P(n) + sl
  1431. 'SI' testprj ;
  1432.  
  1433. 'SI' (NON ('EXIST' (rv.'INCO') 'PRESSION'));
  1434. rv.'INCO'.'PRESSION' = sl;
  1435. Si TPNM2 ; rv.'INCO'.'PNM2' = sl ; Finsi ;
  1436. 'SINON' ;
  1437. PNM1=rv.'INCO'.'PRESSION';
  1438. si ( EGA ISCHT 1) ;
  1439. PN=PNM1 + (1.5*sl) ;
  1440. sinon ;
  1441. PN=PNM1 + sl ;
  1442. finsi ;
  1443.  
  1444. Si TPNM2 ; rv.'INCO'.'PNM2'=PNM1 ; Finsi ;
  1445. rv.'INCO'.'PRESSION'=PN ;
  1446. 'FINSI' ;
  1447.  
  1448. Si (EGA TYPROJ 'PSCT') ;
  1449. rv.'INCO'.'PRESSION' = sl;
  1450. Finsi ;
  1451.  
  1452. 'OUBLIER' sl ;
  1453. 'FINSI' ;
  1454. *******PROJ P(n+1) = P(n) + sl FIN*****
  1455. *******PROJ/////////////////////////////////////////////////////////////
  1456. ***** Avancement en temps FIN
  1457.  
  1458.  
  1459. 'SI' testran ;
  1460. rv . 'CO' . 'VITESSE' ='KOPS' (rv . 'INCO' . nomvi)
  1461. '-' (rv . 'SEDIM') ;
  1462. k = 'ABS' (rv . 'INCO' . 'KN') ;
  1463. e = 'ABS' (rv . 'INCO' . 'EN') ;
  1464. k = 'KOPS' ('KOPS' k '*' k) '/' e ;
  1465. dif = 'KOPS' ('KOPS' k '*' 0.09) '+' (rv . 'COEF') ;
  1466. rv . 'CO' . 'DIFFU' = 'NOEL' rvpd dif ;
  1467. rv . 'CO' . 'TEMPERA' = rv . 'INCO' . 'CN' ;
  1468. 'FINSI' ;
  1469. 'MENAGE' ;
  1470.  
  1471. 'SI' ('EGA' irt 1) ;
  1472. 'MESSAGE' ' Temps final atteint : '
  1473. (rv . 'PASDETPS' . 'TPS') ;
  1474. 'QUITTER' bloc1 ;
  1475. 'FINSI' ;
  1476. 'FIN' bloc1 ;
  1477.  
  1478. 'SI' testpr ;
  1479. rvp . 'PRESSION' = 'KCHT' rvpd 'SCAL' 'CENTRE'
  1480. (rvp . 'PRESSION') ;
  1481. rvp . 'PN' = 'ELNO' rvpd
  1482. (rvp . 'PRESSION') ;
  1483. 'FINSI' ;
  1484. ************************ E X E C ************************************
  1485. 'FINPROC' ;
  1486.  
  1487.  
  1488. opti dime 2 elem QUA4 ;
  1489. GRAPH=VRAI ;
  1490. GRAPH=FAUX ;
  1491. *COMPLET=VRAI;
  1492. COMPLET=FAUX ;
  1493.  
  1494.  
  1495. DISCR='QUAF';
  1496.  
  1497. Si Complet ;
  1498. n1= 42 ; n2= 42 ;
  1499. *n1= 60 ; n2= 60 ;
  1500. *n1= 420 ; n2= 420 ;
  1501. *n1= 100 ; n2= 100 ;
  1502. Sinon;
  1503. n1= 20 ; n2= 20 ;
  1504. Finsi ;
  1505.  
  1506. p1= 0 0 ;p2=1 0 ;p3=1 1 ; p4 = 0 1 ;
  1507. ab= p1 d n1 p2 ;
  1508. mt1= trans ab n2 (0. 1.) ;
  1509. bc= cote 2 mt1 ;
  1510. cd= cote 3 mt1 ;
  1511. da= cote 4 mt1 ;
  1512. mt2= inve mt1 ;
  1513.  
  1514. Mmt1 = chan mt1 QUAF ;
  1515. Mmt2 = chan mt2 QUAF ;
  1516. elim (Mmt1 et Mmt2) 1.e-5 ;
  1517.  
  1518. $mt1= mode Mmt1 'NAVIER_STOKES' DISCR ;
  1519. $mt2= mode Mmt2 'NAVIER_STOKES' DISCR ;
  1520. mt1= doma $mt1 maillage ;
  1521.  
  1522. *zz= chan 'CHAM' ((coor 2 mt1) - (coor 1 mt1)) mt1 'NOEUD' ;
  1523. zz=((coor 2 mt1) - (coor 1 mt1));
  1524. *trace zz mt1 ;
  1525. im= zz MASQU 'INFERIEUR' 0. ;
  1526. tref= (kcht $mt1 scal sommet 1.) * im ;
  1527. *trace tref mt1 ;
  1528.  
  1529. ***==========
  1530. rv1= eqex 'EQUA' 'RIGIDITE'
  1531. 'U' 'T' 'P' $mt1 'VITESSE' 'TEMPERATURE' 'PRESSION' 'CENTREP1'
  1532. 'PERM' 'UN' 'TN' 'PN' NITER 1 OMEGA 1.
  1533. OPTI 'EF' 'IMPL' 'SUPG' CMD 1.
  1534. ZONE $mt1 'OPER' TSCA 'RO' 1.e-5 'UN' 0. INCO 'T'
  1535. 'CLIM' T TIMP (ab et bc) 1. T TIMP (cd et da) 0.
  1536. ;
  1537.  
  1538. rv1.inco=table 'INCO' ;
  1539. rv1.'NUMASSI'=1 ;
  1540.  
  1541. ***==========
  1542.  
  1543.  
  1544. rv1.inco.'TN'=kcht $mt1 scal sommet 0. ;
  1545. rv1.inco.'PN'=kcht $mt1 scal sommet 0. ;
  1546. rv1.inco.'LB'=kcht $mt1 scal sommet 1. ;
  1547. rv1.inco.'RO'=kcht $mt2 scal centre 100. ;
  1548. rv1.inco.'UN'=kcht $mt1 vect sommet (1. 1.);
  1549.  
  1550. exec rv1;
  1551.  
  1552. tn= exco 'SCAL' rv1.inco.'TN' ;
  1553.  
  1554.  
  1555. Si GRAPH ;trace TN mt1 'TITR' 'SUPG' ;Finsi ;
  1556.  
  1557. dg=doma $mt1 'XXDIAGSI' ;
  1558. erl2= somt ( dg * (tn - tref) * (tn - tref)) ;
  1559. mess 'ERL2=' erl2 ;
  1560. Si (erl2 > 2.7e-2); erreur 5 ; Finsi ;
  1561. * opti donn 5 ;
  1562.  
  1563. * Cas CENTREE
  1564. rv1.'1TSCA'.'KOPT'.'IDCEN'=1 ;
  1565. exec rv1;
  1566. tn= exco 'SCAL' rv1.inco.'TN' ;
  1567.  
  1568. Si GRAPH ;trace TN mt1 'TITR' 'CENTREE' ;Finsi ;
  1569.  
  1570. erl2= somt ( dg * (tn - tref) * (tn - tref)) ;
  1571. mess 'ERL2=' erl2 ;
  1572. Si (erl2 > 8.e-2); erreur 5 ; Finsi ;
  1573.  
  1574. * opti donn 5 ;
  1575. * Cas SUPGDC
  1576. rv1.inco.'TN'=kcht $mt1 scal sommet 0. ;
  1577. rv1.'1TSCA'.'KOPT'.'IDCEN'=2 ;
  1578. rv1.'NITER'= 5 ;
  1579. exec rv1;
  1580. tn= exco 'SCAL' rv1.inco.'TN' ;
  1581.  
  1582. Si GRAPH ;trace TN mt1 'TITR' 'SUPGDC' ;Finsi ;
  1583.  
  1584. erl2= somt ( dg * (tn - tref) * (tn - tref)) ;
  1585. mess 'ERL2=' erl2 ;
  1586. Si (erl2 > 3.7e-2); erreur 5 ; Finsi ;
  1587.  
  1588. fin ;
  1589.  
  1590.  
  1591.  
  1592.  
  1593.  
  1594.  
  1595.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales