ccgmet
C CCGMET SOURCE GOUNAND 26/01/09 21:15:06 12441 SUBROUTINE CCGMET(LCOF,NOMLOI, $ FC, $ IMPR,IRET) IMPLICIT REAL*8 (A-H,O-Z) IMPLICIT INTEGER (I-N) C*********************************************************************** C NOM : CCGMET C DESCRIPTION : Lois de comportement aux points de Gauss : C Métrique par rapport à un élément de référence régulier. C (Copie de CCGIME) 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, 2026/01/02, version initiale C HISTORIQUE : v1, 2026/01/02, 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,IHJT.MXMAT POINTEUR H.MXMAT,IH.MXMAT POINTEUR ME.MXMAT * * INTEGER IMPR,IRET * * Executable statements * IF (IMPR.GT.1) WRITE(IOIMP,*) 'Entrée dans ccgmet' 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,IHJT LDIM1=IREF LDIM2=IREF SEGINI,H SEGINI,IH 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 * Calcul de l'inverse, du déterminant et trace de l'inverse de h $ IMPR,IRET) IF (IRET.NE.0) THEN WRITE(IOIMP,*) $ 'Metrique des elements reguliers non inversible' SEGPRT,JMAREG SEGPRT,H GOTO 9999 ENDIF * SEGPRT,IH * 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 h-1 Jt * * Calcul de Jt $ 'TRANSPOS',JT.XMAT,IREF,IREL, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,JT * Calcul de h-1 Jt $ 'FOIS ',IHJT.XMAT,IREF,IREL, $ IMPR,IRET) IF (IRET.NE.0) GOTO 9999 * SEGPRT,IHJT * Calcul de J h-1 Jt $ '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.'METR') 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,IH SEGSUP,H SEGSUP,IHJT 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 ccgmet' RETURN * * End of subroutine CCGMET * END
© Cast3M 2003 - Tous droits réservés.
Mentions légales