C Copyright(C) 1999-2020 National Technology & Engineering Solutions C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with C NTESS, the U.S. Government retains certain rights in this software. C C See packages/seacas/LICENSE for details C======================================================================= SUBROUTINE PXN (RETMIN, PARTYP, LENARY, NELBLK, IXELB, ISEVOK, & NUMIX, IXNODE, IXELEM, PARM1, PARM2, PARM3, & PARM4, PARM5, PARM6, RESULT, *) C======================================================================= C --*** PXN *** (ALGEBRA) Calculate 3x3 principal values C -- Written by Amy Gilkey - revised 05/17/88 C -- C --PXN determines the minimum or maximum principal values. C -- C --Parameters: C -- RETMIN - IN - true iff minimum versus maximum to be calculated C -- PARTYP - IN - the parameter type (element must be handled differently) C -- LENARY - IN - the length of the parameter arrays C -- NELBLK - IN - the number of element blocks C -- IXELB - IN - the cumulative element counts for each element block C -- ISEVOK - IN - the element variable truth table for each element block C -- NUMIX - IN - the number of selected values; <0 if all C -- IXNODE - IN - the indices of the selected nodes (only if NUMIX>=0) C -- IXELEM - IN - the indices of the selected elements (only if NUMIX>=0) C -- PARM1, PARM2, PARM3, PARM4, PARM5, PARM6 - IN - the tensor components C -- RESULT - OUT - the returned principal values C -- * - OUT - return statement if an error is found LOGICAL RETMIN CHARACTER PARTYP INTEGER IXELB(0:NELBLK) LOGICAL ISEVOK(*) INTEGER IXNODE(*) INTEGER IXELEM(*) REAL PARM1(*), PARM2(*), PARM3(*), PARM4(*), PARM5(*), PARM6(*) REAL RESULT(*) REAL EV(3) CHARACTER*5 STRA IF (NUMIX .GE. 0) THEN IF (PARTYP .NE. 'E') THEN DO 100 I = 1, NUMIX J = IXNODE(I) CALL PRINC3 (PARM1(J), PARM2(J), PARM3(J), PARM4(J), $ PARM5(J), PARM6(J), EV, INFO) IF (INFO .NE. 0) THEN CALL INTSTR (1, 0, INFO, STRA, LSTRA) CALL PRTERR ('FATAL', & 'Library function PRINC3 has an error = ' & // STRA(:LSTRA)) GOTO 160 END IF IF (RETMIN) THEN RESULT(J) = EV(1) ELSE RESULT(J) = EV(3) END IF 100 CONTINUE ELSE DO 120 IELB = 1, NELBLK IF (ISEVOK(IELB)) THEN DO 110 I = IXELB(IELB-1)+1, IXELB(IELB) J = IXELEM(I) CALL PRINC3 (PARM1(J), PARM2(J), PARM3(J), $ PARM4(J), PARM5(J), PARM6(J), EV, INFO) IF (INFO .NE. 0) THEN CALL INTSTR (1, 0, INFO, STRA, LSTRA) CALL PRTERR ('FATAL', & 'Library function PRINC3 has an error = ' & // STRA(:LSTRA)) GOTO 160 END IF IF (RETMIN) THEN RESULT(J) = EV(1) ELSE RESULT(J) = EV(3) END IF 110 CONTINUE END IF 120 CONTINUE END IF ELSE C NUMIX < 0; ALL VALUES ARE SELECTED C NUMEL=NUMELO; NUMNP=NUMNPO; IXELB(J)+IXELBO(J) J=1,NELBLK IF (PARTYP .NE. 'E') THEN DO 130 J = 1, LENARY CALL PRINC3 (PARM1(J), PARM2(J), PARM3(J), PARM4(J), $ PARM5(J), PARM6(J), EV, INFO) IF (INFO .NE. 0) THEN CALL INTSTR (1, 0, INFO, STRA, LSTRA) CALL PRTERR ('FATAL', & 'Library function PRINC3 has an error = ' & // STRA(:LSTRA)) GOTO 160 END IF IF (RETMIN) THEN RESULT(J) = EV(1) ELSE RESULT(J) = EV(3) END IF 130 CONTINUE ELSE DO 150 IELB = 1, NELBLK IF (ISEVOK(IELB)) THEN DO 140 J = IXELB(IELB-1)+1, IXELB(IELB) CALL PRINC3 (PARM1(J), PARM2(J), PARM3(J), $ PARM4(J), PARM5(J), PARM6(J), EV, INFO) IF (INFO .NE. 0) THEN CALL INTSTR (1, 0, INFO, STRA, LSTRA) CALL PRTERR ('FATAL', & 'Library function PRINC3 has an error = ' & // STRA(:LSTRA)) GOTO 160 END IF IF (RETMIN) THEN RESULT(J) = EV(1) ELSE RESULT(J) = EV(3) END IF 140 CONTINUE END IF 150 CONTINUE END IF END IF RETURN 160 CONTINUE RETURN 1 END