File: f89.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 (53 lines) | stat: -rw-r--r-- 1,114 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
      FUNCTION F89 (I,A,B,M,N,X)
C
      DIMENSION X(1)
C
      F89  = 0.0
      CAPX = A + B*X(I)
      NFAC = M
      ASSIGN 5 TO IRET
      GO TO 1000
    5 AMF = IFAC
      N1  = M + 1
      N2  = N1 - N
      AN1 = N1
      AN2 = N2
      IS  = 0
      S   = 0.0
      SF  = 1.0
      AMMSF = AMF
      GO TO 50
   10 IS = IS + 1
      S  = IS
      SF = SF*S
      AMMSF = AMMSF/(AN1-S)
   50 CONTINUE
      N3 = N2 - IS
      IF (N3 .EQ. 0) GO TO 100
      F89 = F89 + AMF*((-A)**IS)*(CAPX**N3)/(AMMSF*SF*(AN2-S))
      GO TO 200
  100 CONTINUE
      NFAC = N2
      ASSIGN 110 TO IRET
      GO TO 1000
  110 AMN1F = IFAC
      NFAC  = N - 1
      ASSIGN 120 TO IRET
      GO TO 1000
  120 ANM1F = IFAC
      F89 = F89 + AMF*((-A)**N2)*ALOG(ABS(CAPX))/(AMN1F*ANM1F)
  200 IF (IS .LT.  M) GO TO 10
      IF (B .EQ. 0.0) GO TO 300
      F89 = F89/(B**N1)
      RETURN
C
  300 F89 = 0.0
      RETURN
C
 1000 IFAC = 1
      IF (NFAC .LT. 2) GO TO 1020
      DO 1010 LFAC = 2,NFAC
      IFAC = IFAC*LFAC
 1010 CONTINUE
 1020 GO TO IRET, (5,110,120)
      END