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.

121 lines
4.0 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 RWSTEP (NTXT, NDB, istep, idelb,
& NVARGL, NVARNP, NUMNP, NVAREL, NELBLK, NUMELB,
& ISEVOK, TIME, VAR, *)
C=======================================================================
C --*** RDSTEP *** (TXTEXO) Read database variables for one time step
C -- Written by Amy Gilkey - revised 03/02/88
C --
C --RDSTEP reads the database history, global, nodal, and element variables
C --for one time step.
C --
C --Parameters:
C -- NTXT - IN - the text file
C -- NVARGL - IN - the number of global variables
C -- NVARNP - IN - the number of nodal variables
C -- NUMNP - IN - the number of nodes
C -- NVAREL - IN - the number of element variables
C -- NELBLK - IN - the number of element blocks
C -- NUMELB - IN - the number of elements per block
C -- ISEVOK - IN - the element block variable truth table;
C -- variable i of block j exists iff ISEVOK(j,i)
C -- TIME - OUT - the time step time
C -- VAR - OUT - the global variables for the time step
C -- * - return statement if error encountered, including end-of-file;
C -- message is printed
C --
C --Database must be positioned in front of time step upon entry;
C --upon exit positioned after time step.
INTEGER NUMELB(*)
integer idelb(*)
LOGICAL ISEVOK(NVAREL, *)
REAL VAR(*)
CHARACTER*32 STRA
C --Read step time
READ (NTXT, *, END=180, ERR=130)
READ (NTXT, *, END=180, ERR=130) TIME
call exptim(ndb, istep, time, ierr)
C --Read global variables
IF (NVARGL .GT. 0) THEN
READ (NTXT, *, END=150, ERR=150)
READ (NTXT, *, END=150, ERR=150) (VAR(I), I=1,NVARGL)
call expgv(ndb, istep, nvargl, var, ierr)
END IF
C --Read nodal variables
IF (NVARNP .GT. 0) THEN
READ (NTXT, *, END=160, ERR=160)
DO 100 INP = 1, NUMNP
READ (NTXT, *, END=160, ERR=160)
& (VAR(inp+(i-1)*numnp), I=1,NVARNP)
100 CONTINUE
ioff = 1
do 105 i=1, nvarnp
call expnv(ndb, istep, i, numnp, var(ioff), ierr)
ioff = ioff + numnp
105 continue
END IF
C --Read element variables
C ... Values for all element variables are stored in text file
C Read an element block at a time and then write that element block
IF (NVAREL .GT. 0) THEN
C ... Skip comment line
READ (NTXT, *, END=170, ERR=170)
DO 120 IELB = 1, NELBLK
C ... Skip comment line
READ (NTXT, *, END=170, ERR=170)
READ (NTXT, *, END=170, ERR=170)
DO 110 N = 1, NUMELB(IELB)
READ (NTXT, *, END=170, ERR=170)
& (VAR(N+(I-1)*numelb(ielb)), I=1,NVAREL)
110 CONTINUE
C ... Write this blocks variables
ioff = 1
do 115 i=1, nvarel
if (isevok(i,ielb)) then
call expev(ndb, istep, i, idelb(ielb), numelb(ielb),
& var(ioff), ierr)
end if
ioff = ioff + numelb(ielb)
115 continue
120 CONTINUE
END IF
RETURN
130 CONTINUE
CALL PRTERR ('FATAL', 'Reading TIME STEP TIME')
GOTO 180
150 CONTINUE
CALL PRTERR ('FATAL', 'Reading GLOBAL VARIABLES')
GOTO 180
160 CONTINUE
CALL INTSTR (1, 0, INP, STRA, LSTRA)
CALL PRTERR ('FATAL',
& 'Reading NODAL VARIABLES for node ' // STRA(:LSTRA))
GOTO 180
170 CONTINUE
CALL INTSTR (1, 0, N, STRA, LSTRA)
CALL PRTERR ('FATAL',
& 'Reading ELEMENT VARIABLES for element ' // STRA(:LSTRA))
GOTO 180
180 CONTINUE
RETURN 1
END