LAPACK 3.12.1
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches
dtrttp.f
Go to the documentation of this file.
1*> \brief \b DTRTTP copies a triangular matrix from the standard full format (TR) to the standard packed format (TP).
2*
3* =========== DOCUMENTATION ===========
4*
5* Online html documentation available at
6* http://www.netlib.org/lapack/explore-html/
7*
8*> Download DTRTTP + dependencies
9*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/dtrttp.f">
10*> [TGZ]</a>
11*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/dtrttp.f">
12*> [ZIP]</a>
13*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/dtrttp.f">
14*> [TXT]</a>
15*
16* Definition:
17* ===========
18*
19* SUBROUTINE DTRTTP( UPLO, N, A, LDA, AP, INFO )
20*
21* .. Scalar Arguments ..
22* CHARACTER UPLO
23* INTEGER INFO, N, LDA
24* ..
25* .. Array Arguments ..
26* DOUBLE PRECISION A( LDA, * ), AP( * )
27* ..
28*
29*
30*> \par Purpose:
31* =============
32*>
33*> \verbatim
34*>
35*> DTRTTP copies a triangular matrix A from full format (TR) to standard
36*> packed format (TP).
37*> \endverbatim
38*
39* Arguments:
40* ==========
41*
42*> \param[in] UPLO
43*> \verbatim
44*> UPLO is CHARACTER*1
45*> = 'U': A is upper triangular.
46*> = 'L': A is lower triangular.
47*> \endverbatim
48*>
49*> \param[in] N
50*> \verbatim
51*> N is INTEGER
52*> The order of the matrices AP and A. N >= 0.
53*> \endverbatim
54*>
55*> \param[in] A
56*> \verbatim
57*> A is DOUBLE PRECISION array, dimension (LDA,N)
58*> On exit, the triangular matrix A. If UPLO = 'U', the leading
59*> N-by-N upper triangular part of A contains the upper
60*> triangular part of the matrix A, and the strictly lower
61*> triangular part of A is not referenced. If UPLO = 'L', the
62*> leading N-by-N lower triangular part of A contains the lower
63*> triangular part of the matrix A, and the strictly upper
64*> triangular part of A is not referenced.
65*> \endverbatim
66*>
67*> \param[in] LDA
68*> \verbatim
69*> LDA is INTEGER
70*> The leading dimension of the array A. LDA >= max(1,N).
71*> \endverbatim
72*>
73*> \param[out] AP
74*> \verbatim
75*> AP is DOUBLE PRECISION array, dimension (N*(N+1)/2)
76*> On exit, the upper or lower triangular matrix A, packed
77*> columnwise in a linear array. The j-th column of A is stored
78*> in the array AP as follows:
79*> if UPLO = 'U', AP(i + (j-1)*j/2) = A(i,j) for 1<=i<=j;
80*> if UPLO = 'L', AP(i + (j-1)*(2n-j)/2) = A(i,j) for j<=i<=n.
81*> \endverbatim
82*>
83*> \param[out] INFO
84*> \verbatim
85*> INFO is INTEGER
86*> = 0: successful exit
87*> < 0: if INFO = -i, the i-th argument had an illegal value
88*> \endverbatim
89*
90* Authors:
91* ========
92*
93*> \author Univ. of Tennessee
94*> \author Univ. of California Berkeley
95*> \author Univ. of Colorado Denver
96*> \author NAG Ltd.
97*
98*> \ingroup trttp
99*
100* =====================================================================
101 SUBROUTINE dtrttp( UPLO, N, A, LDA, AP, INFO )
102*
103* -- LAPACK computational routine --
104* -- LAPACK is a software package provided by Univ. of Tennessee, --
105* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
106*
107* .. Scalar Arguments ..
108 CHARACTER UPLO
109 INTEGER INFO, N, LDA
110* ..
111* .. Array Arguments ..
112 DOUBLE PRECISION A( LDA, * ), AP( * )
113* ..
114*
115* =====================================================================
116*
117* .. Parameters ..
118* ..
119* .. Local Scalars ..
120 LOGICAL LOWER
121 INTEGER I, J, K
122* ..
123* .. External Functions ..
124 LOGICAL LSAME
125 EXTERNAL lsame
126* ..
127* .. External Subroutines ..
128 EXTERNAL xerbla
129* ..
130* .. Executable Statements ..
131*
132* Test the input parameters.
133*
134 info = 0
135 lower = lsame( uplo, 'L' )
136 IF( .NOT.lower .AND. .NOT.lsame( uplo, 'U' ) ) THEN
137 info = -1
138 ELSE IF( n.LT.0 ) THEN
139 info = -2
140 ELSE IF( lda.LT.max( 1, n ) ) THEN
141 info = -4
142 END IF
143 IF( info.NE.0 ) THEN
144 CALL xerbla( 'DTRTTP', -info )
145 RETURN
146 END IF
147*
148 IF( lower ) THEN
149 k = 0
150 DO j = 1, n
151 DO i = j, n
152 k = k + 1
153 ap( k ) = a( i, j )
154 END DO
155 END DO
156 ELSE
157 k = 0
158 DO j = 1, n
159 DO i = 1, j
160 k = k + 1
161 ap( k ) = a( i, j )
162 END DO
163 END DO
164 END IF
165*
166*
167 RETURN
168*
169* End of DTRTTP
170*
171 END
subroutine xerbla(srname, info)
Definition cblat2.f:3285
subroutine dtrttp(uplo, n, a, lda, ap, info)
DTRTTP copies a triangular matrix from the standard full format (TR) to the standard packed format (T...
Definition dtrttp.f:102