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.
140 lines
4.3 KiB
140 lines
4.3 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
|
||
|
|
||
|
C=======================================================================
|
||
|
SUBROUTINE HIDCOR (LINSET, IPSET, NPART, IEDSET, NEDGES,
|
||
|
& LENF, NLNKF, LINKF, XN, YN, ZN,
|
||
|
* MREF, LREF)
|
||
|
C=======================================================================
|
||
|
|
||
|
C --*** HIDCOR *** (MESH) Hide partial lines by face
|
||
|
C -- Written by Amy Gilkey - revised 10/22/87
|
||
|
C --
|
||
|
C --HIDCOR deletes partial lines that have a visible node as a corner
|
||
|
C --of a quarilateral and the hidden node is within the area defined
|
||
|
C --by the vectors from the corner to the two adjacent nodes. Such
|
||
|
C --a face totally hides the partial line.
|
||
|
C --
|
||
|
C --Parameters:
|
||
|
C -- LINSET - IN - the sorted line set
|
||
|
C -- IPSET - I/O - the indices of the partial line set
|
||
|
C -- NPART - I/O - the number of lines in the partial line set
|
||
|
C -- IEDSET - I/O - the edge line set;
|
||
|
C -- (0) = face defining edge; 0 to delete edge
|
||
|
C -- NEDGES - I/O - the number of lines in the edge set
|
||
|
C -- LENF - IN - the cumulative face counts by element block
|
||
|
C -- NLNKF - IN - the number of nodes per face
|
||
|
C -- LINKF - IN - the connectivity for all faces
|
||
|
C -- XN,YN,ZN - IN - the nodal coordinates
|
||
|
C --
|
||
|
C --Common Variables:
|
||
|
C -- Uses LLNSET of /D3NUMS/
|
||
|
|
||
|
include 'debug.blk'
|
||
|
include 'dbnums.blk'
|
||
|
include 'd3nums.blk'
|
||
|
|
||
|
INTEGER LINSET(LLNSET,*)
|
||
|
INTEGER IPSET(*)
|
||
|
INTEGER IEDSET(0:2,*)
|
||
|
INTEGER LENF(0:NELBLK)
|
||
|
INTEGER NLNKF(NELBLK)
|
||
|
INTEGER LINKF(*)
|
||
|
REAL XN(*), YN(*), ZN(*)
|
||
|
INTEGER MREF(*), LREF(*)
|
||
|
|
||
|
LOGICAL CKCROS
|
||
|
|
||
|
C --Check each edge line against each partial line for overlap
|
||
|
|
||
|
NOLDPT = NPART
|
||
|
|
||
|
call iniint(numnpf, 0, mref)
|
||
|
call iniint(numnpf, 0, lref)
|
||
|
|
||
|
do ip=1,npart
|
||
|
lref(LINSET(1,IPSET(IP))) = ip
|
||
|
lref(LINSET(2,IPSET(IP))) = ip
|
||
|
end do
|
||
|
|
||
|
do ip=npart,1,-1
|
||
|
mref(LINSET(1,IPSET(IP))) = ip
|
||
|
mref(LINSET(2,IPSET(IP))) = ip
|
||
|
end do
|
||
|
|
||
|
nhid = 0
|
||
|
DO 120 IEDG = 1, NEDGES
|
||
|
IFAC = IEDSET(0,IEDG)
|
||
|
N1 = IEDSET(1,IEDG)
|
||
|
N2 = IEDSET(2,IEDG)
|
||
|
|
||
|
imin = max(1, mref(n1), mref(n2))
|
||
|
imax = min(npart, lref(n1), lref(n2))
|
||
|
do ip = imin, imax
|
||
|
if (ipset(ip) .gt. 0) then
|
||
|
C --Process only if visible node is corner node of face
|
||
|
IV = LINSET(1,IPSET(IP))
|
||
|
IF ((N1 .EQ. IV) .OR. (N2 .EQ. IV)) THEN
|
||
|
IH = LINSET(2,IPSET(IP))
|
||
|
IF (N2 .EQ. IH) GOTO 110
|
||
|
|
||
|
C --Check if face hides the visible part of the line
|
||
|
IELB = 0
|
||
|
IXL = IDBLNK (IELB, IFAC, LENF, NLNKF)
|
||
|
IF (CKCROS (IV, IH, NLNKF(IELB), LINKF(IXL),
|
||
|
& XN, YN, ZN)) THEN
|
||
|
|
||
|
C --Move totally hidden lines from partial set to totally
|
||
|
C --hidden lines
|
||
|
ipset(ip) = -ipset(ip)
|
||
|
nhid = nhid + 1
|
||
|
|
||
|
END IF
|
||
|
END IF
|
||
|
end if
|
||
|
110 CONTINUE
|
||
|
end do
|
||
|
120 CONTINUE
|
||
|
if ((cdebug .eq. 'HIDDEN') .and. (idebug .ge. 1))
|
||
|
& write (*, '(1x,a,i5)') 'partial lines hidden by face =', nhid
|
||
|
|
||
|
nhid = 0
|
||
|
ip = 1
|
||
|
100 continue
|
||
|
if (ip .le. npart) then
|
||
|
if (ipset(ip) .lt. 0) then
|
||
|
I = -IPSET(IP)
|
||
|
IPSET(IP) = IPSET(NPART)
|
||
|
IPSET(NPART) = I
|
||
|
NPART = NPART - 1
|
||
|
IP = IP - 1
|
||
|
nhid = nhid + 1
|
||
|
end if
|
||
|
ip = ip + 1
|
||
|
go to 100
|
||
|
end if
|
||
|
C --Delete the edges which are totally hidden lines
|
||
|
|
||
|
nhid = 0
|
||
|
DO 140 IP = NPART+1, NOLDPT
|
||
|
IV = LINSET(1,IPSET(IP))
|
||
|
IH = LINSET(2,IPSET(IP))
|
||
|
DO 130 IEDG = 1, NEDGES
|
||
|
IF (IEDSET(1,IEDG) .EQ. IV) THEN
|
||
|
IF (IEDSET(2,IEDG) .EQ. IH) THEN
|
||
|
IEDSET(0,IEDG) = 0
|
||
|
nhid = nhid + 1
|
||
|
GOTO 140
|
||
|
END IF
|
||
|
END IF
|
||
|
130 CONTINUE
|
||
|
140 CONTINUE
|
||
|
if ((cdebug .eq. 'HIDDEN') .and. (idebug .ge. 1))
|
||
|
& write (*, '(1x,a,i5)') 'edges hidden by face =', nhid
|
||
|
|
||
|
RETURN
|
||
|
END
|