You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
145 lines
5.1 KiB
145 lines
5.1 KiB
2 years ago
|
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
|