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.

95 lines
2.6 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 SPREAD (A, NPTIMS, IPTIMS, NENUM, PLTVAL)
C=======================================================================
C --*** SPREAD *** (SPLOT) Read plot variables from database
C -- Written by Amy Gilkey - revised 02/02/88
C --
C --SPREAD reads the database and stores all variables needed
C --for all time steps.
C --
C --This routine manipulates dynamic memory, so check after return.
C --
C --Parameters:
C -- A - IN - the dynamic memory base array
C -- NPTIMS - IN - the number of selected times
C -- IPTIMS - IN - the selected time steps
C -- NENUM - IN - the selected node/element numbers
C -- PLTVAL - OUT - the plot variable values
C --
C --Common Variables:
C -- Uses NDIM, NUMNP, NUMEL, NELBLK,
C -- NVARHI, NVARGL, NVARNP, NVAREL of /DBNUMS/
C -- Uses NODVAR, NNENUM of /SELNE/
C -- Uses NSPVAR of /SPVARS/
include 'params.blk'
include 'dbnums.blk'
include 'selne.blk'
include 'spvars.blk'
DIMENSION A(*)
INTEGER IPTIMS(NPTIMS)
INTEGER NENUM(NNENUM)
REAL PLTVAL(NNENUM,NSPVAR,*)
LOGICAL NEEDNV, NEEDEV
C --Determine which types of variables are needed
NEEDNV = .FALSE.
NEEDEV = .FALSE.
LDATA = 0
IF (NODVAR) THEN
NEEDNV = .TRUE.
LDATA = MAX (LDATA, NUMNP)
ELSE
NEEDEV = .TRUE.
LDATA = MAX (LDATA, NUMEL)
END IF
C --Reserve memory for data record
CALL MDRSRV ('DATA', KDATA, LDATA)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 110
C --Transfer element variables onto random file (for efficiency)
IF (NEEDEV) THEN
CALL SPTRND (A, IPTIMS(NPTIMS), 'E', NUMEL, NVAREL, A(KDATA))
END IF
DO 100 NPT = 1, NPTIMS
ISTEP = IPTIMS(NPT)
C --Read and store nodal data to be plotted
IF (NEEDNV) THEN
CALL SPSTOR (A, ISTEP, 'N', NUMNP, NVARNP, NENUM,
& PLTVAL(1,1,NPT), A(KDATA))
END IF
C --Read and store element data to be plotted
IF (NEEDEV) THEN
CALL SPSTOR (A, ISTEP, 'E', NUMEL, NVAREL, NENUM,
& PLTVAL(1,1,NPT), A(KDATA))
END IF
100 CONTINUE
CALL MDDEL ('DATA')
110 CONTINUE
RETURN
END