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.

132 lines
4.4 KiB

2 years ago
C Copyright(C) 1999-2020, 2022 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 ... Each cavity is a single sideset id, but calculates volume of each cavity
C simultaneously and then outputs all data at the end. Only reads the
C displacements a single time for all cavities instead of once per cavity
SUBROUTINE MULTI_CAVITY (A, CRD, IDESS, NEESS, NNESS, IPEESS,
* IPNESS, LTEESS, LTNESS, FACESS, DISP, NUMNP, NDIM, NUMESS,
* TIME, ITMSEL, TITLE, CENT, CENTER)
include 'nu_io.blk'
DIMENSION A(*), CRD(NUMNP,NDIM), IDESS(*), NEESS(*),
* NNESS(*), IPEESS(*), IPNESS(*), LTEESS(*), LTNESS(*),
* FACESS(*), TIME(*), DISP(NUMNP,NDIM), CENT(3)
LOGICAL ITMSEL(*)
CHARACTER*80 TITLE
include 'nu_logs.blk'
include 'nu_ptim.blk'
include 'nu_cav.blk'
LOGICAL ERROR, CENTER
CALL GETCAV (ERROR, IDESS, NUMESS)
IF (ERROR) RETURN
C ... Allocate some memory for use in storing time-related output
C Experimental for use with cavity
call mdrsrv('TIMESCR', ITIMSCR, NSTEP * NUMCAV)
call mdrsrv('TVOL', ITVOL, NUMCAV)
write (*,*) '... Calculating volumes for cavities...'
DO NCAV = 1, NUMCAV
IFLG = IFND(NCAV)
IPTR = IPNESS(IFLG)
IF (NDIM .EQ. 3) THEN
CALL VOL3D( CRD, LTNESS(IPTR), NEESS(IFLG), VOLUME,
* NDIM, NUMESS, CENT, NUMNP, CENTER)
ELSE
CALL VOL2D( CRD, LTNESS(IPTR), NEESS(IFLG), VOLUME,
* NDIM, NUMESS, AXI, CENT, NUMNP, CENTER)
END IF
a(itvol + ncav - 1) = volume
END DO
C ... REWIND EXODUS FILE TO BEGINNING OF TIMESTEPS
IF (EXODUS .AND. ISDIS) THEN
TIMEL = STMIN
CALL GETDSP (CRD, DISP, NDIM, NUMNP, TIME, ITMSEL, 'R', ISTAT)
IF (ISTAT .NE. 0) GO TO 140
istep = 1
90 CONTINUE
CALL GETDSP (CRD, DISP, NDIM, NUMNP, TIME, ITMSEL, 'S', ISTAT)
IF (ISTAT .NE. 0) GO TO 140
DO NCAV = 1, NUMCAV
IFLG = IFND(NCAV)
IPTR = IPNESS(IFLG)
C NOTE: Positive delcav = shrink in cavity volume
IF (NDIM .EQ. 3) THEN
CALL DVOL3D(CRD, DISP, LTNESS(IPTR),
* NEESS(IFLG), DELCAV, NDIM, NUMNP)
ELSE
CALL DVOL2D(CRD, DISP, LTNESS(IPTR),
* NEESS(IFLG), DELCAV, NDIM, AXI, NUMNP)
END IF
a(itimscr + ((ncav-1)*nstep + istep) - 1) = delcav
END DO
istep = istep + 1
GO TO 90
END IF
140 CONTINUE
do ncav = 1, numcav
tvol = a(itvol + ncav - 1)
DO IO=IOMIN, IOMAX
write (IO, 30) icav(ncav)
IF (NDIM .EQ. 2) THEN
WRITE (IO, 40) CENT(1),CENT(2)
ELSE
WRITE (IO, 50) CENT(1),CENT(2),CENT(3)
END IF
WRITE (IO,60) tvol
WRITE (IO, 80)
END DO
DELLAS = 0.0
do istep = 1, nstep
delvol = a(itimscr + ((ncav-1)*nstep + istep) - 1)
deldel = delvol - dellas
IF (istep .eq. 1) THEN
DO IO=IOMIN, IOMAX
WRITE (IO, 130) TIME(ISTEP), TVOL-DELVOL, -DELVOL,
* -DELDEL
END DO
ELSE
DELRAT = DELDEL / (time(istep) - time(istep-1))
DO IO=IOMIN, IOMAX
WRITE (IO, 130) TIME(ISTEP), TVOL-DELVOL, -DELVOL,
* -DELDEL, -DELRAT
END DO
end if
dellas = delvol
end do
end do
CALL INIINT (NUMCAV, 0, ICAV)
NUMCAV = 0
call mddel('TIMESCR')
call mddel('TVOL')
30 FORMAT (/' Cavity Flag(s): ',8I8)
40 FORMAT ( ' Apex at X =',1PE15.8,', Y =',1PE15.8)
50 FORMAT ( ' Apex at X =',1PE15.8,', Y =',1PE15.8,', Z =',1PE15.8)
60 FORMAT (/' Undeformed Volume of Cavity is ',1PE15.8)
80 FORMAT (/,
* 4X,' Cavity Total',
* ' Timestep Rate of',/
* 4X,'Time Volume Change',
* ' Change Change',/
* 4X,'---- ------ ------',
* ' -------- -------')
130 FORMAT (1X,5(1PE15.8,2X))
RETURN
END