cunmrq.f.html

来自「famous linear algebra library (LAPACK) p」· HTML 代码 · 共 294 行 · 第 1/2 页

HTML
294
字号
</span>      INFO = 0
      LEFT = <a name="LSAME.130"></a><a href="lsame.f.html#LSAME.1">LSAME</a>( SIDE, <span class="string">'L'</span> )
      NOTRAN = <a name="LSAME.131"></a><a href="lsame.f.html#LSAME.1">LSAME</a>( TRANS, <span class="string">'N'</span> )
      LQUERY = ( LWORK.EQ.-1 )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">     NQ is the order of Q and NW is the minimum dimension of WORK
</span><span class="comment">*</span><span class="comment">
</span>      IF( LEFT ) THEN
         NQ = M
         NW = MAX( 1, N )
      ELSE
         NQ = N
         NW = MAX( 1, M )
      END IF
      IF( .NOT.LEFT .AND. .NOT.<a name="LSAME.143"></a><a href="lsame.f.html#LSAME.1">LSAME</a>( SIDE, <span class="string">'R'</span> ) ) THEN
         INFO = -1
      ELSE IF( .NOT.NOTRAN .AND. .NOT.<a name="LSAME.145"></a><a href="lsame.f.html#LSAME.1">LSAME</a>( TRANS, <span class="string">'C'</span> ) ) THEN
         INFO = -2
      ELSE IF( M.LT.0 ) THEN
         INFO = -3
      ELSE IF( N.LT.0 ) THEN
         INFO = -4
      ELSE IF( K.LT.0 .OR. K.GT.NQ ) THEN
         INFO = -5
      ELSE IF( LDA.LT.MAX( 1, K ) ) THEN
         INFO = -7
      ELSE IF( LDC.LT.MAX( 1, M ) ) THEN
         INFO = -10
      END IF
<span class="comment">*</span><span class="comment">
</span>      IF( INFO.EQ.0 ) THEN
         IF( M.EQ.0 .OR. N.EQ.0 ) THEN
            LWKOPT = 1
         ELSE
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">           Determine the block size.  NB may be at most NBMAX, where
</span><span class="comment">*</span><span class="comment">           NBMAX is used to define the local array T.
</span><span class="comment">*</span><span class="comment">
</span>            NB = MIN( NBMAX, <a name="ILAENV.167"></a><a href="hfy-index.html#ILAENV">ILAENV</a>( 1, <span class="string">'<a name="CUNMRQ.167"></a><a href="cunmrq.f.html#CUNMRQ.1">CUNMRQ</a>'</span>, SIDE // TRANS, M, N,
     $                               K, -1 ) )
            LWKOPT = NW*NB
         END IF
         WORK( 1 ) = LWKOPT
<span class="comment">*</span><span class="comment">
</span>         IF( LWORK.LT.NW .AND. .NOT.LQUERY ) THEN
            INFO = -12
         END IF
      END IF
<span class="comment">*</span><span class="comment">
</span>      IF( INFO.NE.0 ) THEN
         CALL <a name="XERBLA.179"></a><a href="xerbla.f.html#XERBLA.1">XERBLA</a>( <span class="string">'<a name="CUNMRQ.179"></a><a href="cunmrq.f.html#CUNMRQ.1">CUNMRQ</a>'</span>, -INFO )
         RETURN
      ELSE IF( LQUERY ) THEN
         RETURN
      END IF
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">     Quick return if possible
</span><span class="comment">*</span><span class="comment">
</span>      IF( M.EQ.0 .OR. N.EQ.0 ) THEN
         RETURN
      END IF
<span class="comment">*</span><span class="comment">
</span>      NBMIN = 2
      LDWORK = NW
      IF( NB.GT.1 .AND. NB.LT.K ) THEN
         IWS = NW*NB
         IF( LWORK.LT.IWS ) THEN
            NB = LWORK / LDWORK
            NBMIN = MAX( 2, <a name="ILAENV.197"></a><a href="hfy-index.html#ILAENV">ILAENV</a>( 2, <span class="string">'<a name="CUNMRQ.197"></a><a href="cunmrq.f.html#CUNMRQ.1">CUNMRQ</a>'</span>, SIDE // TRANS, M, N, K,
     $              -1 ) )
         END IF
      ELSE
         IWS = NW
      END IF
<span class="comment">*</span><span class="comment">
</span>      IF( NB.LT.NBMIN .OR. NB.GE.K ) THEN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">        Use unblocked code
</span><span class="comment">*</span><span class="comment">
</span>         CALL <a name="CUNMR2.208"></a><a href="cunmr2.f.html#CUNMR2.1">CUNMR2</a>( SIDE, TRANS, M, N, K, A, LDA, TAU, C, LDC, WORK,
     $                IINFO )
      ELSE
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">        Use blocked code
</span><span class="comment">*</span><span class="comment">
</span>         IF( ( LEFT .AND. .NOT.NOTRAN ) .OR.
     $       ( .NOT.LEFT .AND. NOTRAN ) ) THEN
            I1 = 1
            I2 = K
            I3 = NB
         ELSE
            I1 = ( ( K-1 ) / NB )*NB + 1
            I2 = 1
            I3 = -NB
         END IF
<span class="comment">*</span><span class="comment">
</span>         IF( LEFT ) THEN
            NI = N
         ELSE
            MI = M
         END IF
<span class="comment">*</span><span class="comment">
</span>         IF( NOTRAN ) THEN
            TRANST = <span class="string">'C'</span>
         ELSE
            TRANST = <span class="string">'N'</span>
         END IF
<span class="comment">*</span><span class="comment">
</span>         DO 10 I = I1, I2, I3
            IB = MIN( NB, K-I+1 )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">           Form the triangular factor of the block reflector
</span><span class="comment">*</span><span class="comment">           H = H(i+ib-1) . . . H(i+1) H(i)
</span><span class="comment">*</span><span class="comment">
</span>            CALL <a name="CLARFT.243"></a><a href="clarft.f.html#CLARFT.1">CLARFT</a>( <span class="string">'Backward'</span>, <span class="string">'Rowwise'</span>, NQ-K+I+IB-1, IB,
     $                   A( I, 1 ), LDA, TAU( I ), T, LDT )
            IF( LEFT ) THEN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">              H or H' is applied to C(1:m-k+i+ib-1,1:n)
</span><span class="comment">*</span><span class="comment">
</span>               MI = M - K + I + IB - 1
            ELSE
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">              H or H' is applied to C(1:m,1:n-k+i+ib-1)
</span><span class="comment">*</span><span class="comment">
</span>               NI = N - K + I + IB - 1
            END IF
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">           Apply H or H'
</span><span class="comment">*</span><span class="comment">
</span>            CALL <a name="CLARFB.259"></a><a href="clarfb.f.html#CLARFB.1">CLARFB</a>( SIDE, TRANST, <span class="string">'Backward'</span>, <span class="string">'Rowwise'</span>, MI, NI,
     $                   IB, A( I, 1 ), LDA, T, LDT, C, LDC, WORK,
     $                   LDWORK )
   10    CONTINUE
      END IF
      WORK( 1 ) = LWKOPT
      RETURN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment">     End of <a name="CUNMRQ.267"></a><a href="cunmrq.f.html#CUNMRQ.1">CUNMRQ</a>
</span><span class="comment">*</span><span class="comment">
</span>      END

</pre>

 </body>
</html>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?