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.

142 lines
4.6 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=======================================================================
SUBROUTINE MUNELB (NELBLK, ISTAT, NUMEL,
& IDELB, NUMELB, NUMLNK, NUMATR,
& LINK, ATRIB, LINKX, ATRIBX, IXEL, IXELB, NELBX,
$ ISCR, BLKTYP, SCRSTR, LLINK, LATRIB, ATNAMES,
* EBNAME)
C=======================================================================
C --*** MUNELB *** (GJOIN) Compress and rearrange element blocks
C -- Written by Amy Gilkey - revised 09/29/87
C -- Modified by Greg Sjaardema, 07/11/90
C -- Added element block names
C --
C --MUNELB processes the element blocks according to the block status.
C --Blocks may be combined or deleted.
C --
C --Parameters:
C -- NELBLK - IN/OUT - the number of element blocks
C -- ISTAT - IN - the status of each block:
C -- 0 = same
C -- - = delete
C -- n = combine with block n
C -- NUMEL - IN/OUT - the number of elements
C -- IDELB - IN/OUT - the element block IDs for each block
C -- NUMELB - IN/OUT - the number of elements in each block
C -- NUMLNK - IN/OUT - the number of nodes per element in each block
C -- NUMATR - IN/OUT - the number of attributes in each block
C -- LINK - IN/OUT - the connectivity for each block
C -- ATRIB - IN/OUT - the attributes for each block
C -- LINKX - SCRATCH - sized to hold the new connectivity
C -- ATRIBX - SCRATCH - sized to hold the new attributes
C -- IXEL - OUT - the new element number for each element
C -- IXELB - SCRATCH - size = NELBLK
C -- NELBX - SCRATCH - size = NELBLK
C -- ISCR - SCRATCH - size = NELBLK
C -- BLKTYP - IN/OUT - the names of the element blocks
C -- SCRSTR - SCRATCH - size = MXNAM
include 'gp_params.blk'
include 'gp_namlen.blk'
INTEGER ISTAT(*)
INTEGER IDELB(*)
INTEGER NUMELB(*)
INTEGER NUMLNK(*)
INTEGER NUMATR(*)
INTEGER LINK(*), LINKX(*)
REAL ATRIB(*), ATRIBX(*)
INTEGER IXEL(*)
INTEGER IXELB(*)
INTEGER NELBX(*)
INTEGER ISCR(*)
CHARACTER*(MXSTLN) BLKTYP(*)
CHARACTER*(maxnam) SCRSTR(*)
CHARACTER*(maxnam) ATNAMES(*)
CHARACTER*(maxnam) EBNAME(*)
DO 100 I = 1, NUMEL
IXEL(I) = 0
100 CONTINUE
JEL0 = 0
JLNK = 1
JATR = 1
JBLK = 0
DO 140 IELB = 1, NELBLK
IF (ISTAT(IELB) .EQ. 0) THEN
NINSET = 1
ISCR(NINSET) = IELB
ELSE IF (ISTAT(IELB) .EQ. IELB) THEN
CALL GETALL (IELB, NELBLK, ISTAT, NINSET, ISCR)
ELSE
NINSET = 0
END IF
IF (NINSET .GT. 0) THEN
JBLK = JBLK + 1
IXELB(JBLK) = IELB
NELBX(JBLK) = 0
END IF
DO 130 ISET = 1, NINSET
IBLK = ISCR(ISET)
IEL0 = 0
ILNK = 1
IATR = 1
DO 110 I = 1, IBLK-1
IEL0 = IEL0 + NUMELB(I)
ILNK = ILNK + NUMLNK(I) * NUMELB(I)
IATR = IATR + NUMATR(I) * NUMELB(I)
110 CONTINUE
DO 120 I = 1, NUMELB(IBLK)
IXEL(IEL0+I) = JEL0 + I
120 CONTINUE
CALL MOVINT (NUMELB(IBLK) * NUMLNK(IBLK),
& LINK(ILNK), LINKX(JLNK))
CALL MOVREA (NUMELB(IBLK) * NUMATR(IBLK),
& ATRIB(IATR), ATRIBX(JATR))
NELBX(JBLK) = NELBX(JBLK) + NUMELB(IBLK)
JEL0 = JEL0 + NUMELB(IBLK)
JLNK = JLNK + NUMLNK(IBLK) * NUMELB(IBLK)
JATR = JATR + NUMATR(IBLK) * NUMELB(IBLK)
130 CONTINUE
140 CONTINUE
icold = 0
icnew = 0
do ielb = 1, nelblk
IF (ISTAT(IELB) .EQ. 0) THEN
if (icnew .ne. icold) then
do i1 = 1, numatr(ielb)
atnames(icnew + i1) = atnames(icold + i1)
end do
end if
icnew = icnew + numatr(ielb)
end if
icold = icold + numatr(ielb)
end do
CALL ORDIX (JBLK, IXELB, NELBLK, IDELB, ISCR, IDELB)
CALL MOVINT (JBLK, NELBX, NUMELB)
CALL ORDIX (JBLK, IXELB, NELBLK, NUMLNK, ISCR, NUMLNK)
CALL ORDIX (JBLK, IXELB, NELBLK, NUMATR, ISCR, NUMATR)
CALL ORDSTR (JBLK, IXELB, NELBLK, BLKTYP, SCRSTR)
CALL ORDSTR (JBLK, IXELB, NELBLK, EBNAME, SCRSTR)
NELBLK = JBLK
NUMEL = JEL0
LLINK = JLNK-1
LATRIB = JATR-1
CALL MOVINT (LLINK, LINKX, LINK)
CALL MOVREA (LATRIB, ATRIBX, ATRIB)
RETURN
END