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.

187 lines
6.2 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 PRTIMS (OPTION, NOUT, ALLPRT, ALLTIM,
& NSTEPS, TIMES, WHOTIM)
C=======================================================================
C --*** PRTIMS *** (BLOT) Display database time step times
C -- Written by Amy Gilkey - revised 12/23/87
C --
C --PRTIMS displays the time for all time steps.
C --
C --Parameters:
C -- OPTION - IN - '*' to print all, else print options:
C -- 'N' to print the number of time steps
C -- 'M' to print the minimum and maximum time step times
C -- 'T' to print the time step times
C -- NOUT - IN - the output file, <=0 for standard
C -- ALLPRT - IN - the type of time steps to print:
C -- true to print both whole and history information;
C -- false to print whole time steps
C -- ALLTIM - IN - the type of the input time steps:
C -- true if whole and history information;
C -- false if whole time steps only
C -- NSTEPS - IN - the number of time steps
C -- TIMES - IN - the times for each time step
C -- WHOTIM - IN - true iff TIMES(i) is whole (versus history) time step
CHARACTER*(*) OPTION
LOGICAL ALLPRT, ALLTIM
REAL TIMES(*)
LOGICAL WHOTIM(*)
LOGICAL ISABRT
CHARACTER*80 STRING
CHARACTER*5 ISTRA
CHARACTER*20 RSTR(3)
REAL RNUM(3)
IF (NOUT .GT. 0) WRITE (NOUT, 10030)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, *)
ELSE
WRITE (*, *)
END IF
IF (ALLTIM) THEN
NSTEPW = NUMEQL (.TRUE., NSTEPS, WHOTIM)
ELSE
NSTEPW = NSTEPS
END IF
NSTEPH = NSTEPS - NSTEPW
IF (ALLPRT) THEN
NSTEPX = NSTEPS
ELSE
NSTEPX = NSTEPW
END IF
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'N') .GT. 0)) THEN
WRITE (STRING, 10000, IOSTAT=IDUM) NSTEPS
10000 FORMAT ('Number of time steps = ', I5)
CALL SQZSTR (STRING, LSTR)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10050) STRING(:LSTR)
ELSE
WRITE (*, 10050) STRING(:LSTR)
END IF
END IF
IF (((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'M') .GT. 0))
& .AND. (NSTEPX .GT. 0)) THEN
IF (ALLTIM .AND. (.NOT. ALLPRT)) THEN
CALL MINMXL (NSTEPS, WHOTIM, TIMES, TIMMIN, TIMMAX)
ELSE
CALL MINMAX (NSTEPS, TIMES, TIMMIN, TIMMAX)
END IF
IF (NSTEPX .EQ. 1) THEN
CALL NUMSTR1(8, TIMMIN, RSTR, LSTR)
IF (ALLPRT) THEN
WRITE (STRING, 10040) 'Time = ', RSTR(1)(:LSTR)
ELSE
WRITE (STRING, 10040) 'Whole Time = ', RSTR(1)(:LSTR)
END IF
LSTR = LENSTR (STRING)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10060) STRING(:LSTR)
ELSE
WRITE (*, 10060) STRING(:LSTR)
END IF
ELSE
RNUM(1) = TIMMIN
RNUM(2) = TIMMAX
CALL NUMSTR (2, 8, RNUM, RSTR, LSTR)
IF (ALLPRT) THEN
WRITE (STRING, 10040)
& 'Minimum time = ', RSTR(1)(:LSTR)
ELSE
WRITE (STRING, 10040)
& 'Minimum whole time = ', RSTR(1)(:LSTR)
END IF
LSTR = LENSTR (STRING)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10060) STRING(:LSTR)
ELSE
WRITE (*, 10060) STRING(:LSTR)
END IF
IF (ALLPRT) THEN
LSTR = LENSTR(RSTR(2))
WRITE (STRING, 10040)
& 'Maximum time = ', RSTR(2)(:LSTR)
ELSE
LSTR = LENSTR(RSTR(2))
WRITE (STRING, 10040)
& 'Maximum whole time = ', RSTR(2)(:LSTR)
END IF
LSTR = LENSTR (STRING)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10060) STRING(:LSTR)
ELSE
WRITE (*, 10060) STRING(:LSTR)
END IF
END IF
END IF
IF (((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'T') .GT. 0))
& .AND. (NSTEPX .GT. 0)) THEN
CALL INTSTR (1, 0, NSTEPS, ISTRA, LISTR)
RNUM(2) = TIMES(1)
IF ((RNUM(2) .EQ. 0.0) .AND. (NSTEPS .GT. 1))
& RNUM(2) = TIMES(2)
RNUM(3) = TIMES(NSTEPS)
IF (ALLTIM .AND. (.NOT. ALLPRT)) THEN
DO 100 I = 1, NSTEPS
IF (WHOTIM(I)) THEN
IF (ISABRT ()) RETURN
CALL INTSTR (1, LISTR, I, ISTRA, LI)
RNUM(1) = TIMES(I)
CALL NUMSTR (3, 8, RNUM, RSTR, LSTR)
WRITE (STRING, 10020)
& ISTRA(:LI), RSTR(1)(:LSTR)
10020 FORMAT ('Step ', A, ')', 3X, A, :, 3X, A)
LSTR = LENSTR (STRING)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10060) STRING(:LSTR)
ELSE
WRITE (*, 10060) STRING(:LSTR)
END IF
END IF
100 CONTINUE
ELSE
DO 110 I = 1, NSTEPS
CALL INTSTR (1, LISTR, I, ISTRA, LI)
RNUM(1) = TIMES(I)
CALL NUMSTR (3, 8, RNUM, RSTR, LSTR)
IF (.NOT. ALLTIM) THEN
WRITE (STRING, 10020)
& ISTRA(:LI), RSTR(1)(:LSTR)
ELSE IF (WHOTIM(I)) THEN
WRITE (STRING, 10020)
& ISTRA(:LI), RSTR(1)(:LSTR)
ELSE
WRITE (STRING, 10020)
& ISTRA(:LI), RSTR(1)(:LSTR), '(history-only)'
END IF
LSTR = LENSTR (STRING)
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10060) STRING(:LSTR)
ELSE
WRITE (*, 10060) STRING(:LSTR)
END IF
110 CONTINUE
END IF
END IF
RETURN
10030 FORMAT (/, 1X, 'TIME STEP TIMES')
10040 FORMAT (5A)
10050 FORMAT (1X, 5A)
10060 FORMAT (4X, 5A)
END