2
3
4
5
6
7
8
9
10
11
12
13
14 INTEGER INFO, KL, KU, LDAB, M, N
15
16
17 DOUBLE PRECISION AB( LDAB, * )
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 DOUBLE PRECISION ONE, ZERO
89 parameter( one = 1.0d+0 )
90 parameter( zero = 0.0d+0 )
91
92
93 INTEGER J, JP, JU, KM, KV
94
95
96 INTEGER ISAMAX
97 EXTERNAL isamax
98
99
100 EXTERNAL dger, dscal, dswap
101
102
104
105
106
107
108
109
110 kv = ku
111
112
113
114 info = 0
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133 IF( m.EQ.0 .OR. n.EQ.0 )
134 $ RETURN
135
136
137
138
139
140
141 ju = 1
142
143 DO 40 j = 1,
min( m, n )
144
145
146
147
149 jp = 1
150 IF( ab( kv+1, j ).NE.zero ) THEN
151 ju =
max( ju,
min( j+ku, n ) )
152
153 IF( km.GT.0 ) THEN
154
155
156
157 CALL dscal( km, one / ab( ku+1, j ), ab( ku+2, j ), 1 )
158
159
160
161 IF( ju.GT.j ) THEN
162 CALL dger( km, ju-j, -one, ab( ku+2, j ), 1,
163 $ ab( ku, j+1 ), ldab-1, ab( ku+1, j+1 ),
164 $ ldab-1 )
165 END IF
166 END IF
167 ELSE
168
169 IF( info.EQ.0 )
170 $ info = j
171 END IF
172 40 CONTINUE
173 RETURN
174
175
176