3
4
5
6
7
8
9
10
11
12
13
14
15 CHARACTER TRANS
16 INTEGER INFO, LDB, N, NRHS
17
18
19 DOUBLE PRECISION D( * )
20 DOUBLE PRECISION B( LDB, * ), E( * )
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 LOGICAL NOTRAN
71 INTEGER I, J
72
73
74 LOGICAL LSAME
76
77
78 EXTERNAL xerbla
79
80
82
83
84
85
86
87 info = 0
88 notran =
lsame( trans,
'N' )
89 IF( .NOT.notran .AND. .NOT.
lsame( trans,
'T' ) )
THEN
90 info = -1
91 ELSE IF( n.LT.0 ) THEN
92 info = -2
93 ELSE IF( nrhs.LT.0 ) THEN
94 info = -3
95 ELSE IF( ldb.LT.
max( 1, n ) )
THEN
96 info = -7
97 END IF
98 IF( info.NE.0 ) THEN
99 CALL xerbla( 'DPTTRS', -info )
100 RETURN
101 END IF
102
103
104
105 IF( n.EQ.0 )
106 $ RETURN
107 IF( notran ) THEN
108
109 DO 60 j = 1, nrhs
110
111
112
113 DO 40 i = 2, n
114 b( i, j ) = b( i, j ) - b( i-1, j )*e( i-1 )
115 40 CONTINUE
116 60 CONTINUE
117
118 ELSE
119
120 DO 65 j = 1, nrhs
121
122
123
124 DO 50 i = n - 1, 1, -1
125 b( i, j ) = b( i, j ) -
126 $ b( i+1, j )*( e( i ) )
127 50 CONTINUE
128 65 CONTINUE
129 ENDIF
130
131 RETURN
132
133
134