Python之Python与MATLAB矩阵操作⼩结
⼀、线形代数理论基础
线形代数(linear algebra)是数学的⼀个分⽀,研究矩阵理论、向量空间、线性变换和有限维线形⽅程组等内容。
⽐较重要的思想有:1.线性代数的核⼼内容是研究有限维线性空间的结构和线性空间的线性变换;2.向量的线性相关性是研究线性空间结构与线性变换理论的基础;3.矩阵是有限维线性空间的线性变换的表⽰形式;4.线性⽅程组的求解问题是n维空间到m维空间线性映射求核和全体原象的问题;5.⾏列式是研究这些问题的⼀个⼯具。
主要内容有:1.矩阵运算:加减乘除、转置、逆矩阵、⾏列式、矩阵的幂、伴随矩阵;2.矩阵分块、秩、迹;3.解⽅程;4.线性相关;5.向量空间;6.特征值和特征向量;7.对称、相似;8.⼆次标准型;9.线性空间和基变换;10.正交空间;11.矩阵对⾓化;13.矩阵分解;14.重要数字特征。
⼆、MATLAB的处理
1.建⽴矩阵
MATLAB中,矩阵是默认的数据类型。它把向量看做1×N或者N×1的矩阵。
%建⽴了⼀个⾏向量,不同元素之间使⽤空格或者逗号分开都是可以的。
A=[1,2,3] 或者 A=[1 2 3]
%建⽴⼀个矩阵,使⽤分号隔开不同的⾏。
A=[1,2,3;4,5,6]
%那么,建⽴⼀个列向量就好办了。每⾏⼀个元素,分号分开即可。当然也可以使⽤⾏向量的转置(⼀个撇号表⽰转置)。
A=[1;2;3] 或者 A=[1,2,3]’
MATLAB内置了很多特殊的矩阵⽣成函数,建⽴特殊矩阵⼗分⽅便。
i)第⼀组⽤来⽣成特殊规则的矩阵。如全零、全⼀、随机、等步长等形式。
X=zeros(m,n)
%⽣成⼀个m*n的全0矩阵。同理,ones(m,n)⽣成⼀个全1矩阵;eye(m,n)⽣成⼀个单位阵。它们的重要作⽤在于预先分配矩阵空间,所以,在预知矩阵规模但是不知道矩阵具体数据的情况下,先⽤这⼏
个函数⽣成⼀个矩阵,对提⾼运算速度⼗分有⽤。
X=rand(m,n)
%⽣成⼀个平均分布的随机矩阵,数值区间[0,1]。同理,randn(m,n)⽣成⼀个服从正态分布的随机矩阵。注意,这些所谓的随机实际上都是伪随机。
v=linspace(a,b,n)
%产⽣线性空间⽮量。a和b分别是起点和终点,n是本区间内的点数,默认100个点。同理,logspace(a,b,n)产⽣对数空间⽮量。不过它默认点数是50个。
v=1:0.1:10linspace函数python
%产⽣⼀个线性的⽮量。规格是---起点:步长值:终点
ii)第⼆组⽤来在原有矩阵基础上获得⼀个具有某些特征的矩阵。
X=diag(v,k)和v=diag(X,k)
%前者⽤⽮量v中的元素⽣成⼀个对⾓矩阵,k是对⾓移位因⼦,默认为0,即主对⾓。k>0,对⾓线右
移。后者返回矩阵X的对⾓元素,存在⽮量v中。k的意义相同。
X1=triu(X,k)和X1=tril(X,k)
%分别产⽣矩阵X的上三⾓矩阵和下三⾓矩阵。
fliplr(X)/flipud(X)/rot90(X)
%这都是对矩阵的翻转操作,获得新的矩阵。分别是左右翻转(left-right)、上下翻转(up-down)和逆时针旋转90°操作。
iii)第三组⽤来⽣成⼀些具有理论价值的,往往是以数学家命名的矩阵。
magic(n)⽣成⾏列相加均为同⼀个数字的⽅阵。pascal(n)⽣成帕斯卡尔矩阵。hilb(n)⽣成希尔伯特矩阵。vander(v)⽣成范德蒙德矩阵。等等。
这些矩阵⼀般都有相应的学术背景,⽤到的时候,可以⽤命令help elmat在最后⼀个栏⽬中看看有没有⾃⼰要的特殊矩阵,如果有,点进去进⼀步研究即可。
2.矩阵的特征信息
size(X) %获得矩阵X的⾏、列数。⽐如,X是⼀个3*5的矩阵,p=size(X)返回p=[3 5]
length() %对于⽮量,返回的是⽮量的长度;对数组,返回的是数组最长的那⼀个维度的长度。
ndims() %相当于length(size(x))。
numel() %数组中元素的个数。
isempty()和isequal()等is*型函数%测试矩阵是否满⾜某些条件
[V,D] = eig(A) %矩阵A的特征值D和特征向量V。
k = rank(A) %矩阵A的秩
b = trace(A) %矩阵A的迹,即对⾓线元素之和
d = det(X) %⽅阵A的⾏列式
Y = inv(X) %矩阵X的逆矩阵
n = norm(X,option) %矩阵或者向量的范数,具体使⽤⽤到再说
c = cond(X) %矩阵X的条件数
3.矩阵分解
矩阵分解是矩阵论的重要内容。常⽤的分解形式在MATLAB中都有函数予以实现,并且有些分解考虑了多种情况。常见的如:eig()、qr()、schur()、svd()、chol()、lu()等。具体使⽤的时候
4.矩阵运算
MATLAB默认的是矩阵运算,所以如果想要按元素依次计算,在原来运算符前加⼀个.号。⽐如.*表⽰按元素相乘。
每⼀个运算符都有⼀个对应的函数。如:
A+B=plus(A,B)、A-B=minus(A,B)
A*B=mtimes(A,B)、A.*B=times(A,B)
A/B=mrdivide(A,B)、A./B=rdivide(A,B)、A\B=mldivide(A,B)、A.\B=ldivide(A,B)
A^B=mpower(A,B)、A.^B=power(A,B)
A'=ctranspose(A)、A.'=transpose(A)
其中的前缀m⾃然是表⽰matrix的意思。没有m前缀的就是按元素进⾏的意思。最后那个转置操作,c前缀表⽰的是按照复数操作进⾏转置。此外,还有⼀些⽐较常⽤的运算:
C=cross(A,B)
%⽮量叉乘。类似的,C=dot(A,B) 是⽮量点乘
B = prod(A,dim)
%数组元素的乘积,默认按列计算。dim=1是列,dim=2是按⾏。这个概念很重要!!
类似的,B = sum(A,dim) 求数组元素的和。dim意义和以上同。
expm()
%矩阵指数运算。与此类似的logm(), sqrtm()。其中,funm(A,fun)⽤来计算矩阵A对通⽤函数fun的函数值。
5.矩阵索引
选择使⽤矩阵中的某些元素,就是所谓的矩阵索引了。
A(:,j) %选取矩阵A的所有⾏,第j列,同理,A(i,:)是第i⾏,所有列
A(:,j:k) %所有⾏,第j列⾄第k列(起点和终点均含)
三、Python的处理
Python使⽤NumPy包完成了对N-维数组的快速便捷操作。使⽤这个包,需要导⼊numpy。SciPy包以NumPy包为基础,⼤⼤的扩展了numpy的能⼒。为了使⽤的⽅便,scipy包在最外层名字空间中包括了所有的numpy内容,因此只要导⼊了scipy,不必在单独导⼊numpy 了!但是为了明确哪些是numpy中实现的,哪些是scipy中实现的,本⽂还是进⾏了区分。以下默认已经:import numpy as np 以及 impor scipy as sp
下⾯简要介绍Python和MATLAB处理数学问题的⼏个不同点。1.MATLAB的基本是矩阵,⽽numpy的基本类型是多为数组,把matrix看做是array的⼦类。2.MATLAB的索引从1开始,⽽numpy从0开始。
1.建⽴矩阵
a1=np.array([1,2,3],dtype=int) #建⽴⼀个⼀维数组,数据类型是int。也可以不指定数据类型,使⽤默认。⼏乎所有的数组建⽴函数都可以指定数据类型,即dtype的取值。
a2=np.array([[1,2,3],[2,3,4]]) #建⽴⼀个⼆维数组。此处和MATLAB的⼆维数组(矩阵)的建⽴有很⼤差别。
同样,numpy中也有很多内置的特殊矩阵:
s((2,3)) #⽣成⼀个2⾏3列的全0矩阵。注意,参数是⼀个tuple:(2,3),所以有两个括号。完整的形式为:
zeros(shape,dtype=)。相同的结构,有ones()建⽴全1矩阵。empty()建⽴⼀个空矩阵,使⽤内存中的随机值来填充这个矩阵。
b2=identity(n) #建⽴n*n的单位阵,这只能是⼀个⽅阵。
b3=eye(N,M=None,k=0) #建⽴⼀个对⾓线是1其余值为0的矩阵,⽤k指定对⾓线的位置。M默认None。
此外,numpy中还提供了⼏个like函数,即按照某⼀个已知的数组的规模(⼏⾏⼏列)建⽴同样规模的特殊数组。这样的函数有
zeros_like()、empty_like()、ones_like(),它们的参数均为如此形式:zeros_like(a,dtype=),其中,a是⼀个已知的数组。
c1=np.arange(2,3,0.1) #起点,终点,步长值。含起点值,不含终点值。
c2=np.linspace(1,4,10) #起点,终点,区间内点数。起点终点均包括在内。同理,有logspace()函数
d1=np.linalgpanion(a) #伴随矩阵
d2=iu()/tril() #作⽤同MATLAB中的同名函数
e1=np.random.rand(3,2) #产⽣⼀个3⾏2列的随机数组。同⼀空间下,有randn()/randint()等多个随机函数
fliplr()/flipud()/rot90() #功能类似MATLAB同名函数。
ll(x,2) #roll()是循环移位函数。此调⽤表⽰向右循环移动2位。
2.数组的特征信息
先假设已经存在⼀个N维数组X了,那么可以得到X的⼀些属性,这些属性可以在输⼊X和⼀个.之后,按tab键查看提⽰。这⾥明显看到了Python⾯向对象的特征。
X.flags #数组的存储情况信息。
X.shape #结果是⼀个tuple,返回本数组的⾏数、列数、……
X.ndim #数组的维数,结果是⼀个数
X.size #数组中元素的数量
X.itemsize #数组中的数据项的所占内存空间⼤⼩
X.dtype #数据类型
X.T #如果X是矩阵,发挥的是X的转置矩阵
np.linalg.det(a) #返回的是矩阵a的⾏列式
(a,ord=None) #计算矩阵a的范数
np.linalg.eig(a) #矩阵a的特征值和特征向量
d(a,p=None) #矩阵a的条件数
np.linalg.inv(a) #矩阵a的逆矩阵
3.矩阵分解
常见的矩阵分解函数,numpy.linalg均已经提供。⽐如cholesky()/qr()/svd()/lu()/schur()等。某些算法为了⽅便计算或者针对不同的特殊情况,还给出了多种调⽤形式,以便得到最佳结果。
4.矩阵运算
np.dot(a,b)⽤来计算数组的点积;vdot(a,b)专门计算⽮量的点积,和dot()的区别在于对complex数据类型的处理不⼀样;innner(a,b)⽤来计算内积;outer(a,b)计算外积。
专门处理矩阵的数学函数在numpy的⼦包linalg中定义。⽐如np.linalg.logm(A)计算矩阵A的对数。可见,这个处理和MATLAB是类似的,使⽤⼀个m后缀表⽰是矩阵的运算。在这个空间内可以使⽤的有cosm()/sinm()/signm()/sqrtm()等。其中常规exp()对应有三种矩阵形式:expm()使⽤Pade近似算法、expm2()使⽤特征值分析算法、expm3()使⽤泰勒级数算法。在numpy中,也有⼀个计算矩阵的函数:funm(A,func)。
5.索引
numpy中的数组索引形式和Python是⼀致的。如:
x=np.arange(10)
print x[2] #单个元素,从前往后正向索引。注意下标是从0开始的。
print x[-2] #从后往前索引。最后⼀个元素的下标是-1
print x[2:5] #多个元素,左闭右开,默认步长值是1
print x[:-7] #多个元素,从后向前,制定了结束的位置,使⽤默认步长值
print x[1:7:2] #指定步长值
x.shape=(2,5) #x的shape属性被重新赋值,要求就是元素个数不变。2*5=10
print x[1,3] #⼆维数组索引单个元素,第2⾏第4列的那个元素
print x[0] #第⼀⾏所有的元素
y=np.arange(35).reshape(5,7) #reshape()函数⽤于改变数组的维度
print y[1:5:2,::2] #选择⼆维数组中的某些符合条件的元素
-
------------------------------------------------分割线-------------------------------------------------
作为第⼀篇正式的介绍技术操作的⽂章,终于写完了,很费劲。恰恰就是在这个费劲的过程中,让我能更好的认识两者的区别和联系,同时梳理了展开的思路,摸索出了进⼀步学习的⽅法。
我们可以看到,MATLAB中实现了的函数或者功能,在numpy中都有了对应,并且有些实现的更好。当然,这只是冰⼭⼀⾓。如果你不愿意通读⽂档(很枯燥,谁也不愿意⼲!)也应该有理由相信,Python有能胜任⼯作的实现已经存在。后⾯的内容,将不再这样列出各种函数和功能,⽽是以某⼀个实际问题为核⼼,进⾏专题式的研究。⾄于全⽅位的了解,请⾃⼰查阅⽂档。有个经验之谈,就是,应该充分的利⽤⽂档中的【see also】功能,依此追踪下去,必然会获得关于某主题的全⽅位的认识。⽐如,在查阅ones()的时候,MATLAB的【see also】就给出了complex|eye|true|zeros四个链接。这就说明,这⼏个函数其实是有关联的,点进去进⾏简单的学习,到共性,那么,可能很多⼈都遇到过的最⼤的困惑——那么多函数怎么记住呀?——就已经解决了。因为,我们不需要记住所有的函数,我们只需要记住有那么回事,只需要记住⼀个类似的函数,就可以很轻易的在⽤的时候顺藤摸⽠出需要的函数。
下⾯简单的给出MATLAB和Python的⾃查⾃学⽅法吧!
1.MATLAB
help 函数名
%在控制台给出某函数或者主题的帮助信息
doc 函数名
%在帮助浏览器中给出帮助信息,这个界⾯更友好。在help browser中既有MATLAB整个产品的浏览左窗⼝,也有⼀个搜索框。同时还有⼤量存在的超链接。就⼀个感兴趣的主题,点下去,全⾯学习。不过要记住:别分神哦~~点到最后都忘了⾃⼰究竟要做什么!
lookfor 关键词
%这是⼀个模糊寻,含有关键词的词条⼊⼝都会给出来
2.Python
help(np.array) #查看关于array的帮助信息
help(np.add) #查看关于add的帮助信息
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论