Télécharger ccar5w.dgibi

Retour à la liste

Numérotation des lignes :

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

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