tassp2
C TASSP2 SOURCE PV090527 25/01/03 21:15:34 12111 C====================================================================== C CE SOUS PROGRAMME EST APPELE PAR TASSPO ELIMIN OU CONFON C C itlac1 est une liste de pointeurs sur les maillages arguments C icpr etablit une correspondance entre la numerotation globale C des noeuds et une numerotation locale qui tient compte de C l'elimination C icdour est le max des valeurs de icpr C C MODIF OCTOBRE 1988 PAR PV TRAITE TOUS LES MELEME C QUE SAUVER SAIT TRAITER C===================================================================== implicit integer (i-n) implicit real*8(a-h,o-z) integer I, I1, I2, I3, IA, IB integer ICDOUR, mena integer ICHPOI, ICOMPT integer IGE, ILG, IMA, IN, IOB, IOU, IP,IPILE, IPREME integer IRATT, ITL, J, JJ, K, LCONMO, NAL1, NAL2 integer NBEMEL, NBNNAC, NBNNPR, NBPTS, NCONCH, NPM, NSOUPO -INC PPARAM -INC CCOPTIO -INC COCOLL -INC CCNOYAU -INC CCGEOME -INC CCPRECO -INC CCASSIS C==DEB= FORMULATION HHO == Donnees globales ============================ -INC CCHHOPA -INC CCHHOPR C==FIN= FORMULATION HHO ================================================ -INC SMELEME -INC SMCOORD -INC SMTABLE -INC SMCHAML -INC TMLCHA8 -INC SMCHPOI -INC SMNUAGE -INC TMCOLAC -INC SMLOBJE SEGMENT TAB1 REAL*8 XCOOR1(ILG) ENDSEGMENT SEGMENT TAB2 REAL*8 RCOOR1(ILR) ENDSEGMENT SEGMENT icpr(0) segment idcp(icdour) SEGMENT ITRAV(NPM) segment itrav2(nbpts) C Piles de communication MPI pointeur piles.LISPIL pointeur jcolac.ICOLAC pointeur jlisse.ILISSE pointeur jtlacc.ITLACC pointeur pile.ITLACC C CHARACTER*8 TYPE C LOGICAL FLAG DATA NBNNPR/0/ C===================================================================== iun=1 TYPE=' ' K=-1 C on recupere dans k -npossi, le nombre de type objet possibles C la pile icolac est cree SEGACT ICOLAC*MOD ITLACC=KCOLA(1) ILISSE=ILISSG segact ilisse*mod IF (ITLAC1.NE.0) THEN SEGSUP ITLACC KCOLA(1)=ITLAC1 ITLACC=KCOLA(1) C il faut initialiser ilisse sinon on retrouve deux fois les segments DO 5468 K=1,ITLAC(/1) IA=ITLAC(K) IF(IA.EQ.0) GO TO 5468 ILISEG((IA-1)/npgcd)=K 5468 CONTINUE ENDIF C initialisation avec les maillages preconditionnees do 145 ith=0,nbesc do ip=1,nbemel ipreme= premel(ip,ith) if (ipreme.ne.0) then else goto 145 endif enddo 145 continue C preconditionnement des MMODEL et MTABLE ESCLAVES de CCPRECO DO IIMOD = 1, NMOPAR IMO = PARMOD(IIMOD) IF (IMO .EQ. 0) GOTO 143 IES = PESCLA(IIMOD) C 38 pour les MMODEL C 10 pour les MTABLE ITLACC=KCOLA(38) ITLACC=KCOLA(10) ENDDO 143 CONTINUE C==DEB= FORMULATION HHO == Conservation des maillages globaux ========== IF (MSQHHO .GT. 0) THEN c-dbg write(ioimp,*) 'TASSP2 - HHO - AJOUN' itlacc = KCOLA(1) ip = MSQHHO c-dbg write(ioimp,*) ' HHO - MSQHHO',MSQHHO,ip DO i = 1, NFAMAX ip = MAFHHO(i) c-dbg write(ioimp,*) ' HHO - MAFHHO',i,MAFHHO(i),ip END DO ip = MCEHHO c-dbg write(ioimp,*) ' HHO - MCEHHO',MCEHHO,ip DO i = 1, NCEMAX ip = MACHHO(i) c-dbg write(ioimp,*) ' HHO - MACHHO',i, MACHHO(i),ip END DO ip = MPFHHO c-dbg write(ioimp,*) ' HHO - MPFHHO',MPFHHO,ip ip = MPCHHO c-dbg write(ioimp,*) ' HHO - MPCHHO',MPCHHO,ip END IF C==FIN= FORMULATION HHO ================================================ C recupere la liste des types des objets en memoire C remplit les piles itlacc avec les objet de type mlcha8 SEGSUP MLCHA8 C reinitialise preconditionnement COMP do ip = 1, nbepre precle(ip) = ' ' prepre(ip) = 0 preori(ip) = 0 enddo C C complete icolac apres l'examen de chaque pile itlacc C C C on ne traite les points que si leur nombre a change C segact mcoord*mod nbnnac = nbpts nbnnpr=min(nbnnac,nbnnpr) C write (6,*) 'nb points avant maintenant ',nbnnpr,nbnnac,locerr if (mena.eq.1) then if (nbnnac.le.nbnnpr+10000) goto 570 endif C write (6,*) ' menage complet ' nbnnpr = nbnnac ipass=0 * cas ou un objet a ete fourni dans tass * on shunte la passe 1 if(idonn.ne.0) ipass=1 * premiere passe pour construire la liste des points * deuxieme passe pour les renumeroter dans l'ordre de la numerotatopn initiale ** write(6,*) 'TASSP2 appele avec idonn ',idonn 1000 continue ipass=ipass+1 *** write(6,*) 'icdour ipass ib en 142 ',icdour,ipass,ib if (ipass.eq.2.and.idonn.eq.0)then * reordonner suivant la numerotation initiale segini idcp ib=0 do i=1,icpr(/1) if(icpr(i).ne.0) then if(idcp(icpr(i)).ne.0) then icpr(i)=icpr(idcp(icpr(i))) else ib=ib+1 idcp(icpr(i))=i icpr(i)=ib endif endif enddo *** write(6,*) 'icdour ib en 153 ',icdour,ib segsup idcp endif C C TRAVAILLER SUR LES MELEME C SEGACT ICOLAC*MOD ITLACC=KCOLA(1) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1111) (ITLAC(I),I=1,ITL) 1111 FORMAT (/,' LISTE DES OBJETS ACCESSIBLES',/,(10I8)) C RENUMEROTATION EN FONCTION DU PREMIER OBJET npm=20 if(ipass.eq.2) segini itrav,itrav2 * Limitation du nombre de messages erreur(516) à 5 maximum iresu=1 ims=0 imsmax=5 C C boucle sur chaque objet de type maillage icompt=0 DO 10 IOB=1,ITL MELEME=ITLAC(IOB) IF (MELEME.EQ.0) goto 10 SEGACT MELEME*MOD IF (LISOUS(/1).NE.0) GOTO 60 if (num(/1).gt.npm) then npm=num(/1) if(ipass.eq.2) segadj itrav endif C boucle sur chaque element icompt=icompt+1 if(ipass.eq.2) then do 14 i1=1,num(/1) 14 continue endif C boucle sur chaque noeud DO 13 I1=1,NUM(/1) if (ip.ne.0) then IF (ICPR(IP).EQ.0) THEN C on affecte un nouveau numero a ce noeud ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF C on change la reference avec le nouveau numero ENDIF if(ipass.eq.2) then C VERIFICATION PAS DE NOEUDS DOUBLES DANS UN ELEMENT if (itrav2(icpr(ip)).eq.icompt) then DO 11 i3=1,i1-1 $ itrav(i1).ne.itrav(i3))then if (iresu.EQ.1) ims=ims+1 if (ims.LE.imsmax) then INTERR(2)=MELEME C on signale la creation d'un noeud double endif endif 11 continue endif itrav2(icpr(ip))=icompt endif 13 CONTINUE 12 CONTINUE 60 CONTINUE SEGACT,MELEME*NOMOD 10 CONTINUE if (ipass.eq.2) SEGSUP ITRAV,itrav2 if (iresu.eq.1.and.ims.gt.imsmax) then INTERR(1)=ims-imsmax endif C C MISE A JOUR DE L'OEIL PAR DEFAUT C IF (IOEIL.NE.0) THEN IF (ICPR(IOEIL).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IOEIL)=ICDOUR ENDIF IF (IIMPI.NE.0) WRITE (6,*) ' ANCIEN OEIL ',IOEIL, > ' NOUVEL OEIL ',ICPR(IOEIL) if(ipass.eq.2) IOEIL=ICPR(IOEIL) ENDIF C C MISE A JOUR DE ILGNI si necessaire C C* write (6,*) ' tassp2 ilgnio ilgnin ',ilgni,icpr(ilgni) IF (ILGNI.NE.0) THEN IF (ICPR(ILGNI).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(ILGNI)=ICDOUR ENDIF if(ipass.eq.2) ILGNI=ICPR(ILGNI) ENDIF C C TRAVAILLER SUR LES POINTS DANS LES TABLES : C ITLACC=KCOLA(10) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1112) (ITLAC(I),I=1,ITL) 1112 FORMAT (/,' LISTE DES TABLES ACCESSIBLES',/,(10I8)) C RENUMEROTATION EN FONCTION DU PREMIER OBJET DO 110 IOB=1,ITL MTABLE=ITLAC(IOB) SEGACT MTABLE*MOD DO 120 I=1,MLOTAB IF (MTABTI(I).EQ.'POINT ') THEN IP=MTABII(I) IF (IP.EQ.0) then write(ioimp,*) 'tassp2 1' ENDIF IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if(ipass.eq.2) MTABII(I)=ICPR(IP) ENDIF IF (MTABTV(I).EQ.'POINT ') THEN IP=MTABIV(I) if(icpr(IP) .gt.icdour) then write(6,*) ' pas beau icpr(ip) icdour', icpr(ip) , icdour endif IF (IP.EQ.0) then write(ioimp,*) 'tassp2 point' ENDIF IF (ICPR(IP).EQ.0) THEN C write(6,*) ' ip icdour ' , ip,icdour ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if (ipass.eq.2) MTABIV(I)=ICPR(IP) ENDIF 120 CONTINUE SEGDES MTABLE 110 CONTINUE C C attention a la derniere lecture dans gibiane si c'etait un point! C C write(6,*) ' ibpile ,ihpile ', ibpile, ihpile do ib=ibpile,ihpile if( jtyobj(ib).eq.'POINT ') then ip= jpoob4(ib) C write(6,*) ' on a trouve le point ' , ip if(icpr(ip).eq.0) then icdour=icdour+1 icpr(ip)=icdour endif if(ipass.eq.2) jpoob4(ib)=icpr(ip) endif enddo C C TRAVAILLER SUR LES POINTS DANS LES OBJETS C ITLACC=KCOLA(44) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,4112) (ITLAC(I),I=1,ITL) 4112 FORMAT (/,' LISTE DES OBJETS ACCESSIBLES',/,(10I8)) C RENUMEROTATION EN FONCTION DU PREMIER OBJET DO 4110 IOB=1,ITL MTABLE=ITLAC(IOB) SEGACT MTABLE*MOD DO 4120 I=1,MLOTAB IF (MTABTI(I).EQ.'POINT ') THEN IP=MTABII(I) IF (IP.EQ.0) then write(ioimp,*) 'tassp2 2' ENDIF IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if(ipass.eq.2) MTABII(I)=ICPR(IP) ENDIF IF (MTABTV(I).EQ.'POINT ') THEN IP=MTABIV(I) IF (IP.EQ.0) then write(ioimp,*) 'tassp2 3' ENDIF IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if(ipass.eq.2) MTABIV(I)=ICPR(IP) ENDIF 4120 CONTINUE SEGDES MTABLE 4110 CONTINUE C C TRAVAll sur les points dans les LISTOBJE C ITLACC=KCOLA(50) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1173) (ITLAC(I),I=1,ITL) 1173 FORMAT (/,' LISTE DES LISTOBJE ACCESSIBLES',/,(10I8)) DO 7300 IOB=1,ITL MLOBJE=ITLAC(IOB) SEGACT,MLOBJE*MOD IF (TYPOBJ.EQ.'POINT ') THEN DO 7310 K=1,LISOBJ(/1) IP=LISOBJ(K) IF (IP.EQ.0) write(6,*) 'tassp2 lisobj' IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if(ipass.eq.2) LISOBJ(K)=ICPR(IP) 7310 CONTINUE ENDIF SEGDES,MLOBJE 7300 CONTINUE C C Travail sur les points dans les nuages C ITLACC=KCOLA(41) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1121) (ITLAC(I),I=1,ITL) 1121 FORMAT (/,' LISTE DES NUAGES ACCESSIBLES',/,(10I8)) DO 7230 IOB=1,ITL MNUAGE=ITLAC(IOB) SEGACT MNUAGE DO 7231 I=1,NUAPOI(/1) IF(NUATYP(I).EQ.'POINT ')THEN NUAVIN=NUAPOI(I) SEGACT NUAVIN*MOD DO 7233 K=1,NUAINT(/1) IP=NUAINT(K) IF (IP.EQ.0) then write(ioimp,*) 'tassp2 4' ENDIF IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF if(ipass.eq.2) NUAINT(K)=ICPR(IP) 7233 CONTINUE SEGDES NUAVIN ENDIF 7231 CONTINUE SEGDES MNUAGE 7230 CONTINUE C TRAVAILLER SUR LES POINTS DANS LES MCHAML C ITLACC=KCOLA(39) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1113) (ITLAC(I),I=1,ITL) 1113 FORMAT (/,' LISTE DES IELVALS ACCESSIBLES',/,(10I8)) C RENUMEROTATION EN FONCTION DU PREMIER OBJET DO 210 IOB=1,ITL MCHELM=ITLAC(IOB) if (mchelm.eq.0) goto 210 SEGACT MCHELM DO 220 I=1,ICHAML(/1) MCHAML=ICHAML(I) SEGACT MCHAML*MOD DO 230 J=1,TYPCHE(/2) IF(TYPCHE(J).EQ.'POINTEURPOINT ') THEN MELVAL = IELVAL(J) IF(MELVAL.LT.0) GO TO 230 SEGACT MELVAL*MOD NAL1 = IELCHE(/1) NAL2 = IELCHE(/2) DO 250 I1=1,NAL1 if (ip.le.0) goto 250 IF(IP.EQ.0) then write(6,*)'tassp2 5',nomche(j),conche(i),imache(i) endif IF (ICPR(IP).EQ.0) THEN ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR ENDIF 250 CONTINUE 240 CONTINUE SEGACT,MELVAL*NOMOD IELVAL(J)=-MELVAL ENDIF 230 CONTINUE C PP ON DESACTIVE SEGACT,MCHAML*NOMOD 220 CONTINUE 210 CONTINUE C on remet tout dans l'etat initial DO 211 IOB=1,ITL MCHELM=ITLAC(IOB) if (mchelm.eq.0) goto 211 DO 221 I=1,ICHAML(/1) MCHAML=ICHAML(I) C PP ON REACTIVE SEGACT MCHAML*MOD DO 231 J=1,TYPCHE(/2) IF(TYPCHE(J).EQ.'POINTEURPOINT ') THEN IELVAL(J)=ABS(IELVAL(J)) MELVAL = IELVAL(J) SEGACT MELVAL*MOD NAL1 = IELCHE(/1) NAL2 = IELCHE(/2) DO 251 I1=1,NAL1 251 CONTINUE 241 CONTINUE SEGDES MELVAL ENDIF 231 CONTINUE SEGACT,MCHAML*NOMOD 221 CONTINUE SEGDES,MCHELM 211 CONTINUE C C CAS DE LA DEFORMATION PLANE GENERALISEE : C Les points supports etant maintenant stockes dans un maillage C (MELEME) de type POI1 (1 seul element), il n'y a plus de travail C specifique a realiser. NSDPGE n'est plus utilise aussi. C C Pour les CHARGEMENTS, les rares points utilises pour decrire le C mouvement du chargement sont maintenant stockes dans des maillages C (MELEME) et ne necessitent donc pas de traitement particulier. C A noter qu'avant ces points n'etaient pas traites, d'ou un risque de C probleme, suite a une renumerotation. C C travail sur le itlac des points deja sauves C IF(IPSAUV.NE.0) THEN ICOLA1=IPSAUV SEGACT ICOLA1 ITLAC2=ICOLA1.KCOLA(32) SEGACT ITLAC2*MOD IF(ITLAC2.ITLAC(/1).NE.0) THEN DO 560 K=1,ITLAC2.ITLAC(/1) If(icpr(ITLAC2.ITLAC(K)).eq.0) then icdour=icdour+1 icpr(ITLAC2.ITLAC(K))=icdour endif if(ipass.eq.2) ITLAC2.ITLAC(K) = icpr(ITLAC2.ITLAC(K)) 560 CONTINUE ENDIF SEGDES ICOLA1,ITLAC2 ENDIF C C travail sur les itlac des points communiques C if(piComm.gt.0) then piles=piComm segact piles do ipile=1,piles.proc(/1) jcolac= piles.proc(ipile) if(jcolac.ne.0) then segact jcolac pile = jcolac.kcola(32) segact pile*mod if(pile.itlac(/1).ne.0) then do k=1,pile.itlac(/1) if(icpr(pile.itlac(k)).eq.0) then icdour=icdour+1 icpr(pile.itlac(k))=icdour endif if(ipass.eq.2) pile.itlac(k) = icpr(pile.itlac(k)) enddo endif segdes jcolac,pile endif enddo segdes piles endif C C ON MET A LA SUITE LES POINTS NOMMES NON DEJA ACCEDES C POUR COMPLETER LA NOUVELLE LA NUMEROTATION ICPR DO 50 I=1,LMNNOM IF (INOOB2(I).NE.'POINT ') GOTO 50 IP=IOUEP2(I) IF (IP.EQ.0) GOTO 50 IF (ICPR(IP).NE.0) GOTO 51 ICDOUR=ICDOUR+1 ICPR(IP)=ICDOUR 51 CONTINUE if(ipass.eq.2) IOUEP2(I)=ICPR(IP) 50 CONTINUE if (ipass.eq.1) goto 1000 C ICPR CONTIENT LA NOUVELLE NUMEROTATION (LES POINTS A GARDER) C LES SEGMENTS D'ELEMENTS ONT ETE MIS A JOUR C DONC TASSER LES POINTS SEGACT MCOORD*mod ILG=ICDOUR*(IDIM+1) SEGINI TAB1 DO 22 I=ICPR(/1),1,-1 IF (ICPR(I).EQ.0) GOTO 22 DO 21 K=1,IDIM+1 XCOOR1((ICPR(I)-1)*(IDIM+1)+K)=XCOOR((I-1)*(IDIM+1)+K) 21 CONTINUE 22 CONTINUE C IL FAUT GARDER LE MEME POINTEUR SUR MCOORD NBPTS=ICDOUR SEGADJ MCOORD DO 23 K=1,ILG XCOOR(K)=XCOOR1(K) 23 CONTINUE SEGSUP TAB1 IF(MROTA.NE.0) THEN MROTAT=MROTA SEGACT MROTAT ILR=ICDOUR*IDIM SEGINI TAB2 DO 32 I=ICPR(/1),1,-1 IF (ICPR(I).EQ.0) GOTO 32 DO 31 K=1,IDIM RCOOR1((ICPR(I)-1)*IDIM+K)=XROTA((I-1)*IDIM+K) 31 CONTINUE 32 CONTINUE SEGADJ MROTAT DO 33 K=1,ILR XROTA(K)=RCOOR1(K) 33 CONTINUE SEGSUP TAB2 ENDIF C C petit travail pour les objets configuration! C MCOOR1=MCOORD ITLACC=KCOLA(33) ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1114) (ITLAC(I),I=1,ITL) 1114 FORMAT (/,' LISTE DES CONFIGURATIONS ACCESSIBLES',/,(10I8)) DO 70 IOB=1,ITL MCOORD=ITLAC(IOB) if (mcoord.eq.mcoor1) then goto 70 endif SEGACT MCOORD*mod IMA=xcoor(/1)/(idim+1) ILG=ICDOUR*(IDIM+1) SEGINI TAB1 DO 2201 I=ICPR(/1),IMA+1,-1 IF (ICPR(I).EQ.0) GOTO 2201 DO 2101 K=1,IDIM+1 XCOOR1((ICPR(I)-1)*(IDIM+1)+K)= > MCOOR1.XCOOR((ICPR(I)-1)*(IDIM+1)+K) 2101 CONTINUE 2201 CONTINUE DO 2200 I=MIN(IMA,ICPR(/1)),1,-1 IF (ICPR(I).EQ.0) GOTO 2200 DO 2100 K=1,IDIM+1 XCOOR1((ICPR(I)-1)*(IDIM+1)+K)=XCOOR((I-1)*(IDIM+1)+K) 2100 CONTINUE 2200 CONTINUE C IL FAUT GARDER LE MEME POINTEUR SUR MCOORD NBPTS=ICDOUR SEGADJ MCOORD DO 2300 K=1,ILG XCOOR(K)=XCOOR1(K) 2300 CONTINUE SEGSUP TAB1 SEGDES MCOORD 70 CONTINUE MCOORD=MCOOR1 segact mcoord*mod nbpts=xcoor(/1)/(idim+1) C on garde icpr pour construire le maillage resultat C SEGSUP ICPR C ILP=ICDOUR C------------------------------------------------------------------ C on travaille sur les champs de points pour signaler le cas C de points multiples C C on recherche les noms des objets C attention fillno desactive icolac SEGACT ICOLAC*MOD ITLAC1= KCOLA(1) ITLACC=KCOLA(2) SEGACT ITLACC*MOD ITL=ITLAC(/1) IF (IIMPI.EQ.9) WRITE(IOIMP,1115) (ITLAC(I),I=1,ITL) 1115 FORMAT (/,' LISTE DES OBJETS ACCESSIBLES',/,(10I8)) C NPM = ICDOUR SEGINI ITRAV C BOUCLE SUR LES CHAMPS DE POINTS DE LA PILE ITLACC DO 550 I=1,ITL MCHPOI=ITLAC(I) IF (MCHPOI.EQ.0) goto 550 SEGACT MCHPOI NSOUPO=IPCHP(/1) C C BOUCLE SUR LES SOUS CHAMP DE POINTS DO 520 J=1,NSOUPO MSOUPO=IPCHP(J) SEGACT MSOUPO MELEME=IGEOC SEGACT MELEME IF ( LISOUS(/1) .NE. 0 ) GOTO 515 C BOUCLE SUR LES POINTS DU SOUS CHAMP DO I1=1,NUM(/1) C ITRAV CONTIENT LE NBRE D'OCCURENCE DE CHAQUE POINT enddo enddo 515 CONTINUE 520 CONTINUE C C Y A T-IL UN NOEUD DOUBLE ? C C FLAG = .FALSE. DO 521 J=1,NSOUPO MSOUPO=IPCHP(J) SEGACT MSOUPO MELEME=IGEOC SEGACT,MELEME IF ( LISOUS(/1) .NE. 0 ) GOTO 516 C BOUCLE SUR LES POINTS DU SOUS CHAMP DO I1=1,NUM(/1) C ICHPOI = MCHPOI iratt=0 segact meleme ITLAC(I)=ICHPOI IF (Iratt .NE. 0 ) THEN ISGTR = ICOLA(2) C le chpoint a t-il un nom MOTERR =' ' DO 530 JJ=1,ISGTRC(/2) IF ( ISGTRI(JJ) .EQ. I ) MOTERR = ISGTRC(I) 530 CONTINUE C INTERR(2)= MCHPOI c remise a zero de ierr por pouvoir afficher les erreurs suivantes IERR = 0 ENDIF ENDIF C enddo enddo C SEGDES MELEME 516 continue C SEGDES MSOUPO 521 CONTINUE c SEGACT ITLAC1*MOD MCHPO1=mCHPOI SEGACT MCHPO1 ILISSE=ILISSG SEGACT ILISSE*MOD DO 566 IOU=1,MCHPO1.IPCHP(/1) MSOUP1=MCHPO1.IPCHP(IOU) SEGACT MSOUP1 IGE=MSOUP1.IGEOC C SEGDES MSOUP1 566 CONTINUE C SEGDES ILISSE C SEGDES MCHPO1 C C SEGDES MCHPOI 550 CONTINUE C SEGsup ITRAV 570 CONTINUE segact icolac*mod C------------------------------------------------------------------ C ON APPELLE MAINTENANT MENAG5 POUR FAIRE LE NETTOYAGE DE LA MEMOIRE C CALL MENAG5(ICOLAC,ITLAC1) C ON NOTE QUE ITLAC1 N'A PAS ETE DETRUIT (DANS MENAG5) c RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales