rlexf2
C RLEXF2 SOURCE OF166741 24/12/13 21:17:30 12097 IMPLICIT INTEGER(I-N) -INC PPARAM -INC CCOPTIO INTEGER NBNN, NBELEM -INC SMELEME -INC SMCHAML C -INC SMCHPOI POINTEUR MCHCEN.MCHPOI, MCHLIM.MCHPOI, MCHFAC.MCHPOI POINTEUR MPOCEN.MPOVAL, MPOLIM.MPOVAL, MPOFAC.MPOVAL C -INC SMLENTI POINTEUR MLECEN.MLENTI, MLELIM.MLENTI, MLEFAC.MLENTI C INTEGER IGEOM, NCOM, NBSOUS, ISOUS, IELEM, NGF, NLF, NGV, NLV & ,IVOI, ICOM, I2 REAL*8 VAL CHARACTER*(LOCOMP) NOM1 C LOGICAL LOGCEN IF(IERR.NE.0)GOTO 9999 NCOM=MPOCEN.VPOCHA(/2) C En LICHT SEGACT*MOD MPOCEN IF(IERR.NE.0)GOTO 9999 C C**** En KRIPAD C SEGACT IGEOM C SEGINI MLECEN C MELEME=IGEOM SEGDES MELEME C IF(MCHLIM.GT.0)THEN IF(IERR.NE.0)GOTO 9999 C En LICHT SEGACT*MOD MPOLIM IF(IERR.NE.0)GOTO 9999 C C**** En KRIPAD C SEGACT IGEOM C SEGINI MLELIM C MELEME=IGEOM SEGDES MELEME ELSE MPOLIM=0 MLELIM=0 ENDIF C IF(IERR.NE.0)GOTO 9999 C En LICHT SEGACT*MOD MPOFAC IF(IERR.NE.0)GOTO 9999 C C**** En KRIPAD C SEGACT IGEOM C SEGINI MLEFAC C MELEME=IGEOM SEGDES MELEME C SEGACT MCHELM NBSOUS=MCHELM.IMACHE(/1) C DO ISOUS=1,NBSOUS,1 MELEME=MCHELM.IMACHE(ISOUS) MCHAM1=MCHELM.ICHAML(ISOUS) SEGACT MELEME SEGACT MCHAM1 MELVA1=MCHAM1.IELVAL(1) MELVA2=MCHAM1.IELVAL(2) SEGACT MELVA1 SEGACT MELVA2 NOM1=MCHAM1.NOMCHE(1) IF(NOM1 .NE. 'alphax')THEN WRITE(IOIMP,*) NOM1, '!=', 'alphax ' C 21 2 C Données incompatibles GOTO 9999 ENDIF NOM1=MCHAM1.NOMCHE(2) IF(NOM1 .NE. 'alphay')THEN WRITE(IOIMP,*) NOM1, '!=', 'alphay ' C 21 2 C Données incompatibles GOTO 9999 ENDIF IF(IDIM.EQ.3)THEN MELVA3=MCHAM1.IELVAL(3) SEGACT MELVA3 NOM1=MCHAM1.NOMCHE(3) IF(NOM1 .NE. 'alphaz')THEN WRITE(IOIMP,*) NOM1, '!=', 'alphaz ' C 21 2 C Données incompatibles GOTO 9999 ENDIF ENDIF C NBNN=MELEME.NUM(/1) NBELEM=MELEME.NUM(/2) C DO IELEM=1,NBELEM,1 NGF=MELEME.NUM(1,IELEM) NLF=MLEFAC.LECT(NGF) IF(NLF.EQ.0)THEN WRITE (IOIMP,*) 'subroutine rlexf2.eso' GOTO 9999 ENDIF DO IVOI=2,NBNN,1 NGV=MELEME.NUM(IVOI,IELEM) NLV=MLECEN.LECT(NGV) IF(NLV.NE.0)THEN LOGCEN=.TRUE. ELSE LOGCEN=.FALSE. NLV=MLELIM.LECT(NGV) IF(NLV.EQ.0)THEN WRITE(IOIMP,*) 'subroutine rlexf2.eso' GOTO 9999 ENDIF ENDIF DO ICOM = 1, NCOM, 1 IF(LOGCEN)THEN VAL=MPOCEN.VPOCHA(NLV,ICOM) ELSE VAL=MPOLIM.VPOCHA(NLV,ICOM) ENDIF & (MELVA1.VELCHE(IVOI,IELEM)*VAL) & (MELVA2.VELCHE(IVOI,IELEM)*VAL) IF(IDIM.EQ.3) & (MELVA3.VELCHE(IVOI,IELEM)*VAL) ENDDO ENDDO ENDDO SEGDES MELEME SEGDES MCHAM1 SEGDES MELVA1 SEGDES MELVA2 IF(IDIM.EQ.3) SEGDES MELVA3 ENDDO C SEGDES MCHELM IF(MPOLIM .NE. 0) THEN SEGDES MPOLIM SEGSUP MLELIM ENDIF SEGDES MPOFAC SEGDES MPOCEN SEGSUP MLECEN SEGSUP MLEFAC C 9999 RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales