3 * =========== DOCUMENTATION ===========
5 * Online html documentation available at
6 * http://www.netlib.org/lapack/explore-html/
9 *> Download DTPMQRT + dependencies
10 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/dtpmlqt.f">
12 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/dtpmlqt.f">
14 *> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/dtpmlqt.f">
21 * SUBROUTINE DTPMLQT( SIDE, TRANS, M, N, K, L, MB, V, LDV, T, LDT,
22 * A, LDA, B, LDB, WORK, INFO )
24 * .. Scalar Arguments ..
25 * CHARACTER SIDE, TRANS
26 * INTEGER INFO, K, LDV, LDA, LDB, M, N, L, MB, LDT
28 * .. Array Arguments ..
29 * DOUBLE PRECISION V( LDV, * ), A( LDA, * ), B( LDB, * ),
30 * $ T( LDT, * ), WORK( * )
39 *> DTPMQRT applies a real orthogonal matrix Q obtained from a
40 *> "triangular-pentagonal" real block reflector H to a general
41 *> real matrix C, which consists of two blocks A and B.
49 *> SIDE is CHARACTER*1
50 *> = 'L': apply Q or Q**T from the Left;
51 *> = 'R': apply Q or Q**T from the Right.
56 *> TRANS is CHARACTER*1
57 *> = 'N': No transpose, apply Q;
58 *> = 'T': Transpose, apply Q**T.
64 *> The number of rows of the matrix B. M >= 0.
70 *> The number of columns of the matrix B. N >= 0.
76 *> The number of elementary reflectors whose product defines
83 *> The order of the trapezoidal part of V.
84 *> K >= L >= 0. See Further Details.
90 *> The block size used for the storage of T. K >= MB >= 1.
91 *> This must be the same value of MB used to generate T
97 *> V is DOUBLE PRECISION array, dimension (LDA,K)
98 *> The i-th row must contain the vector which defines the
99 *> elementary reflector H(i), for i = 1,2,...,k, as returned by
100 *> DTPLQT in B. See Further Details.
106 *> The leading dimension of the array V.
107 *> If SIDE = 'L', LDV >= max(1,M);
108 *> if SIDE = 'R', LDV >= max(1,N).
113 *> T is DOUBLE PRECISION array, dimension (LDT,K)
114 *> The upper triangular factors of the block reflectors
115 *> as returned by DTPLQT, stored as a MB-by-K matrix.
121 *> The leading dimension of the array T. LDT >= MB.
126 *> A is DOUBLE PRECISION array, dimension
127 *> (LDA,N) if SIDE = 'L' or
128 *> (LDA,K) if SIDE = 'R'
129 *> On entry, the K-by-N or M-by-K matrix A.
130 *> On exit, A is overwritten by the corresponding block of
131 *> Q*C or Q**T*C or C*Q or C*Q**T. See Further Details.
137 *> The leading dimension of the array A.
138 *> If SIDE = 'L', LDC >= max(1,K);
139 *> If SIDE = 'R', LDC >= max(1,M).
144 *> B is DOUBLE PRECISION array, dimension (LDB,N)
145 *> On entry, the M-by-N matrix B.
146 *> On exit, B is overwritten by the corresponding block of
147 *> Q*C or Q**T*C or C*Q or C*Q**T. See Further Details.
153 *> The leading dimension of the array B.
159 *> WORK is DOUBLE PRECISION array. The dimension of WORK is
160 *> N*MB if SIDE = 'L', or M*MB if SIDE = 'R'.
166 *> = 0: successful exit
167 *> < 0: if INFO = -i, the i-th argument had an illegal value
173 *> \author Univ. of Tennessee
174 *> \author Univ. of California Berkeley
175 *> \author Univ. of Colorado Denver
178 *> \date November 2015
180 *> \ingroup doubleOTHERcomputational
182 *> \par Further Details:
183 * =====================
187 *> The columns of the pentagonal matrix V contain the elementary reflectors
188 *> H(1), H(2), ..., H(K); V is composed of a rectangular block V1 and a
189 *> trapezoidal block V2:
194 *> The size of the trapezoidal block V2 is determined by the parameter L,
195 *> where 0 <= L <= K; V2 is lower trapezoidal, consisting of the first L
196 *> rows of a K-by-K upper triangular matrix. If L=K, V2 is lower triangular;
197 *> if L=0, there is no trapezoidal block, hence V = V1 is rectangular.
199 *> If SIDE = 'L': C = [A] where A is K-by-N, B is M-by-N and V is K-by-M.
202 *> If SIDE = 'R': C = [A B] where A is M-by-K, B is M-by-N and V is K-by-N.
204 *> The real orthogonal matrix Q is formed from V and T.
206 *> If TRANS='N' and SIDE='L', C is on exit replaced with Q * C.
208 *> If TRANS='T' and SIDE='L', C is on exit replaced with Q**T * C.
210 *> If TRANS='N' and SIDE='R', C is on exit replaced with C * Q.
212 *> If TRANS='T' and SIDE='R', C is on exit replaced with C * Q**T.
215 * =====================================================================
216 SUBROUTINE DTPMLQT( SIDE, TRANS, M, N, K, L, MB, V, LDV, T, LDT,
217 $ A, LDA, B, LDB, WORK, INFO )
219 * -- LAPACK computational routine (version 3.6.0) --
220 * -- LAPACK is a software package provided by Univ. of Tennessee, --
221 * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
224 * .. Scalar Arguments ..
225 CHARACTER SIDE, TRANS
226 INTEGER INFO, K, LDV, LDA, LDB, M, N, L, MB, LDT
228 * .. Array Arguments ..
229 DOUBLE PRECISION V( LDV, * ), A( LDA, * ), B( LDB, * ),
230 $ T( LDT, * ), WORK( * )
233 * =====================================================================
236 * .. Local Scalars ..
237 LOGICAL LEFT, RIGHT, TRAN, NOTRAN
238 INTEGER I, IB, NB, LB, KF, LDAQ
240 * .. External Functions ..
244 * .. External Subroutines ..
245 EXTERNAL XERBLA, DLARFB
247 * .. Intrinsic Functions ..
250 * .. Executable Statements ..
252 * .. Test the input arguments ..
255 LEFT = LSAME( SIDE, 'L' )
256 RIGHT = LSAME( SIDE, 'R' )
257 TRAN = LSAME( TRANS, 'T' )
258 NOTRAN = LSAME( TRANS, 'N' )
262 ELSE IF ( RIGHT ) THEN
265 IF( .NOT.LEFT .AND. .NOT.RIGHT ) THEN
267 ELSE IF( .NOT.TRAN .AND. .NOT.NOTRAN ) THEN
269 ELSE IF( M.LT.0 ) THEN
271 ELSE IF( N.LT.0 ) THEN
273 ELSE IF( K.LT.0 ) THEN
275 ELSE IF( L.LT.0 .OR. L.GT.K ) THEN
277 ELSE IF( MB.LT.1 .OR. (MB.GT.K .AND. K.GT.0) ) THEN
279 ELSE IF( LDV.LT.K ) THEN
281 ELSE IF( LDT.LT.MB ) THEN
283 ELSE IF( LDA.LT.LDAQ ) THEN
285 ELSE IF( LDB.LT.MAX( 1, M ) ) THEN
290 CALL XERBLA( 'DTPMLQT', -INFO )
294 * .. Quick return if possible ..
296 IF( M.EQ.0 .OR. N.EQ.0 .OR. K.EQ.0 ) RETURN
298 IF( LEFT .AND. NOTRAN ) THEN
301 IB = MIN( MB, K-I+1 )
302 NB = MIN( M-L+I+IB-1, M )
308 CALL DTPRFB( 'L', 'T', 'F', 'R', NB, N, IB, LB,
309 $ V( I, 1 ), LDV, T( 1, I ), LDT,
310 $ A( I, 1 ), LDA, B, LDB, WORK, IB )
313 ELSE IF( RIGHT .AND. TRAN ) THEN
316 IB = MIN( MB, K-I+1 )
317 NB = MIN( N-L+I+IB-1, N )
323 CALL DTPRFB( 'R', 'N', 'F', 'R', M, NB, IB, LB,
324 $ V( I, 1 ), LDV, T( 1, I ), LDT,
325 $ A( 1, I ), LDA, B, LDB, WORK, M )
328 ELSE IF( LEFT .AND. TRAN ) THEN
332 IB = MIN( MB, K-I+1 )
333 NB = MIN( M-L+I+IB-1, M )
339 CALL DTPRFB( 'L', 'N', 'F', 'R', NB, N, IB, LB,
340 $ V( I, 1 ), LDV, T( 1, I ), LDT,
341 $ A( I, 1 ), LDA, B, LDB, WORK, IB )
344 ELSE IF( RIGHT .AND. NOTRAN ) THEN
348 IB = MIN( MB, K-I+1 )
349 NB = MIN( N-L+I+IB-1, N )
355 CALL DTPRFB( 'R', 'T', 'F', 'R', M, NB, IB, LB,
356 $ V( I, 1 ), LDV, T( 1, I ), LDT,
357 $ A( 1, I ), LDA, B, LDB, WORK, M )