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.

97 lines
3.2 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
SUBROUTINE DELHOL (IPTR, MXND, LXK, KXL, NXL, LXN, NXH, NUID, NNN,
& IAVAIL, NAVAIL, NOROOM, ERR)
C***********************************************************************
C SUBROUTINE DELNOD = DELETES ALL LINES, ELEMENTS, ETC. ATTACHED TO
C A NODE
C***********************************************************************
DIMENSION LXK(4, MXND), KXL(2, 3*MXND), NXL(2, 3*MXND)
DIMENSION LXN(4, MXND), NXH(MXND), NUID(MXND)
DIMENSION KLIST(20)
LOGICAL ERR, NOROOM
ERR = .FALSE.
CALL GKXN (MXND, KXL, LXN, IPTR, KS, KLIST, ERR)
IF (.NOT. ERR) THEN
ERR = .TRUE.
C DELETE LINES PER ELEMENT; MARK ELEMENT NODES
DO 110 J = 1, KS
DO 100 K = 1, 4
IF (NXH(NXL(1, LXK(K, KLIST(J)))) .EQ. 0)
& NXH(NXL(1, LXK(K, KLIST(J)))) = 1
IF (NXH(NXL(2, LXK(K, KLIST(J)))) .EQ. 0)
& NXH(NXL(2, LXK(K, KLIST(J)))) = 1
IF (KXL(1, LXK(K, KLIST(J))) .EQ. KLIST(J))
& KXL(1, LXK(K, KLIST(J))) = 0
IF (KXL(2, LXK(K, KLIST(J))) .EQ. KLIST(J))
& KXL(2, LXK(K, KLIST(J))) = 0
LXK(K, KLIST(J)) = 0
100 CONTINUE
110 CONTINUE
NXH(IPTR) = -1
DO 120 J = 1, 3
IF (LXN(J, IPTR) .GT. 0) THEN
C DELETE LINE ATTACHED TO OPPOSITE END NODE
IF (NXL(1, LXN(J, IPTR)) .EQ. IPTR) THEN
CALL DELLXN (MXND, LXN, NUID, NAVAIL, IAVAIL,
& NXL(2, LXN(J, IPTR)), LXN(J, IPTR), NNN, ERR,
& NOROOM)
ELSE IF (NXL(2, LXN(J, IPTR)) .EQ. IPTR) THEN
CALL DELLXN (MXND, LXN, NUID, NAVAIL, IAVAIL,
& NXL(1, LXN(J, IPTR)), LXN(J, IPTR), NNN, ERR,
& NOROOM)
END IF
IF (NOROOM) RETURN
C DELETE NODES PER LINE; ELEMENTS PER LINE
NXL(1, LXN(J, IPTR)) = 0
NXL(2, LXN(J, IPTR)) = 0
KXL(1, LXN(J, IPTR)) = 0
KXL(2, LXN(J, IPTR)) = 0
LXN(J, IPTR) = 0
END IF
120 CONTINUE
C FOR LAST LINE, SAVE LINK ON IAVAIL
IF (LXN(4, IPTR) .GT. 0) THEN
IF (NXL(1, LXN(4, IPTR)) .EQ. IPTR) THEN
CALL DELLXN (MXND, LXN, NUID, NAVAIL, IAVAIL,
& NXL(2, LXN(4, IPTR)), LXN(4, IPTR), NNN, ERR,
& NOROOM)
ELSE IF (NXL(2, LXN(J, IPTR)) .EQ. IPTR) THEN
CALL DELLXN (MXND, LXN, NUID, NAVAIL, IAVAIL,
& NXL(1, LXN(4, IPTR)), LXN(4, IPTR), NNN, ERR,
& NOROOM)
END IF
IF (NOROOM) RETURN
NXL(1, LXN(4, IPTR)) = 0
NXL(2, LXN(4, IPTR)) = 0
KXL(1, LXN(4, IPTR)) = 0
KXL(2, LXN(4, IPTR)) = 0
END IF
LXN(4, IPTR) = IAVAIL
IAVAIL = IPTR
NAVAIL = NAVAIL + 1
ERR = .FALSE.
END IF
RETURN
END