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.

127 lines
4.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
C=======================================================================
SUBROUTINE SCAPRT (NAMECO, NAME, IVAR, TIMES,
& VALMIN, NUMMIN, XYZMIN, ISTMIN, VALMAX, NUMMAX, XYZMAX, ISTMAX)
C=======================================================================
C --*** SCAPRT *** (BLOT) Print variable min/max
C -- Written by Amy Gilkey - revised 04/01/88
C --
C --SCAPRT prints the minimum and maximum values for the desired variable.
C --
C --Parameters:
C -- NAMECO - IN - the coordinate names
C -- NAME - IN - the variable name
C -- IVAR - IN - the variable index
C -- TIMES - IN - the database times
C -- VALMIN, VALMAX - IN - the minimum and maximum value
C -- (with selected element block and birth/death)
C -- NUMMIN, NUMMAX - IN - the node or element number of the minimum and
C -- maximum value (nodal and element variable only)
C -- XYZMIN, XYZMAX - IN - the coordinates of NUMMIN, NUMMAX
C -- ISTMIN, ISTMAX - IN - the step number of the minimum and maximum
C -- value
C --
C --Common Variables:
C -- Uses NDIM of /DBNUMS/
include 'dbnums.blk'
CHARACTER*(*) NAMECO(*)
CHARACTER*(*) NAME
REAL TIMES(*)
REAL XYZMIN(3), XYZMAX(3)
REAL RVAL(2), RXYZ(2,3), RTIM(2)
CHARACTER*20 SVAL(0:2), SXYZ0(3), SXYZ(2,3), STIM(0:2)
CHARACTER*4 STR4
CHARACTER TYP
IF ((ISTMIN .LE. 0) .OR. (VALMIN .EQ. VALMAX)) THEN
CALL NUMSTR1(4, VALMIN, SVAL(1), LVAL)
WRITE (*, 10060) NAME(:LENSTR(NAME)),
& ' does not vary - all values = ', SVAL(1)(:LVAL)
ELSE
CALL DBVTYP_BL (IVAR, TYP, IDUM)
RVAL(1) = VALMIN
RVAL(2) = VALMAX
CALL NUMSTR (2, 4, RVAL, SVAL(1), LVAL)
CALL CENLAB ('Value', 2, SVAL(1), LVAL, SVAL(0))
IF ((TYP .EQ. 'N') .OR. (TYP .EQ. 'E')) THEN
NNDIM = MAX (MIN (NDIM, 3), 2)
DO 100 I = 1, MIN (NDIM, 3)
RXYZ(1,I) = XYZMIN(I)
RXYZ(2,I) = XYZMAX(I)
100 CONTINUE
CALL NUMSTR (NNDIM * 2, 3, RXYZ, SXYZ(1,1), LX)
LY = LX
LZ = LX
CALL CENLAB (NAMECO(1), 2, SXYZ(1,1), LX, SXYZ0(1))
CALL CENLAB (NAMECO(2), 2, SXYZ(1,2), LY, SXYZ0(2))
IF (NDIM .GE. 3) THEN
CALL CENLAB (NAMECO(3), 2, SXYZ(1,3), LZ, SXYZ0(3))
END IF
END IF
RTIM(1) = TIMES(ISTMIN)
RTIM(2) = TIMES(ISTMAX)
CALL NUMSTR (2, 4, RTIM, STIM(1), LTIM)
CALL CENLAB ('Time', 2, STIM(1), LTIM, STIM(0))
IF ((TYP .EQ. 'N') .OR. (TYP .EQ. 'E')) THEN
IF (TYP .EQ. 'N') THEN
STR4 = 'Node'
ELSE
STR4 = 'Elem'
END IF
IF (NDIM .LE. 2) THEN
WRITE (*, 10000) 'Range: ', SVAL(0)(:LVAL),
& SXYZ0(1)(:LX), SXYZ0(2)(:LY),
& STIM(0)(:LTIM), STR4, 'Step'
WRITE (*, 10010, IOSTAT=IDUM) 'Minimum', SVAL(1)(:LVAL),
& SXYZ(1,1)(:LX), SXYZ(1,2)(:LY),
& STIM(1)(:LTIM), NUMMIN, ISTMIN
WRITE (*, 10010, IOSTAT=IDUM) 'Maximum', SVAL(2)(:LVAL),
& SXYZ(2,1)(:LX), SXYZ(2,2)(:LY),
& STIM(2)(:LTIM), NUMMAX, ISTMAX
10000 FORMAT (4X, A7, 1X, A, 3X, 2 (1X, A),
& 4X, A, 3X, A4, 3X, A4)
10010 FORMAT (4X, A7, 1X, A, 3X, 2 (1X, A), 4X, A, I7, I7)
ELSE
WRITE (*, 10020) 'Range: ', SVAL(0)(:LVAL),
& SXYZ0(1)(:LX), SXYZ0(2)(:LY), SXYZ0(3)(:LZ),
& STIM(0)(:LTIM), STR4, 'Step'
WRITE (*, 10030, IOSTAT=IDUM) 'Minimum', SVAL(1)(:LVAL),
& SXYZ(1,1)(:LX), SXYZ(1,2)(:LY), SXYZ(1,3)(:LZ),
& STIM(1)(:LTIM), NUMMIN, ISTMIN
WRITE (*, 10030, IOSTAT=IDUM) 'Maximum', SVAL(2)(:LVAL),
& SXYZ(2,1)(:LX), SXYZ(2,2)(:LY), SXYZ(2,3)(:LZ),
& STIM(2)(:LTIM), NUMMAX, ISTMAX
10020 FORMAT (4X, A7, 1X, A, 3X, 3 (1X, A),
& 4X, A, 3X, A4, 3X, A4)
10030 FORMAT (4X, A7, 1X, A, 3X, 3 (1X, A), 4X, A, I7, I7)
END IF
ELSE
WRITE (*, 10040) 'Range: ', SVAL(0)(:LVAL),
& STIM(0)(:LTIM), 'Step'
WRITE (*, 10050, IOSTAT=IDUM) 'Minimum', SVAL(1)(:LVAL),
& STIM(1)(:LTIM), ISTMIN
WRITE (*, 10050, IOSTAT=IDUM) 'Maximum', SVAL(2)(:LVAL),
& STIM(2)(:LTIM), ISTMAX
10040 FORMAT (4X, A7, 1X, A, 4X, A, 3X, A4)
10050 FORMAT (4X, A7, 1X, A, 4X, A, I7)
END IF
END IF
RETURN
10060 FORMAT (' *** WARNING - ', 5A)
END