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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
C SUBROUTINE MATINV.F
C
C SOURCE
C BEVINGTON, PAGES 302-303.
C
C PURPOSE
C INVERT A SYMMETRIC MATRIX AND CALCULATE ITS DETERMINANT
C
C USAGE
C CALL MATINV (ARRAY, NORDER, DET)
C
C DESCRIPTION OF PARAMETERS
C ARRAY - INPUT MATRIX WHICH IS REPLACED BY ITS INVERSE
C NORDER - DEGREE OF MATRIX (ORDER OF DETERMINANT)
C DET - DETERMINANT OF INPUT MATRIX
C
C SUBROUTINES AND FUNCTION SUBPROGRAMS REQUIRED
C NONE
C
C COMMENT
C DIMENSION STATEMENT VALID FOR NORDER UP TO 10
C
SUBROUTINE MATINV (ARRAY,NORDER,DET)
DOUBLE PRECISION ARRAY,AMAX,SAVE
DIMENSION ARRAY(10,10),IK(10),JK(10)
C
10 DET=1.
11 DO 100 K=1,NORDER
C
C FIND LARGEST ELEMENT ARRAY(I,J) IN REST OF MATRIX
C
AMAX=0.
21 DO 30 I=K,NORDER
DO 30 J=K,NORDER
23 IF (DABS(AMAX)-DABS(ARRAY(I,J))) 24,24,30
24 AMAX=ARRAY(I,J)
IK(K)=I
JK(K)=J
30 CONTINUE
C
C INTERCHANGE ROWS AND COLUMNS TO PUT AMAX IN ARRAY(K,K)
C
31 IF (AMAX) 41,32,41
32 DET=0.
GOTO 140
41 I=IK(K)
IF (I-K) 21,51,43
43 DO 50 J=1,NORDER
SAVE=ARRAY(K,J)
ARRAY(K,J)=ARRAY(I,J)
50 ARRAY(I,J)=-SAVE
51 J=JK(K)
IF (J-K) 21,61,53
53 DO 60 I=1,NORDER
SAVE=ARRAY(I,K)
ARRAY(I,K)=ARRAY(I,J)
60 ARRAY(I,J)=-SAVE
C
C ACCUMULATE ELEMENTS OF INVERSE MATRIX
C
61 DO 70 I=1,NORDER
IF (I-K) 63,70,63
63 ARRAY(I,K)=-ARRAY(I,K)/AMAX
70 CONTINUE
71 DO 80 I=1,NORDER
DO 80 J=1,NORDER
IF (I-K) 74,80,74
74 IF (J-K) 75,80,75
75 ARRAY(I,J)=ARRAY(I,J)+ARRAY(I,K)*ARRAY(K,J)
80 CONTINUE
81 DO 90 J=1,NORDER
IF (J-K) 83,90,83
83 ARRAY(K,J)=ARRAY(K,J)/AMAX
90 CONTINUE
ARRAY(K,K)=1./AMAX
100 DET=DET*AMAX
C
C RESTORE ORDERING OF MATRIX
C
101 DO 130 L=1,NORDER
K=NORDER-L+1
J=IK(K)
IF (J-K) 111,111,105
105 DO 110 I=1,NORDER
SAVE=ARRAY(I,K)
ARRAY(I,K)=-ARRAY(I,J)
110 ARRAY(I,J)=SAVE
111 I=JK(K)
IF (I-K) 130,130,113
113 DO 120 J=1,NORDER
SAVE=ARRAY(K,J)
ARRAY(K,J)=-ARRAY(I,J)
120 ARRAY(I,J)=SAVE
130 CONTINUE
140 RETURN
END
|