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.
210 lines
7.2 KiB
210 lines
7.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 STRSIZ (MAXNP, X, Y, NINT, N, XEND, YEND, XDIFF, YDIFF,
|
||
|
& D, ERR, TEST, XNOLD, YNOLD, NXKOLD, LINKEG, LISTEG, BMESUR,
|
||
|
& MLINK, NPNOLD, NPEOLD, NNXK, REMESH, REXMIN, REXMAX, REYMIN,
|
||
|
& REYMAX, IDIVIS, SIZMIN, EMAX, EMIN, GRAPH, DXMAX)
|
||
|
C***********************************************************************
|
||
|
|
||
|
C SUBROUTINE STRSIZ = GETS INTERVALS ON A SRAIGHT LINE BASED ON ERROR
|
||
|
C SIZE
|
||
|
|
||
|
C***********************************************************************
|
||
|
|
||
|
DIMENSION X (MAXNP), Y (MAXNP)
|
||
|
|
||
|
DIMENSION XNOLD(NPNOLD), YNOLD(NPNOLD), NXKOLD(NNXK, NPEOLD)
|
||
|
DIMENSION LINKEG(2, MLINK), LISTEG(4 * NPEOLD), BMESUR(NPNOLD)
|
||
|
|
||
|
LOGICAL GRAPH, REMESH, TEST, ERR, SGRAPH, MOVED
|
||
|
|
||
|
IF (GRAPH) THEN
|
||
|
SGRAPH = .TRUE.
|
||
|
ELSE
|
||
|
SGRAPH = .FALSE.
|
||
|
ENDIF
|
||
|
|
||
|
ITERAT = 100
|
||
|
EPS = .01
|
||
|
|
||
|
DSTNOW = 0.
|
||
|
INTNOW = 0
|
||
|
SIZNOW = 0.0
|
||
|
IF (GRAPH) THEN
|
||
|
CALL SYMBOL (1, X(1), Y(1), 'DIAMND')
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
100 CONTINUE
|
||
|
INTNOW = INTNOW + 1
|
||
|
IF (DSTNOW + (SIZNOW * 1.3) .GT. D)THEN
|
||
|
|
||
|
C THE END OF THE LINE (OR CLOSE ENOUGH) HAS BEEN REACHED
|
||
|
|
||
|
C IF WE ARE TESTING OR THE INTERVALS MATCH, THEN SIMPLY FINISH THE
|
||
|
C LINE.
|
||
|
|
||
|
IF ((TEST) .OR. (INTNOW .EQ. NINT)) THEN
|
||
|
NINT = INTNOW
|
||
|
N = NINT + 1
|
||
|
X(N) = XEND
|
||
|
Y(N) = YEND
|
||
|
IF (GRAPH) THEN
|
||
|
CALL SYMBOL (1, X(INTNOW), Y(INTNOW), 'DIAMND')
|
||
|
CALL MPD2VC (1, X(INTNOW), Y(INTNOW),
|
||
|
& X(N), Y(N))
|
||
|
CALL SYMBOL (1, X(N), Y(N), 'DIAMND')
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
ELSE
|
||
|
|
||
|
C OTHERWISE, MAKE SURE THE INTERVALS ARE ALRIGHT AND ADD THE EXTRA ONE
|
||
|
|
||
|
EPS = .001
|
||
|
IF (INTNOW + 1 .NE. NINT) THEN
|
||
|
CALL MESSAGE('** PROBLEMS WITH INTNOW '//
|
||
|
& 'IN PLINE **')
|
||
|
ERR = .TRUE.
|
||
|
GOTO 160
|
||
|
ENDIF
|
||
|
X(INTNOW + 1) = (X(INTNOW) + XEND) * .5
|
||
|
Y(INTNOW + 1) = (Y(INTNOW) + YEND) * .5
|
||
|
N = NINT + 1
|
||
|
X(N) = XEND
|
||
|
Y(N) = YEND
|
||
|
IF (GRAPH) THEN
|
||
|
CALL SYMBOL (1, X(INTNOW + 1), Y(INTNOW + 1),
|
||
|
& 'DIAMND')
|
||
|
CALL SYMBOL (1, X(N), Y(N),
|
||
|
& 'DIAMND')
|
||
|
CALL MPD2VC (1, X(INTNOW), Y(INTNOW),
|
||
|
& X(INTNOW+1), Y(INTNOW+1))
|
||
|
CALL MPD2VC (1, X(INTNOW+1), Y(INTNOW+1),
|
||
|
& X(N), Y(N))
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
ENDIF
|
||
|
ELSE
|
||
|
|
||
|
C NOT TO THE END YET
|
||
|
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG, LISTEG, BMESUR,
|
||
|
& MLINK, NPNOLD, NPEOLD, NNXK, REMESH, REXMIN, REXMAX,
|
||
|
& REYMIN, REYMAX, IDIVIS, SIZMIN, EMAX, EMIN,
|
||
|
& X(INTNOW), Y(INTNOW), S1)
|
||
|
|
||
|
XNEW1 = X(1) + (((DSTNOW + S1) / D) * XDIFF)
|
||
|
YNEW1 = Y(1) + (((DSTNOW + S1) / D) * YDIFF)
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG, LISTEG, BMESUR,
|
||
|
& MLINK, NPNOLD, NPEOLD, NNXK, REMESH, REXMIN, REXMAX,
|
||
|
& REYMIN, REYMAX, IDIVIS, SIZMIN, EMAX, EMIN,
|
||
|
& XNEW1, YNEW1, S2)
|
||
|
XNEW2 = X(1) + (((DSTNOW + ((S1+S2) * .5)) / D) * XDIFF)
|
||
|
YNEW2 = Y(1) + (((DSTNOW + ((S1+S2) * .5)) / D) * YDIFF)
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG, LISTEG, BMESUR,
|
||
|
& MLINK, NPNOLD, NPEOLD, NNXK, REMESH, REXMIN, REXMAX,
|
||
|
& REYMIN, REYMAX, IDIVIS, SIZMIN, EMAX, EMIN,
|
||
|
& XNEW2, YNEW2, S3)
|
||
|
|
||
|
SIZNOW = (((S1 + S2) * .5) + S3) * .5
|
||
|
|
||
|
DSTNOW = DSTNOW + SIZNOW
|
||
|
X(INTNOW + 1) = X(1) + ((DSTNOW / D) * XDIFF)
|
||
|
Y(INTNOW + 1) = Y(1) + ((DSTNOW / D) * YDIFF)
|
||
|
IF (GRAPH) THEN
|
||
|
CALL SYMBOL (1, X(INTNOW + 1), Y(INTNOW + 1),
|
||
|
& 'DIAMND')
|
||
|
CALL MPD2VC (1, X(INTNOW), Y(INTNOW),
|
||
|
& X(INTNOW+1), Y(INTNOW+1))
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
GOTO 100
|
||
|
ENDIF
|
||
|
|
||
|
C ERASE THE NODES FOR REPLOTTING IF NEEDED
|
||
|
|
||
|
IF ((.NOT. SGRAPH) .AND. (GRAPH)) THEN
|
||
|
DO 110 J = 2, NINT
|
||
|
CALL LCOLOR ('BLACK')
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J+1), Y(J+1))
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J-1), Y(J-1))
|
||
|
CALL SYMBOL (1, X(J), Y(J), 'DIAMND')
|
||
|
CALL LCOLOR ('WHITE')
|
||
|
CALL PLTFLU
|
||
|
110 CONTINUE
|
||
|
ENDIF
|
||
|
|
||
|
C NOW SMOOTH THE NODES ALONG THE LINE
|
||
|
|
||
|
DO 130 I = 1, ITERAT
|
||
|
MOVED = .FALSE.
|
||
|
DO 120 J = 2, NINT
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG,
|
||
|
& LISTEG, BMESUR, MLINK, NPNOLD, NPEOLD, NNXK,
|
||
|
& REMESH, REXMIN, REXMAX, REYMIN, REYMAX,
|
||
|
& IDIVIS, SIZMIN, EMAX, EMIN, X(J-1), Y(J-1), SIZE1)
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG,
|
||
|
& LISTEG, BMESUR, MLINK, NPNOLD, NPEOLD, NNXK,
|
||
|
& REMESH, REXMIN, REXMAX, REYMIN, REYMAX,
|
||
|
& IDIVIS, SIZMIN, EMAX, EMIN, X(J), Y(J), SIZE2)
|
||
|
CALL GETSIZ (XNOLD, YNOLD, NXKOLD, LINKEG,
|
||
|
& LISTEG, BMESUR, MLINK, NPNOLD, NPEOLD, NNXK,
|
||
|
& REMESH, REXMIN, REXMAX, REYMIN, REYMAX,
|
||
|
& IDIVIS, SIZMIN, EMAX, EMIN, X(J+1), Y(J+1), SIZE3)
|
||
|
DIST1 = SQRT ( ((X(J-1) - X(J)) **2) +
|
||
|
& ((Y(J-1) - Y(J)) **2) )
|
||
|
DIST2 = SQRT ( ((X(J) - X(J+1)) **2) +
|
||
|
& ((Y(J) - Y(J+1)) **2) )
|
||
|
DTOTAL = DIST1 + DIST2
|
||
|
RATIO = DIST1 / DTOTAL
|
||
|
DRATIO = ((SIZE1 + SIZE2) * .5) /
|
||
|
& ( ((SIZE1 + SIZE2) * .5) +
|
||
|
& ((SIZE2 + SIZE3) * .5) )
|
||
|
TRATIO = (RATIO + DRATIO) * .5
|
||
|
IF (SGRAPH) THEN
|
||
|
CALL LCOLOR ('BLACK')
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J+1), Y(J+1))
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J-1), Y(J-1))
|
||
|
CALL SYMBOL (1, X(J), Y(J), 'DIAMND')
|
||
|
CALL LCOLOR ('WHITE')
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
X(J) = (TRATIO * (X(J+1) - X(J-1))) + X(J-1)
|
||
|
Y(J) = (TRATIO * (Y(J+1) - Y(J-1))) + Y(J-1)
|
||
|
IF (SGRAPH) THEN
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J+1), Y(J+1))
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J-1), Y(J-1))
|
||
|
CALL SYMBOL (1, X(J), Y(J), 'DIAMND')
|
||
|
CALL PLTFLU
|
||
|
ENDIF
|
||
|
DX1 = DIST1 / (.5 * (SIZE1 + SIZE2))
|
||
|
DX2 = DIST2 / (.5 * (SIZE2 + SIZE3))
|
||
|
IF (J .EQ. 2) THEN
|
||
|
DXMAX = AMAX1 (DX1, DX2)
|
||
|
ELSE
|
||
|
DXMAX = AMAX1 (DXMAX, DX1, DX2)
|
||
|
ENDIF
|
||
|
DT = ABS((TRATIO * DTOTAL) - DIST1)
|
||
|
IF (DT/DTOTAL .GT. EPS) MOVED = .TRUE.
|
||
|
120 CONTINUE
|
||
|
IF (.NOT. MOVED) GOTO 140
|
||
|
130 CONTINUE
|
||
|
140 CONTINUE
|
||
|
IF ((.NOT. SGRAPH) .AND. (GRAPH)) THEN
|
||
|
DO 150 J = 2, NINT
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J+1), Y(J+1))
|
||
|
CALL MPD2VC (1, X(J), Y(J), X(J-1), Y(J-1))
|
||
|
CALL SYMBOL (1, X(J), Y(J), 'DIAMND')
|
||
|
CALL PLTFLU
|
||
|
150 CONTINUE
|
||
|
ENDIF
|
||
|
|
||
|
160 CONTINUE
|
||
|
|
||
|
RETURN
|
||
|
|
||
|
END
|