devfb2
C DEVFB2 SOURCE BP208322 20/09/18 21:15:27 10718 & NPLB,IND,IND1,INDM1,NPA,NPAM1,IND2,PDT,PDTS2, & FEXPSM,NPC1,XABSCI,XORDON,NIP,I,iannul) *--------------------------------------------------------------------* * * * Operateur DYNE et DYNC : * * Calcul des forces de choc pour les liaisons B de type : * * - POINT_POINT avec ou sans amortissement * * - POINT_POINT_FROTTEMENT avec ou sans amortissement * * * *--------------------------------------------------------------------* * * * Parametres: * * * * e ITYP type de la liaison. * * es FTOTB Forces exterieures totalisees sur la base B. * * e XPTB Tableau des deplacements des points * * e IPALB Renseigne sur la liaison. * * e IPLIB Tableau contenant les numeros "DYNE" de la liaison. * * e XPALB Tableau contenant les parametres de la liaison. * * es XVALB Tableau contenant les variables internes de liaisons. * * e NLIAB Nombre de liaisons sur la base B. * * e NPLB Nombre total de points intervenant dans les liaisons. * * e IND Indice du pas. * * e I numero de la liaison. * * * *--------------------------------------------------------------------* IMPLICIT INTEGER(I-N) IMPLICIT REAL*8(A-H,O-Z) * INTEGER IPALB(NLIAB,*),IPLIB(NLIAB,*) REAL*8 XPALB(NLIAB,*),XPTB(NPLB,2,*),FTOTB(NPLB,*) REAL*8 XVALB(NLIAB,4,*),FEXPSM(NPLB,NPC1,2,*) REAL*8 XABSCI(NLIAB,NIP),XORDON(NLIAB,NIP) * * *--------------------------------------------------------------------* * --- choc elementaire POINT_POINT avec amortissement *--------------------------------------------------------------------* * IF (ITYP.EQ.11 .OR. ITYP.EQ.111) THEN NPOA = IPLIB(I,1) NPOB = IPLIB(I,2) IDIM = IPALB(I,3) IPERM = IPALB(I,4) XRAID = XPALB(I,1) XJEU = XPALB(I,2) XAMO = XPALB(I,3) ETA = 0.D0 XDEP = 0.D0 cbp,2020-09 XDEPM1 = 0.D0 XVIT = 0.D0 DO 20 ID = 1,IDIM IDA = 3 + ID IDB = 3 + IDIM + ID XDEA = XPTB(NPOA,1,ID) cbp,2020-09 XDMA = XPTB(NPOA,IND2,ID) XVIA = XPTB(NPOA,2,ID) XDEB = XPTB(NPOB,1,ID) cbp,2020-09 XDMB = XPTB(NPOB,IND2,ID) XVIB = XPTB(NPOB,2,ID) XVALB(I,IND,IDA) = XDEA XVALB(I,IND,IDB) = XDEB XDEA = XDEA + FEXPSM(NPOA,NPA,IND1,ID) XDEB = XDEB + FEXPSM(NPOB,NPA,IND1,ID) cbp,2020-09 XDMA = XDMA + FEXPSM(NPOA,NPAM1,INDM1,ID) cbp,2020-09 XDMB = XDMB + FEXPSM(NPOB,NPAM1,INDM1,ID) XDEP = XDEP + (XDEA - XDEB) * XPALB(I,3+ID) cbp,2020-09 XDEPM1 = XDEPM1 + (XDMA - XDMB) * XPALB(I,3+ID) XVIT = XVIT + (XVIA - XVIB) * XPALB(I,3+ID) 20 CONTINUE cbp,2020-09 XVIT = (XDEP - XDEPM1) / PDTS2 XVALB(I,IND,3) = XVIT IF (ITYP.EQ.11) THEN & XFLA,DFDX,DFDV,IPERM,iannul) ELSE & NLIAB,I, XFLA,IPERM,iannul) ENDIF XFLB = -1.D0 * XFLA XVALB(I,IND,1) = XFLA XVALB(I,IND,2) = XFLB DO 22 ID = 1,IDIM FTOTB(NPOA,ID) = FTOTB(NPOA,ID) + XFLA * XPALB(I,3+ID) FTOTB(NPOB,ID) = FTOTB(NPOB,ID) + XFLB * XPALB(I,3+ID) 22 CONTINUE * *--------------------------------------------------------------------* * --- choc elementaire POINT_POINT_FROTTEMENT avec ou sans amortissement *--------------------------------------------------------------------* * ELSEIF ((ITYP.EQ.13) .or. ( ityp .eq. 113)) THEN NPOA = IPLIB(I,1) NPOB = IPLIB(I,2) IGP = IPALB(I,2) IDIM = IPALB(I,3) ID1 = 7 ID2 = ID1 + IDIM ID3 = ID1 + 2*IDIM ID4 = ID1 + 3*IDIM ID5 = ID1 + 4*IDIM ID6 = ID1 + 5*IDIM ID7 = ID1 + 6*IDIM * Si glissement au pas precedent, reactualisation de la position-ecart * origine d'adherence IF (IGP.EQ.1 .OR. IGP.EQ.-1) THEN DO 30 ID=1,IDIM XPALB(I,ID5+ID) =(XPTB(NPOa,1,ID) + & FEXPSM(NPOa,NPA,IND1,ID) ) & - ( XPTB(NPOb,1,ID) + & FEXPSM(NPOb,NPA,IND1,ID)) 30 CONTINUE ENDIF * Calcul de l'enfoncement relatif et de la vitesse normale relative XDEP = 0.D0 XVITN= 0.D0 PSN0 = 0.D0 DO 32 ID = 1,IDIM IDD1 = 3 + ID xvalb(i,ind,idd1) = XPTB(NPOa,1,ID) xvalb(i,ind,idd1 + idim) = XPTB(NPOb,1,ID) XDE2 = XPTB(NPOa,1,ID) - XPTB (NPOb,1,ID) XDE2 = XDE2 + FEXPSM(NPOa,NPA,IND1,ID) & - FEXPSM(NPOb,NPA,IND1,ID) cbp,2020-09 XDM2 = XPTB(NPOa,IND2,ID) - XPTB (NPOb,IND2,ID) cbp,2020-09 XDM2 = XDM2 + FEXPSM(NPOA,NPAM1,INDM1,ID) cbp,2020-09 & - FEXPSM(NPOb,NPAM1,INDM1,ID) cbp,2020-09 XPALB(I,ID2+ID) = XDE2 - XDM2 XPALB(I,ID2+ID) = XPTB(NPOa,2,ID) - XPTB (NPOb,2,ID) XPALB(I,ID3+ID) = XDE2 - XPALB(I,ID5+ID) XDEP = XDEP + XDE2 * XPALB(I,ID1+ID) XVITN= XVITN+ XPALB(I,ID2+ID) * XPALB(I,ID1+ID) PSN0 = PSN0 + XPALB(I,ID3+ID) * XPALB(I,ID1+ID) 32 CONTINUE * Projette la vitesse relative * et la variation de deplacement relatif par rapport a * l' ecart origine d'adherence sur le plan tangent DO 34 ID = 1,IDIM XPALB(I,ID2+ID) = (XPALB(I,ID2+ID) - XVITN*XPALB(I,ID1+ID)) cbp,2020-09 & / PDTS2 XPALB(I,ID3+ID) = XPALB(I,ID3+ID) - PSN0 * XPALB(I,ID1+ID) 34 CONTINUE cbp,2020-09 XVITN = PSN / PDTS2 XVALB(I,IND,3) = XVITN IF (ITYP.EQ.13) THEN & ,iannul) ELSE & XABSCI,XORDON,NIP,iannul) ENDIF Xfla = XFN Xflb = -1d0 * XFN XVALB(I,IND,1) = XFla XVALB(I,IND,2) = XFlb XVALB(I,IND,10) = ABS(XFT) XVALB(I,IND,12) = XPUS IPALB(I,2) = IGP * Si glissement, memorisation de la vitesse tangentielle et de la force * tangentielle IF (IGP.EQ.1.OR.IGP.EQ.-1) THEN DO 36 ID = 1,IDIM XPALB(I,ID6+ID) = XPALB(I,ID2+ID) XPALB(I,ID7+ID) = XPALB(I,ID4+ID) 36 CONTINUE ENDIF DO 38 ID = 1,IDIM FTOTB(NPOa,ID) = FTOTB(NPOa,ID) + XFla* XPALB(I,ID1+ID) & + XPALB(I,ID4+ID) FTOTB(NPOb,ID) = FTOTB(NPOb,ID) + XFlb* XPALB(I,ID1+ID) & - XPALB(I,ID4+ID) 38 CONTINUE ***************************************************************** *--------------------------------------------------------------------* ** modele de Nedjai. On ne garantit rien --> a supprimer ? *--------------------------------------------------------------------* ELSEIF (ITYP.EQ.-13) THEN NPOA = IPLIB(I,1) NPOB = IPLIB(I,2) IGP = IPALB(I,2) IDIM = IPALB(I,3) ID1 = 7 ID2 = ID1 + IDIM ID3 = ID1 + 2*IDIM ID4 = ID1 + 3*IDIM ID5 = ID1 + 4*IDIM ID6 = ID1 + 5*IDIM ID7 = ID1 + 6*IDIM * Si glissement au pas precedent, reactualisation de la position-ecart * origine d'adherence IF (IGP.EQ.1 .OR. IGP.EQ.-1) THEN DO 130 ID=1,IDIM XPALB(I,ID5+ID) =(XPTB(NPOa,1,ID) + & FEXPSM(NPOa,NPA,IND1,ID) ) & - ( XPTB(NPOb,1,ID) + & FEXPSM(NPOb,NPA,IND1,ID)) 130 CONTINUE ENDIF * Calcul de l'enfoncement relatif et de la vitesse normale relative XDEP = 0.D0 XVITN= 0.D0 PSN0 = 0.D0 DO 132 ID = 1,IDIM IDD1 = 3 + ID xvalb(i,ind,idd1) = XPTB(NPOa,1,ID) xvalb(i,ind,idd1 + idim) = XPTB(NPOb,1,ID) XDE2 = XPTB(NPOA,1,ID) - XPTB (NPOB,1,ID) XDE2 = XDE2 + FEXPSM(NPOa,NPA,IND1,ID) & - FEXPSM(NPOb,NPA,IND1,ID) cbp,2020-09 XDm2 = XPTB(NPOa,IND2,ID) - xptb (npob,ind2,id) cbp,2020-09 XDM2 = XDM2 + FEXPSM(NPOA,NPAM1,INDM1,ID) cbp,2020-09 & - FEXPSM(NPOb,NPAM1,INDM1,ID) cbp,2020-09 XPALB(I,ID2+ID) = XDE2 - XDM2 XPALB(I,ID2+ID) = XPTB(NPOa,2,ID) - xptb (npob,2,id) *A ENLEVER**XPALB(I,ID3+ID) = XDE2 - XPALB(I,ID5+ID) XDEP = XDEP + XDE2 * XPALB(I,ID1+ID) XVITN= XVITN+ XPALB(I,ID2+ID) * XPALB(I,ID1+ID) PSN0 = PSN0 + XPALB(I,ID3+ID) * XPALB(I,ID1+ID) 132 CONTINUE * Projette la vitesse relative * et la variation de deplacement relatif par rapport a * l' ecart origine d'adherence sur le plan tangent DO 134 ID = 1,IDIM XPALB(I,ID2+ID) = (XPALB(I,ID2+ID) - XVITN*XPALB(I,ID1+ID)) cbp,2020-09 & / PDTS2 *A enlever**XPALB(I,ID3+ID) = XPALB(I,ID3+ID) - PSN0 * XPALB(I,ID1+ID) 134 CONTINUE cbp,2020-09 XVITN = PSN / PDTS2 XVALB(I,IND,3) = XVITN ***RAJOUT DE XPAS DANS CALL DYCHA4 & ,iannul,PDTS2) Xfla = XFN Xflb = -1d0 * XFN XVALB(I,IND,1) = XFla XVALB(I,IND,2) = XFlb XVALB(I,IND,10) = ABS(XFT) XVALB(I,IND,12) = XPUS IPALB(I,2) = IGP * Si glissement, memorisation de la vitesse tangentielle et de la force * tangentielle *AENLEV**IF (IGP.EQ.1.OR.IGP.EQ.-1) THEN DO 136 ID = 1,IDIM **ON A REMPLACE ID6 PAR ID3 (NEDJAI) XPALB(I,ID3+ID) = XPALB(I,ID2+ID) XPALB(I,ID7+ID) = XPALB(I,ID4+ID) 136 CONTINUE **AENLEV**ENDIF DO 138 ID = 1,IDIM FTOTB(NPOa,ID) = FTOTB(NPOa,ID) + XFla* XPALB(I,ID1+ID) & + XPALB(I,ID4+ID) FTOTB(NPOb,ID) = FTOTB(NPOb,ID) + XFlb* XPALB(I,ID1+ID) & - XPALB(I,ID4+ID) 138 CONTINUE * * --- choc ........... * * ELSE IF (ITYP.EQ. ) THEN * ....... * ....... * ENDIF * END
© Cast3M 2003 - Tous droits réservés.
Mentions légales