Cloned SEACAS for EXODUS library with extra build files for internal package management.
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.

70 lines
1.9 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
SUBROUTINE PRINC3(SK1, SK2, SK3, SK4, SK5, SK6, EV, INFO)
REAL EV(3)
REAL I1, I2, I3
INTEGER INFO
PARAMETER (THIRD = 0.33333 33333 33333 33333 33333)
SQRT3 = SQRT(3.0)
INFO = 0
C Find principal trial stresses and directions -
I1 = ( SK1 + SK2 + SK3 )
I2 = ( (SK1-SK2)**2 + (SK1-SK3)**2 + (SK2-SK3)**2 ) / 6.0
* + SK4**2 + SK5**2 + SK6**2
S1 = ( (SK1 - SK2) + (SK1 - SK3) ) * THIRD
S2 = (-(SK1 - SK2) + (SK2 - SK3) ) * THIRD
S3 = (-(SK1 - SK3) - (SK2 - SK3) ) * THIRD
I3 = S1 * S2 * S3 + 2.*SK4 * SK5 * SK6
* - S1 * SK5**2 - S2 * SK6**2
* - S3 * SK4**2
C Calculate constants for Malvern Method (p92)
C .... This sign trick does not work on Ultrix (and others?) with IEEE
C since IEEE has a signed 0...........
CC FI2 = I2 + (SIGN (0.5, I2) + SIGN (0.5, -I2))
IF (I2 .EQ. 0.0) THEN
FI2 = 1.0
ELSE
FI2 = I2
END IF
COS3AL = SQRT3 * 1.5 * I3 / FI2 / SQRT(FI2)
COS3AL = SIGN( MIN( 1.0, ABS(COS3AL) ),COS3AL )
C ... TRIG FUNCTION USED
CALPHA = COS( ACOS(COS3AL) / 3.0)
SALPHA = SQRT(1.0 - CALPHA**2)
T = SQRT3 * SQRT(I2)
P1 = (I1 + T * 2. * CALPHA ) * THIRD
P2 = (I1 - T * (CALPHA + SALPHA * SQRT3)) * THIRD
P3 = (I1 - T * (CALPHA - SALPHA * SQRT3)) * THIRD
C ... Sort Into Correct Position (ev1 < ev2 < ev3)
EV(1) = MIN(P1, P2, P3)
EV(3) = MAX(P1, P2, P3)
C ... This is bad from a round-off perspective, but we don't use the
C value in algebra. Be warned if use where you need an accurate
C ev(2).....
EV(2) = P1 + P2 + P3 - EV(1) - EV(3)
RETURN
END