File: fndset.f

package info (click to toggle)
nastran 0.1.95-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye, sid
  • size: 122,540 kB
  • sloc: fortran: 284,409; sh: 771; makefile: 324
file content (68 lines) | stat: -rw-r--r-- 2,053 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
      SUBROUTINE FNDSET (GPID,X,IBUF,N)
C
C     GPID = GRID POINT TABLE FOR THIS SET
C
C     N  = 0 INPUT
C     FNDSET READS THE COORDINATES OF THE GRID POINTS IN THIS SET.
C     IF THE GRID POINT TABLE VALUE IS ZERO THE CORRESPONDING GRID
C     POINT IS NOT USED IN THIS SET AND ITS VALUES SKIPPED, OTHERWISE
C     THE XYZ COORDINDATE VALUES ARE READ FROM BGPDT AND PACKED INTO
C     X SPACE. TOTALLY THERE ARE NGPSET GRID DATA SAVED IN X.
C     CORE NEEDED FOR X = 3*NGPSET (PROVIDED BY CALLING ROUTINE)
C
C     N  = 1 INPUT/OUTPUT
C     FNDSET POSITIONS THE STRESS FILE TO THE SUBCASE/VALUE LAST
C     PROCESSED
C
      INTEGER         GPID(1),BGPDT,OES1,REW,SUBC
      REAL            X(3,1),U(3)
      COMMON /BLANK / NGP,SKP11(4),NGPSET,SKP12(4),SKP21(4),BGPDT,
     1                SKP22(8),OES1
      COMMON /NAMES / NIREW,INPREW,SKPN1(2),REW,NOREW
      COMMON /XXPARM/ SKPP(211),SUBC,FLAG,DATA
      EQUIVALENCE     (U(1),INSUB)
      DATA    TWOPI / 0.0 /
C
      IF (N .NE. 0) GO TO 30
      CALL GOPEN (BGPDT,GPID(IBUF),INPREW)
      J = 1
      DO 20 I = 1,NGP
      IF (GPID(I) .NE. 0) GO TO 10
      CALL FREAD (BGPDT,0,-4,0)
      GO TO 20
   10 CALL FREAD (BGPDT,0,-1,0)
      CALL FREAD (BGPDT,X(1,J),3,0)
      J = J + 1
   20 CONTINUE
      CALL CLOSE (BGPDT,REW)
      GO TO 110
C
C     POSITION OES1
C
   30 IF (TWOPI .LT. 6.2) TWOPI = 8.0*ATAN(1.0)
      CALL GOPEN (OES1,GPID(IBUF),INPREW)
   40 CALL READ  (*90,*90,OES1,J,1,0,I)
      CALL FREAD (OES1,0,-2,0)
      CALL FREAD (OES1,U,3,0)
      IF (SUBC .NE. INSUB) GO TO 70
      IF (FLAG-1.0) 100,60,50
   50 J = J/10
C
C     REAL EIGENVALUE ANALYSIS - CONVERT TO FREQUENCY
C
      IF (J .EQ. 2) U(3) = SQRT(ABS(U(3)))/TWOPI
      IF (DATA-U(3) .GT. 1.0E-6) GO TO 70
      GO TO 100
   60 IF (DATA-U(2)) 70,100,70
C
C     WRONG CASE
C
   70 CALL FWDREC (*90,OES1)
      CALL FWDREC (*90,OES1)
      GO TO 40
   90 N = N + 1
  100 CALL BCKREC (OES1)
      CALL CLOSE  (OES1,NOREW)
C
  110 RETURN
      END