zerrst.f
来自「famous linear algebra library (LAPACK) p」· F 代码 · 共 763 行 · 第 1/3 页
F
763 行
CALL ZSTEQR( 'V', 2, D, E, Z, 1, RW, INFO )
CALL CHKXER( 'ZSTEQR', INFOT, NOUT, LERR, OK )
NT = NT + 3
*
* ZSTEDC
*
SRNAMT = 'ZSTEDC'
INFOT = 1
CALL ZSTEDC( '/', 0, D, E, Z, 1, W, 1, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZSTEDC( 'N', -1, D, E, Z, 1, W, 1, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 6
CALL ZSTEDC( 'V', 2, D, E, Z, 1, W, 4, RW, 23, IW, 28, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZSTEDC( 'N', 2, D, E, Z, 1, W, 0, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZSTEDC( 'V', 2, D, E, Z, 2, W, 0, RW, 23, IW, 28, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZSTEDC( 'N', 2, D, E, Z, 1, W, 1, RW, 0, IW, 1, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZSTEDC( 'I', 2, D, E, Z, 2, W, 1, RW, 1, IW, 12, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZSTEDC( 'V', 2, D, E, Z, 2, W, 4, RW, 1, IW, 28, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 12
CALL ZSTEDC( 'N', 2, D, E, Z, 1, W, 1, RW, 1, IW, 0, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 12
CALL ZSTEDC( 'I', 2, D, E, Z, 2, W, 1, RW, 23, IW, 0, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
INFOT = 12
CALL ZSTEDC( 'V', 2, D, E, Z, 2, W, 4, RW, 23, IW, 0, INFO )
CALL CHKXER( 'ZSTEDC', INFOT, NOUT, LERR, OK )
NT = NT + 11
*
* ZHEEVD
*
SRNAMT = 'ZHEEVD'
INFOT = 1
CALL ZHEEVD( '/', 'U', 0, A, 1, X, W, 1, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZHEEVD( 'N', '/', 0, A, 1, X, W, 1, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 3
CALL ZHEEVD( 'N', 'U', -1, A, 1, X, W, 1, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 5
CALL ZHEEVD( 'N', 'U', 2, A, 1, X, W, 3, RW, 2, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEVD( 'N', 'U', 1, A, 1, X, W, 0, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEVD( 'N', 'U', 2, A, 2, X, W, 2, RW, 2, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEVD( 'V', 'U', 2, A, 2, X, W, 3, RW, 25, IW, 12, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZHEEVD( 'N', 'U', 1, A, 1, X, W, 1, RW, 0, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZHEEVD( 'N', 'U', 2, A, 2, X, W, 3, RW, 1, IW, 1, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZHEEVD( 'V', 'U', 2, A, 2, X, W, 8, RW, 18, IW, 12, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 12
CALL ZHEEVD( 'N', 'U', 1, A, 1, X, W, 1, RW, 1, IW, 0, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
INFOT = 12
CALL ZHEEVD( 'V', 'U', 2, A, 2, X, W, 8, RW, 25, IW, 11, INFO )
CALL CHKXER( 'ZHEEVD', INFOT, NOUT, LERR, OK )
NT = NT + 12
*
* ZHEEV
*
SRNAMT = 'ZHEEV '
INFOT = 1
CALL ZHEEV( '/', 'U', 0, A, 1, X, W, 1, RW, INFO )
CALL CHKXER( 'ZHEEV ', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZHEEV( 'N', '/', 0, A, 1, X, W, 1, RW, INFO )
CALL CHKXER( 'ZHEEV ', INFOT, NOUT, LERR, OK )
INFOT = 3
CALL ZHEEV( 'N', 'U', -1, A, 1, X, W, 1, RW, INFO )
CALL CHKXER( 'ZHEEV ', INFOT, NOUT, LERR, OK )
INFOT = 5
CALL ZHEEV( 'N', 'U', 2, A, 1, X, W, 3, RW, INFO )
CALL CHKXER( 'ZHEEV ', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEV( 'N', 'U', 2, A, 2, X, W, 2, RW, INFO )
CALL CHKXER( 'ZHEEV ', INFOT, NOUT, LERR, OK )
NT = NT + 5
*
* ZHEEVX
*
SRNAMT = 'ZHEEVX'
INFOT = 1
CALL ZHEEVX( '/', 'A', 'U', 0, A, 1, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 1, W, 1, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZHEEVX( 'V', '/', 'U', 0, A, 1, 0.0D0, 1.0D0, 1, 0, 0.0D0,
$ M, X, Z, 1, W, 1, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 3
CALL ZHEEVX( 'V', 'A', '/', 0, A, 1, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 1, W, 1, RW, IW, I3, INFO )
INFOT = 4
CALL ZHEEVX( 'V', 'A', 'U', -1, A, 1, 0.0D0, 0.0D0, 0, 0,
$ 0.0D0, M, X, Z, 1, W, 1, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 6
CALL ZHEEVX( 'V', 'A', 'U', 2, A, 1, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 2, W, 3, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEVX( 'V', 'V', 'U', 1, A, 1, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 1, W, 1, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 9
CALL ZHEEVX( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 1, W, 1, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 10
CALL ZHEEVX( 'V', 'I', 'U', 2, A, 2, 0.0D0, 0.0D0, 2, 1, 0.0D0,
$ M, X, Z, 2, W, 3, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 15
CALL ZHEEVX( 'V', 'A', 'U', 2, A, 2, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 1, W, 3, RW, IW, I3, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
INFOT = 17
CALL ZHEEVX( 'V', 'A', 'U', 2, A, 2, 0.0D0, 0.0D0, 0, 0, 0.0D0,
$ M, X, Z, 2, W, 2, RW, IW, I1, INFO )
CALL CHKXER( 'ZHEEVX', INFOT, NOUT, LERR, OK )
NT = NT + 10
*
* ZHEEVR
*
SRNAMT = 'ZHEEVR'
N = 1
INFOT = 1
CALL ZHEEVR( '/', 'A', 'U', 0, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZHEEVR( 'V', '/', 'U', 0, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 3
CALL ZHEEVR( 'V', 'A', '/', -1, A, 1, 0.0D0, 0.0D0, 1, 1,
$ 0.0D0, M, R, Z, 1, IW, Q, 2*N, RW, 24*N,
$ IW( 2*N+1 ), 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 4
CALL ZHEEVR( 'V', 'A', 'U', -1, A, 1, 0.0D0, 0.0D0, 1, 1,
$ 0.0D0, M, R, Z, 1, IW, Q, 2*N, RW, 24*N,
$ IW( 2*N+1 ), 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 6
CALL ZHEEVR( 'V', 'A', 'U', 2, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 8
CALL ZHEEVR( 'V', 'V', 'U', 1, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 9
CALL ZHEEVR( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 0, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 10
*
CALL ZHEEVR( 'V', 'I', 'U', 2, A, 2, 0.0D0, 0.0D0, 2, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 15
CALL ZHEEVR( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 0, IW, Q, 2*N, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 18
CALL ZHEEVR( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N-1, RW, 24*N, IW( 2*N+1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 20
CALL ZHEEVR( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N-1, IW( 2*N-1 ),
$ 10*N, INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
INFOT = 22
CALL ZHEEVR( 'V', 'I', 'U', 1, A, 1, 0.0D0, 0.0D0, 1, 1, 0.0D0,
$ M, R, Z, 1, IW, Q, 2*N, RW, 24*N, IW, 10*N-1,
$ INFO )
CALL CHKXER( 'ZHEEVR', INFOT, NOUT, LERR, OK )
NT = NT + 12
*
* ZHPEVD
*
SRNAMT = 'ZHPEVD'
INFOT = 1
CALL ZHPEVD( '/', 'U', 0, A, X, Z, 1, W, 1, RW, 1, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 2
CALL ZHPEVD( 'N', '/', 0, A, X, Z, 1, W, 1, RW, 1, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 3
CALL ZHPEVD( 'N', 'U', -1, A, X, Z, 1, W, 1, RW, 1, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 7
CALL ZHPEVD( 'V', 'U', 2, A, X, Z, 1, W, 4, RW, 25, IW, 12,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 9
CALL ZHPEVD( 'N', 'U', 1, A, X, Z, 1, W, 0, RW, 1, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 9
CALL ZHPEVD( 'N', 'U', 2, A, X, Z, 2, W, 1, RW, 2, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 9
CALL ZHPEVD( 'V', 'U', 2, A, X, Z, 2, W, 2, RW, 25, IW, 12,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 11
CALL ZHPEVD( 'N', 'U', 1, A, X, Z, 1, W, 1, RW, 0, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 11
CALL ZHPEVD( 'N', 'U', 2, A, X, Z, 2, W, 2, RW, 1, IW, 1,
$ INFO )
CALL CHKXER( 'ZHPEVD', INFOT, NOUT, LERR, OK )
INFOT = 11
CALL ZHPEVD( 'V', 'U', 2, A, X, Z, 2, W, 4, RW, 18, IW, 12,
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?