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.

585 lines
17 KiB

2 years ago
C Copyright(C) 1999-2021 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=======================================================================
PROGRAM EX1EX2V2
C=======================================================================
C --*** EX1EX2V2 *** EXODUS I to EXODUS II translator
C --
C --EX1EX2V2 reads EXODUS I database and writes an EXODUS II V2.03 database
C --
include 'exodusII.inc'
INCLUDE 'argparse.inc'
CHARACTER*8 QAINFO(6)
CHARACTER*80 TITLE
PARAMETER (MAXQA = 100, MAXINF = 100)
PARAMETER (MAXDIM=6, MAXELB=512, MAXVAR=512)
CHARACTER*8 QAREC(4,MAXQA)
CHARACTER*80 INFO(MAXINF)
CHARACTER*8 NAMECO(MAXDIM)
CHARACTER*8 NAMELB(MAXELB)
CHARACTER*8 NAMES(MAXVAR)
character*2048 exofil, netfil, scratch
character*8 name
integer cpuws,wsout
DIMENSION A(1)
DIMENSION IA(1)
EQUIVALENCE (A(1), IA(1))
C --A - the dynamic memory base array
CHARACTER*8 STR8
LOGICAL EXODUS
LOGICAL WHOTIM
data (qainfo(i), i=1,3) / 'ex1ex2v2', '20210128', 'v 2.13 ' /
data iin,iout/5,6/
data nsteps /0/
data cpuws,wsout /0,0/
CALL STRTUP (QAINFO)
CALL BANNER (0, QAINFO,
& 'EXODUS I TO EXODUS II FILE TRANSLATOR',
& ' ', ' ')
C --Open the input and output files
NDB = 11
NET = 20
c make netCDF and exodus errors not show up
call exopts(0,ierr)
C .. Get filename from command line. If not specified, emit error message
NARG = argument_count()
if (narg .lt. 2) then
CALL PRTERR ('FATAL', 'Filenames not specified.')
CALL PRTERR ('FATAL',
* 'Syntax is: "ex1ex2v2 exo1_file exo2_file"')
GOTO 140
else if (narg .gt. 2) then
CALL PRTERR ('FATAL', 'Too many arguments specified.')
CALL PRTERR ('FATAL',
* 'Syntax is: "ex1ex2v2 exo1_file exo2_file"')
GOTO 140
end if
CALL get_argument(1,exofil, lnam)
write(*,*)'Input filename: ',exofil(1:lnam)
open(unit=ndb, file=exofil(:lnam), form='unformatted',
* status='old', iostat=ierr)
IF (IERR .NE. 0) THEN
SCRATCH = 'Database "'//exofil(:lnam)//'" does not exist.'
CALL PRTERR ('FATAL', SCRATCH(:LENSTR(SCRATCH)))
GOTO 140
END IF
CALL get_argument(2,netfil, lnam)
write(*,*)'Output filename: ',netfil(1:lnam)
wsout = 8
write(*,*)'Output word size: ',wsout
CALL MDINIT (A)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
CALL MDFILL(-1)
C --Read the initial variables from exodusI database
CALL DBIINI (NDB, '*', NVERS, TITLE, NDIM, NUMNP, NUMEL, NELBLK,
& NUMNPS, LNPSNL, NUMESS, LESSEL, LESSNL, *150)
c create the a netcdf file
idexo = excre (netfil(1:lnam), EXCLOB, cpuws, wsout, ierr)
if (ierr .lt. 0) then
call exerr('ex1ex2v2','Error from excre', EXLMSG)
go to 140
end if
c write initial variables to netcdf file
call expini (idexo, title, ndim, numnp, numel, nelblk, numnps,
& numess, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2',' Error from expini', EXLMSG)
goto 150
end if
CALL DBPINI ('NTIS', NDB, TITLE, NDIM, NUMNP, NUMEL, NELBLK,
& NUMNPS, LNPSNL, NUMESS, LESSEL, LESSNL,
& IDUM, IDUM, IDUM, IDUM)
WRITE(*,*)
C --Read the coordinates from the exodusI database
CALL MDRSRV ('XN', KXN, NUMNP)
CALL MDRSRV ('YN', KYN, NUMNP)
IF (NDIM .GE. 3) THEN
CALL MDRSRV ('ZN', KZN, NUMNP)
ELSE
KZN = 1
END IF
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
CALL DBIXYZ (NDB, '*', NDIM, NUMNP, A(KXN), A(KYN), A(KZN), *150)
c write the coordinates to the regular netcdf file
call expcor (idexo, a(kxn), a(kyn), a(kzn), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expcor', EXLMSG)
goto 150
end if
CALL MDDEL ('XN')
CALL MDDEL ('YN')
IF (NDIM .GE. 3) CALL MDDEL ('ZN')
C --Read the element order map from the exodusI database
CALL MDRSRV ('MAPEL', KMAPEL, NUMEL)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
CALL DBIMAP (NDB, '*', NUMEL, IA(KMAPEL), *150)
c write the element order map to the regular netcdf file
call expmap (idexo, ia(kmapel), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expmap', EXLMSG)
goto 150
end if
CALL MDDEL ('MAPEL')
C --Read the element blocks
CALL MDRSRV ('NUMELB', KNELB, NELBLK)
CALL MDRSRV ('LINK', KLINK, 0)
CALL MDRSRV ('ATRIB', KATRIB, 0)
call MDRSRV ('IDELB', KIDELB, NELBLK)
call MDRSRV ('NUMLNK', KNMLNK, NELBLK)
call MDRSRV ('NUMATR', KNMATR, NELBLK)
CALL MDSTAT (IERR, MEM)
IF (IERR .GT. 0) goto 150
CALL DBIELB (NDB, '*', 1, nelblk, IA(KIDELB), IA(KNELB),
* IA(KNMLNK), IA(KNMATR), A, KLINK, KATRIB, *150)
CALL MDSTAT (IERR, MEM)
IF (IERR .GT. 0) goto 150
C --Read the nodal points sets
CALL MDRSRV ('IDNPS', KIDNS, NUMNPS)
CALL MDRSRV ('NNNPS', KNNNS, NUMNPS)
CALL MDRSRV ('IXNNPS', KIXNNS, NUMNPS)
CALL MDRSRV ('LSTNPS', KLSTNS, LNPSNL)
CALL MDRSRV ('FACNPS', KFACNS, LNPSNL)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
CALL DBINPS (NDB, '*', NUMNPS, LNPSNL,
& IA(KIDNS), IA(KNNNS), IA(KIXNNS), IA(KLSTNS), A(KFACNS), *150)
C --Read the element side sets
CALL MDRSRV ('IDESS', KIDSS, NUMESS)
CALL MDRSRV ('NEESS', KNESS, NUMESS)
CALL MDRSRV ('NNESS', KNNSS, NUMESS)
CALL MDRSRV ('IXEESS', KIXESS, NUMESS)
CALL MDRSRV ('IXNESS', KIXNSS, NUMESS)
CALL MDRSRV ('LTEESS', KLTESS, LESSEL)
CALL MDRSRV ('LTNESS', KLTNSS, LESSNL)
CALL MDRSRV ('FACESS', KFACSS, LESSNL)
CALL MDRSRV ('SACESS', KLTSSS, LESSEL)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
CALL DBIESS (NDB, '*', NUMESS, LESSEL, LESSNL,
& IA(KIDSS), IA(KNESS), IA(KNNSS), IA(KIXESS), IA(KIXNSS),
& IA(KLTESS), IA(KLTNSS), A(KFACSS), *150)
C --Read the QA and info records
C ... Exodus set to .FALSE. if end of file during this read
CALL DBIQA (NDB, '*', MAXQA, MAXINF, NQAREC, QAREC, NINFO, INFO,
& EXODUS, *150)
c**********************************************************************
C --Read the database names
if (exodus) then
C ... Exodus set to .FALSE. if end of file during this read
CALL DBINAM (NDB, '*', NDIM, NELBLK,
& NNDIM, NNELB, NVARHI, NVARGL, NVARNP, NVAREL,
& NAMECO, NAMELB, NAMES, IXHV, IXGV, IXNV, IXEV,
& A, KIEVOK, EXODUS, *150)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
if (.not. exodus) then
nvarhi = 0
nvargl = 0
nvarnp = 0
nvarel = 0
end if
CALL DBPINI ('V', NDB, TITLE, NDIM, NUMNP, NUMEL, NELBLK,
& NUMNPS, LNPSNL, NUMESS, LESSEL, LESSNL,
& NVARHI, NVARGL, NVARNP, NVAREL)
else
C ... Assign dummy coordinate names...
NAMECO(1) = 'X'
NAMECO(2) = 'Y'
NAMECO(3) = 'Z'
C ... Try to infer the element block names also
do 50 ielb = 0, nelblk-1
namelb(ielb+1) = 'UNKNOWN'
npe = ia(knmlnk+ielb)
if (ndim .eq. 2) then
if (npe .eq. 4) then
namelb(ielb+1) = 'QUAD'
else if (npe .eq. 8) then
namelb(ielb+1) = 'QUAD8'
else if (npe .eq. 3) then
namelb(ielb+1) = 'TRIANGLE'
end if
else if (ndim .eq. 3) then
if (npe .eq. 4) then
if (ia(knmatr+ielb) .eq. 0) then
namelb(ielb+1) = 'TETRA'
else
namelb(ielb+1) = 'SHELL'
end if
else if (npe .eq. 8) then
if (ia(knmatr+ielb) .eq. 0) then
namelb(ielb+1) = 'HEX'
else
namelb(ielb+1) = 'SHELL8'
end if
else if (npe .eq. 6) then
namelb(ielb+1) = 'WEDGE'
end if
end if
50 continue
END IF
c*********
ioff = 0
DO 100 IELB = 1, NELBLK
c write element block parameters to the netcdf file
call expelb (IDEXO, IA(KIDELB+IELB-1), namelb(IELB),
1 IA(KNELB+IELB-1),
2 IA(KNMLNK+IELB-1), IA(KNMATR+IELB-1), IERR)
IF (IERR .lt. 0) THEN
CALL exerr('ex1ex2v2','Error from expelb',EXLMSG)
ENDIF
c write block attributes to the netcdf file
IF (IA(KNMATR+IELB-1) .GT. 0) THEN
call expeat (IDEXO, IA(KIDELB+IELB-1), A(KATRIB+ioff), IERR)
IF (IERR .lt. 0) THEN
CALL exerr ('rdelb','Error from expeat', EXLMSG)
ENDIF
end if
ioff = ioff + ia(knmatr + ielb-1) * ia(knelb + ielb-1)
c CALL MDLONG ('LINK', KLINK, 0)
c CALL MDLONG ('ATRIB', KATRIB, 0)
100 CONTINUE
iptr = klink
do 101 ielb = 1, nelblk
c write the element block connectivity to the netcdf file
c skipping null element blocks
if (IA(KNELB+IELB-1) .eq. 0) then
write(*,*)'Null element block: ',ielb
else
call expelc (idexo, ia(kidelb+ielb-1), ia(iptr), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expelc', exlmsg)
goto 150
end if
end if
iptr = iptr + ( ia(knmlnk+ielb-1) * ia(knelb+ielb-1) )
101 continue
c write out the nodal point sets to the regular netcdf file
c Note: For exodus I data, dist factors always exist.
if (numnps .gt. 0) then
call expcns (idexo, ia(kidns), ia(knnns), ia(knnns),
* ia(kixnns), ia(kixnns), ia(klstns), a(kfacns), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expcns', exlmsg)
goto 150
end if
endif
c write element side sets
c Note: Exodus II V2.0 represents a major change for side sets:
c They are represented as side IDs - not node IDs and
c must be translated.
if (numess .gt. 0) then
call excn2s (idexo, ia(kness), ia(knnss), ia(kixess),
1 ia(kixnss), ia(kltess), ia(kltnss), ia(kltsss), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from excn2s', exlmsg)
goto 150
end if
call expcss (idexo, ia(kidss), ia(kness), ia(knnss), ia(kixess),
& ia(kixnss), ia(kltess), ia(kltsss), a(kfacss), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expcss', exlmsg)
goto 150
end if
endif
call mddel ('LINK')
call mddel ('NUMLNK')
CALL MDDEL ('ATRIB')
CALL MDDEL ('NUMATR')
CALL MDDEL ('IDNPS')
CALL MDDEL ('NNNPS')
CALL MDDEL ('IXNNPS')
CALL MDDEL ('LSTNPS')
CALL MDDEL ('FACNPS')
CALL MDDEL ('IDESS')
CALL MDDEL ('NEESS')
CALL MDDEL ('NNESS')
CALL MDDEL ('IXEESS')
CALL MDDEL ('IXNESS')
CALL MDDEL ('LTEESS')
CALL MDDEL ('LTNESS')
CALL MDDEL ('FACESS')
CALL MDDEL ('SACESS')
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
c write the QA records
IF (NQAREC .GT. 0) then
call expqa (idexo, NQAREC, QAREC, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expqa', exlmsg)
goto 150
end if
end if
c write the info records
if (NINFO .gt. 0) then
call expinf (idexo, ninfo, info, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expinf', exlmsg)
goto 150
end if
end if
c**********************************************************************
c write coordinate names
call expcon (idexo, nameco, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expcon', exlmsg)
goto 150
end if
if (.not. EXODUS) goto 150
c write the number of global variables
if (nvargl .gt. 0) then
call expvp (idexo, 'G', nvargl, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvp', exlmsg)
goto 140
end if
c write the global variable names
call expvan (idexo, 'G', nvargl, names(ixgv), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvan', exlmsg)
goto 140
end if
end if
c write the number of nodal variables
if (nvarnp .gt. 0) then
call expvp (idexo, 'N', nvarnp, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvp', exlmsg)
goto 140
end if
c write the nodal variable names
call expvan (idexo, 'N', nvarnp, names(ixnv), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvan', exlmsg)
goto 140
end if
end if
c write the number of element variables
if (nvarel .gt. 0) then
call expvp (idexo, 'E', nvarel, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvp', exlmsg)
goto 140
end if
c write the element variable names
call expvan (idexo, 'E', nvarel, names(ixev), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from exvan', exlmsg)
goto 140
end if
end if
c write the element variable truth table
call mdrsrv ('ebids', kebids, nelblk)
call exgebi (idexo, ia(kebids), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from exgebi', exlmsg)
goto 140
end if
if (nvarel .gt. 0) then
call expvtt(idexo, nelblk, nvarel, ia(kievok), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expvtt', exlmsg)
goto 140
end if
end if
call mddel ('ebids')
IF (.NOT. EXODUS) GOTO 140
C --Read the database time steps
CALL MDRSRV ('VARHI', KVARHI, NVARHI)
CALL MDRSRV ('VARGL', KVARGL, NVARGL)
CALL MDRSRV ('VARNP', KVARNP, NVARNP * NUMNP)
CALL MDRSRV ('VAREL', KVAREL, NVAREL * NUMEL)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 130
nwstep = 0
nhstep = 0
110 CONTINUE
IF (.TRUE.) THEN
CALL DBISTE (NDB, '*', NhSTEP+1,
& NVARHI, NVARGL, NVARNP, NUMNP, NVAREL, NELBLK,
& ia(knelb), IA(KIEVOK), TIME, WHOTIM, A(KVARHI),
& A(KVARGL), A(KVARNP), A(KVAREL), *120)
nhstep = nhstep + 1
if (whotim) then
nwstep = nwstep+1
write (*,'(4x, "processing whole time step ", i4)') nwstep
c write global variables
if (nvargl .gt. 0) then
call expgv (idexo, nwstep, nvargl, a(kvargl), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expgv', exlmsg)
goto 140
end if
end if
c write nodal variable values
if (nvarnp .gt. 0) then
do 111 i= 1,nvarnp
call expnv (idexo, nwstep, i, numnp,
& a(kvarnp+(i-1)*numnp), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from expnv', exlmsg)
goto 140
end if
111 continue
end if
c write element variable values
if (nvarel .gt. 0) then
call putev (idexo, nwstep, nelblk, nvarel,
& ia(knelb), a(kvarel), ia(kidelb), ia(kievok), ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from putev', exlmsg)
goto 140
end if
end if
c write whole time step
call exptim (idexo, nwstep, time, ierr)
if (ierr .lt. 0) then
call exerr ('ex1ex2v2','Error from exptim', exlmsg)
goto 140
end if
end if
GOTO 110
END IF
120 CONTINUE
call mddel ('IDELB')
WRITE (STR8, '(I8)', IOSTAT=K) NwSTEP
CALL SQZSTR (STR8, LSTR)
WRITE (*, 10010) STR8(:LSTR)
10010 FORMAT (/, 4X, A,
& ' time steps have been written to the file')
GOTO 140
130 CONTINUE
CALL MEMERR
CALL MDSTAT (NERR, MEM)
WRITE(*,10020) QAINFO(1), MEM
10020 FORMAT(1x,A8,' currently using ', I10, ' words of memory')
140 CONTINUE
150 if (idexo .gt. 0) call exclos (idexo, ierr)
IF (NDB .NE. 0) CLOSE (NDB, IOSTAT=K)
call addlog (QAINFO(1)(:lenstr(QAINFO(1))))
CALL WRAPUP (QAINFO(1))
STOP
END