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.
167 lines
4.8 KiB
167 lines
4.8 KiB
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 RDMESH (NPNODE, NPELEM, NPNBC, NPSBC, NPREGN, MS, MR,
|
|
& NNUID, NNXK, IUNIT, NNN, KKK, IPART, LSTNBC, LSTSBC, NUID, XN,
|
|
& YN, NXK, MAT, MATMAP, NUMMAT, ISIDE, NLPS, IFLINE, ILLIST,
|
|
& LINKS, LINKR, IMAT, LINKB, JMAT, NNNBC, NNSBC, ERR)
|
|
C***********************************************************************
|
|
|
|
C SUBROUTINE RDMESH = THE CURRENT MESH STORED ON DISK
|
|
|
|
C***********************************************************************
|
|
|
|
DIMENSION IPART(3, NPREGN), ISIDE(MS), NLPS(MS), IFLINE(MS)
|
|
DIMENSION ILLIST(MS*3), LINKS(2, MS), LINKB(2, MS), LINKR(2, MR)
|
|
DIMENSION IMAT(MR), JMAT(MS)
|
|
|
|
DIMENSION NUID(NNUID), XN(NPNODE), YN(NPNODE)
|
|
DIMENSION NXK(NNXK, NPELEM), MAT(NPELEM)
|
|
|
|
DIMENSION LSTNBC(NPNBC), LSTSBC(NPSBC)
|
|
DIMENSION MATMAP(3, NPREGN)
|
|
|
|
LOGICAL ERR, BAR, ADDLNK
|
|
|
|
ERR = .FALSE.
|
|
|
|
C READ THE MESH TAPE
|
|
|
|
REWIND IUNIT
|
|
NNN = 0
|
|
KKK = 0
|
|
NNNBC = 0
|
|
NNSBC = 0
|
|
ADDLNK = .FALSE.
|
|
DO 100 I = 1, NPREGN
|
|
IPART(1, I) = 0
|
|
IPART(2, I) = 0
|
|
IPART(3, I) = 0
|
|
100 CONTINUE
|
|
|
|
NUMMAT = 0
|
|
DO 220 IR = 1, NPREGN
|
|
READ(IUNIT, END = 230) KKKREG, NNNREG, NNBCRG, NSBCRG, KREG,
|
|
& BAR, M1
|
|
|
|
C READ THE NODES
|
|
|
|
N1 = NNN + 1
|
|
NNN = NNN + NNNREG
|
|
IF (NNNREG .GE. 1)READ(IUNIT, END = 230) (NUID(I), XN(I),
|
|
& YN(I), I = N1, NNN)
|
|
|
|
C READ THE ELEMENTS
|
|
|
|
K1 = KKK + 1
|
|
IPART(1, IR) = KREG
|
|
IPART(2, IR) = K1
|
|
KKK = KKK + KKKREG
|
|
IPART(3, IR) = KKK
|
|
READ(IUNIT, END = 230) ((NXK(I, K), I = 1, 4), K = K1, KKK)
|
|
|
|
C ZERO THE MIDSIDE NODE LOCATIONS IN THE NXK ARRAY
|
|
|
|
DO 120 I = 5, NNXK
|
|
DO 110 K = K1, KKK
|
|
NXK(I, K) = 0
|
|
110 CONTINUE
|
|
120 CONTINUE
|
|
|
|
C SET UP THE MATERIAL ARRAY AND MAXIMUM NUMBER OF MATERIALS
|
|
|
|
IF (BAR) THEN
|
|
CALL LTSORT (MS, LINKB, KREG, IPNTR, ADDLNK)
|
|
KMAT = ABS (JMAT(IPNTR))
|
|
ELSE
|
|
CALL LTSORT (MR, LINKR, KREG, IPNTR, ADDLNK)
|
|
KMAT = IMAT(IPNTR)
|
|
END IF
|
|
|
|
C SEE IF ALTERNATING MATERIALS WITHIN A REGION ARE ENABLED
|
|
|
|
IF (KMAT .LT. 0) THEN
|
|
CALL LTSORT (MS, LINKS, IABS(KMAT), JPNTR, ADDLNK)
|
|
IF ((JPNTR .GT. 0) .AND. (NLPS(JPNTR) .GE. 2)) THEN
|
|
|
|
C ADD MATERIAL NUMBER BY ROW OF ELEMENTS
|
|
|
|
MATPNT = IFLINE(JPNTR)
|
|
DO 140 K = K1, KKK - M1 + 1, M1
|
|
DO 130 L = K, K + M1 - 1
|
|
MAT(L) = ILLIST(MATPNT)
|
|
130 CONTINUE
|
|
|
|
C UPDATE THE POINTER TO THE NEXT MATERIAL
|
|
|
|
MATPNT = MATPNT + 1
|
|
IF (MATPNT .GT. IFLINE(JPNTR) + NLPS(JPNTR) - 1)
|
|
& MATPNT = IFLINE(JPNTR)
|
|
140 CONTINUE
|
|
ELSE
|
|
WRITE(*, 10000) IABS(KMAT), ISIDE(JPNTR)
|
|
END IF
|
|
|
|
C PUT THE NEW MATERIALS INTO THE MATERIAL ARRAYS
|
|
|
|
DO 170 MATPNT = IFLINE(JPNTR),
|
|
& IFLINE(JPNTR) + NLPS(JPNTR) - 1
|
|
DO 150 K = 1, NUMMAT
|
|
IF (MATMAP(1, K) .EQ. ILLIST(MATPNT)) GO TO 160
|
|
150 CONTINUE
|
|
NUMMAT = NUMMAT + 1
|
|
MATMAP(1, NUMMAT) = ILLIST(MATPNT)
|
|
160 CONTINUE
|
|
170 CONTINUE
|
|
ELSE
|
|
|
|
C JUST INPUT THE ONE MATERIAL
|
|
|
|
DO 180 K = K1, KKK
|
|
MAT(K) = KMAT
|
|
180 CONTINUE
|
|
DO 190 K = 1, NUMMAT
|
|
IF (MATMAP(1, K) .EQ. KMAT) GO TO 200
|
|
190 CONTINUE
|
|
NUMMAT = NUMMAT + 1
|
|
MATMAP(1, NUMMAT) = KMAT
|
|
END IF
|
|
200 CONTINUE
|
|
|
|
C READ THE NODAL BOUNDARY CONDITIONS
|
|
|
|
NNNBC1 = NNNBC + 1
|
|
NNNBC = NNNBC + NNBCRG
|
|
IF (NNBCRG .GE. 1) READ(IUNIT)(LSTNBC(I), I = NNNBC1, NNNBC)
|
|
|
|
C READ THE SIDE BOUNDARY CONDITIONS
|
|
|
|
NNSBC1 = NNSBC + 1
|
|
NNSBC = NNSBC + NSBCRG
|
|
IF (NSBCRG .GE. 1) THEN
|
|
READ(IUNIT)(LSTSBC(I), I = NNSBC1, NNSBC)
|
|
DO 210 I = NNSBC1 + 1, NNSBC, 3
|
|
LSTSBC(I) = LSTSBC(I) + K1 - 1
|
|
210 CONTINUE
|
|
END IF
|
|
220 CONTINUE
|
|
|
|
RETURN
|
|
|
|
230 CONTINUE
|
|
CALL MESSAGE('PREMATURE END OF FILE ON MESH READ')
|
|
CALL MESSAGE('CHECK MESH PROCESSING OUTPUT TO DETERMINE')
|
|
CALL MESSAGE('INCOMPLETE MESH DESCRIPTION')
|
|
ERR = .TRUE.
|
|
NNN = 0
|
|
KKK = 0
|
|
RETURN
|
|
|
|
10000 FORMAT(' THE ALTERNATING MATERIAL NUMBERS FOR REGION(S) WITH', /,
|
|
& ' NEGATIVE MATERIAL NUMBER:', I5, ' DO NOT CORRESPOND TO A',/,
|
|
& ' VALID SIDE NUMBER:', I5, ' WITH AT LEAST TWO LINES.')
|
|
|
|
END
|
|
|