LAPACK 3.12.1
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches
strtri.f
Go to the documentation of this file.
1*> \brief \b STRTRI
2*
3* =========== DOCUMENTATION ===========
4*
5* Online html documentation available at
6* http://www.netlib.org/lapack/explore-html/
7*
8*> Download STRTRI + dependencies
9*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/strtri.f">
10*> [TGZ]</a>
11*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/strtri.f">
12*> [ZIP]</a>
13*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/strtri.f">
14*> [TXT]</a>
15*
16* Definition:
17* ===========
18*
19* SUBROUTINE STRTRI( UPLO, DIAG, N, A, LDA, INFO )
20*
21* .. Scalar Arguments ..
22* CHARACTER DIAG, UPLO
23* INTEGER INFO, LDA, N
24* ..
25* .. Array Arguments ..
26* REAL A( LDA, * )
27* ..
28*
29*
30*> \par Purpose:
31* =============
32*>
33*> \verbatim
34*>
35*> STRTRI computes the inverse of a real upper or lower triangular
36*> matrix A.
37*>
38*> This is the Level 3 BLAS version of the algorithm.
39*> \endverbatim
40*
41* Arguments:
42* ==========
43*
44*> \param[in] UPLO
45*> \verbatim
46*> UPLO is CHARACTER*1
47*> = 'U': A is upper triangular;
48*> = 'L': A is lower triangular.
49*> \endverbatim
50*>
51*> \param[in] DIAG
52*> \verbatim
53*> DIAG is CHARACTER*1
54*> = 'N': A is non-unit triangular;
55*> = 'U': A is unit triangular.
56*> \endverbatim
57*>
58*> \param[in] N
59*> \verbatim
60*> N is INTEGER
61*> The order of the matrix A. N >= 0.
62*> \endverbatim
63*>
64*> \param[in,out] A
65*> \verbatim
66*> A is REAL array, dimension (LDA,N)
67*> On entry, the triangular matrix A. If UPLO = 'U', the
68*> leading N-by-N upper triangular part of the array A contains
69*> the upper triangular matrix, and the strictly lower
70*> triangular part of A is not referenced. If UPLO = 'L', the
71*> leading N-by-N lower triangular part of the array A contains
72*> the lower triangular matrix, and the strictly upper
73*> triangular part of A is not referenced. If DIAG = 'U', the
74*> diagonal elements of A are also not referenced and are
75*> assumed to be 1.
76*> On exit, the (triangular) inverse of the original matrix, in
77*> the same storage format.
78*> \endverbatim
79*>
80*> \param[in] LDA
81*> \verbatim
82*> LDA is INTEGER
83*> The leading dimension of the array A. LDA >= max(1,N).
84*> \endverbatim
85*>
86*> \param[out] INFO
87*> \verbatim
88*> INFO is INTEGER
89*> = 0: successful exit
90*> < 0: if INFO = -i, the i-th argument had an illegal value
91*> > 0: if INFO = i, A(i,i) is exactly zero. The triangular
92*> matrix is singular and its inverse can not be computed.
93*> \endverbatim
94*
95* Authors:
96* ========
97*
98*> \author Univ. of Tennessee
99*> \author Univ. of California Berkeley
100*> \author Univ. of Colorado Denver
101*> \author NAG Ltd.
102*
103*> \ingroup trtri
104*
105* =====================================================================
106 SUBROUTINE strtri( UPLO, DIAG, N, A, LDA, INFO )
107*
108* -- LAPACK computational routine --
109* -- LAPACK is a software package provided by Univ. of Tennessee, --
110* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
111*
112* .. Scalar Arguments ..
113 CHARACTER DIAG, UPLO
114 INTEGER INFO, LDA, N
115* ..
116* .. Array Arguments ..
117 REAL A( LDA, * )
118* ..
119*
120* =====================================================================
121*
122* .. Parameters ..
123 REAL ONE, ZERO
124 parameter( one = 1.0e+0, zero = 0.0e+0 )
125* ..
126* .. Local Scalars ..
127 LOGICAL NOUNIT, UPPER
128 INTEGER J, JB, NB, NN
129* ..
130* .. External Functions ..
131 LOGICAL LSAME
132 INTEGER ILAENV
133 EXTERNAL lsame, ilaenv
134* ..
135* .. External Subroutines ..
136 EXTERNAL strmm, strsm, strti2, xerbla
137* ..
138* .. Intrinsic Functions ..
139 INTRINSIC max, min
140* ..
141* .. Executable Statements ..
142*
143* Test the input parameters.
144*
145 info = 0
146 upper = lsame( uplo, 'U' )
147 nounit = lsame( diag, 'N' )
148 IF( .NOT.upper .AND. .NOT.lsame( uplo, 'L' ) ) THEN
149 info = -1
150 ELSE IF( .NOT.nounit .AND. .NOT.lsame( diag, 'U' ) ) THEN
151 info = -2
152 ELSE IF( n.LT.0 ) THEN
153 info = -3
154 ELSE IF( lda.LT.max( 1, n ) ) THEN
155 info = -5
156 END IF
157 IF( info.NE.0 ) THEN
158 CALL xerbla( 'STRTRI', -info )
159 RETURN
160 END IF
161*
162* Quick return if possible
163*
164 IF( n.EQ.0 )
165 $ RETURN
166*
167* Check for singularity if non-unit.
168*
169 IF( nounit ) THEN
170 DO 10 info = 1, n
171 IF( a( info, info ).EQ.zero )
172 $ RETURN
173 10 CONTINUE
174 info = 0
175 END IF
176*
177* Determine the block size for this environment.
178*
179 nb = ilaenv( 1, 'STRTRI', uplo // diag, n, -1, -1, -1 )
180 IF( nb.LE.1 .OR. nb.GE.n ) THEN
181*
182* Use unblocked code
183*
184 CALL strti2( uplo, diag, n, a, lda, info )
185 ELSE
186*
187* Use blocked code
188*
189 IF( upper ) THEN
190*
191* Compute inverse of upper triangular matrix
192*
193 DO 20 j = 1, n, nb
194 jb = min( nb, n-j+1 )
195*
196* Compute rows 1:j-1 of current block column
197*
198 CALL strmm( 'Left', 'Upper', 'No transpose', diag,
199 $ j-1,
200 $ jb, one, a, lda, a( 1, j ), lda )
201 CALL strsm( 'Right', 'Upper', 'No transpose', diag,
202 $ j-1,
203 $ jb, -one, a( j, j ), lda, a( 1, j ), lda )
204*
205* Compute inverse of current diagonal block
206*
207 CALL strti2( 'Upper', diag, jb, a( j, j ), lda, info )
208 20 CONTINUE
209 ELSE
210*
211* Compute inverse of lower triangular matrix
212*
213 nn = ( ( n-1 ) / nb )*nb + 1
214 DO 30 j = nn, 1, -nb
215 jb = min( nb, n-j+1 )
216 IF( j+jb.LE.n ) THEN
217*
218* Compute rows j+jb:n of current block column
219*
220 CALL strmm( 'Left', 'Lower', 'No transpose', diag,
221 $ n-j-jb+1, jb, one, a( j+jb, j+jb ), lda,
222 $ a( j+jb, j ), lda )
223 CALL strsm( 'Right', 'Lower', 'No transpose', diag,
224 $ n-j-jb+1, jb, -one, a( j, j ), lda,
225 $ a( j+jb, j ), lda )
226 END IF
227*
228* Compute inverse of current diagonal block
229*
230 CALL strti2( 'Lower', diag, jb, a( j, j ), lda, info )
231 30 CONTINUE
232 END IF
233 END IF
234*
235 RETURN
236*
237* End of STRTRI
238*
239 END
subroutine xerbla(srname, info)
Definition cblat2.f:3285
subroutine strmm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
STRMM
Definition strmm.f:177
subroutine strsm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
STRSM
Definition strsm.f:181
subroutine strti2(uplo, diag, n, a, lda, info)
STRTI2 computes the inverse of a triangular matrix (unblocked algorithm).
Definition strti2.f:108
subroutine strtri(uplo, diag, n, a, lda, info)
STRTRI
Definition strtri.f:107