Télécharger transport1EFMH.dgibi
		
* fichier : transport1EFMH.dgibi
*
********************* CAS TEST : transport1.dgibi ********************
*
GRAPH = 'N' ;
CRIT1 = 1.D-6 ;
'SAUT' 'PAGE' ;
*
*---------------------------------------------------------------------
* TEST TRANSPORT1
* CALCUL DARCY ISOTROPE TRANSPORT.
* Transport d'un front.
*
* dT
* -- + div (uT - Kgrad(T)) = 0
* dt
*
* Ce test permet de vérifier le bon fonctionnement des opérateurs
* utilisés afin de résoudre l'équation de transport par diffusion
* convection d'un champ scalaire passif par la méthode d'éléments
* finis mixtes hybrides implanté dans CASTEM2000.
*
* Le maillage ne comporte qu'un élément dans la direction transverse
* à l'écoulement puisque le phénomène étudié est 1D. Dans le sens de
* l'écoulement, le pas de discrétisation est constant.
*
* Les conditions initiales correspondent à l'entrée du front dans le
* domaine. Comme le champ de vitesse choisi est positif, la trace de
* concentration est égale à 1 à gauche du domaine.
*
* Les conditions aux limites imposent la trace de concentration à
* gauche du domaine égale à un; sur les autres frontières ce sont
* les conditions aux limites naturelles.
*
* Le schéma en temps utilisé est le schéma d'Euler implicite
* (teta-méthode avec teta=1.0).
*
* Données physiques :
* VK : Coefficient de diffusion ................. 1.D-4
* VX1 : Vitesse suivant x......................... 1.
* VY1 : Vitesse suivant y......................... 0.
* T0 : Concentration initiale.................... 0.
* T1 : Concentration en entrée................... 1.
*
* Données temporelles :
* TMIN : Temps initial............................. 0.
* TMAX : Temps final............................... 30.
* DELTAT: Pas de temps.............................. 1.
* T0 : Concentration initiale.................... 0.
* T1 : Concentration en entrée................... 1.
*
* Parametres de maillage :
* L : longueur du domaine ....................... 100.
* H : hauteur du domaine ........................ 1.
* INUMX : Nombre d'éléments en x .................... 100
* INUMY : Nombre d'éléments en y .................... 1 car 1D
*
*---------------------------------------------------------------------
*
*------------------
* Options generales
*------------------
*
*
*
*=========
* MAILLAGE
*=========
*
*
*- Création des points supports du contour du domaine, et des droites
*- passant par les centres et les faces pour le post-traitement.
*
L = 100.D0 ;
LS2 = L / 2.D0 ;
H = 20.D0 ;
HS2 = H / 2.D0 ;
X0 = 0.D0 ;
X1 = X0 + L ;
Y0 = 0.D0 ;
Y1 = Y0 + H ;
INUMX = 100 ;
INUMY = 1 ;
*INUM1 = INUMX - 1 ;
*Y01 = Y0 + Y1 * 0.5D0 ;
DX = X1 - X0 / INUMX ;
DY = H '/' INUMY ;
*DX1 = DX / 2.D0 ;
*XG = X0 + DX1 ;
*XD = X1 - DX1 ;
*
A1 = X0 Y0 ;
A3 = X1 Y0 ;
D1 = X0 Y1 ;
D3 = X1 Y1 ;
*B1 = X0 Y01 ;
*B3 = X1 Y01 ;
*C1 = XG Y01 ;
*C3 = XD Y01 ;
*P6 = LS2 Y01 ;
*
*- Création des DROITES frontieres
*
PELIM = DY / (100.D0) ;
*
*- Creation maillage GEOMETRIQUE
*
*
*- Creation maillage HYBRIDE y compris sous-objets (cond. limites)
*
*DRMID = B1 'DROI' INUMX B3 ;
*DRMIC = C1 'DROI' INUM1 C3 ;
*EXT1 = 'MANU' 'POI1' B1 ;
*
*
*================
* INITIALISATIONS
*================
*
* ----------------
* = MODELISATION =
* ----------------
*
* ---------------------
* = Donnees physiques =
* ---------------------
*
T0 = 0.D0 ; T1 = 1.D0 ;
VX1 = 1.D0 ; VY1 = 0.D0 ;
VK = 1.D-4 ;
*MATI2 = KCHA MODHYB MATI2 'CHAM';
*
'VX' VX1 'VY' VY1 'NATURE' 'DISCRET' ;
'VX' VX1 'VY' VY1 'NATURE' 'DISCRET' ;
FLU2 = CHYB1 * FLU1 ;
*
* -----------------------
* = Donnees transitoire =
* -----------------------
* TETA : Parametre de le theta-méthode
* TMAX : Temps final
* TSUP : Temps pour conditions aux limites
* DELTAT : Pas de temps
*
TETA = 1.00D0 ;
TMIN = 0.D0 ;
TMAX = 30.00D0 ;
TSUP = 1.2D0 * TMAX ;
DELTAT = 0.5D0 ;
*
*
* ------------------------
* = Conditions initiales =
* ------------------------
*TCHYB = 'MANU' 'CHPO' ('DOMA' MODHYB 'CENTRE') 1 'H' 1.D0
* 'NATURE' 'DISCRET' ;
TCHYB = 'MASQUE' xcoor SUPERIEUR ((L/2.D0) '-' (dx/2.D0));
TCHYB = TCHYB * (
'MASQUE' xcoor INFERIEUR ((L/2.D0) '+' (dx/2.D0)));
TCHYB = TCHYB * (
'MASQUE' ycoor INFERIEUR ((H/2.D0) '+' (dy/2.D0)));
TCHYB = TCHYB * (
'MASQUE' xcoor SUPERIEUR ((L/2.D0) '-' (dx/2.D0)));
*
* --------------
* = T imposée =
* --------------
*opti donn 5;
*
* ---------------------------
* = Table DARCY_TRANSITOIRE =
* ---------------------------
*
*
*
*-- Table de transport :
Transp = 'TABLE';
Transp . 'MODELE' = MODHYB ;
Transp.'TEMPS' = 'TABLE';
Transp.'CONCENTRATION' = 'TABLE';
Transp.'FLUXDIFF' = 'TABLE';
Transp.'FLUXCONV' = 'TABLE';
Transp.'CARACTERISTIQUES' = MATI2;
Transp.'POROSITE' = 1.D0;
Transp.'COEF_RETARD' = 1.D0;
Transp.'CONVECTION' = Transp.'CONVECTION' /
Transp . 'CONVECTION' = Transp . CONVECTION *
Transp.'VITELEM' = SPEEDC ;
*Transp . 'ALPHAL' = MANU 'CHPO' (doma MODHYB centre)
* 'SCAL' 1.D0;
*Transp . 'ALPHAT' = MANU 'CHPO' (doma MODHYB centre)
* 'SCAL' 0.D0;
* Conditions initiales :
Transp.'TEMPS'. 0 = TMIN ;
Transp.'CONCENTRATION'. 0 = TCHYB;
Transp.'FLUXDIFF'. 0 = 0.D0 * FLU3 ;
Transp.'FLUXCONV'. 0 = 0.D0 * FLU3;
* Conditions aux limites :
'H' 1.D0 'NATURE' 'DISCRET')
*Transp . 'FLUXTOT_IMP' = TTT1 ;
* Paramètres numériques :
Transp.'THETA_DIFF' = 1.D0;
Transp.'THETA_CONVECTION' = 1.D0;
Transp.'TYPDISCRETISATION' = 'EFMH';
Transp.'DECENTR' = VRAI;
TABRES = table METHINV;
TABRES . 'TYPINV' = 1;
TABRES . 'PRECOND' = 3;
Transp . 'METHINV' = TABRES;
Transp.'TEMPS_CALCULES' = LiCalc;
Transp.'TEMPS_SAUVES' = LiSauv;
Transp . INTCONC = TABLE;
Transp . INTCONC . 0 = 0.D0 * TCHYB;
* ==========
* | CALCUL |
* ==========
*=======================
* Resolution transitoire
*=======================
*
TRANSGEN TRANSP ;
PEK = VX1 * DX / (2. * VK) ;
FOU = 2. * VK * DELTAT / (DX * DX) ;
*
ISOR1 = INDEX ( TRANSp . 'TEMPS') ;
NTSO1 = NTSOR - 1 ;
IOK = FAUX ;
IRESU = 1 ;
*
*-----------------------
REPETER VISURESU NTSO1 ;
*-----------------------
*
IRESU = IRESU + 1 ;
INDI1 = ISOR1.IRESU ;
TTRA = TRANSP . 'TEMPS' . INDI1 ;
* Principe du maximum
EPR1 = TRANSP . 'CONCENTRATION' . INDI1 ;
VTEST = PMA + PMI ;
'MESS' ' Précision demandée ' CRIT1 ;
* Centre de gravité
*
XV1 = XC * EPR1 ;
XV3 = XV2 / M1 ;
YV1 = YC * EPR1 ;
YV3 = YV2 / M1 ;
XTEST = TTRA / 2.D0 ;
*
'MESS' ' THEORIQUE ' XTEST HS2 ;
'MESS' ' OBTENU ' XV3 YV3 ;
'MESS' ' TAILLE D UNE MAILLE ' DX ;
'SI' ( VTEST 'NEG' T1 CRIT1 ) ;
IOK = VRAI ;
'MESSAGE' 'vtest';
'FINS' ;
'SI' ( XV3 'NEG' XTEST DX ) ;
IOK = VRAI ;
'MESSAGE' 'XV3';
'FINS' ;
'SI' ( YV3 'NEG' HS2 CRIT1 ) ;
IOK = VRAI ;
'MESSAGE' 'YV3';
'FINS' ;
*
'SI' ('NEG' GRAPH 'N' ) ;
LTI2 = 'CHAINE' 'Front 1D-h temps ' TTRA ;
'TITR' LTI2 ;
'DESS' AV2 'MIMA' ;
'FINS' ;
*
*-------------
FIN VISURESU ;
*-------------
*
*
'SI' ( IOK ) ;
'SINO' ;
'FINSI' ;
*
'FIN' ;
*
*
*=================
* POST-TRAITEMENT
*=================
					© Cast3M 2003 - Tous droits réservés.
					Mentions légales