* T_PITETA PROCEDUR JC220346 12/09/12 21:15:08 7501 * *|=====================================================================| *| | *| OBJET : | *| ======= | *| | *| 1) calculer la derivee seconde de l'energie potentielle vis a vis | *| de la longueur d'une (ou des) fissure(s) intéragissantes. dG/da | *| (G = taux de restitution d'énergie, a = longueur le la fissure) | *| pour etudier éventuellement la stabilite de propagation d'une | *| (ou des) fissure(s). | *| 2) calculer une intégrale permettant de decouper les modes mixtes. | *| Dans ce cas, la procedure, appelée par G_THETA, ne fonctionne | *| qu'en elasticite pour problèmes de configuration en 2D, 3D ou | *| axisymetrique modèlisés par éléments dits massifs. Seuls les | *| materiaux homogenes et isotropes sont acceptables. L'application | *| du chargement peut etre de type mecaniques, thermiques, forces | *| volumiques, ou/et pressions sur le fond de la fissure. | *| | *| | *| ENTREE : | *| ======== | *| | *| Arquments obliquatoires : | *| ------------------------- | *| | *| OBJMOD objet du type TABLE stockant tous les objets MODELS | *| sur une petite zone de maillage entourant le plus grand des | *| contours qu'on a defini pour calculer dG/da. L'indice | *| de cette table est 1, 2, 3,...,n (n : nombre de modeles | *| dans la petite zone de maillage). Si l'on n'a pas prevu des | *| modeles dans cette petite zone, OBJMOD ici doit contenir | *| les objets MODELS globales du problems utilises dans la | *| resolution par elements finis. Dans ce cas le support | *| maillage de l'ensemble de modeles est la structure totale | *| etudiee. | *| MATERI Objet MCHAML de sous-type CARACTERISTIQUES donnant les | *| propriétés matérielles (module Young, coefficient de | *| Poisson...) + les proprietes geometriques dans le cas | *| des elements en coque mince (epaisseur, excentrement...). | *| Les composantes de MATERI peuvent etre des objets de type | *| FLOTTANT, MCHAML, EVOLUTIO, NUAGE selon le probleme traité. | *| Il convient de donner ici le materiau total du probleme | *| englobant toute la structure. | *| SUPTAB Objet de type TABLE. | *| En entrée, SUPTAB sert à définir les options et les | *| paramètres du calcul. Ses indices sont des objets de type | *| MOTS (à écrire en toutes lettres) dont voici la liste: | *| | *| SUPTAB.CHTHETA = CHPOINT (TABLE en 3D) de deplacement cree | *| par la procedure CH_THETA. | *| SUPTAB.DEPLACEMENT = TABLE si le calcul est effectue pas a pas, | *| CHPOINT si en un seul pas (probleme lineaire). | *| Dans le premier cas SUPTAB.DEPLACEMENT | *| contient touts les deplacements en indice | *| de la definition des valeurs du parametre | *| d'evolution (ex : table RESUDEPL de NONLIN). | *| SUPTAB.CONTRAINTE = TABLE si le calcul est effectue pas a pas, | *| MCHAML si en un seul pas (probleme lineaire). | *| Dans le premier cas SUPTAB.CONTRAINTE contient | *| toutes les contraintes en meme indice du | *| parametre d'evolution que la table | *| SUPTAB.DEPLACEMDNT (ex : table RESUCONT de | *| NONLIN). | *| | *| | *| Arquments facultatifs : | *| ----------------------- | *| | *| 1 : Probleme non-lineaire (elasto ou visco-plasticite) | *| | *| SUPTAB.VARINTERNE = TABLE. Pour les calculs non-lineaires effectues | *| pas a pas, elle donne les variables internes | *| en meme indice d'evolution que les tables | *| SUPTAB.DEPLACEMENT ou SUPTAB.CONTRAINTE | *| (ex : table RESUVARI de NONLIN). Cette table | *| est fournie dans le cas ou les deformations | *| inelastiques ne sont pas nulles, sinon | *| le probleme est considere comme lineaire. | *| | *| 2 : En thermo-mecanique | *| | *| SUPTAB.TEMPERATURE = TABLE pour les calculs effectues pas a pas, | *| CHPOINT si en un seul pas (probleme lineaire). | *| Dans le premier cas SUPTAB.TEMPERATURE | *| contient toutes les temperatures absolutes | *| en indice d'evolution du parametre de temps, | *| qui doit etre plus large ou egale a celle des | *| tables SUPTAB.DEPLACEMENT ou SUPTAB.CONTRAINTE | *| (ex : table CHPOTHETA utilisee dans NONLIN). | *| SUPTAB.TREFERENCE = CHPOINT de temperature de reference (ex : | *| chpoint TREFERENCE utilisee dans NONLIN). | *| | *| 3 : En presence de pression ou/et force volumique | *| agissant dans un voisinage du fond de la fissure | *| | *| SUPTAB.PRESSION = Objet de type CHPOINT ou CHARGEMENT, requis dans | *| dans le cas ou il existe une force volumique | *| ou/et une pression s'exercant dans un voisinage | *| du fond de la fissure. Si cette force varie avec | *| le temps on donne un objet de type CHARGEMENT. | *| SI cette force reste constante, on donne un | *| un objet de type CHPOINT | *| | *| 4 : En cas de calcul de la derivee seconde de l'energie permet- | *| tant d'etudier la stabilite de propagation des fissures | *| | *| SUPTAB.CHPI = CHPOINT (TABLE en 3D) de deplacement cree | *| par la procedure CH_THETA. | *| SUPTAB.RITOTA = RIGIDITE. C'est la rigidité complète de la | *| structure, y compris les conditions aux limites | *| de type DEPLACEMENT ou ROTATION. | *| | *| 5 : En cas de calcul de la derivee seconde de l'energie | *| avec une autre solution auxilaire (intégrale permettant, | *| par exemple, de decouper les modes) | *| | *| SUPTAB.'DEPL_AUXI' = Solution auxilaire de deplacement (CHPOINT) | *| SUPTAB.'CONT_AUXI' = Solution auxilaire de contrainte (MCHAML) | *| SUPTAB.'PRES_AUXI' = Pression auxilaire si elle applique sur le | *| voisinage du fond de la fissure (CHPOINT) | *| | *| | *| 6 : Pour un front de fissure tridimensionnel | *| | *| SUPTAB.'AVANCE' = MAILLAGE pour donner les points du front pour | *| lesquels le calcul sera effectue. Si cet | *| argument est absent, le calcul sera fait pour | *| tous les noeuds sur le front de la fissure. | *| | *| 7 : En cas d'existence de plusieurs materiaux | *| | *| SUPTAB.'PARALLELE' = VRAI si la fissure est parallele a l'interface | *| FAUX sinon . | *| | *| SORTIE : | *| ======== | *| | *| Dans tous les cas de calcul | *| --------------------------- | *| | *| SUPTAB.'DGDA' = En 2D, une table si le calcul est effectue pas a | *| pas, flottant si en un seul pas. Dans le premier | *| cas, dG/da est en meme indice d'evolution du | *| parametre de temps que celle des tables | *| SUPTAB.DEPLACEMENT ou SUPTAB.CONTRAINTE (ou | *| SUPTAB.VARINTERNE en elasto ou visco-plasticite). | *| En 3D, si le calcul est realise pas a pas | *| SUPTAB.'DGDA' est indicee par deux parametres dont | *| le premier est le facteur d'evolution de temps et | *| le deuxieme les points sur le front de la fissure. | *| Pour un calcul realise en un seul pas SUPTAB.G a | *| une seule indice representant les points sur le | *| front de la fissure. | *| Exemple : la valeur de dG/da est | *| en 2D pour un calcul realise pas a pas a l'instant | *| T1, (SUPTAB.'DGDA'.T1) | *| en 2D pour un calcul en un seul pas, (SUPTAB.'DGDA')| *| en 3D au point P1 pour un calcul realise pas a pas | *| a l'instant T1 et, (SUPTAB.'DGDA'.T1.P1) | *| en 3D au point P1 pour un calcul realise en un seul | *| pas, (SUPTAB.'DGDA'.P1) | *| SUPTAB.'IERR' = logique egale a VRAI si l'on n'a pas reussit le | *| calcul ou les donnees sont fautes, sinon | *| SUPTAB.'IERR' vaut FAUT. | *| | *| En cas de calcul effectue pas a pas | *| ----------------------------------- | *| | *| SUPTAB.EVOLDGDA En cas de calcul de la variation seconde | *| d'énergie, SUPTAB.EVOLDGDA est un objet de type | *| EVOLUTION donnant la valeur de dG/da en fonction | *| du temps en elasto-plasticite. Pour un front de | *| fissure tridimensionnel EVOLDGDA est une table | *| indicee par les points donnant les evolutions de | *| dG/da pour chaque point en fonction du temps. | *| Exemple : En 2D, on peut tracer l'evolution de | *| dG/da par : DESS (SUPTAB.'EVOLDGDA'); | *| En 3D, on peut tracer l'evolution de dG/da | *| au point P1 en fonction du temps par : | *| DESS (SUPTAB.'EVOLDGDA'.P1); | *|=====================================================================| * **** **** 'SI' ('>' NBOBJ 1) ; 'REPETER' NBJ1 (NBOBJ - 1); I = I + 1; OBJMOD = OBJMOD 'ET' TABMOD.I; 'FIN' NBJ1; 'FINSI' ; **** ILIN = 'EGA' NBNO1 2; IQUA = 'EGA' NBNO1 3; ************************************************** ********* TEST DE COMPABILITE DES DONNEES ******** ************************************************** SUPTAB.'IERR' = FAUX; 'MESS' 'ERREUR : LE SUPPORT GEOMETRIQUE DE MATERIAU EST'; 'FINSI'; 'MESS' 'ERREUR : LE SUPPORT GEOMETRIQUE DE MATERIAU EST'; 'FINSI'; **** IAUXI = ('EXIST' SUPTAB 'DEPL_AUXI') 'OU' ('EXIST' SUPTAB 'CONT_AUXI') 'OU' ('EXIST' SUPTAB 'PRES_AUXI'); 'SI' IAUXI; 'SI' ('NON' ('EXIST' SUPTAB 'DEPL_AUXI')); 'ERREUR' 'ON VEUT LA SOLUTION AUXILAIRE DE DEPLACEMENT'; 'FINSI'; 'SI' ('NON' ('EXIST' SUPTAB 'CONT_AUXI')); 'ERREUR' 'ON VEUT LA SOLUTION AUXILAIRE DE CONTRAINTE'; 'FINSI'; 'FINSI'; IPRE_A = FAUX; 'SI' ('EXIST' SUPTAB 'PRES_AUXI'); PRES_A = SUPTAB.'PRES_AUXI'; IPRE_A = VRAI; 'FINSI'; **** 'SI' ('NON' ('EXISTE' SUPTAB 'CONTRAINTE')); 'ERREUR' 'IL FAUT DONNER LE CHAMP DE CONTRAINTE'; 'FINSI'; 'SI' ('NON' ('EXISTE' SUPTAB 'DEPLACEMENT')); 'ERREUR' 'IL FAUT DONNER LE CHAMP DE DEPLACEMENT'; 'FINSI'; 'SI' ('EXISTE' SUPTAB 'PARALLELE'); 'SI' (NBOBJ 'EGA' 1); 'ERRE' 'IL FAUT UNE TABLE STOCKANT TOUS LES OBJETS MODELES'; 'FINSI'; IPARAL = SUPTAB.'PARALLELE'; 'SINON'; IPARAL = FAUX; 'FINSI'; 'SI' IPAP; 'SI' ('NON' ('EXISTE' SUPTAB 'VARINTERNE')); *& 'MESS' ' ATTENTION : EN ABSENCE DES VARIABLES INTERNES'; *& 'MESS' ' LE PROBLEME EST CONSIDERE COMME LINEAIRE.'; 'FINSI'; 'FINSI'; 'SI' ('NON' ('EXISTE' SUPTAB 'CHTHETA')); 'ERREUR' 'IL FAUT DONNER LE CHAMP THETA'; 'FINSI'; **** ISECO = ('EXIST' SUPTAB 'CHPI') 'OU' ('EXIST' SUPTAB 'RITOTA'); 'SI' ISECO; 'SI' ('NON' ('EXIST' SUPTAB 'CHPI')); 'ERREUR' 'IL FAUT DONNER LE CHAMP PI'; 'FINSI'; 'SI' ('NON' ('EXIST' SUPTAB 'RITOTA')); 'ERREUR' 'IL FAUT DONNER LA RIGIDITE COMPLETE'; 'FINSI'; RITOTA = SUPTAB.'RITOTA'; 'FINSI'; **** 'SI' (('NON' IAUXI) 'ET' ('NON' ISECO)); 'ERREUR' 'LES DONNEES NE SONT PAS COMPLETES'; 'FINSI'; 'SI' (IAUXI 'ET' ISECO); 'FINSI'; **** PASA = FAUX; ITHER = ('EXIST' SUPTAB 'TEMPERATURE') 'OU' ('EXIST' SUPTAB 'TREFERENCE'); 'SI' ITHER; 'SI' ('NON' ('EXIST' SUPTAB 'TEMPERATURE')) ; 'ERREUR' 'ON VEUT LA CARTE DE TEMPERATURE'; 'FINSI' ; 'SI' ('NON' ('EXIST' SUPTAB 'TREFERENCE')) ; 'ERREUR' 'ON VEUT LA TEMPERATURE DE REFERENCE'; 'FINSI' ; 'SI' ('EXIST' (SUPTAB.'TEMPERATURE') 'T ') ; PASA = VRAI; 'FINSI'; 'FINSI'; 'FINSI' ; **** IPRES = FAUX; 'SI' ('EXIST' SUPTAB 'PRESSION') ; PRESSI = SUPTAB.'PRESSION'; IPRES = VRAI ; 'FINSI' ; **** **** YOUVARI = FAUX; NUVARI = FAUX; ALFVARI = FAUX; TRAVARI = FAUX; SIGVARI = FAUX; HVARI = FAUX; 'REPETER' BCMOD1 NBOBJ; 'SI' ('EGA' TYPYO 'EVOLUTIO'); YOUVARI = VRAI; 'SINON'; 'SI' ((TEST1 '>' 1.E-10) ET (NON IPARAL)); YOUVARI = VRAI; 'FINSI'; 'FINSI'; 'SI' ('EGA' TYPNU 'EVOLUTIO'); NUVARI = VRAI; 'SINON'; 'SI' ((TEST1 '>' 1.E-10) ET (NON IPARAL)); NUVARI = VRAI; 'FINSI'; 'FINSI'; 'SI' ITHER; 'SI' ('EGA' TYPAL 'EVOLUTIO'); ALFVARI = VRAI; 'SINON'; 'SI' (TEST1 '>' 1.E-10); ALFVARI = VRAI; 'FINSI'; 'FINSI'; 'FINSI'; 'SI' ('EGA' TYPTR 'NUAGE '); TRAVARI = VRAI; 'FINSI'; 'FINSI'; 'SI' ('EXIST' MATI 'SIGY'); 'SI' ('EGA' TYPSI 'EVOLUTIO'); SIGVARI = VRAI; 'FINSI'; 'FINSI'; 'SI' ('EXIST' MATI 'H'); 'SI' ('EGA' TYPH 'EVOLUTIO'); HVARI = VRAI; 'FINSI'; 'FINSI'; 'FIN' BCMOD1; MATVARI = YOUVARI 'OU' NUVARI 'OU' ALFVARI 'OU' TRAVARI 'OU' SIGVARI 'OU' HVARI; 'SI' MATVARI; 'ERREUR' 'MATERIAU NON CONSTANT. OPTION NON DISPONIBLE'; 'FINSI'; **** 'SI' IPAP; 'SINON'; 'FINSI'; ************************************************** *** QUELQUES MOTS POUR SIMPLIFIER L'ECRITURE *** ************************************************** 'FINSI'; 'FINSI'; **** TX2 = 'CHAIN' ' Contribution a la derivee dG/da due au chargement'; 'SI' ITHER; 'SINON'; 'FINSI'; TX3 = 'CHAIN' ' °°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°°'; *************************************************** ********** DEPLACEMENT, GRADIANT INITIAUX ********* *************************************************** ******************************************** *** ZONE OU LE CHAMP THETA N'EST PAS NUL *** ******************************************** 'FINSI'; 'FINSI'; TETA = TETA + DEP000; NORM1 = ((E MU1 TETA 'SCAL')**2) + ((E MU2 TETA 'SCAL')**2); NORM1 = NORM1 + ((E MU3 TETA 'SCAL')**2); 'FINSI'; *************************************************** ***** INDICE DE TEMPERATURE RANGEE DENA LTHER ***** *************************************************** 'SI' ('NON' PASA) ; 'SI' (ITHER 'ET' IPAP) ; TEPER*'TABLE'= SUPTAB.'TEMPERATURE'; IT = 1 ; 'REPETER' TEPERATU ; IT = IT + 1 ; 'SI' ('EXISTE' ITET IT) ; LTHER = LTHER 'ET' VALTET ; 'SINON' ; 'QUITTER' TEPERATU ; 'FINSI' ; 'FIN' TEPERATU ; LTHER = 'ORDONNER' LTHER ; 'FINSI' ; 'FINSI' ; *************************************************** ********* TABLES POUR STOCKER LES RESULTATS ******* *************************************************** SUPTAB.'DGDA' = TABLE; *************************************************** **************** AFFICHAGE DU TITRE ************** *************************************************** 'SI' IPAP; 'SI' ISECO; 'MESS' ' ' TX1; 'MESS'; 'MESS' ' Instant ' TXMECANI TXTERMI TXPRESS MOTCO; 'FINSI'; 'FINSI'; 'SI' ISECO; 'MESS' ' ' TX1; 'MESS'; 'MESS' ' Noeuds ' ' Instant ' TXMECANI TXTERMI TXPRESS MOTCO; 'FINSI'; 'FINSI'; 'SINON'; 'SI' ISECO; 'FINSI'; 'FINSI'; 'SI' ISECO; 'FINSI'; 'FINSI'; 'FINSI'; **** 'SI' ('NON' IPAP); NBDEP = 1; 'SINON'; SIG*'TABLE' = SUPTAB.'CONTRAINTE' ; DEP*'TABLE' = SUPTAB.'DEPLACEMENT' ; 'SI' ('EXIST' SUPTAB 'VARINTERNE'); VAR*'TABLE' = SUPTAB.'VARINTERNE'; 'SINON'; VAR = TABLE; 'FINSI'; 'FINSI'; *************************************************** *************************************************** ********* BOUCLE SUR LE PAS DE CALCUL ********* *************************************************** *************************************************** IABC = 0 ; 'REPETER' BOUCEXT NBDEP ; IABC = IABC + 1 ; S10 = 0.; S20 = 0.; S30 = 0.; S40 = 0.; S50 = 0.; S60 = 0.; S70 = 0.; S80 = 0.; S90 = 0.; S100 = 0.; S110 = 0.; S120 = 0.; S130 = 0.; S140 = 0.; *************************************************** ***** DEPLACEMENT,CONTRAINTE A L INSTANT INST ***** *************************************************** 'SI' IPAP; INST = IDEP.IABC ; 'SI' ('EXIST' VAR INST); 'SINON'; 'FINSI'; 'FINSI'; *************************************************** *********** TEMPERATURE A L INSTANT INST ********** *************************************************** 'SI' ITHER ; 'SI' IPAP; 'SI' PASA ; 'SINON'; K = 0 ; 'REPETER' BLOC1 NBTET ; K = K + 1 ; 'SI' (NBRE '>EG' INST) ; 'QUITTER' BLOC1 ; 'FINSI' ; 'FIN' BLOC1 ; K = K - 1 ; 'SI' (> ('ABS' ((NBRE-INST)/INST)) 0.001) ; D1 = INST - NBRE1 ; D2 = NBRE2 - INST ; 'SINON'; 'FINSI'; 'FINSI'; 'SINON'; 'FINSI'; 'FINSI'; *************************************************** ************ MATERIAU A L INSTANT INST ************ *************************************************** 'SI' (MATVARI 'ET' ITHER); 'SINON'; MAT1 = MATREDU; 'FINSI'; *************************************************** ************ GRADIENT A L INSTANT INST ************ *************************************************** 'SI' ITHER; 'SI' ISECO; DEPDT = (E GR1 TEPEGR MU1) + (E GR2 TEPEGR MU2); DEPDT = DEPDT + (E GR3 TEPEGR MU3); 'FINSI'; 'FINSI'; 'FINSI'; ******************************************************* **** ENERGIE DE DEFORMATION ELASTIQUE ET PLASTIQUE **** ******************************************************* 'SI' IPAP; 'SI' ('EGA' IABC 1); WPLAS = 0.5*VMI1*(E VARF 'EPSE') ; 'SINON' ; SIGMOY = 0.5*(SIG1 + SIGF); WPLAS = WPLAS + (VMI1*(E (VARF - VAR1) 'EPSE')); 'FINSI' ; ENERM = WELAS + WPLAS ; SIG1 = SIGF; VAR1 = VARF; 'SINON'; ENERM = WELAS; 'FINSI'; **************************************************** ********** RECUPERATION DU POINT A AVANCER ********* **************************************************** 'SI' IPAP; SUPTAB.'DGDA'.INST = TABLE; 'FINSI'; TTETA*'TABLE' = SUPTAB.'CHTHETA'; 'SI' ISECO; TPI*'TABLE' = SUPTAB.'CHPI'; 'FINSI'; INT = 'INDEX' TTETA; 'SI' IPARTI; 'SINON'; PMA = SUPTAB.'AVANCE'; NBOU = 2; 'FINSI'; 'SINON'; 'FINSI'; 'FINSI'; NBOU = 1; 'FINSI'; ************************************************** ******** BOUCLE SUR LES POINTS A AVANCER ******* ************************************************** 'REPETER' BCNOEU NBOU; 'SI' (&BCNOEU 'EGA' NBOU); 'SINON'; PM = INT.&BCNOEU; 'SI' IPARTI; 'SINON'; PM = SUPTAB.'AVANCE'; 'FINSI'; 'FINSI'; 'FINSI'; TETA = TTETA.PM; 'SI' ISECO; PI = TPI.PM; 'FINSI'; 'FINSI'; TETA = SUPTAB.'CHTHETA'; 'SI' ISECO; PI = SUPTAB.'CHPI'; 'FINSI'; 'FINSI'; ************************************************** ***** GRADIANT DU CHAMP THETA ET DU CHAMP PI ***** ************************************************** TETA = TETA + DEP000; DIVTETA = (E GR1 TETAGR S)+(E GR5 TETAGR S)+(E GR9 TETAGR S); 'FINSI'; 'SI' ISECO; PI = PI + DEP000; DIVPI = (E GR1 PIGR S)+(E GR5 PIGR S)+(E GR9 PIGR S); PITAGR = (OBJMOD PIGR * TETAGR) ; DIVPITA = (E GR1 PITAGR S)+(E GR5 PITAGR S)+(E GR9 PITAGR S); ADJ = (DIVPITA - (DIVPI * DIVTETA)) ; 'FINSI'; 'FINSI'; ********************************************************* ***************** TEMU = (Grad T)*THETA ***************** ****************** TEMU1 = (Grad T)*PI ****************** *********** TEMU2 = (Grad (Grad T))*PI*THETA ************ ********************************************************* 'SI' ITHER; TEMU = ((E GR1 TEPEGR S)*OBJMOD TETX) + ((E GR2 TEPEGR S)*OBJMOD TETY) ; TEMU = TEMU + ((E GR3 TEPEGR S)*OBJMOD TETZ); 'FINSI' ; 'SI' ISECO; TEMU1 = ((E GR1 TEPEGR S)*OBJMOD PIX) + ((E GR2 TEPEGR S)*OBJMOD PIY); TXXPIX = (E GR1 DEPDTGR S)*OBJMOD PIX; TYXPIY = (E GR2 DEPDTGR S)*OBJMOD PIY; TXYPIX = (E GR4 DEPDTGR S)*OBJMOD PIX; TYYPIY = (E GR5 DEPDTGR S)*OBJMOD PIY; TEMU2 = (TETX*OBJMOD (TXXPIX + TYXPIY)) + (TETY*OBJMOD (TXYPIX + TYYPIY)); TEMU1 = TEMU1 + ((E GR3 TEPEGR S)*OBJMOD PIZ); TZXPIZ = (E GR3 DEPDTGR S)*OBJMOD PIZ; TZYPIZ = (E GR6 DEPDTGR S)*OBJMOD PIZ; TXZPIX = (E GR7 DEPDTGR S)*OBJMOD PIX; TYZPIY = (E GR8 DEPDTGR S)*OBJMOD PIY; TZZPIY = (E GR9 DEPDTGR S)*OBJMOD PIZ; TEMU2 = (TETX*OBJMOD (TXXPIX + TYXPIY + TZXPIZ)) + (TETY*OBJMOD (TXYPIX + TYYPIY + TZYPIZ)) + (TETZ*OBJMOD (TXZPIX + TYZPIY + TZZPIZ)); 'FINSI'; 'FINSI' ; 'FINSI'; ******************************************************************** ****** On calcul la variation de contrainte et de déplacement ****** ******************************************************************** 'SI' ISECO; GRAD11 = (OBJMOD GRADEP * PIGR) ; EPXX1 = E GR1 GRAD11 S; EPYY1 = E GR5 GRAD11 S; EPZZ1 = E GR9 GRAD11 S; GAXY1 = (E GR2 GRAD11 S) + (E GR4 GRAD11 S) ; GAXZ1 = (E GR3 GRAD11 S) + (E GR7 GRAD11 S) ; GAYZ1 = (E GR6 GRAD11 S) + (E GR8 GRAD11 S) ; EPSIA1 = 'MANU' 'CHML' OBJMOD EP1 EPXX1 EP2 EPYY1 EP3 EPZZ1 EP4 GAXY1 EP5 GAXZ1 EP6 GAYZ1 'TYPE' 'DEFORMATIONS' 'STRESSES'; 'SINON'; EPSIA1 = 'MANU' 'CHML' OBJMOD EP1 EPXX1 EP2 EPYY1 EP3 EPZZ1 EP4 GAXY1 'TYPE' 'DEFORMATIONS' 'STRESSES'; 'FINSI'; 'SI' ITHER; EPSIA1 = EPSIA1 + EPSTU1; 'FINSI'; 'SINON'; 'FINSI'; ****************************************************** ***** S10 = -SIGF*(Grad U)*(Grad PI)*(Grad TETA) ***** ***** S20 = -SIGF*(Grad U)*(Grad TETA)*(Grad PI) ***** ***** S30 = SIGF*(Grad U)*(Grad TETA)*(Div PI) ******* ***** S40 = SIGF*(Grad U)*(Grad PI)*(Div TETA) ******* ***** S50 = ENEGIE*(ADJ TETA*PI) ********************* ***** S60 = ALPH*SIGF*(Grad (Grad T))*PI*TETA ******** ***** S70 = ALPH*SIGF*((Grad T)*PI)*(Div TETA) ******* ***** S80 = ALPH*SIGF*((Grad T)*TETA)*(Div PI) ******* ***** S120= ALPH*SIG1*((Grad T)*TETA) **************** ***** S90 = SIG1*(Grad U)*(Grad TETA) **************** ***** S100= SIGF*(Grad U1)*(Grad TETA) *************** ***** S110= -SIGF*(Grad U1)*(Div TETA) *************** ***** S130= PRESSION*(grad A_DEPI)*THETA ************* ***** S140= PRESSION_AUXI*(grad U)*THETA ************* ****************************************************** 'SI' ISECO; (OBJMOD GRADEP * (OBJMOD PIGR * TETAGR)))); (OBJMOD GRADEP * (OBJMOD TETAGR * PIGR)))); SIGF (OBJMOD GRADEP * TETAGR)) * DIVPI); SIGF (OBJMOD GRADEP * PIGR)) * DIVTETA); 'SI' ITHER ; 'FINSI'; 'FINSI'; 'SI' ITHER ; 'FINSI'; 'SI' IPRE_A ; DEPLX = ((E GR1 GRADCH S)*(E MU1 TETA S)) + ((E GR2 GRADCH S)*(E MU2 TETA S)) ; DEPLY = ((E GR4 GRADCH S)*(E MU1 TETA S)) + ((E GR5 GRADCH S)*(E MU2 TETA S)) ; DEPLX = DEPLX + ((E GR3 GRADCH S)*(E MU3 TETA S)); DEPLY = DEPLY + ((E GR6 GRADCH S)*(E MU3 TETA S)); DEPLZ = ((E GR7 GRADCH S)*(E MU1 TETA S)) + ((E GR8 GRADCH S)*(E MU2 TETA S)) + ((E GR9 GRADCH S)*(E MU3 TETA S)) ; 'FINSI'; 'FINSI' ; 'SI' IPRES ; DEPLX = ((E GR1 GRADCH S)*(E MU1 TETA S)) + ((E GR2 GRADCH S)*(E MU2 TETA S)) ; DEPLY = ((E GR4 GRADCH S)*(E MU1 TETA S)) + ((E GR5 GRADCH S)*(E MU2 TETA S)) ; DEPLX = DEPLX + ((E GR3 GRADCH S)*(E MU3 TETA S)); DEPLY = DEPLY + ((E GR6 GRADCH S)*(E MU3 TETA S)); DEPLZ = ((E GR7 GRADCH S)*(E MU1 TETA S)) + ((E GR8 GRADCH S)*(E MU2 TETA S)) + ((E GR9 GRADCH S)*(E MU3 TETA S)) ; 'FINSI'; 'FINSI'; A_SIGF (OBJMOD GRADEP * TETAGR)); SIGF (OBJMOD A_DEPGR * TETAGR)); OBJMOD SIGF A_DEPGR) * DIVTETA)) ; ************************************************** ******** RASSEMBLAGE DE DIFFERENTS TERMES ******** ************************************************** TMCANI = S10 + S20 + S30 + S40 + S50 + S90 + S100 + S110; TTERMI = S60 + S70 + S80 + S120 ; TPRESS = S130 + S140; TTOTA = TMCANI + TTERMI + TPRESS ; *************************************************** **** STOCKAGE DES RESULTATS DANS SUPTAB.'DGDA' **** *************************************************** C1 = C TMCANI ' '; C2 = C TTERMI ' '; C3 = C TPRESS ' '; C4 = C TTOTA; 'SI' IPAP; SUPTAB.'DGDA'.INST = TTOTA; 'FINSI'; SUPTAB.'DGDA'.INST.PM = TTOTA; 'FINSI'; 'SINON'; 'MESS' C1 C2 C3 C4; SUPTAB.'DGDA' = TTOTA; 'FINSI'; 'MESS' NUNOE C1 C2 C3 C4; SUPTAB.'DGDA'.PM = TTOTA; 'FINSI'; 'FINSI'; 'MENA'; 'FIN' BCNOEU; 'MENA'; 'SI' (IPAP 'ET' (NBOU '>' 1)); 'FINSI'; 'SI' (IPAP 'ET' (NBOU 'EGA' 1)); 'SI' (('ABS' ((&BOUCEXT/10) - (&BOUCEXT/10.))) '<' 1.D-10); 'FINSI'; 'FINSI'; 'FIN' BOUCEXT ; **************************************************** ********* FIN BOUCLE SUR LE PAS DE CALCUL ********* **************************************************** **************************************************** ** STOCKAGE DES RESULTATS DANS SUPTAB.'EVOLDGDA' *** **************************************************** 'SI' IPAP; SUPTAB.'EVOLDGDA' = TABLE; 'TITRE' CHA1; T1 = IND1.&BB1; 'FIN' BB1; 'FINSI'; T1 = IND1.&BB2; 'FIN' BB2; 'FIN' BB1; 'FINSI'; 'FINSI'; 'FINPROC' SUPTAB ;
© Cast3M 2003 - Tous droits réservés.
Mentions légales