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.
115 lines
3.4 KiB
115 lines
3.4 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 LINE3 (COORD, NUMNP, DIST, T, NDIM, P1, P2, TOLER,
|
|
* NODEL, BOUND, SORTYP, MAP, SORUP, INUM, OPT, SELECT)
|
|
DIMENSION COORD (NUMNP,*), DIST(*), T(*), P1(*), P2(*),
|
|
* TOLER(2), MAP(*)
|
|
CHARACTER*(*) NODEL, BOUND, SORTYP, OPT
|
|
LOGICAL SORUP, SELECT(*), ISABRT
|
|
include 'nu_io.blk'
|
|
|
|
CALL LOCOUT ('LINE', NDIM, NODEL, TOLER, SORTYP, P1, P2, BOUND)
|
|
|
|
IF (BOUND(:3) .EQ. 'BOU') THEN
|
|
BMULT = 1.0
|
|
ELSE
|
|
BMULT = 0.0
|
|
END IF
|
|
|
|
TEMP = TOLER(1)
|
|
TOLER(1) = MAX(0.0, TEMP - TOLER(2))
|
|
TOLER(2) = MAX(0.0, TEMP + TOLER(2))
|
|
|
|
A = P2(1) - P1(1)
|
|
B = P2(2) - P1(2)
|
|
C = P2(3) - P1(3)
|
|
X1 = P1(1)
|
|
Y1 = P1(2)
|
|
Z1 = P1(3)
|
|
DLINE = A**2 + B**2 + C**2
|
|
IF (DLINE .EQ. 0.0) THEN
|
|
CALL PRTERR ('CMDERR', 'Zero length line input')
|
|
RETURN
|
|
END IF
|
|
|
|
DO 10 I=1, NUMNP
|
|
IF (SELECT(I)) THEN
|
|
X0 = COORD(I,1)
|
|
Y0 = COORD(I,2)
|
|
Z0 = COORD(I,3)
|
|
T(I) = -1. * (A * (X1 - X0) + B * (Y1 - Y0) + C * (Z1 - Z0))
|
|
* / (A**2 + B**2 + C**2)
|
|
|
|
X = X1 + A * T(I)
|
|
Y = Y1 + B * T(I)
|
|
Z = Z1 + C * T(I)
|
|
|
|
DIST(I) = (X - X0)**2 + (Y - Y0)**2 + (Z - Z0)**2
|
|
END IF
|
|
10 CONTINUE
|
|
INUM = 0
|
|
DISMIN = 1.0E38
|
|
DO 20 I=1, NUMNP
|
|
IF (SELECT(I)) THEN
|
|
DISMIN = MIN(DIST(I), ABS(DISMIN-TEMP))
|
|
IF (DIST(I) .GE. TOLER(1)**2 .AND. DIST(I) .LE. TOLER(2)**2
|
|
* .AND. BMULT * T(I) .GE. 0.0 .AND. BMULT * T(I) .LE. 1.0)
|
|
* THEN
|
|
INUM = INUM + 1
|
|
MAP(INUM) = I
|
|
END IF
|
|
END IF
|
|
20 CONTINUE
|
|
|
|
IF (SORTYP .EQ. 'X') THEN
|
|
CALL INDEXX (COORD(1,1), MAP, INUM, .FALSE.)
|
|
ELSE IF (SORTYP .EQ. 'Y') THEN
|
|
CALL INDEXX (COORD(1,2), MAP, INUM, .FALSE.)
|
|
ELSE IF (SORTYP .EQ. 'Z') THEN
|
|
CALL INDEXX (COORD(1,3), MAP, INUM, .FALSE.)
|
|
ELSE IF (SORTYP .EQ. 'T' .OR. SORTYP .EQ. 'PARAMETR') THEN
|
|
CALL INDEXX (T, MAP, INUM, .FALSE.)
|
|
ELSE IF (SORTYP .EQ. 'DISTANCE') THEN
|
|
CALL INDEXX (DIST, MAP, INUM, .FALSE.)
|
|
END IF
|
|
|
|
IF (SORUP) THEN
|
|
IBEG = 1
|
|
IEND = INUM
|
|
IINC = 1
|
|
ELSE
|
|
IBEG = INUM
|
|
IEND = 1
|
|
IINC = -1
|
|
END IF
|
|
|
|
IF (OPT .EQ. '*' .OR. INDEX(OPT, 'P') .GT. 0) THEN
|
|
DO 30 IO=IOMIN, IOMAX
|
|
WRITE (IO, 40) NODEL
|
|
30 CONTINUE
|
|
40 FORMAT (/,T50,'DISTANCE',/2X,A8,T16,'X',T26,'Y',T36,'Z',
|
|
* T45,'NORMAL',T55,'PARAMETRIC',/)
|
|
DO 60 IN = IBEG, IEND, IINC
|
|
IF (ISABRT()) RETURN
|
|
I = MAP(IN)
|
|
DO 50 IO=IOMIN, IOMAX
|
|
WRITE (IO, 90) I, (COORD(I,J),J=1,3), SQRT(DIST(I)),
|
|
* T(I)
|
|
50 CONTINUE
|
|
60 CONTINUE
|
|
|
|
IF (INUM .EQ. 0) THEN
|
|
DO 70 IO=IOMIN, IOMAX
|
|
WRITE (IO, 80) SQRT(DISMIN)
|
|
70 CONTINUE
|
|
END IF
|
|
END IF
|
|
80 FORMAT (/' None found within range, minimum distance = ',
|
|
* 1PE12.3,/)
|
|
90 FORMAT (I10, 3(F10.4), 2(1PE12.3))
|
|
RETURN
|
|
END
|
|
|