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

◆ dorgtsqr()

subroutine dorgtsqr ( integer m,
integer n,
integer mb,
integer nb,
double precision, dimension( lda, * ) a,
integer lda,
double precision, dimension( ldt, * ) t,
integer ldt,
double precision, dimension( * ) work,
integer lwork,
integer info )

DORGTSQR

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

Purpose:
!>
!> DORGTSQR generates an M-by-N real matrix Q_out with orthonormal columns,
!> which are the first N columns of a product of real orthogonal
!> matrices of order M which are returned by DLATSQR
!>
!>      Q_out = first_N_columns_of( Q(1)_in * Q(2)_in * ... * Q(k)_in ).
!>
!> See the documentation for DLATSQR.
!> 
Parameters
[in]M
!>          M is INTEGER
!>          The number of rows of the matrix A.  M >= 0.
!> 
[in]N
!>          N is INTEGER
!>          The number of columns of the matrix A. M >= N >= 0.
!> 
[in]MB
!>          MB is INTEGER
!>          The row block size used by DLATSQR to return
!>          arrays A and T. MB > N.
!>          (Note that if MB > M, then M is used instead of MB
!>          as the row block size).
!> 
[in]NB
!>          NB is INTEGER
!>          The column block size used by DLATSQR to return
!>          arrays A and T. NB >= 1.
!>          (Note that if NB > N, then N is used instead of NB
!>          as the column block size).
!> 
[in,out]A
!>          A is DOUBLE PRECISION array, dimension (LDA,N)
!>
!>          On entry:
!>
!>             The elements on and above the diagonal are not accessed.
!>             The elements below the diagonal represent the unit
!>             lower-trapezoidal blocked matrix V computed by DLATSQR
!>             that defines the input matrices Q_in(k) (ones on the
!>             diagonal are not stored) (same format as the output A
!>             below the diagonal in DLATSQR).
!>
!>          On exit:
!>
!>             The array A contains an M-by-N orthonormal matrix Q_out,
!>             i.e the columns of A are orthogonal unit vectors.
!> 
[in]LDA
!>          LDA is INTEGER
!>          The leading dimension of the array A.  LDA >= max(1,M).
!> 
[in]T
!>          T is DOUBLE PRECISION array,
!>          dimension (LDT, N * NIRB)
!>          where NIRB = Number_of_input_row_blocks
!>                     = MAX( 1, CEIL((M-N)/(MB-N)) )
!>          Let NICB = Number_of_input_col_blocks
!>                   = CEIL(N/NB)
!>
!>          The upper-triangular block reflectors used to define the
!>          input matrices Q_in(k), k=(1:NIRB*NICB). The block
!>          reflectors are stored in compact form in NIRB block
!>          reflector sequences. Each of NIRB block reflector sequences
!>          is stored in a larger NB-by-N column block of T and consists
!>          of NICB smaller NB-by-NB upper-triangular column blocks.
!>          (same format as the output T in DLATSQR).
!> 
[in]LDT
!>          LDT is INTEGER
!>          The leading dimension of the array T.
!>          LDT >= max(1,min(NB1,N)).
!> 
[out]WORK
!>          (workspace) DOUBLE PRECISION array, dimension (MAX(2,LWORK))
!>          On exit, if INFO = 0, WORK(1) returns the optimal LWORK.
!> 
[in]LWORK
!>          LWORK is INTEGER
!>          The dimension of the array WORK.  LWORK >= (M+NB)*N.
!>          If LWORK = -1, then a workspace query is assumed.
!>          The routine only calculates the optimal size of the WORK
!>          array, returns this value as the first entry of the WORK
!>          array, and no error message related to LWORK is issued
!>          by XERBLA.
!> 
[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.
Contributors:
!>
!> November 2019, Igor Kozachenko,
!>                Computer Science Division,
!>                University of California, Berkeley
!>
!> 

Definition at line 172 of file dorgtsqr.f.

174 IMPLICIT NONE
175*
176* -- LAPACK computational routine --
177* -- LAPACK is a software package provided by Univ. of Tennessee, --
178* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
179*
180* .. Scalar Arguments ..
181 INTEGER INFO, LDA, LDT, LWORK, M, N, MB, NB
182* ..
183* .. Array Arguments ..
184 DOUBLE PRECISION A( LDA, * ), T( LDT, * ), WORK( * )
185* ..
186*
187* =====================================================================
188*
189* .. Parameters ..
190 DOUBLE PRECISION ONE, ZERO
191 parameter( one = 1.0d+0, zero = 0.0d+0 )
192* ..
193* .. Local Scalars ..
194 LOGICAL LQUERY
195 INTEGER IINFO, LDC, LWORKOPT, LC, LW, NBLOCAL, J
196* ..
197* .. External Subroutines ..
198 EXTERNAL dcopy, dlamtsqr, dlaset, xerbla
199* ..
200* .. Intrinsic Functions ..
201 INTRINSIC dble, max, min
202* ..
203* .. Executable Statements ..
204*
205* Test the input parameters
206*
207 lquery = lwork.EQ.-1
208 info = 0
209 IF( m.LT.0 ) THEN
210 info = -1
211 ELSE IF( n.LT.0 .OR. m.LT.n ) THEN
212 info = -2
213 ELSE IF( mb.LE.n ) THEN
214 info = -3
215 ELSE IF( nb.LT.1 ) THEN
216 info = -4
217 ELSE IF( lda.LT.max( 1, m ) ) THEN
218 info = -6
219 ELSE IF( ldt.LT.max( 1, min( nb, n ) ) ) THEN
220 info = -8
221 ELSE
222*
223* Test the input LWORK for the dimension of the array WORK.
224* This workspace is used to store array C(LDC, N) and WORK(LWORK)
225* in the call to DLAMTSQR. See the documentation for DLAMTSQR.
226*
227 IF( lwork.LT.2 .AND. (.NOT.lquery) ) THEN
228 info = -10
229 ELSE
230*
231* Set block size for column blocks
232*
233 nblocal = min( nb, n )
234*
235* LWORK = -1, then set the size for the array C(LDC,N)
236* in DLAMTSQR call and set the optimal size of the work array
237* WORK(LWORK) in DLAMTSQR call.
238*
239 ldc = m
240 lc = ldc*n
241 lw = n * nblocal
242*
243 lworkopt = lc+lw
244*
245 IF( ( lwork.LT.max( 1, lworkopt ) ).AND.(.NOT.lquery) ) THEN
246 info = -10
247 END IF
248 END IF
249*
250 END IF
251*
252* Handle error in the input parameters and return workspace query.
253*
254 IF( info.NE.0 ) THEN
255 CALL xerbla( 'DORGTSQR', -info )
256 RETURN
257 ELSE IF ( lquery ) THEN
258 work( 1 ) = dble( lworkopt )
259 RETURN
260 END IF
261*
262* Quick return if possible
263*
264 IF( min( m, n ).EQ.0 ) THEN
265 work( 1 ) = dble( lworkopt )
266 RETURN
267 END IF
268*
269* (1) Form explicitly the tall-skinny M-by-N left submatrix Q1_in
270* of M-by-M orthogonal matrix Q_in, which is implicitly stored in
271* the subdiagonal part of input array A and in the input array T.
272* Perform by the following operation using the routine DLAMTSQR.
273*
274* Q1_in = Q_in * ( I ), where I is a N-by-N identity matrix,
275* ( 0 ) 0 is a (M-N)-by-N zero matrix.
276*
277* (1a) Form M-by-N matrix in the array WORK(1:LDC*N) with ones
278* on the diagonal and zeros elsewhere.
279*
280 CALL dlaset( 'F', m, n, zero, one, work, ldc )
281*
282* (1b) On input, WORK(1:LDC*N) stores ( I );
283* ( 0 )
284*
285* On output, WORK(1:LDC*N) stores Q1_in.
286*
287 CALL dlamtsqr( 'L', 'N', m, n, n, mb, nblocal, a, lda, t, ldt,
288 $ work, ldc, work( lc+1 ), lw, iinfo )
289*
290* (2) Copy the result from the part of the work array (1:M,1:N)
291* with the leading dimension LDC that starts at WORK(1) into
292* the output array A(1:M,1:N) column-by-column.
293*
294 DO j = 1, n
295 CALL dcopy( m, work( (j-1)*ldc + 1 ), 1, a( 1, j ), 1 )
296 END DO
297*
298 work( 1 ) = dble( lworkopt )
299 RETURN
300*
301* End of DORGTSQR
302*
subroutine xerbla(srname, info)
Definition cblat2.f:3285
subroutine dcopy(n, dx, incx, dy, incy)
DCOPY
Definition dcopy.f:82
subroutine dlamtsqr(side, trans, m, n, k, mb, nb, a, lda, t, ldt, c, ldc, work, lwork, info)
DLAMTSQR
Definition dlamtsqr.f:201
subroutine dlaset(uplo, m, n, alpha, beta, a, lda)
DLASET initializes the off-diagonal elements and the diagonal elements of a matrix to given values.
Definition dlaset.f:108
Here is the call graph for this function:
Here is the caller graph for this function: