extr14
C EXTR14 SOURCE SP204843 24/12/04 21:15:02 12088 C_____________________________________________________________________ C C Extrait une composante d'un MCHAML C C Entrees : C --------- C C IPCHE1 Pointeur sur un MCHAML C IENT1 Numero de la sous zone C IENT2 Numero de l'element C IENT3 Numero du point de gauss C MOT Nom de la composante a extraire ou mot cle indiquant C l'action a effectuer (TITR = TYPE ou MAIL) C C JM CAMPENON le 07/91 C C La Borderie le 21/07/92 :possibilite d'extraire une composante entiere C PP 21/12/92 :extension a l'extraction d'un objet de type quelconque C_____________________________________________________________________ C IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) C -INC PPARAM -INC CCOPTIO -INC CCGEOME -INC SMCHAML -INC SMINTE -INC SMLMOTS -INC SMELEME C logical ltelq REAL*8 FLOX CHARACTER*(LOCOMP) MOT CHARACTER*(4) MOT4 CHARACTER*8 TYPOBJ CHARACTER*(LOCHAI) CTEXT C MCHELM=IPCHE1 SEGACT MCHELM NSOUS=ICHAML(/1) C MOT4=MOT IF ((MOT4.EQ.'TITR').OR.(MOT4.EQ.'TYPE')) THEN JGM=1 JGN=TITCHE(/1) CTEXT=TITCHE SEGINI MLMOTS IPMOTS=MLMOTS SEGDES MLMOTS RETURN ELSEIF (MOT4.EQ.'MAIL') THEN N1 = IMACHE(/1) IF ( N1 .EQ. 0) THEN C Cas du MCHAML VIDE ==> MAILLAGE VIDE NBELEM=0 NBNN =NBNNE(ILCOUR) NBREF =0 NBSOUS=0 SEGINI MELEME ITYPEL = ILCOUR IPP1 = MELEME ELSE IPP1=IMACHE(1) IF(NSOUS.GT.1) THEN DO 30 I=2,NSOUS IPP2=IMACHE(I) ltelq=.false. IPP1=IRET 30 CONTINUE ENDIF ENDIF GOTO 555 ENDIF C Extraction de la valeur dans 1 element : C Recherche du numero de la sous-zone et de l'element dans le MCHAML IF (IPMAI1.NE.0) THEN N1 = IMACHE(/1) IF (N1.EQ.0) THEN MOTERR(1:8) = 'MCHAML' GOTO 555 ENDIF IPT1 = IPMAI1 ITYP1 = IPT1.ITYPEL DO 40 I=1,NSOUS MELEME = IMACHE(I) SEGACT,MELEME IF (ITYPEL.NE.ITYP1) GOTO 40 MCHAML = ICHAML(I) SEGACT,MCHAML IOK = 0 NCOMP = NOMCHE(/1) DO 405 ICOMP=1,NCOMP IF (MOT.EQ.NOMCHE(ICOMP)) IOK = 1 405 CONTINUE IF (IOK.NE.1) GOTO 40 NBNO1 = NUM(/1) NBEL1 = NUM(/2) DO 400 IEL=1,NBEL1 DO 410 INO=1,NBNO1 IF (NUM(INO,IEL).NE.IPT1.NUM(INO,1)) GOTO 400 410 CONTINUE IENT1 = I IENT2 = IEL GOTO 50 400 CONTINUE 40 CONTINUE C Element pas trouve dans MCHAML RETURN C Element trouve : on poursuit 50 CONTINUE ENDIF IF (IENT1.GT.NSOUS) THEN C C Sous zone inexistante C GOTO 555 ENDIF C MELEME=IMACHE(IENT1) SEGACT MELEME NBELEM=NUM(/2) NBPGAU=NUM(/1) C N3=INFCHE(/2) IF (N3.GE.4) THEN MINTE=INFCHE(IENT1,4) IF(MINTE.NE.0)THEN SEGACT MINTE NBPGAU=POIGAU(/1) ENDIF ENDIF IF (IENT3.GT.NBPGAU.OR.IENT2.GT.NBELEM) THEN C C Numero du point de gauss ou de l'element trop grand C GOTO 555 ENDIF C MCHAML=ICHAML(IENT1) SEGACT MCHAML NCOMP=IELVAL(/1) DO 100 ICOMP=1,NCOMP IF (MOT.EQ.NOMCHE(ICOMP)) GOTO 200 100 CONTINUE C C Composante inexistante C GOTO 444 C 200 CONTINUE MELVAL=IELVAL(ICOMP) SEGACT MELVAL C+PP IF(TYPCHE(ICOMP)(1:6).EQ.'REAL*8')THEN IF (IENT3.EQ.0) THEN IF (VELCHE(/1).EQ.1) THEN IENT3 = 1 ELSE RETURN ENDIF ENDIF IGMN=MIN(IENT3,VELCHE(/1)) IBMN=MIN(IENT2,VELCHE(/2)) FLOX=VELCHE(IGMN,IBMN) ELSE IF (IENT3.EQ.0) THEN IF (IELCHE(/1).EQ.1) THEN IENT3 = 1 ELSE RETURN ENDIF ENDIF TYPOBJ=TYPCHE(ICOMP)(9:16) IGMN=MIN(IENT3,IELCHE(/1)) IBMN=MIN(IENT2,IELCHE(/2)) IPOOBJ=IELCHE(IGMN,IBMN) C Gestion des pointeurs nuls (et oui, ca arrive) IF (IPOOBJ.EQ.0) THEN MOTERR(1:8)=TYPOBJ ENDIF ENDIF C+PP C 444 CONTINUE C 555 CONTINUE END
© Cast3M 2003 - Tous droits réservés.
Mentions légales