LAPACK 3.12.1
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches
dpptri.f
Go to the documentation of this file.
1*> \brief \b DPPTRI
2*
3* =========== DOCUMENTATION ===========
4*
5* Online html documentation available at
6* http://www.netlib.org/lapack/explore-html/
7*
8*> Download DPPTRI + dependencies
9*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/dpptri.f">
10*> [TGZ]</a>
11*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/dpptri.f">
12*> [ZIP]</a>
13*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/dpptri.f">
14*> [TXT]</a>
15*
16* Definition:
17* ===========
18*
19* SUBROUTINE DPPTRI( UPLO, N, AP, INFO )
20*
21* .. Scalar Arguments ..
22* CHARACTER UPLO
23* INTEGER INFO, N
24* ..
25* .. Array Arguments ..
26* DOUBLE PRECISION AP( * )
27* ..
28*
29*
30*> \par Purpose:
31* =============
32*>
33*> \verbatim
34*>
35*> DPPTRI computes the inverse of a real symmetric positive definite
36*> matrix A using the Cholesky factorization A = U**T*U or A = L*L**T
37*> computed by DPPTRF.
38*> \endverbatim
39*
40* Arguments:
41* ==========
42*
43*> \param[in] UPLO
44*> \verbatim
45*> UPLO is CHARACTER*1
46*> = 'U': Upper triangular factor is stored in AP;
47*> = 'L': Lower triangular factor is stored in AP.
48*> \endverbatim
49*>
50*> \param[in] N
51*> \verbatim
52*> N is INTEGER
53*> The order of the matrix A. N >= 0.
54*> \endverbatim
55*>
56*> \param[in,out] AP
57*> \verbatim
58*> AP is DOUBLE PRECISION array, dimension (N*(N+1)/2)
59*> On entry, the triangular factor U or L from the Cholesky
60*> factorization A = U**T*U or A = L*L**T, packed columnwise as
61*> a linear array. The j-th column of U or L is stored in the
62*> array AP as follows:
63*> if UPLO = 'U', AP(i + (j-1)*j/2) = U(i,j) for 1<=i<=j;
64*> if UPLO = 'L', AP(i + (j-1)*(2n-j)/2) = L(i,j) for j<=i<=n.
65*>
66*> On exit, the upper or lower triangle of the (symmetric)
67*> inverse of A, overwriting the input factor U or L.
68*> \endverbatim
69*>
70*> \param[out] INFO
71*> \verbatim
72*> INFO is INTEGER
73*> = 0: successful exit
74*> < 0: if INFO = -i, the i-th argument had an illegal value
75*> > 0: if INFO = i, the (i,i) element of the factor U or L is
76*> zero, and the inverse could not be computed.
77*> \endverbatim
78*
79* Authors:
80* ========
81*
82*> \author Univ. of Tennessee
83*> \author Univ. of California Berkeley
84*> \author Univ. of Colorado Denver
85*> \author NAG Ltd.
86*
87*> \ingroup pptri
88*
89* =====================================================================
90 SUBROUTINE dpptri( UPLO, N, AP, INFO )
91*
92* -- LAPACK computational routine --
93* -- LAPACK is a software package provided by Univ. of Tennessee, --
94* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
95*
96* .. Scalar Arguments ..
97 CHARACTER UPLO
98 INTEGER INFO, N
99* ..
100* .. Array Arguments ..
101 DOUBLE PRECISION AP( * )
102* ..
103*
104* =====================================================================
105*
106* .. Parameters ..
107 DOUBLE PRECISION ONE
108 parameter( one = 1.0d+0 )
109* ..
110* .. Local Scalars ..
111 LOGICAL UPPER
112 INTEGER J, JC, JJ, JJN
113 DOUBLE PRECISION AJJ
114* ..
115* .. External Functions ..
116 LOGICAL LSAME
117 DOUBLE PRECISION DDOT
118 EXTERNAL lsame, ddot
119* ..
120* .. External Subroutines ..
121 EXTERNAL dscal, dspr, dtpmv, dtptri, xerbla
122* ..
123* .. Executable Statements ..
124*
125* Test the input parameters.
126*
127 info = 0
128 upper = lsame( uplo, 'U' )
129 IF( .NOT.upper .AND. .NOT.lsame( uplo, 'L' ) ) THEN
130 info = -1
131 ELSE IF( n.LT.0 ) THEN
132 info = -2
133 END IF
134 IF( info.NE.0 ) THEN
135 CALL xerbla( 'DPPTRI', -info )
136 RETURN
137 END IF
138*
139* Quick return if possible
140*
141 IF( n.EQ.0 )
142 $ RETURN
143*
144* Invert the triangular Cholesky factor U or L.
145*
146 CALL dtptri( uplo, 'Non-unit', n, ap, info )
147 IF( info.GT.0 )
148 $ RETURN
149*
150 IF( upper ) THEN
151*
152* Compute the product inv(U) * inv(U)**T.
153*
154 jj = 0
155 DO 10 j = 1, n
156 jc = jj + 1
157 jj = jj + j
158 IF( j.GT.1 )
159 $ CALL dspr( 'Upper', j-1, one, ap( jc ), 1, ap )
160 ajj = ap( jj )
161 CALL dscal( j, ajj, ap( jc ), 1 )
162 10 CONTINUE
163*
164 ELSE
165*
166* Compute the product inv(L)**T * inv(L).
167*
168 jj = 1
169 DO 20 j = 1, n
170 jjn = jj + n - j + 1
171 ap( jj ) = ddot( n-j+1, ap( jj ), 1, ap( jj ), 1 )
172 IF( j.LT.n )
173 $ CALL dtpmv( 'Lower', 'Transpose', 'Non-unit', n-j,
174 $ ap( jjn ), ap( jj+1 ), 1 )
175 jj = jjn
176 20 CONTINUE
177 END IF
178*
179 RETURN
180*
181* End of DPPTRI
182*
183 END
subroutine xerbla(srname, info)
Definition cblat2.f:3285
subroutine dspr(uplo, n, alpha, x, incx, ap)
DSPR
Definition dspr.f:127
subroutine dpptri(uplo, n, ap, info)
DPPTRI
Definition dpptri.f:91
subroutine dscal(n, da, dx, incx)
DSCAL
Definition dscal.f:79
subroutine dtpmv(uplo, trans, diag, n, ap, x, incx)
DTPMV
Definition dtpmv.f:142
subroutine dtptri(uplo, diag, n, ap, info)
DTPTRI
Definition dtptri.f:115