Main Content

colperm

基于非零项计数的稀疏列置换

语法

j = colperm(S)

说明

j = colperm(S) 生成置换向量 j,根据非零项数升序对 S(:,j) 的列进行排序。这有时可用于对 LU 分解进行预先排序;在这种情况下,请使用 lu(S(:,j))

如果 S 是对称矩阵,则 j = colperm(S) 生成置换矩阵 j,根据非零项数升序对 S(j,j) 的行和列两者都进行排序。如果 S 是正定矩阵,则这有时可用于对乔列斯基分解进行预先排序;在这种情况下,请使用 chol(S(j,j))

示例

100×100 箭尖矩阵

n = 100;
A = [ones(1,n); ones(n-1,1) speye(n-1,n-1)]

包含全满的第一行和第一列。其 LU 分解 lu(A) 也几乎是全满的。语句

j = colperm(A)

返回 j = [2:n 1]。因此 A(j,j) 将该全满的行和列移到底部和后部,且 lu(A(j,j)) 具有与 A 自身相同的非零结构体。

另一方面,布基球示例

B = bucky

在每行和每列中恰好有三个非零元素,这样 j = colperm(B) 是单位置换,对于降低后续分解的填充元没有任何作用。

算法

算法涉及对每列中的非零项数进行排序。

扩展功能

版本历史记录

在 R2006a 之前推出

另请参阅

| | | | | |