* fichier : caculVF.dgibi ************************************************************************ ************************************************************************ ********************************************************************************** * LA SOLUTION ANALYTIQUE ********************************************************************************** ALF = 0.08D0 * 100.D0 ; KS = 5.85D-2 / 3600.D0 ; TS = 0.3D0 ; *TS = 1.D0; TR = 0.055D0 ; *TR = 0.0D0; TSR = TS - TR ; N = 2.0304D0 ; N1 = 1.D0/N ; MOINSN = (-1.D0)*N ; M = -0.5075D0 ; M1 = 1.D0/M ; BET = -0.029227D0 * 100.D0 ; nb = 300 ; H00 = -1.D-12 ; Hinf = -1.15D0 ; RA2PI = PI ** (-0.5D0) * 2.D0 ; *opti trac ps ; ******************************************** DEBPROC KKR_pro TT*FLOTTANT ; *K0 = (TT '-' TR) '/' TSR * ALF EXP * KS ; K0 = (TT '-' TR) '/' TSR ** ALF * KS ; FINPROC K0 ; ******************************************** ******************************************** DEBPROC HHT_pro H1*FLOTTANT ; T1 = H1 * BET ** N + 1.D0 ** m * TSR + TR ; FINPROC T1 ; ******************************************** ******************************************** DEBPROC TH_pro T1*FLOTTANT ; H1 = T1 - TR / TSR ** M1 - 1.D0 ** N1 / BET ; FINPROC H1 ; ******************************************** ******************************************** DEBPROC DHDT_pro H1*FLOTTANT T1*FLOTTANT ; DHDT0 = BET*(H1 '-' 1.D-13) ** MOINSN + 1. * (H1 '-' 1.D-13) / (T1 - TR) * N1 * M1 ; FINPROC DHDT0 ; ******************************************** ******************************************** DEBPROC KINPHI int00*FLOTTANT ; phi0 = 0. ; int0 = int00 ; repeter b1 (nb - 1); phi0 = 2. * d0 / int0 + phi0 ; int0 = int0 - phi0 ; fin b1 ; phi0 = 2. * d0 / iNT0 + phi0 ; FINPROC phi_p0 Int_p0 ; ******************************************** ******************************************** DT = T00 - TN0 / NB0 ; SI (EGA MO1 DEMI ) ; T = T00 - (dt*0.5) ; SINON ; T = T00 ; H = TH_pro T ; * K = KR_pro H ; K = KKR_pro T ; DHDT = DHDT_pro H T ; D = K*DHDT ; C = 1.D0/(DHDT '+' 1.D-10) ; T = T - DT ; FINSI; repe b0 nb0 ; H = TH_pro T ; * K = KR_pro H ; K = KKR_pro T ; DHDT = DHDT_pro H T ; D = K*DHDT ; C = 1./DHDT ; T = T - DT ; FIN B0 ; FINPROC h_pr0 K_pr0 D_pr0 C_pr0 T_pr0 ; ******************************************** ******************************************** DEBPROC A x*FLOTTANT ; si (x < 2.9 ) ; X2 = (-1.D0)*X*X ; sinon ; X2 = X ** (-2.D0) * -0.5D0 ; A0 = 108830.*X2+8162.*X2+706.*X2+74.*X2+10.*X2+2.*X2+1.; *A0 = 8162.*X2+706.*X2+74.*X2+10.*X2+2.*X2+1.; *A0 = 706.*X2+74.*X2+10.*X2+2.*X2+1.; *A0 = 74.*X2+10.*X2+2.*X2+1.; FINSI ; FINPROC A0 ; ******************************************** ******************************************** DEBPROC INTN phi*LISTREEL ; XX = PNM1 * 0.5D0 * (DD0 ** -0.5D0) ; IC0 = PNM1*0.5D0 + (2.D0*DD0/PNM1*(A XX)) ; FINPROC IC0 ; ******************************************** HN = HINF ; *KN = KR_pro HN ; LIST KN ; DN = KN*DHDTN ; CN = 1./DHDTN ; T0 = HHT_pro H00 ; DT = T0 - TN / NB ; h_prog K_prog D_prog C_prog T_prog = KPROG T0 TN NB 'TOTA'; *DESS TfH_evol MIMA TITX 'pression (m)' TITY 'T eau' ; *DESS KfH_evol MIMA LOGY TITX 'pression (m)' TITY 'KR (m/s)' ; *DESS CfH_evol MIMA TITX 'pression (m)' TITY 'C m' ; *DESS DfH_evol MIMA LOGY TITX 'pression (m)' TITY 'D m2/s' ; *DESS TfH_evol MIMA TITX 'teneur en eau' TITY 'T eau' ; *DESS KfH_evol MIMA LOGY TITX 'teneur en eau' TITY 'KR (m/s)' ; *DESS CfH_evol MIMA TITX 'teneur en eau' TITY 'C m' ; *DfH_evol = evol manu T_prog D_prog ; *DESS DfH_evol MIMA LOGY *TITR 'diffusivité fct(T)' *TITX 'teneur en eau' *TITY 'D m2/s' ; *OPTI TRAC X ; TN = HHT_pro Hinf ; db0 = 2.D0 / ((T01 - TN1) ** 2.D0) ; *-------------------------- Dmoy par D *-------------------------- calcul de I 1/2 (j = 1) *???????????????????????????????????? *-------------------------- Dmoy par K *-------------------------- calcul de I 1/2 (j = 1) *???????????????????????????????????? *Int = 1.e-3/(ts - tn)*nb ;list Int ; *Int = int * 2. ; *-------------------------- calcul de D (I + 1/2) h2_prog K2_prog D2_prog C2_prog T2_prog = KPROG T0 TN nb DEMI ; *-------------------------- calcul de PHI (I + 1/2) phi_prog Int_prog = KINPHI Int ; *I2_evol = evol manu phi_prog T_prog ; *DESS I2_evol ; *opti donn 5 ; *-------------------------- calcul de ICHA (N - 1/2) ICHA = INTN phi_prog ; *-------------------------- DELTA (J=1) *-------------------------- calcul de I 1/2 (j = 2) int1 = int ; Int = int1 - (DELTA * 0.5d0) ; deltI = Int - Int1 ; repeter b2 20 ; *-------------------------- calcul de PHI (I + 1/2) phi_prog Int_prog = KINPHI Int ; *-------------------------- calcul de ICHA (N - 1/2) ICHA = INTN phi_prog ; *-------------------------- DELTA (J=1) delta1 = DELTA ; *-------------------------- calcul de I 1/2 int1 = int ; *int = int1 - (DELTA * delta1 / (DELTA + delta1)) ; *int = int1 - (DELTA * deltI / (DELTA + delta1)) ; Int = int1 - (DELTA * 0.5d0 ) ; deltI = Int - Int1 ; si ( (DELTA abs) < (ICHA*1.e-6)) quitter b2 ; finsi; menage ; fin b2 ; *'LISTE' h_prog; *dess ( evol manu phi_prog T_prog); *dess ( evol manu phi_prog h_prog); nnlist = 2 * nlist; * on inverse l'axe des x *'ORDONNER' CROISSANT h_prog ; *'LISTE' h_prog; * il faut tronquer la derniere valeur de phi_prog et mettre * un grand nombre à la place. roro = 'ENLEVER' phi_prog nlist ; tabcool = 'TABLE' ; tabcool . 1 = 'TURQ'; tabcool . 2 = 'TURQ'; tabcool . 3 = 'TURQ'; tabcool . 4 = 'TURQ'; *********************************************************************************** * LE CAS TEST ********************************************************************************** ******************** CAS TEST : cacul.dgibi ************************ * * * Test de fonctionnement de DARCYSAT en 2D sans effet de gravité. * =================================================================== * Infiltration d'eau dans une colonne horizontale de sable uniformément * désaturé. * * - condition initiale : désaturation uniforme correspondant à une * succion de 1,15 m ; * - a l'instant initial, une extrémité de la colonne est noyée. * La frontière est supposée rester a pression nulle ; * * =================================================================== * Les options de modélisation declarées dans la table transmise à * la procédure DARCYSAT sont les suivantes : * * * - les effets gravitationnels ne sont pas pris en compte : pression = * charge (indice GRAVITE absent ; valeur par défaut : FAUX); * * - Une liste de temps de sauvegarde est fournie en valeur de l'indice * TEMPS_SAUVES ; * * - Le pas de temps est d'abord automatique (indice TEMPS_CALCULES absent) * L'utilisateur fournit * > le pas de temps initial (indice 'DT_INITIAL'), * > le nombre d'itérations recherché par pas de temps (indice 'NITER') * > le nombre de pas de temps (indice 'NPAS') * * - Le calcul est ensuite refais avec une liste de temps de calcul * donnée à l'indice TEMPS_CALCULES ; * * - L'homogenéisation spatiale des propriétes physiques s'effectue * par moyenne arithmétique des valeurs obtenues aux faces (indice * HOMOGENEISATION de valeur DECENTRE) * * cas test tiré du rapport DMT 97/25 : * "Implémentation dans CASTEM 2000 d'un modèle de transfert hydrique * en milieu poreux non saturé" * * ********************* CAS TEST : cacul.dgibi ************************ 'OPTION' 'ECHO' 1 ; 'SAUTER' 'PAGE'; * *'OPTION' 'ISOV' 'LIGN' ; *'TRACER' 'PSC' ; ************************************************************************ * Fonction qui calcule la perméabilité en fonction de la * saturation réduite. * * Loi puissance : * Perméabilité : K = Ks S^B * * Paramètres physiques à définir dans la table LOI : * -------------------------------------------------- * ALPHA : coef. B (s.d.) * PERMSAT : coef. Ks, perméabilité à saturation (m/s) * * Entrée : * -------- * LOI : table de données décrite ci-dessus * SAT : saturation réduite * * Sortie : * -------- * K1 : perméabilité totale en eau (m/s) * ************************************************************************ ************************************************************************ COMPLET = FAUX ; GRAPH = FAUX ; *-------------------------------------------------------------------- * Création maillage * *- Discrétisation : ENX = 1 ; ENY = 200 ; *- Création des points et des droites * A0 = -0.5 1.0D0; B0 = 0.5 1.0D0; A1 = -0.5 0.75D0; B1 = 0.5 0.75D0; A2 = -0.5 0.5D0 ; B2 = 0.5 0.5D0 ; A3 = -0.5 0.0D0; B3 = 0.5 0.0D0 ; *- Création des droites * AB0 = 'DROIT' ENX A0 B0 ; AB1 = 'DROIT' ENX A1 B1 ; AB2 = 'DROIT' ENX A2 B2 ; AB3 = 'DROIT' ENX A3 B3 ; *- Creation des surfaces * MASSIF0 = AB3 'REGLER' AB2 'REGLER' AB1; MASSIF0 = MASSIF0 'REGLER' AB0 ; ENTR = 'COULEUR' ('INVERSE' AB0) 'ROUGE' ; 'SI' GRAPH ; 'FINSI' ; *- Creation des maillages contenant tous les points * QFTOT = 'CHANGER' MASSIF0 'QUAF' ; QFENTR = 'CHANGER' ENTR 'QUAF' ; 'ELIMINATION' 0.00001 (QFTOT 'ET' QFSORT 'ET' QFENTR) ; *- Modèles * MODHYB = 'MODELE' QFTOT 'DARCY' 'ISOTROPE' ; MODENTR = 'MODELE' QFENTR 'DARCY' 'ISOTROPE' ; MODSORT = 'MODELE' QFSORT 'DARCY' 'ISOTROPE' ; *- Création ligne de suivi pour le post-traitement et le test * ligne des points centres (cas 1D) * 'REPETER' BCL (ENY - 1) ; IP = &BCL ; JP = IP + 1 ; PI = 'POINT' HYCEN IP ; PJ = 'POINT' HYCEN JP ; 'SI' (IP 'EGA' 1); 'SINON' ; 'FINSI' ; FIN BCL ; *-------------------------------------------------------------------- *- pression initiale (metre d'eau) dans le sable HN = -1.15 ; *-------------------------------------------------------------------- *- Conditions aux limites * GBM modifie supprime bloque *- frontière en limite du domaine de calcul (milieu désaturé) *- frontière mouillée *- chargement des CLs *-------------------------------------------------------------------- *- initialisation des inconnues * *- trace de charge d'eau *TH0 = 'MANU' 'CHPO' ('DIFF' CEENTR HYFAC) 1 'TH' HN 'NATURE' 'DISCRET'; *TH0 = TH0 + SIMPE ; *- charge d'eau *- flux * --------------------------- * = Table DARCY_TRANSITOIRE = * --------------------------- *- initialisation table SATUR = 'TABLE' ; SATUR. 'TEMPS' = 'TABLE' ; SATUR. 'CHARGE' = 'TABLE' ; SATUR . 'ITMAX' = 45; *- données géommétriques SATUR. 'SOUSTYPE' = 'DARCY_TRANSATUR' ; SATUR. 'MODELE' = MODHYB ; SATUR . 'XI' = 1.D-10; SATUR . 'COEF_EMMAGASINEMENT' = 0.D0 ; *- instant initial SATUR. 'TEMPS' . 0 = 0. ; SATUR. 'CHARGE' . 0 = H0 ; ********************************************* *- conditions aux limites et chargements SATUR . 'TRACE_IMPOSE' = VALI0 ; SATUR . 'TYPDISCRETISATION' = 'VF' ; TABRES = table METHINV; TABRES . 'TYPINV' = 2; TABRES . 'PRECOND' = 5; SATUR . 'METHINV' = TABRES; SATUR . 'METHINV' . RESID = 1.D-20; ******************************************* ******************************************* *- données physiques * loi de perméabilité LoiP = 'TABLE' 'PUISSANCE'; LoiP. 'ALPHA' = 8.D0 ; LoiP. 'PERMSAT' = 5.85E-2 / 3600. ; SATUR.'LOI_PERMEABILITE' = 'TABLE' LoiP ; * loi de succion LoiS = 'TABLE' 'VAN_GENUCHTEN'; LoiS. 'PORO' = 0.3 ; *LoiS. 'PORO' = 1. ; LoiS. 'TERESIDU' = 0.055 ; *LoiS. 'TERESIDU' = 0.0 ; LoiS. 'NEXP' = 2.0304 ; *LoiS. 'NEXP' = 1.D0 ; LoiS. 'MEXP' = 0.5075 ; *LoiS. 'MEXP' = -1.D0 ; LoiS. 'BHETA' = 0.029227 * 100. ; SATUR.'LOI_SATURATION' = 'TABLE' LoiS ; *- données numériques 'SI' (COMPLET) ; SATUR. 'TEMPS_FINAL' = 10000.D0 ; 'REPETER' bbb 4 ; tfin = 2500.D0 * &bbb ; * var de Boltzman znew = xabs '/' (tfin '**' 0.5D0); 'ORDONNER' CROISSANT ress; 'SI' ('EGA' &bbb 1) ; 'SINON' ; courb = courb 'ET' 'FINSI' ; 'FIN' bbb; TAB1 = 'TABLE' ; TAB1 . 'TITRE' = 'TABLE' ; TAB1 . 'TITRE' . 1 = 'exacte 2500' ; TAB1 . 'TITRE' . 2 = 'exacte 5000' ; TAB1 . 'TITRE' . 3 = 'exacte 7500' ; TAB1 . 'TITRE' . 4 = 'exacte 10000' ; TAB1 . 1 = 'TIRR '; TAB1 . 2 = 'TIRR '; TAB1 . 3 = 'TIRR '; TAB1 . 4 = 'TIRR '; 'SINON' ; 'REPETER' bbb 4 ; tfin = 500.D0 * &bbb ; * var de Boltzman znew = xabs '/' (tfin '**' 0.5D0); 'ORDONNER' CROISSANT ress; 'SI' ('EGA' &bbb 1) ; 'SINON' ; courb = courb 'ET' 'FINSI' ; 'FIN' bbb; TAB1 = 'TABLE' ; TAB1 . 'TITRE' = 'TABLE' ; TAB1 . 'TITRE' . 1 = 'exacte 500' ; TAB1 . 'TITRE' . 2 = 'exacte 1000' ; TAB1 . 'TITRE' . 3 = 'exacte 1500' ; TAB1 . 'TITRE' . 4 = 'exacte 2000' ; TAB1 . 1 = 'TIRR '; TAB1 . 2 = 'TIRR '; TAB1 . 3 = 'TIRR '; TAB1 . 4 = 'TIRR '; SATUR. 'TEMPS_FINAL' = 2000.D0 ; 'FINSI' ; SATUR. 'HOMOGENEISATION' = 'CHAINE' 'DECENTRE' ; SATUR. 'NPAS' = 4000 ; SATUR. 'RESIDU_MAX' = 1.D-4 ; SATUR. 'NITER' = 10 ; SATUR. 'DT_INITIAL' = 1.D0 ; 'SI' COMPLET ; 'SINON' ; 'FINSI' ; *SATUR. 'TEMPS_CALCULES' = ('PROG' 1 'PAS' 1 10.)*360. ; SATUR. 'MESSAGES' = 2 ; 'SI' GRAPH ; *-------------------------------------------------------------------- *- Vérification du choix du dp minimum pour le calcul de la capacité. * droite support des variables dx = 'DROIT' (0. -1.15 ) 1000 (0. 0.) ; * calcul de la teneur en eau pour la pression zc 'DESSIN' evt 'TITX' 'Pc(m)' 'TITY' 'S(%)' 'TITRE' 'Loi capillaire S(Pc)' ; * calcul de la teneur en eau pour la pression zc - dp dp = 1.e-4 ; * représentation de la capacité c1 = (t0 - t1) / dp; 'TITRE' 'Capacite capillaire' ; 'FINSI' ; * =========================== * | 1er CALCUL | * =========================== *- fonctionnement avec temps automatiques DARCYSAT SATUR ; * Post-traitement * =============== TDES . 5 = 'TABLE' ; TDES . 5 . LEGEND2 = TAB1 . TITRE . 1; TDES . 5 . LEGEND1 = ' ' ; TDES . 6 = 'TABLE' ; TDES . 6 . LEGEND2 = TAB1 . TITRE . 2; TDES . 6 . LEGEND1 = ' ' ; TDES . 7 = 'TABLE' ; TDES . 7 . LEGEND2 = TAB1 . TITRE . 3; TDES . 7 . LEGEND1 = ' ' ; TDES . 8 = 'TABLE' ; TDES . 8 . LEGEND2 = TAB1 . TITRE . 4; TDES . 8 . LEGEND1 = ' ' ; 'SI' GRAPH ; 'FINSI' ; * On compare l'integrale de la saturation au temps final entre les * solutions analytiques et non analytiques. err = 'ABS' (inta '-' intb '/' inta); 'LISTE' err; 'SI' (err > 7.D-2) ; 'ERREUR' 5; 'FINSI' ; 'FIN';
© Cast3M 2003 - Tous droits réservés.
Mentions légales