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.

78 lines
2.8 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 INITIM (MAXTIM, WHONLY, NSTEPS, TIMES, WHOTIM,
& TMIN, TMAX, DELT, NINTV, NPTIMS, IPTIMS)
C=======================================================================
C --*** INITIM *** (TIMSEL) Initialize time step parameters
C -- Written by Amy Gilkey - revised 11/12/87
C --
C --INITIM initializes the time step parameters. The initialization
C --is dependent on the MAXTIM parameter.
C --
C --Parameters:
C -- MAXTIM - IN - the initialization parameter
C -- =0 - select all times
C -- >0 - select NINTV interval times (up to number of steps - 1)
C -- with interval starting at TMIN + offset
C -- <0 - select -NINTV interval times (up to number of steps)
C -- with interval starting at TMIN
C -- WHONLY - IN - true iff only whole times may be selected
C -- NSTEPS - IN - the number of time steps
C -- TIMES - IN - the database times
C -- WHOTIM - IN - true iff TIMES(i) is whole (versus history) time step
C -- TMIN - OUT - the minimum selected time; set to minimum time
C -- TMAX - OUT - the maximum selected time; set to maximum time
C -- DELT - OUT - the interval between selected times
C -- (<0 = selected times); set to 0 (for all times) or interval
C -- NINTV - IN/OUT - the number of times between tmin and tmax to select
C -- (negative for zero interval);
C -- NPTIMS - OUT - the number of selected times
C -- IPTIMS - OUT - the selected time step numbers
C --Routines Called:
C -- MINMAX - (etclib) Find minimum and maximum value
C -- MINMXL - (etclib) Find minimum and maximum value of selected values
C -- NUMEQL - (etclib) Count the number of equal values
LOGICAL WHONLY
REAL TIMES(*)
LOGICAL WHOTIM(*)
INTEGER IPTIMS(*)
IF (.NOT. WHONLY) THEN
CALL MINMAX (NSTEPS, TIMES, TMIN, TMAX)
ELSE
CALL MINMXL (NSTEPS, WHOTIM, TIMES, TMIN, TMAX)
END IF
IF (.NOT. WHONLY) THEN
NSTEPX = NSTEPS
ELSE
NSTEPX = NUMEQL (.TRUE., NSTEPS, WHOTIM)
END IF
IF (MAXTIM .NE. 0) THEN
IF (MAXTIM .GT. 0) THEN
NINTV = MIN (MAXTIM, NSTEPX-1)
ELSE
NINTV = - MIN (MAXTIM, NSTEPX)
END IF
DELT = 999.0
ELSE IF (MAXTIM .EQ. 0) THEN
DELT = 0.0
NINTV = 0
END IF
NPTIMS = -999
CALL CALTIM (WHONLY, TMIN, TMAX, DELT, NINTV,
& NSTEPS, TIMES, WHOTIM, NPTIMS, IPTIMS)
RETURN
END