Schur-class
位于 Matrix
包(package)。 说明
Schur
是 实数矩阵 的 Schur 分解类,具有一般形式
其中 是正交矩阵, 是块上三角矩阵,其中 或 对角块指定 的实数和复数共轭特征值。 的列向量是 的 Schur 向量, 是 的 Schur 形式。
Schur 分解将普通矩阵 (其 Schur 形式为块对角线)的谱分解推广为任意方阵。
细节
矩阵 及其Schur 形式 相似,因此具有相同的频谱。特征值被简单地计算为 的对角线块的特征值。
插槽
Dim
,Dimnames
-
从虚拟类
MatrixFactorization
继承。 Q
-
正交矩阵,继承自虚拟类
Matrix
。 T
-
块上三角矩阵,继承自虚拟类
Matrix
。对角块的尺寸为 1×1 或 2×2。 EValues
-
包含
T
对角线块的特征值的数值或复数向量,它们是T
的特征值,因此也是分解矩阵的特征值。
扩展
直接类 SchurFactorization
。类 MatrixFactorization
,按类 SchurFactorization
,距离 2。
实例化
对象可以通过 new("Schur", ...)
形式的调用直接生成,但它们更通常作为继承自 Matrix
(通常是 dgeMatrix
)的 x
的 Schur(x)
值获得。
方法
determinant
-
signature(from = "Schur", logarithm = "logical")
:计算因式分解矩阵 的行列式或其对数。 expand1
-
signature(x = "Schur")
:参见expand1-methods
。 expand2
-
signature(x = "Schur")
:参见expand2-methods
。 solve
-
signature(a = "Schur", b = .)
:参见solve-methods
。
例子
showClass("Schur")
set.seed(0)
n <- 4L
(A <- Matrix(rnorm(n * n), n, n))
## With dimnames, to see that they are propagated :
dimnames(A) <- list(paste0("r", seq_len(n)),
paste0("c", seq_len(n)))
(sch.A <- Schur(A))
str(e.sch.A <- expand2(sch.A), max.level = 2L)
## A ~ Q T Q' in floating point
stopifnot(exprs = {
identical(names(e.sch.A), c("Q", "T", "Q."))
all.equal(A, with(e.sch.A, Q %*% T %*% Q.))
})
## Factorization handled as factorized matrix
b <- rnorm(n)
stopifnot(all.equal(det(A), det(sch.A)),
all.equal(solve(A, b), solve(sch.A, b)))
## One of the non-general cases:
Schur(Diagonal(6L))
参考
The LAPACK source code, including documentation; see https://netlib.org/lapack/double/dgees.f.
Golub, G. H., & Van Loan, C. F. (2013). Matrix computations (4th ed.). Johns Hopkins University Press. doi:10.56021/9781421407944
也可以看看
相关用法
- R Schur-methods Schur 分解方法
- R Subassign-methods “[<-”的方法 - 分配给“矩阵”的子集
- R Subscript-methods “[”的方法:在“Matrix”包中提取或取子集
- R dtrMatrix-class 三角形稠密数值矩阵
- R facmul-methods 乘以矩阵因式分解的因数
- R solve-methods 函数求解矩阵包中的方法
- R updown-methods 更新和降级稀疏 Cholesky 分解
- R bdiag 构建分块对角矩阵
- R printSpMatrix 灵活格式化和打印稀疏矩阵
- R symmetricMatrix-class 包矩阵中对称矩阵的虚拟类
- R all.equal-methods 函数 all.equal() 的矩阵封装方法
- R boolmatmult-methods 布尔算术矩阵乘积:%&% 和方法
- R ltrMatrix-class 三角密集逻辑矩阵
- R Hilbert 生成希尔伯特矩阵
- R nearPD 最近正定矩阵
- R lsyMatrix-class 对称密集逻辑矩阵
- R CHMfactor-class 稀疏 Cholesky 分解
- R symmpart-methods 矩阵的对称部分和偏斜(对称)部分
- R sparseMatrix 从非零项构建一般稀疏矩阵
- R dgCMatrix-class 压缩、稀疏、面向列的数值矩阵
- R Cholesky-methods Cholesky 分解方法
- R ldenseMatrix-class 密集逻辑矩阵的虚拟类“ldenseMatrix”
- R norm-methods 矩阵范数
- R ngeMatrix-class 一般密集非零模式矩阵的“ngeMatrix”类
- R CAex 阿尔伯斯的示例矩阵与“困难”特征分解
注:本文由纯净天空筛选整理自R-devel大神的英文原创作品 Schur Factorizations。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。