*> \brief \b SLARF
*
* =========== DOCUMENTATION ===========
*
* Online html documentation available at
*
http://www.netlib.org/lapack/explore-html/
*
*> \htmlonly
*> Download SLARF + dependencies
*> <a href=
"http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/slarf.f">
*> [TGZ]</a>
*> <a href=
"http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/slarf.f">
*> [ZIP]</a>
*> <a href=
"http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/slarf.f">
*> [TXT]</a>
*> \endhtmlonly
*
* Definition:
* ===========
*
*
SUBROUTINE SLARF( SIDE, M, N, V, INCV, TAU, C, LDC, WORK )
*
* .. Scalar Arguments ..
*
CHARACTER SIDE
*
INTEGER INCV, LDC, M, N
*
REAL TAU
* ..
* .. Array Arguments ..
*
REAL C( LDC, * ), V( * ), WORK( * )
* ..
*
*
*> \par Purpose:
* =============
*>
*> \verbatim
*>
*> SLARF applies a
real elementary reflector H
to a
real m by n matrix
*> C, from either the left or the right. H is represented
in the
form
*>
*> H = I - tau * v * v**T
*>
*>
where tau is a
real scalar and v is a
real vector.
*>
*>
If tau = 0,
then H is taken
to be the
unit matrix.
*> \endverbatim
*
* Arguments:
* ==========
*
*> \param[
in] SIDE
*> \verbatim
*> SIDE is
CHARACTER*1
*> =
'L':
form H * C
*> =
'R':
form C * H
*> \endverbatim
*>
*> \param[
in] M
*> \verbatim
*> M is
INTEGER
*> The
number of rows of the matrix C.
*> \endverbatim
*>
*> \param[
in] N
*> \verbatim
*> N is
INTEGER
*> The
number of columns of the matrix C.
*> \endverbatim
*>
*> \param[
in] V
*> \verbatim
*> V is
REAL array,
dimension
*> (1 + (M-1)*abs(INCV))
if SIDE =
'L'
*> or (1 + (N-1)*abs(INCV))
if SIDE =
'R'
*> The vector v
in the representation of H. V is not used
if
*> TAU = 0.
*> \endverbatim
*>
*> \param[
in] INCV
*> \verbatim
*> INCV is
INTEGER
*> The increment between elements of v. INCV <> 0.
*> \endverbatim
*>
*> \param[
in] TAU
*> \verbatim
*> TAU is
REAL
*> The value tau
in the representation of H.
*> \endverbatim
*>
*> \param[
in,
out] C
*> \verbatim
*> C is
REAL array,
dimension (LDC,N)
*> On
entry, the m by n matrix C.
*> On
exit, C is overwritten by the matrix H * C
if SIDE =
'L',
*> or C * H
if SIDE =
'R'.
*> \endverbatim
*>
*> \param[
in] LDC
*> \verbatim
*> LDC is
INTEGER
*> The leading
dimension of the array C. LDC >= max(1,M).
*> \endverbatim
*>
*> \param[
out] WORK
*> \verbatim
*> WORK is
REAL array,
dimension
*> (N)
if SIDE =
'L'
*> or (M)
if SIDE =
'R'
*> \endverbatim
*
* Authors:
* ========
*
*> \author Univ. of Tennessee
*> \author Univ. of California Berkeley
*> \author Univ. of Colorado Denver
*> \author NAG Ltd.
*
*> \date November 2011
*
*> \ingroup realOTHERauxiliary
*
* =====================================================================
SUBROUTINE SLARF( SIDE, M, N, V, INCV, TAU, C, LDC, WORK )
*
* -- LAPACK auxiliary routine (version 3.4.0) --
* -- LAPACK is a software package provided by Univ. of Tennessee, --
* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
* November 2011
*
* .. Scalar Arguments ..
CHARACTER SIDE
INTEGER INCV, LDC, M, N
REAL TAU
* ..
* .. Array Arguments ..
REAL C( LDC, * ), V( * ), WORK( * )
* ..
*
* =====================================================================
*
* .. Parameters ..
REAL ONE, ZERO
PARAMETER ( ONE = 1.0E+0, ZERO = 0.0E+0 )
* ..
* .. Local Scalars ..
LOGICAL APPLYLEFT
INTEGER I, LASTV, LASTC
* ..
* ..
External Subroutines ..
EXTERNAL SGEMV, SGER
* ..
* ..
External Functions ..
LOGICAL LSAME
INTEGER ILASLR, ILASLC
EXTERNAL LSAME, ILASLR, ILASLC
* ..
* .. Executable Statements ..
*
APPLYLEFT = LSAME( SIDE,
'L' )
LASTV = 0
LASTC = 0
IF( TAU.NE.ZERO )
THEN
! Set up variables for scanning V. LASTV begins pointing
to the
end
! of V.
IF( APPLYLEFT )
THEN
LASTV = M
ELSE
LASTV = N
END IF
IF( INCV.GT.0 )
THEN
I = 1 + (LASTV-1) * INCV
ELSE
I = 1
END IF
! Look for the last non-zero row
in V.
DO WHILE( LASTV.GT.0 .AND. V( I ).EQ.ZERO )
LASTV = LASTV - 1
I = I - INCV
END DO
IF( APPLYLEFT )
THEN
! Scan for the last non-zero column
in C(1:lastv,:).
LASTC = ILASLC(LASTV, N, C, LDC)
ELSE
! Scan for the last non-zero row
in C(:,1:lastv).
LASTC = ILASLR(M, LASTV, C, LDC)
END IF
END IF
! Note that lastc.eq.0 renders the BLAS operations
null; no special
!
case is needed at this level.
IF( APPLYLEFT )
THEN
*
*
Form H * C
*
IF( LASTV.GT.0 )
THEN
*
* w(1:lastc,1) := C(1:lastv,1:lastc)**T * v(1:lastv,1)
*
CALL SGEMV(
'Transpose', LASTV, LASTC, ONE, C, LDC, V, INCV,
$ ZERO, WORK, 1 )
*
* C(1:lastv,1:lastc) := C(...) - v(1:lastv,1) * w(1:lastc,1)**T
*
CALL SGER( LASTV, LASTC, -TAU, V, INCV, WORK, 1, C, LDC )
END IF
ELSE
*
*
Form C * H
*
IF( LASTV.GT.0 )
THEN
*
* w(1:lastc,1) := C(1:lastc,1:lastv) * v(1:lastv,1)
*
CALL SGEMV(
'No transpose', LASTC, LASTV, ONE, C, LDC,
$ V, INCV, ZERO, WORK, 1 )
*
* C(1:lastc,1:lastv) := C(...) - w(1:lastc,1) * v(1:lastv,1)**T
*
CALL SGER( LASTC, LASTV, -TAU, WORK, 1, V, INCV, C, LDC )
END IF
END IF
RETURN
*
*
End of SLARF
*
END