Télécharger konv_resi_ther_cons2.dgibi
* fichier : konv_resi_ther_cons2.dgibi ************************************************************************ ************************************************************************ *********************************************************** **** APPROCHE VF "Cell-Centred Formulation" pour la **** **** solution des **** **** Equations d'Euler pour un gaz parfait **** **** OPERATEURS PRET, KONV **** **** **** **** Cas gaz multi-especes "thermally perfect" **** **** Consistence **** **** Splitting des scalaires passifs **** **** **** **** Methodes: VLH, SS **** **** **** **** A. BECCANTINI DRN/DMT/SEMT/LTMF AVRIL 2001 **** *********************************************************** 'OPTION' 'ELEM' QUA4 ; 'OPTION' 'ECHO' 0 ; 'OPTION' 'TRAC' 'X' ; * *** GRAPH * GRAPH = FAUX ; * GRAPH = VRAI ; *********************** **** LA TABLE PGAZ **** *********************** PGAZ = 'TABLE' ; PGAZ2 = 'TABLE' ; * **** Ordre des polynoms cv_i * PGAZ . 'NORD' = 1 ; PGAZ2 . 'NORD' = 1 ; * **** Especes qui sont dans les equations d'Euler * * **** Espece qui n'y est pas * PGAZ . 'ESPNEULE' = 'N2 '; PGAZ2 . 'ESPNEULE' = 'N2 '; * PGAZ . 'H2 ' = 'TABLE' ; PGAZ . 'H2O ' = 'TABLE' ; PGAZ . 'N2 ' = 'TABLE' ; PGAZ . 'O2 ' = 'TABLE' ; PGAZ2 . 'H2 ' = 'TABLE' ; PGAZ2 . 'H2O ' = 'TABLE' ; PGAZ2 . 'N2 ' = 'TABLE' ; PGAZ2 . 'O2 ' = 'TABLE' ; * **** R (J/Kg/K) * PGAZ . 'H2 ' . 'R' = 4130.0 ; PGAZ . 'H2O ' . 'R' = 461.4 ; PGAZ . 'N2 ' . 'R' = 296.8 ; PGAZ . 'O2 ' . 'R' = 259.8 ; PGAZ2 . 'H2 ' . 'R' = 4130.0 ; PGAZ2 . 'H2O ' . 'R' = 461.4 ; PGAZ2 . 'N2 ' . 'R' = 296.8 ; PGAZ2 . 'O2 ' . 'R' = 259.8 ; * **** Regressions polynomials * * **** "Enthalpies" (ou energies) de formations a OK (J/Kg) * Note: ce sont des entites numeriques PGAZ . 'H2 ' . 'H0K' = -4.195D6 ; PGAZ . 'H2O ' . 'H0K' = -1.395D7 ; PGAZ . 'N2 ' . 'H0K' = -2.953D5 ; PGAZ . 'O2 ' . 'H0K' = -2.634D5 ; PGAZ2 . 'H2 ' . 'H0K' = -4.195D6 ; PGAZ2 . 'H2O ' . 'H0K' = -1.395D7 ; PGAZ2 . 'N2 ' . 'H0K' = -2.953D5 ; PGAZ2 . 'O2 ' . 'H0K' = -2.634D5 ; * PGAZ2: transport de scalaires passifs *************************** ***** DOMAINE SPATIAL **** *************************** A1 = 0.0D0 0.0D0; A2 = 1.0D0 0.0D0; A3 = 2.0D0 0.0D0; A4 = 2.0D0 1.0D0; A5 = 1.0D0 1.0D0; A6 = 0.0D0 1.0D0; L12 = A1 'DROIT' 1 A2; L23 = A2 'DROIT' 1 A3; L34 = A3 'DROIT' 1 A4; L45 = A4 'DROIT' 1 A5; L56 = A5 'DROIT' 1 A6; L61 = A6 'DROIT' 1 A1; L25 = A2 'DROIT' 1 A5; DOM10 = 'DALL' L12 L25 L56 L61 'PLANE'; 'PLANE'; * *** Point ou on controlle la consistence * P10 = 1.0 0.5; * *** Etats gauche et droite * rogd = 1.412 ; pgd = 1.17D6 ; ungd = 8.34 ; utgd = 18.2 ; yh2gd = 0.1 ; yh2Ogd = 0.2 ; yN2gd = 0.15 ; yO2gd = 1 '-' (yh2gd '+' yh2Ogd '+' yn2gd) ; tutugd = 14.9 ; tatagd = 23.8 ; * **** tg * tgd = pgd '/' (rogd * ((yh2gd * (PGAZ . 'H2 ' . 'R')) '+' (yh2Ogd * (PGAZ . 'H2O ' . 'R')) '+' (yn2gd * (PGAZ . 'N2 ' . 'R')) '+' (yo2gd * (PGAZ . 'O2 ' . 'R')))) ; * **** gamg, gamd , htg , htd * * A0H2 = 'EXTRAIRE' (PGAZ . 'H2 ' . 'A') 1 ; A1H2 = 'EXTRAIRE' (PGAZ . 'H2 ' . 'A') 2 ; A0H2O= 'EXTRAIRE' (PGAZ . 'H2O ' . 'A') 1 ; A1H2O= 'EXTRAIRE' (PGAZ . 'H2O ' . 'A') 2 ; A0N2 = 'EXTRAIRE' (PGAZ . 'N2 ' . 'A') 1 ; A1N2 = 'EXTRAIRE' (PGAZ . 'N2 ' . 'A') 2 ; A0O2 = 'EXTRAIRE' (PGAZ . 'O2 ' . 'A') 1 ; A1O2 = 'EXTRAIRE' (PGAZ . 'O2 ' . 'A') 2 ; T = tgd ; T2 = T * T ; ETGD = (yh2gd * ((A0H2 * T) '+' (A1H2 * T2 '/' 2))); ETGD = ETGD '+' (yH2Ogd * ((A0H2O * T) '+' (A1H2O * T2 '/' 2))); ETGD = ETGD '+' (yN2gd * ((A0N2 * T) '+' (A1N2 * T2 '/' 2))); ETGD = ETGD '+' (yO2gd * ((A0O2 * T) '+' (A1O2 * T2 '/' 2))) ; ecingd = 0.5D0 '*' ((ungd '*' ungd) '+' (utgd '*' utgd)); retgd = rogd '*' (ETGd '+' ecingd) ; * *** flux en (n,t) * f1gd = ungd '*' rogd ; f2gd = (rogd '*' (ungd '*' ungd)) '+' pgd ; f3gd = rogd '*' ungd '*' utgd ; f4gd = ungd '*' (retgd '+' pgd); f5gd = ungd '*' rogd '*' yh2gd ; f6gd = ungd '*' rogd '*' yo2gd ; f7gd = ungd '*' rogd '*' yh2ogd ; ftutugd = ungd '*' rogd '*' tutugd ; ftatagd = ungd '*' rogd '*' tatagd ; **************************************************** **************************************************** ******** Boucle sur les angles ********* **************************************************** **************************************************** DANGLE = 360 '/' 7.15; ANGLE = 11.3 ; 'REPETER' BLOC 8; * *** Rotation * ANGLE = ANGLE '+' DANGLE; ORIG = 0.0D0 0.0D0; 'MESSAGE' ; 'MESSAGE' ('CHAINE' 'Angle de rotation= ' ANGLE); 'MESSAGE' ; DOM1 = DOM10 'TOURNER' ANGLE ORIG; DOM2 = DOM20 'TOURNER' ANGLE ORIG; P1 = P10 'TOURNER' ANGLE ORIG; DOMTOT = DOM1 'ET' DOM2; 'ELIMINATION' DOMTOT 1D-6; $DOMTOT = 'MODELISER' DOMTOT 'EULER'; $DOM1 = 'MODELISER' DOM1 'EULER'; $DOM2 = 'MODELISER' DOM2 'EULER'; MDOM1 = TDOM1 . 'QUAF' ; MDOM2 = TDOM2 . 'QUAF' ; MDOMTOT = TDOMTOT . 'QUAF' ; 'SI' GRAPH; 'FINSI' ; * **** Redefinition de P1 dans $DOMTOT 'FACE' * *********************** **** Les CHPOINTs **** *********************** uxgd = (ungd '*' ('COS' ANGLE)) '-' (utgd '*' ('SIN' ANGLE)); uygd = (ungd '*' ('SIN' ANGLE)) '+' (utgd '*' ('COS' ANGLE)); 'NATU' 'DISCRET' ; 'UY' uygd 'NATU' 'DISCRET' ; 'NATU' 'DISCRET' ; * attention: PGAZ . 'ESPEULE' = 'MOTS' 'H2 ' 'O2 ' 'H2O ' ; 'H2 ' yh2gd 'O2 ' yo2gd 'H2O ' yh2ogd 'NATU' 'DISCRET' ; * attention: PGAZ . 'SCALPASS' = 'MOTS' 'TUTU' 'TATA' ; 'TATA' tatagd 'NATU' 'DISCRET' ; *************************** **** L'operateur PRET**** *************************** ORDESP = 1; ORDTEM = 1; ROF VITF PF YF = 'PRET' 'PERFTEMP' ORDESP ORDTEM $DOMTOT PGAZ RN VN PN YN ; ROF2 VITF2 PF2 YF2 SCAF = 'PRET' 'PERFTEMP' ORDESP ORDTEM $DOMTOT PGAZ2 RN VN PN YN SCAN ; * **** Orientation de la normal n de castem par raport a la * notre; t est par consequence * NCOS = 'EXTRAIRE' REFGEOP1 'NX' 1 1 1; NSIN = 'EXTRAIRE' REFGEOP1 'NY' 1 1 1; 'SI' (('ABS' NCOS) > ('ABS' NSIN)); ORIENT = ('COS' ANGLE) '/' NCOS; 'SINON'; ORIENT = ('SIN' ANGLE) '/' NSIN; 'FINSI' ; * **** Test 'KONV' * 'REPETER' BLMETO 2 ; 'SI' ('EGA' &BLMETO 1) ; METO = 'VLH' ; 'FINSI' ; 'SI' ('EGA' &BLMETO 2) ; METO = 'SS' ; 'FINSI' ; 'MESSAGE' ('CHAINE' 'METO = ' METO) ; ; $DOMTOT PGAZ LISTINC1 ROF VITF PF YF ; FLUX2N = (FLUX2X '*' ('COS' ANGLE)) '+' (FLUX2Y * ('SIN' ANGLE)); FLUX2T = (FLUX2Y '*' ('COS' ANGLE)) '-' (FLUX2X * ('SIN' ANGLE)); (PGAZ . 'ESPEULE') 'NATU' 'DISCRET' ; f1 = 'EXTRAIRE' FLUX1 'SCAL' P1; ERRO = 'ABS' (1D-8 '*' f1gd); LOGI1 = ('ABS' ((f1 '*' ORIENT) '-' f1gd)) < ERRO; f2 = 'EXTRAIRE' FLUX2N 'SCAL' P1; ERRO = 'ABS' (1D-8 '*' f2gd); LOGI2 = ('ABS' ((f2 '*' ORIENT) '-' f2gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; f3 = 'EXTRAIRE' FLUX2T 'SCAL' P1; ERRO = 'ABS' (1D-8 '*' f3gd) ; LOGI2 = ('ABS' ((f3 '*' ORIENT) '-' f3gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; f4 = 'EXTRAIRE' FLUX3 'SCAL' P1; ERRO = 'ABS' (1D-8 '*' f4gd) ; LOGI2 = ('ABS' ((f4 '*' ORIENT) '-' f4gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; f5 = 'EXTRAIRE' FLUX4 'H2 ' P1; ERRO = 'ABS' (1D-8 '*' f5gd) ; LOGI2 = ('ABS' ((f5 '*' ORIENT) '-' f5gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; f6 = 'EXTRAIRE' FLUX4 'O2 ' P1; ERRO = 'ABS' (1D-8 '*' f6gd) ; LOGI2 = ('ABS' ((f6 '*' ORIENT) '-' f6gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; f7 = 'EXTRAIRE' FLUX4 'H2O ' P1; ERRO = 'ABS' (1D-8 '*' f7gd) ; LOGI2 = ('ABS' ((f7 '*' ORIENT) '-' f7gd)) < ERRO; LOGI1 = LOGI1 'ET' LOGI2; 'SI' ('NON' LOGI1); 'MESSAGE' ; 'MESSAGE' 'OPERATEUR KONV'; 'MESSAGE' ('CHAINE' METO); 'MESSAGE' ; 'MESSAGE' ('CHAINE' 'df1 ' ('ABS' (f1gd '-' (ORIENT '*'f1))) ' f1 ' f1); 'MESSAGE' ('CHAINE' 'df2 ' ('ABS' (f2gd '-' (ORIENT '*'f2))) ' f2 ' f2); 'MESSAGE' ('CHAINE' 'df3 ' ('ABS' (f3gd '-' (ORIENT '*'f3))) ' f3 ' f3); 'MESSAGE' ('CHAINE' 'df4 ' ('ABS' (f4gd '-' (ORIENT '*'f4))) ' f4 ' f4); 'MESSAGE' ('CHAINE' 'df5 ' ('ABS' (f5gd '-' (ORIENT '*'f5))) ' f5 ' f5); 'MESSAGE' ('CHAINE' 'df6 ' ('ABS' (f6gd '-' (ORIENT '*'f6))) ' f6 ' f6); 'MESSAGE' ('CHAINE' 'df7 ' ('ABS' (f7gd '-' (ORIENT '*'f7))) ' f7 ' f7); 'ERREUR' 5; 'FINSI' ; ************************************************ ***** Splitting des scalaires passifs ********** ************************************************ 'MESSAGE' ('CHAINE' 'METO = ' METO ' (scalaires passifs)') ; 'TUTU' 'TATA') ; $DOMTOT PGAZ2 LISTINC2 ROF VITF PF YF SCAF ; 'SI' (('MAXIMUM' (CHPFLU3 '-' CHPFLU) 'ABS') > 1.0D-15) ; 'MESSAGE' 'Probleme dans les transport de scalaires passifs' ; 'ERREUR' 5; 'FINSI' ; * **** Test 'KONV' * fceltutu = 'EXTRAIRE' CHPFLU2 'TUTU' P1; LOGI1 = ('ABS' ((fceltutu '*' ORIENT) '-' ftutugd)) < ('ABS' (1.0D-8 * fceltutu)) ; fceltata = 'EXTRAIRE' CHPFLU2 'TATA' P1; LOGI2 = ('ABS' ((fceltata '*' ORIENT) '-' ftatagd)) < ('ABS' (1.0D-8 * fceltata)) ; LOGI1 = LOGI1 'ET' LOGI2; 'SI' ('NON' LOGI1); 'MESSAGE' ; 'MESSAGE' 'OPERATEUR KONV'; 'MESSAGE' 'Transport de scalaires passifs' ; 'ERREUR' 5; 'FINSI' ; * ****** Le residu * * ****** CHPDIR = chpoint sur les face de chaque elts * * * NB Dans ce cas particulier, DOMTOT n'a que de QUA4, * donc ($DOMTOT . 'XXNORMAE') contient une seule * zona elementaire! 'REPETER' BLELE NBELEM ; ELEMC1 = 'CHANGER' ELEM1 'POI1' ; 'REPETER' BLEPO NBPOIN ; ELEP1 = 'MANUEL' 'POI1' P1 ; 'SCAL' 1 &BLELE &BLEPO ; COEFNO 'NATU' 'DISCRET') ; 'FIN' BLEPO ; MAIDIR = 'EXTRAIRE' CHPDIR 'MAILLAGE' ; * ********* Le flux qui sort * ('MOTS' 'SCAL' 'SCAL' 'SCAL' 'SCAL' 'SCAL' 'SCAL' 'SCAL' 'SCAL' 'SCAL' ) LISTINC2 LISTINC2 ; 'REPETER' BLCOM NBCOMP ; NOMCOM = 'EXTRAIRE' LISTINC2 &BLCOM ; NOMCOM CELSCA 'NATU' 'DISCRET') ; 'FIN' BLCOM ; 'FIN' BLELE ; $DOMTOT PGAZ2 LISTINC2 ROF VITF PF YF SCAF ; 'SI' (ERRO > 1.0D-8) ; 'MESSAGE' ; 'ERREUR' 5 ; 'FINSI' ; ERRO = 'ABS' (DT '-' DT1) ; 'SI' (ERRO > 1.0D-15) ; 'MESSAGE' ; 'ERREUR' 5 ; 'FINSI' ; 'FIN' BLMETO ; **************************************************** **************************************************** ******** Fin boucle sur les angles ********* **************************************************** **************************************************** 'FIN' BLOC; 'FIN' ;
© Cast3M 2003 - Tous droits réservés.
Mentions légales