* fichier : darcy3VF.dgibi ************************************************************************ ************************************************************************ * ************************** CAS TEST : darcy3.dgibi ****************** * GRAPH = 'N' ; 'SAUT' 'PAGE' ; NITER = 40 ; * *------------------------------------------------------------------- * TEST DARCY3 * CALCUL DARCY ORTHOTROPE 3D * * TEST de TRANGEOL en VF * * On effectue trois calculs sur un cube, maillé par des cubes * réguliers. * Les conditions aux limites varient suivant le cas considéré : * On impose le flux ou la charge sur les cotés du domaine. * * La solution analytique en charge est un polynome de degré un, * la vitesse est constante et la conductivité hydraulique orthotrope. * __ __ * | | * | 1 0 0 | * K = | 0 3/4 0 | * | 0 0 1/2 | * |__ __| * * H(x,y,z) = -45 x -80 y -60z + 200. * V(x,y,z) = ( 45 ; 60 ; 30 ) * * On s'attend à une précision de l'ordre de la précision machine. * LE calcul est effectué comme limite d'un instationnaire pour * tester TRANGEOL dans une boucle * *------------------------------------------------------------------- * 'SAUT' 'PAGE' ; * *- Options générales de calcul. * * * ------------ * = MAILLAGE = * ------------ OEIL = 5.D0 6.D0 7.D0 ; VECX = 1.D0 0.D0 0.D0 ; VECY = 0.D0 1.D0 0.D0 ; VECZ = 0.D0 0.D0 1.D0 ; * ENX = 6 ; ENY = 6 ; ENZ = 6 ; DX = 1.D0 / ENX ; DY = 1.D0 / ENY ; DZ = 1.D0 / ENZ ; * *- Création des points * A0 = 0.D0 0.D0 0.D0 ; B0 = 1.D0 0.D0 0.D0 ; C0 = 1.D0 1.D0 0.D0 ; D0 = 0.D0 1.D0 0.D0 ; E0 = 0.D0 0.D0 1.D0 ; F0 = 1.D0 0.D0 1.D0 ; G0 = 1.D0 1.D0 1.D0 ; H0 = 0.D0 1.D0 1.D0 ; * *- Création des droites * * * *- Creation des faces du cube * * *- Création maillage géométrique * ENXM = ENX + ENY + ENZ ; ELI0 = 1.D0 / ENXM / 10.D0 ; 'SINON' ; 'ET' SGAU 'ET' SDRO) ; 'FINSI' ; QFTOT = CHANGE CUBE1 QUAF ; QFGAU = CHANGE SGAU QUAF ; QFDRO = CHANGE SDRO QUAF ; QFHAU = CHANGE SHAU QUAF ; QFBAS = CHANGE SBAS QUAF ; QFDEV = CHANGE SDEV QUAF ; QFDER = CHANGE SDER QUAF ; QFDER ) ; * *- Création maillage HYBRIDE et sous-objets (conditions aux limites) * * *- Solution analytique * * VKX = 1.D0 ; VKY = 0.75D0 ; VKZ = 0.5D0 ; VVKX = CHANGER ATTRIBUT VVKX 'NATU' DISCRET ; VVKY = CHANGER ATTRIBUT VVKY 'NATU' DISCRET ; VVKZ = CHANGER ATTRIBUT VVKZ 'NATU' DISCRET ; AA = -45.D0 ; BB = -80.D0 ; CC = -60.D0 ; DD = 200.D0 ; AAA = -1.D0 * VKX * AA ; BBB = -1.D0 * VKY * BB ; CCC = -1.D0 * VKZ * CC ; * PANAF = (AA * XX) + (BB * YY) + (CC * ZZ) + DD ; PANAC = (AA * XXC) + (BB * YYC) + (CC * ZZC) + DD ; 'VY' BBB 'VZ' CCC ; 'VY' BBB 'VZ' CCC ; * * -------------- * = RESOLUTION = * -------------- * * ; *- Conditions aux limites * * *- TH imposée * * *- Flux imposé * * * *- Assemblage et résolution en TH * h_lim = 'RESOUD' (BBGAU 'ET' BBDEV) (EEGAU 'ET' EEDEV) ; CHCLIM = TABLE; 'ET' FLDRO 'ET' FLDER)); GEOL1 = TABLE; GEOL1 . 'TYPDISCRETISATION' = 'VF' ; GEOL1 . 'THETA_DIFFUSION' = 1.0D0 ; GEOL1 . 'THETA_CONVECTION' = 1.0D0 ; GEOL1 . 'DECENTREMENT' = FAUX ; GEOL1 . 'DELTAT' = 10.D0 / NITER ; GEOL1 . 'DIFFUSIVITE' = mati3 ; GEOL1 . 'SOLVEUR' = 3 ; GEOL1 . 'PRECONDITIONNEUR' = 3 ; GEOL1 . 'CLIMITES' = CHCLIM ; GEOL1 . 'RECALCUL' = VRAI ; * * boucle transitoire REPE blocc NITER ; GEOL1 . 'RECALCUL' = FAUX ; FIN blocc; * *- Calcul de V * VFACE3 = QFACE3 * CHYB2 / CHYB1 ; * * ----------------- * = Calcul ERREUR = * ----------------- * ERReur relative en charge H au centre des éléments * Erreur relative sur la vitesse au centre des éléments * ERRP3 = ERRP3 - PANAC / PANAC ; ERRP3 = 'ABS' ERRP3 ; * * VD3 = VANAC - VCENT3 ; SDC3 = 'ABS' ( VC3 / VDVD ) ; SDC3 = SDC3 '**' 0.5 ; * * ------------------- * = Tracé resultats = * ------------------- 'SI' ('NEG' GRAPH 'N') ; * *- Transformation des quantités aux centres en MCHAML constant. * * * L'erreur relative sur la charge au centre * L'erreur relative sur la Vitesse au centre * 'TRAC' MODHYB ERRP3 ; 'TRAC' MODHYB SDS3 ; * 'FINSI' ; * * ------------------- * = Gestion ERREURS = * ------------------- * 'SAUT' 'PAGE' ; 'MESS' ' ERREURS RELATIVES ' ; 'MESS' ' cas test H V' ; 'MESS' ' numero3 ' maxp3 ' ' maxv3 ; * EPS0 = 1.D-7 ; LOG6 = MAXP3 > EPS0 ; LOG9 = MAXV3 > EPS0 ; LP0 = LOG6 ; LV0 = LOG9 ; L0 = LP0 'OU' LV0 ; 'SI' ( L0 ) ; 'SINO' ; 'FINSI' ; * 'FIN' ;
© Cast3M 2003 - Tous droits réservés.
Mentions légales