adevo
C ADEVO SOURCE BP208322 15/05/11 21:15:00 8528 IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) C C======================================================================= C = = C = APPELE PAR ADEVOL = C = = C = CONSTRUCTION D'UN OBJET DE TYPE EVOL CONTENANT LA SOMME OU LA = C = DIFFERENCE TERME A TERME DE DEUX OBJETS EVOLUTION = C = DE MEMES ABSCISSES = C = = C = SYNTAXE : PROD = EVOLF + EVOLV = C = = C = ON EXECUTE LA SOMME TERME A TERME DES ORDONNEES DES DEUX = C = OBJETS DE TYPE EVOLUTIO EVOLF ET EVOLV. LES ABSCISSES DE PROD, = C = L'OBJET AINSI CREE, RESTENT CELLES DE EVOLF ET EVOLV. = C = = C = = C = = C = MEVOL1 : POINTEUR SUR MEVOLF (OBJET EVOLUTION) = C = MEVOL2 : POINTEUR SUR MEVOLV " " = C = KEVOL1 : POINTEUR SUR KEVOLF = C = KEVOL2 : POINTEUR SUR KEVOLV = C = MLREE1 : POINTEUR SUR LA LISTREEL ORDONNEE DE EVOLF = C = MLREE2 : POINTEUR SUR LA LISTREEL ORDONNEE DE EVOLV = C = = C = CREATION : 4/12/87 = C = F.ROULLIER = C======================================================================= C -INC PPARAM -INC CCOPTIO -INC SMEVOLL -INC SMLREEL C SEGMENT TEMPP IMPLIED DR1(NPT),DI1(NPT),DM1(NPT),DP1(NPT) ENDSEGMENT CHARACTER *72 TI CHARACTER*4 ITYP1,ITYP2 C C LES 2 OBJETS EVOLUTION DOIVENT ETRE DE MEME SOUS-TYPE C ET DE MEME LONGUEUR C MEVOL1=IPEV1 MEVOL2=IPEV2 SEGACT MEVOL1,MEVOL2 ITYP1=MEVOL1.ITYEVO ITYP2=MEVOL2.ITYEVO ICMP=1 IF (ITYP1.EQ.'COMP'.AND.ITYP2.EQ.'COMP') GO TO 198 IF (ITYP1.EQ.'REEL'.AND.ITYP2.EQ.'REEL') GO TO 199 197 MOTERR(1:8)='EVOLUTIO' RETURN 198 ICMP=2 199 CONTINUE C C BOUCLE SUR LES COURBES C NC1=MEVOL1.IEVOLL(/1) NC2=MEVOL2.IEVOLL(/1) IF(NC1.EQ.NC2) GOTO 200 RETURN C 200 CONTINUE N=NC1 NC=NC1/ICMP SEGINI MEVOLL IRET=MEVOLL TI=TITREE IEVTEX=TI ITYEVO=MEVOL1.ITYEVO C C DO 201 IC=1,NC,ICMP KEVOL1=MEVOL1.IEVOLL(IC) KEVOL2=MEVOL2.IEVOLL(IC) SEGACT KEVOL1,KEVOL2 ITYP1=KEVOL1.NUMEVY ITYP2=KEVOL2.NUMEVY MLREE1=KEVOL1.IPROGX MLREE2=KEVOL2.IPROGX SEGACT MLREE1,MLREE2 C C LES LISTREEL ONT-ILS MEME LONGUEUR ? IF(L1.EQ.L2)GOTO 10 GOTO 100 10 CONTINUE C C LES LISTREEL DES ABSCISSES SONT ILS IDENTIQUES ? IF(IRETOU.EQ.0) THEN RETURN ENDIF C SEGINI KEVOLL IEVOLL(IC)=KEVOLL c KEVTEX=TI KEVTEX=KEVOL1.KEVTEX NOMEVX=KEVOL1.NOMEVX NOMEVY=KEVOL1.NOMEVY NUMEVX=KEVOL1.NUMEVX NUMEVY=KEVOL1.NUMEVY TYPX=KEVOL1.TYPX TYPY=KEVOL1.TYPY JG=L1 SEGINI MLREEL IPROGX=MLREEL DO 31 I=1,L1 31 CONTINUE SEGDES MLREEL,KEVOLL,MLREE1,MLREE2 C MLREE1=KEVOL1.IPROGY MLREE2=KEVOL2.IPROGY SEGACT MLREE1,MLREE2 C NPT=L1 SEGINI TEMPP IMOD1=0 IMOD2=0 IF (ITYP1.EQ.'MODU') THEN IMOD1=1 DO 180 I=1,L1 180 CONTINUE ELSE DO 181 I=1,L1 181 CONTINUE ENDIF C IF (ITYP2.EQ.'MODU') THEN IMOD2=1 DO 182 I=1,L1 182 CONTINUE ELSE DO 183 I=1,L1 183 CONTINUE ENDIF SEGDES MLREE1,MLREE2 SEGDES KEVOL1,KEVOL2 C IF (ICMP.EQ.1) GO TO 170 C KEVOL1=MEVOL1.IEVOLL(IC+1) KEVOL2=MEVOL2.IEVOLL(IC+1) SEGACT KEVOL1,KEVOL2 MLREE1=KEVOL1.IPROGX SEGACT MLREE1 C SEGINI KEVOLL IEVOLL(IC+1)=KEVOLL KEVTEX=TI NOMEVX=KEVOL1.NOMEVX NOMEVY=KEVOL1.NOMEVY NUMEVX=KEVOL1.NUMEVX NUMEVY=KEVOL1.NUMEVY TYPX=KEVOL1.TYPX TYPY=KEVOL1.TYPY C JG=L1 SEGINI MLREEL IPROGX=MLREEL DO 35 I=1,L1 35 CONTINUE SEGDES MLREEL,KEVOLL,MLREE1 C MLREE1=KEVOL1.IPROGY MLREE2=KEVOL2.IPROGY SEGACT MLREE1,MLREE2 C IF (IMOD1.EQ.1) THEN DO 190 I=1,L1 190 CONTINUE ELSE DO 191 I=1,L1 191 CONTINUE ENDIF IF (IMOD2.EQ.1) THEN DO 192 I=1,L1 192 CONTINUE ELSE DO 193 I=1,L1 193 CONTINUE ENDIF SEGDES MLREE1,MLREE2 SEGDES KEVOL1,KEVOL2 C IF (IMOD1.EQ.1) THEN ENDIF C IF (IMOD2.EQ.1) THEN ENDIF C DO 20 I=1,L1 DR1(I)=DR1(I)+DR2(I) 20 CONTINUE ELSE DO 21 I=1,L1 DR1(I)=DR1(I)-DR2(I) 21 CONTINUE ENDIF C KEVOL1=IEVOLL(IC) KEVOL2=IEVOLL(IC+1) SEGACT KEVOL1*MOD,KEVOL2*MOD JG=L1 SEGINI MLREE1,MLREE2 KEVOL1.IPROGY=MLREE1 KEVOL2.IPROGY=MLREE2 C IF (IMOD1.EQ.1) THEN DO 22 I=1,L1 22 CONTINUE ELSE DO 23 I=1,L1 23 CONTINUE ENDIF C SEGDES MLREE1,MLREE2,KEVOL1,KEVOL2 GO TO 196 C 170 CONTINUE DO 171 I=1,L1 DR1(I)=DR1(I)+DR2(I) 171 CONTINUE ELSE DO 172 I=1,L1 DR1(I)=DR1(I)-DR2(I) 172 CONTINUE ENDIF C KEVOL1=IEVOLL(IC) SEGACT KEVOL1 JG=L1 SEGINI MLREE1 KEVOL1.IPROGY=MLREE1 C IF (IMOD1.EQ.1) THEN DO 173 I=1,L1 173 CONTINUE ELSE DO 174 I=1,L1 174 CONTINUE ENDIF C SEGDES MLREE1,KEVOL1 C 196 SEGSUP TEMPP 201 CONTINUE C SEGDES MEVOLL,MEVOL1,MEVOL2 C 100 CONTINUE RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales