ssygst.f.html
来自「famous linear algebra library (LAPACK) p」· HTML 代码 · 共 274 行 · 第 1/2 页
HTML
274 行
</span><span class="comment">*</span><span class="comment"> Determine the block size for this environment.
</span><span class="comment">*</span><span class="comment">
</span> NB = <a name="ILAENV.121"></a><a href="hfy-index.html#ILAENV">ILAENV</a>( 1, <span class="string">'<a name="SSYGST.121"></a><a href="ssygst.f.html#SSYGST.1">SSYGST</a>'</span>, UPLO, N, -1, -1, -1 )
<span class="comment">*</span><span class="comment">
</span> IF( NB.LE.1 .OR. NB.GE.N ) 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="SSYGS2.127"></a><a href="ssygs2.f.html#SSYGS2.1">SSYGS2</a>( ITYPE, UPLO, N, A, LDA, B, LDB, INFO )
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( ITYPE.EQ.1 ) THEN
IF( UPPER ) THEN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Compute inv(U')*A*inv(U)
</span><span class="comment">*</span><span class="comment">
</span> DO 10 K = 1, N, NB
KB = MIN( N-K+1, NB )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Update the upper triangle of A(k:n,k:n)
</span><span class="comment">*</span><span class="comment">
</span> CALL <a name="SSYGS2.142"></a><a href="ssygs2.f.html#SSYGS2.1">SSYGS2</a>( ITYPE, UPLO, KB, A( K, K ), LDA,
$ B( K, K ), LDB, INFO )
IF( K+KB.LE.N ) THEN
CALL STRSM( <span class="string">'Left'</span>, UPLO, <span class="string">'Transpose'</span>, <span class="string">'Non-unit'</span>,
$ KB, N-K-KB+1, ONE, B( K, K ), LDB,
$ A( K, K+KB ), LDA )
CALL SSYMM( <span class="string">'Left'</span>, UPLO, KB, N-K-KB+1, -HALF,
$ A( K, K ), LDA, B( K, K+KB ), LDB, ONE,
$ A( K, K+KB ), LDA )
CALL SSYR2K( UPLO, <span class="string">'Transpose'</span>, N-K-KB+1, KB, -ONE,
$ A( K, K+KB ), LDA, B( K, K+KB ), LDB,
$ ONE, A( K+KB, K+KB ), LDA )
CALL SSYMM( <span class="string">'Left'</span>, UPLO, KB, N-K-KB+1, -HALF,
$ A( K, K ), LDA, B( K, K+KB ), LDB, ONE,
$ A( K, K+KB ), LDA )
CALL STRSM( <span class="string">'Right'</span>, UPLO, <span class="string">'No transpose'</span>,
$ <span class="string">'Non-unit'</span>, KB, N-K-KB+1, ONE,
$ B( K+KB, K+KB ), LDB, A( K, K+KB ),
$ LDA )
END IF
10 CONTINUE
ELSE
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Compute inv(L)*A*inv(L')
</span><span class="comment">*</span><span class="comment">
</span> DO 20 K = 1, N, NB
KB = MIN( N-K+1, NB )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Update the lower triangle of A(k:n,k:n)
</span><span class="comment">*</span><span class="comment">
</span> CALL <a name="SSYGS2.172"></a><a href="ssygs2.f.html#SSYGS2.1">SSYGS2</a>( ITYPE, UPLO, KB, A( K, K ), LDA,
$ B( K, K ), LDB, INFO )
IF( K+KB.LE.N ) THEN
CALL STRSM( <span class="string">'Right'</span>, UPLO, <span class="string">'Transpose'</span>, <span class="string">'Non-unit'</span>,
$ N-K-KB+1, KB, ONE, B( K, K ), LDB,
$ A( K+KB, K ), LDA )
CALL SSYMM( <span class="string">'Right'</span>, UPLO, N-K-KB+1, KB, -HALF,
$ A( K, K ), LDA, B( K+KB, K ), LDB, ONE,
$ A( K+KB, K ), LDA )
CALL SSYR2K( UPLO, <span class="string">'No transpose'</span>, N-K-KB+1, KB,
$ -ONE, A( K+KB, K ), LDA, B( K+KB, K ),
$ LDB, ONE, A( K+KB, K+KB ), LDA )
CALL SSYMM( <span class="string">'Right'</span>, UPLO, N-K-KB+1, KB, -HALF,
$ A( K, K ), LDA, B( K+KB, K ), LDB, ONE,
$ A( K+KB, K ), LDA )
CALL STRSM( <span class="string">'Left'</span>, UPLO, <span class="string">'No transpose'</span>,
$ <span class="string">'Non-unit'</span>, N-K-KB+1, KB, ONE,
$ B( K+KB, K+KB ), LDB, A( K+KB, K ),
$ LDA )
END IF
20 CONTINUE
END IF
ELSE
IF( UPPER ) THEN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Compute U*A*U'
</span><span class="comment">*</span><span class="comment">
</span> DO 30 K = 1, N, NB
KB = MIN( N-K+1, NB )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Update the upper triangle of A(1:k+kb-1,1:k+kb-1)
</span><span class="comment">*</span><span class="comment">
</span> CALL STRMM( <span class="string">'Left'</span>, UPLO, <span class="string">'No transpose'</span>, <span class="string">'Non-unit'</span>,
$ K-1, KB, ONE, B, LDB, A( 1, K ), LDA )
CALL SSYMM( <span class="string">'Right'</span>, UPLO, K-1, KB, HALF, A( K, K ),
$ LDA, B( 1, K ), LDB, ONE, A( 1, K ), LDA )
CALL SSYR2K( UPLO, <span class="string">'No transpose'</span>, K-1, KB, ONE,
$ A( 1, K ), LDA, B( 1, K ), LDB, ONE, A,
$ LDA )
CALL SSYMM( <span class="string">'Right'</span>, UPLO, K-1, KB, HALF, A( K, K ),
$ LDA, B( 1, K ), LDB, ONE, A( 1, K ), LDA )
CALL STRMM( <span class="string">'Right'</span>, UPLO, <span class="string">'Transpose'</span>, <span class="string">'Non-unit'</span>,
$ K-1, KB, ONE, B( K, K ), LDB, A( 1, K ),
$ LDA )
CALL <a name="SSYGS2.216"></a><a href="ssygs2.f.html#SSYGS2.1">SSYGS2</a>( ITYPE, UPLO, KB, A( K, K ), LDA,
$ B( K, K ), LDB, INFO )
30 CONTINUE
ELSE
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Compute L'*A*L
</span><span class="comment">*</span><span class="comment">
</span> DO 40 K = 1, N, NB
KB = MIN( N-K+1, NB )
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> Update the lower triangle of A(1:k+kb-1,1:k+kb-1)
</span><span class="comment">*</span><span class="comment">
</span> CALL STRMM( <span class="string">'Right'</span>, UPLO, <span class="string">'No transpose'</span>, <span class="string">'Non-unit'</span>,
$ KB, K-1, ONE, B, LDB, A( K, 1 ), LDA )
CALL SSYMM( <span class="string">'Left'</span>, UPLO, KB, K-1, HALF, A( K, K ),
$ LDA, B( K, 1 ), LDB, ONE, A( K, 1 ), LDA )
CALL SSYR2K( UPLO, <span class="string">'Transpose'</span>, K-1, KB, ONE,
$ A( K, 1 ), LDA, B( K, 1 ), LDB, ONE, A,
$ LDA )
CALL SSYMM( <span class="string">'Left'</span>, UPLO, KB, K-1, HALF, A( K, K ),
$ LDA, B( K, 1 ), LDB, ONE, A( K, 1 ), LDA )
CALL STRMM( <span class="string">'Left'</span>, UPLO, <span class="string">'Transpose'</span>, <span class="string">'Non-unit'</span>, KB,
$ K-1, ONE, B( K, K ), LDB, A( K, 1 ), LDA )
CALL <a name="SSYGS2.239"></a><a href="ssygs2.f.html#SSYGS2.1">SSYGS2</a>( ITYPE, UPLO, KB, A( K, K ), LDA,
$ B( K, K ), LDB, INFO )
40 CONTINUE
END IF
END IF
END IF
RETURN
<span class="comment">*</span><span class="comment">
</span><span class="comment">*</span><span class="comment"> End of <a name="SSYGST.247"></a><a href="ssygst.f.html#SSYGST.1">SSYGST</a>
</span><span class="comment">*</span><span class="comment">
</span> END
</pre>
</body>
</html>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?