ccgime
C CCGIME SOURCE PV 22/04/22 21:15:03 11344 $ FC, $ IMPR,IRET) IMPLICIT REAL*8 (A-H,O-Z) IMPLICIT INTEGER (I-N) C*********************************************************************** C NOM : CCGIME C DESCRIPTION : Lois de comportement aux points de Gauss : C Inverse de la métrique par rapport à un C élément de référence régulier. C C LANGAGE : ESOPE C AUTEUR : Stéphane GOUNAND (CEA/DRN/DMT/SEMT/LTMF) C mél : gounand@semt2.smts.cea.fr C*********************************************************************** C APPELES : C APPELE PAR : C*********************************************************************** C ENTREES : C ENTREES/SORTIES : C SORTIES : - C TRAVAIL : C*********************************************************************** C VERSION : v1, 22/09/10, version initiale C HISTORIQUE : v1, 22/09/10, création C HISTORIQUE : C*********************************************************************** C Prière de PRENDRE LE TEMPS de compléter les commentaires C en cas de modification de ce sous-programme afin de faciliter C la maintenance ! C*********************************************************************** -INC PPARAM -INC CCOPTIO -INC CCREEL -INC TNLIN *-INC SMCHAEL INTEGER NBLIG,NBCOL,N2LIG,N2COL,NBPOI,NBELM,N1 POINTEUR FC.MCHEVA POINTEUR LCOF.LCHEVA POINTEUR JMAJAC.MCHEVA POINTEUR JMIJAC.MCHEVA POINTEUR JDTJAC.MCHEVA POINTEUR JMAREG.MCHEVA CHARACTER*8 NOMLOI INTEGER ICOF * -INC TMXMAT * Objets temporaires POINTEUR JAC.MXMAT,JT.MXMAT,MJT.MXMAT POINTEUR G.MXMAT,IG.MXMAT,H.MXMAT,HIG.MXMAT,IGHIG.MXMAT POINTEUR ME.MXMAT * SEGMENT MCOF POINTEUR COEF(IDIM,IDIM).MCHEVA ENDSEGMENT * LOGICAL LBID INTEGER LAXSP REAL*8 DEUPI,XR REAL*8 XL,XM DIMENSION DETG(1) * INTEGER IMPR,IRET * * Executable statements * IF (IMPR.GT.1) WRITE(IOIMP,*) 'Entrée dans ccgime' C IF (.NOT.(IDIM.EQ.1)) THEN C WRITE(IOIMP,*) 'IDIM=',IDIM,' ?' C GOTO 9999 C ENDIF NLFC=FC.WELCHE(/6) NPFC=FC.WELCHE(/5) ICOF=0 * ICOF=ICOF+1 JMAJAC=LCOF.LISCHE(ICOF) NLJA=JMAJAC.WELCHE(/6) NPJA=JMAJAC.WELCHE(/5) IREF=JMAJAC.WELCHE(/4) IREL=JMAJAC.WELCHE(/3) * IF (IREL.NE.IDIM) THEN WRITE(IOIMP,*) 'Erreur dims JMAJAC' GOTO 9999 ENDIF * ICOF=ICOF+1 ICOF=ICOF+1 ICOF=ICOF+1 JMAREG=LCOF.LISCHE(ICOF) NLJR=JMAREG.WELCHE(/6) NPJR=JMAREG.WELCHE(/5) I1 =JMAREG.WELCHE(/4) $ THEN WRITE(IOIMP,*) 'Erreur dims JMAREG' GOTO 9999 ENDIF * * Objets temporaires et à préconditionner * LDIM1=IREL LDIM2=IREF SEGINI,JAC LDIM1=IREF LDIM2=IREL SEGINI,JT SEGINI,MJT LDIM1=IREF LDIM2=IREF SEGINI,G SEGINI,IG SEGINI,H SEGINI,HIG SEGINI,IGHIG LDIM1=IREL LDIM2=IREL SEGINI,ME * * Calcul de la métrique des éléments réguliers * $ 'JTJ ',H.XMAT,IREF,IREF, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,H * DO ILFC=1,NLFC IF (NLJA.EQ.1) THEN ILJA=1 ELSE ILJA=ILFC ENDIF DO IPFC=1,NPFC IF (NPJA.EQ.1) THEN IPJA=1 ELSE IPJA=IPFC ENDIF * * Copie du jacobien * $ 'COPIE ', $ JAC.XMAT,IREL,IREF, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,JAC * * Calcul de la métrique ME = J (JtJ)-1 h (JtJ)-1 Jt = J M Jt * * Calcul de Jt $ 'TRANSPOS',JT.XMAT,IREF,IREL, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,JT * Calcul de G=JtJ $ 'FOIS ',G.XMAT,IREF,IREF, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,G * Calcul de l'inverse, du déterminant et trace de l'inverse de g LBID=.FALSE. $ LBID,IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,IG * Calcul de hg-1, de sa trace et de son déterminant $ 'FOIS ',HIG.XMAT,IREF,IREF,IMPR,IRET) IF (IRET.NE.0) GOTO 9999 $ 'FOIS ',IGHIG.XMAT,IREF,IREF,IMPR,IRET) IF (IRET.NE.0) GOTO 9999 $ 'FOIS ',MJT.XMAT,IREF,IREL,IMPR,IRET) IF (IRET.NE.0) GOTO 9999 $ 'FOIS ',ME.XMAT,IREL,IREL,IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * * Calcul des la métrique inverse de l'élément * IF (NOMLOI(1:4).EQ.'IMET') THEN IF (IRET.NE.0) GOTO 9999 IF (IRET.NE.0) GOTO 9999 CONTRI=ME.XMAT(IDIM1,IDIM2) * WRITE(IOIMP,*) 'CONTRI=',CONTRI ELSE WRITE(IOIMP,*) 'NOMLOI=',NOMLOI WRITE(IOIMP,*) 'Erreur grave' GOTO 9999 ENDIF FC.WELCHE(1,1,1,1,IPFC,ILFC)= $ FC.WELCHE(1,1,1,1,IPFC,ILFC)+ $ CONTRI ENDDO ENDDO SEGSUP,ME SEGSUP,IGHIG SEGSUP,HIG SEGSUP,H SEGSUP,IG SEGSUP,G SEGSUP,MJT SEGSUP,JT SEGSUP,JAC * * Normal termination * IRET=0 RETURN * * Format handling * * * Error handling * 9999 CONTINUE IRET=1 WRITE(IOIMP,*) 'An error was detected in subroutine ccgime' RETURN * * End of subroutine CCGIME * END
© Cast3M 2003 - Tous droits réservés.
Mentions légales