LAPACK 3.12.1
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches

◆ ztrttp()

subroutine ztrttp ( character uplo,
integer n,
complex*16, dimension( lda, * ) a,
integer lda,
complex*16, dimension( * ) ap,
integer info )

ZTRTTP copies a triangular matrix from the standard full format (TR) to the standard packed format (TP).

Download ZTRTTP + dependencies [TGZ] [ZIP] [TXT]

Purpose:
!>
!> ZTRTTP copies a triangular matrix A from full format (TR) to standard
!> packed format (TP).
!> 
Parameters
[in]UPLO
!>          UPLO is CHARACTER*1
!>          = 'U':  A is upper triangular;
!>          = 'L':  A is lower triangular.
!> 
[in]N
!>          N is INTEGER
!>          The order of the matrices AP and A.  N >= 0.
!> 
[in]A
!>          A is COMPLEX*16 array, dimension (LDA,N)
!>          On entry, the triangular matrix A.  If UPLO = 'U', the leading
!>          N-by-N upper triangular part of A contains the upper
!>          triangular part of the matrix A, and the strictly lower
!>          triangular part of A is not referenced.  If UPLO = 'L', the
!>          leading N-by-N lower triangular part of A contains the lower
!>          triangular part of the matrix A, and the strictly upper
!>          triangular part of A is not referenced.
!> 
[in]LDA
!>          LDA is INTEGER
!>          The leading dimension of the array A.  LDA >= max(1,N).
!> 
[out]AP
!>          AP is COMPLEX*16 array, dimension ( N*(N+1)/2 ),
!>          On exit, the upper or lower triangular matrix A, packed
!>          columnwise in a linear array. The j-th column of A is stored
!>          in the array AP as follows:
!>          if UPLO = 'U', AP(i + (j-1)*j/2) = A(i,j) for 1<=i<=j;
!>          if UPLO = 'L', AP(i + (j-1)*(2n-j)/2) = A(i,j) for j<=i<=n.
!> 
[out]INFO
!>          INFO is INTEGER
!>          = 0:  successful exit
!>          < 0:  if INFO = -i, the i-th argument had an illegal value
!> 
Author
Univ. of Tennessee
Univ. of California Berkeley
Univ. of Colorado Denver
NAG Ltd.

Definition at line 101 of file ztrttp.f.

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 COMPLEX*16 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( 'ZTRTTP', -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 ZTRTTP
170*
subroutine xerbla(srname, info)
Definition cblat2.f:3285
logical function lsame(ca, cb)
LSAME
Definition lsame.f:48
Here is the call graph for this function:
Here is the caller graph for this function: