三、矩阵运算
(一)矩阵函数和特殊矩阵
- 常见的矩阵处理函数
- 表3-1 常见的矩阵函数
函数 | 说明 |
/或\ | 矩阵除法中的左除或右除,可以用于求解线性方程组 |
accumarray(ind,val) | 累加创建数组 |
A^n | 求解矩阵A的n次幂 |
balance(A) | 将矩阵A进行缩放以提高其特征值的精度 |
[V,D]=cdf2rdf(V,D) | 将复数对角矩阵转换为两个实数对角矩阵 |
chol(A) | 对矩阵A进行Cholesky因式分解 |
cholinc(A,DropTol) | 对矩阵A进行不完全的Cholesky因式分解,DropTol指定分解误差 |
cholinc(A,Options) | 对矩阵A进行不完全的Cholesky因式分解,Options为包含3个分量的结构体 |
cholupdate(R,X) | Cholesky因式分解的秩1升级 |
cond(A) | 利用奇异值分解求矩阵A的范数 |
condest(A) | 求矩阵A的范数1的条件数估计 |
[V,D,s]=condeig(A) | 求矩阵A与重特征值相对应的条件数 |
det(A) | 求矩阵的行列式 |
dmperm(A) | 求矩阵A进行Dulmage-Mendelsohn排列 |
eig(A) | 求矩阵A的特征值和特征向量 |
[V,D]=eig(A) | 求矩阵A的特征向量矩阵(V)和特征值对角矩阵(D) |
expm(A) | 矩阵指数函数 |
funm(A) | 矩阵通用函数 |
gsvd(A,B) | 求矩阵A的广义奇异值 |
[U,V,X,C,S]=gsvd(A) | 求矩阵A进行广义奇异值分解 |
hess(A) | 求矩阵A的Hessenburg标准型 |
inv(A) | 求矩阵A的逆 |
linsolve(A,y,options) | 快速求解方程组Ax=y,其中A的结构由options条件给定 |
logm(A) | 矩阵的对数运算 |
lscov(A,y,V) | 已知数据的协方差矩阵(V),求线性方程组的最小二乘解 |
lsqnonneg(A,y) | 求线性方程组的非负最小二乘解 |
[L,U,P]=lu(A) | 对矩阵A进行LU分解 |
minres(A,y) | 利用最小残差方法求线性方程组的解 |
norm(A,type) | 求矩阵或向量(由type指定)的范数 |
null(A) | 求A的零空间 |
orth(A) | 求A的正交空间 |
pinv(A) | 求A的伪逆矩阵 |
planerot(X) | 求X进行平面旋转 |
ploy(A) | 求A的特征多项式 |
polyeig(A0,A1,...) | 多项式的特征值解 |
polyvalm(A) | 求A的矩阵多项式 |
qr(A) | 对A进行正交三角分解 |
qrdelete(Q,R,J) | 从QR分解中删除行或列 |
qrinsert(Q,R,J,X) | 在QR分解中插入行或列 |
qz(A,B) | 广义特征值问题求解 |
rank(A) | 利用奇异值分解求A的秩 |
rcond(A) | 对A进行LAPACK倒数条件估计 |
rref(A) | 将矩阵A变换为行阶梯型 |
rsf2csf(A) | 将A由实块对角阵转换为复块对角阵 |
schur(A) | 对矩阵A进行Schur分解 |
sqrtm(A) | 求矩阵A的平方根 |
subspace(A,B) | 求两个子空间A和B之间的角度 |
svd(A) | 求矩阵A的奇异值 |
[U,S,V]=svd(A) | 对A进行奇异值分解 |
trace(A) | 求矩阵A的迹(即对角线元素之和) |
- 特殊矩阵
- 表3-2 特殊矩阵
矩阵 | 说明 |
[] | 空矩阵 |
blkdiag(a0,a1,...) | 以输入参数为对角元素生成对角矩阵 |
compan(P) | 求多项式的伴随矩阵 |
eye(r,c) | 产生r行,c列的单位矩阵 |
gallery | 生成一系列的测试矩阵(50个以上) |
hadamard(n) | 生成1个n阶的Hadamard矩阵 |
hankel(C) | 生成C的Hankel矩阵 |
hilb(n) | 生成n阶的Hilbert矩阵 |
invhilb(n) | 生成n阶的逆Hilbert矩阵 |
magic(n) | 生成n阶的魔幻矩阵 |
ones(r,c) | 生成r行、c列的全1矩阵 |
pascal(n) | 生成n阶的Pascal矩阵 |
rand(r,c) | 生成r行、c列的随机矩阵(元素值介于0和1之间) |
randn(r,c) | 生成r行、c列的零均值和单位方差的正态分布的随机矩阵 |
rosser | 典型的对称矩阵特征值问题测试 |
toeplitz(C,R) | 生成Toeplitz矩阵 |
vander(C) | 生成Vandermonde矩阵 |
wilkinson(n) | 生成n阶的Wilkinson特征值测试矩阵 |
zeros(r,c) | 生成r行、c列的全0矩阵 |
- 稀疏矩阵
- 稀疏矩阵中大部分元素都是0,只有少部分元素是非0的。
- 一般,MATLAB存储稀疏矩阵需要通过3个矩阵,对于一个m×n的矩阵(假设其中有nz个非0元素,存储在长度为nz_max的矩阵中)
- 第一个矩阵:存储所有非0元素,矩阵长度为nz_max
- 第二个矩阵:存储所有非0元素的行下标,矩阵长度也为nz_max
- 第三个矩阵:存储每一列开始处的指针和标志这3个矩阵结束的指针,存储长度为n+1
- 创建稀疏矩阵
- sparse(i,j,s,m,n,nz_max)使用[i,j,s]来创建m×n维稀疏矩阵s(s为所有非0元素构成的向量,ij为非0元素的行下标、列下标)
- spdiags(B,d,m,n)可以抽取、创建或替代对角稀疏矩阵(d表示长度为p的整数向量,B为满矩阵)
- 表3-3 稀疏矩阵函数
函数 | 说明 |
bicg | 求解双共轭梯度迭代线性方程的解 |
bicgstab | 求解双共轭梯度稳定迭代线性方程的解 |
cgs | 求解二次共轭梯度迭代线性方程曾的解 |
cholinc | 不完全Cholesky分解 |
colamd | 列估计最小度重排序方法 |
colamdtree | 带列消元树排序后的colamd方法 |
colmmd | 列最小度排序 |
colperm | 对列进行随机排序 |
condest | 1范数估计 |
dmperm | Dulmage-Nebdeksohn重排序方法 |
eigs | 使用APPACK的特征值 |
etree | 矩阵消元树结构 |
etreeplot | 绘制消元路径 |
find | 寻找非0元素索引 |
full | 将稀疏矩阵转化为完整矩阵 |
gmres | 求广义最小残差迭代线性方程的解 |
gplot | 绘制图论图形 |
issparse | 判断是否为稀疏矩阵 |
lsqr | 标准方程中共轭梯度的LSQR实现 |
luinc | 不完全LU因式分解 |
minres | 最小残差迭代线性方程求解 |
Nnz | 求矩阵中的非0元素个数 |
nonzeros | 提取矩阵中的非0元素 |
normest | 矩阵的2范数估计 |
nzmax | 求分配给非0元素的存储空间 |
pcg | 求预处理共轭梯度迭代线性方程组的解 |
qmr | 伪最小残差迭代线性方程组解法 |
randperm | 产生随机排列的数组 |
spalloc | 为稀疏矩阵分配内存空间 |
sparse | 创建稀疏矩阵 |
spaugment | 建立最小二乘增广矩阵 |
spconvert | 从外部格式中载入稀疏矩阵 |
sodiags | 利用对角元素生成稀疏矩阵 |
speye | 单位稀疏矩阵 |
spfun | 将一个函数应用于非0元素 |
spones | 将所有非0元素用1代替 |
spparms | 设置稀疏矩阵程序的参数 |
sprand | 创建均匀分布的随机稀疏矩阵 |
sprandn | 创建高斯分布的随机稀疏矩阵 |
sprandsym | 创建对称的随机稀疏矩阵 |
sprank | 求结构秩的值 |
spy | 稀疏矩阵的图形表示 |
svds | 产生一些奇异值 |
symbfact | 符合因式分解 |
symamd | 对称估计最小阶次重排序法 |
symamdtree | 带对称消元树排序后的symand |
symmd | 对称最小阶次重排序 |
symmlq | 对称LQ迭代线性方程的求解 |
symrcm | 对称的反向Cuthill-Mckee重排序 |
treelayout | 变换成树状结构 |
treeplot | 画出树状图 |
- 创建稀疏矩阵并画出稀疏矩阵的图(e_three_1.m)
(二)矩阵分析
- 范数分析
- 向量的范数
- 线性空间中的某个向量$\textbf{x}=\left \{ x_{1},x_{2},\cdots ,x_{n} \right \}$,其p范数定义为:$\left \| \mathbf{x} \right \|_{p}=\left ( \sum_{i=1}^{n}\left | x_{i}\right |^{p}\right )^{\frac{1}{p}}$