求问Matlab程序怎么加快程序运算改可以显示运算后矩阵结果

MATLAB矩阵及其数值运算 - Matlab论坛 -
中国电子技术论坛 -
最好最受欢迎电子论坛!
后使用快捷导航没有帐号?
MATLAB矩阵及其数值运算
资深工程师
10:16:23  
10649&查看
MATLAB矩阵及其数值运算
变量和数据操作
变量与赋值
1.变量命名
在MATLAB6.5中,变量名是以字母开头,后接字母、数字或下划线的字符序列,最多63个字符。在MATLAB中,变量名区分字母的大小写。
2.赋值语句
(1) 变量=表达式
(2) 表达式
其中表达式是用运算符将有关运算量连接起来的式子,其结果是一个矩阵。
例2-1 计算表达式的值,并显示计算结果。
在MATLAB命令窗口输入命令:
y=3-sqrt(17);
z=(cos(abs(x+y))-sin(78*pi/180))/(x+abs(y))
其中pi和i都是MATLAB预先定义的变量,分别代表代表圆周率π和虚数单位。
输出结果是:
z = -0.3488 + 0.3286i
预定义变量
在MATLAB工作空间中,还驻留几个由系统本身定义的变量。例如,用pi表示圆周率π的近似值,用i,j表示虚数单位。
预定义变量有特定的含义,在使用时,应尽量避免对这些变量重新赋值。
内存变量的管理
1.内存变量的删除与修改
MATLAB工作空间窗口专门用于内存变量的管理。在工作空间窗口中可以显示所有内存变量的属性。当选中某些变量后,再单击Delete按钮,就能删除这些变量。当选中某些变量后,再单击Open按钮,将进入变量编辑器。通过变量编辑器可以直接观察变量中的具体元素,也可修改变量中的具体元素。
clear命令用于删除MATLAB工作空间中的变量。who和whos这两个命令用于显示在MATLAB工作空间中已经驻留的变量名清单。who命令只显示出驻留变量的名称,whos在给出变量名的同时,还给出它们的大小、所占字节数及数据类型等信息。
2.内存变量文件
利用MAT文件可以把当前MATLAB工作空间中的一些有用变量长久地保留下来,扩展名是.mat。MAT文件的生成和装入由save和load命令来完成。常用格式为:
save 文件名 [变量名表]&&[-append][-ascii]
load 文件名&&[变量名表] [-ascii]
其中,文件名可以带路径,但不需带扩展名.mat,命令隐含一定对.mat文件进行操作。变量名表中的变量个数不限,只要内存或文件中存在即可,变量名之间以空格分隔。当变量名表省略时,保存或装入全部变量。-ascii选项使文件以ASCII格式处理,省略该选项时文件将以二进制格式处理。save命令中的-append选项控制将变量追加到MAT文件中。
MATLAB常用数学函数
MATLAB提供了许多数学函数,函数的自变量规定为矩阵变量,运算法则是将函数逐项作用于矩阵的元素上,因而运算的结果是一个与自变量同维数的矩阵。
函数使用说明:
(1) 三角函数以弧度为单位计算。
(2) abs函数可以求实数的绝对值、复数的模、字符串的ASCII码值。
(3)用于取整的函数有fix、floor、ceil、round,要注意它们的区别。
(4)rem与mod函数的区别。rem(x,y)和mod(x,y)要求x,y必须为相同大小的实矩阵或为标量。
&&数据的输出格式
& &MATLAB用十进制数表示一个常数,具体可采用日常记数法和科学记数法两种表示方法。
& &在一般情况下,MATLAB内部每一个数据元素都是用双精度数来表示和存储的。数据输出时用户可以用format命令设置或改变数据输出格式。format命令的格式为:
& &format&&格式符
其中格式符决定数据的输出格式
MATLAB矩阵
&&矩阵的建立
1.直接输入法
& &最简单的建立矩阵的方法是从键盘直接输入矩阵的元素。具体方法如下:将矩阵的元素用方括号括起来,按矩阵行的顺序输入各元素,同一行的各元素之间用空格或逗号分隔,不同行的元素之间用分号分隔。
2.利用M文件建立矩阵
& &对于比较大且比较复杂的矩阵,可以为它专门建立一个M文件。下面通过一个简单例子来说明如何利用M文件创建矩阵。
& &例2-2&&利用M文件建立MYMAT矩阵。
(1) 启动有关编辑程序或MATLAB文本编辑器,并输入待建矩阵:
(2) 把输入的内容以纯文本方式存盘(设文件名为mymatrix.m)。
(3)在MATLAB命令窗口中输入mymatrix,即运行该M文件,就会自动建立一个名为MYMAT的矩阵,可供以后使用。
3.利用冒号表达式建立一个向量
& &冒号表达式可以产生一个行向量,一般格式是:
& &e1:e2:e3
其中e1为初始值,e2为步长,e3为终止值。
在MATLAB中,还可以用linspace函数产生行向量。其调用格式为:
linspace(a,b,n)
其中a和b是生成向量的第一个和最后一个元素,n是元素总数。
显然,linspace(a,b,n)与a:(b-a)/(n-1):b等价。
4.建立大矩阵
大矩阵可由方括号中的小矩阵或向量建立起来。
&&矩阵的拆分
1.矩阵元素
& &通过下标引用矩阵的元素,例如
A(3,2)=200
采用矩阵元素的序号来引用矩阵元素。矩阵元素的序号就是相应元素在内存中的排列顺序。在MATLAB中,矩阵元素按列存储,先第一列,再第二列,依次类推。例如
A=[1,2,3;4,5,6];
显然,序号(Index)与下标(Subscript)是一一对应的,以m×n矩阵A为例,矩阵元素A(i,j)的序号为(j-1)*m+i。其相互转换关系也可利用sub2ind和ind2sub函数求得。
2.矩阵拆分
& & (1)利用冒号表达式获得子矩阵
& && & ①A(:,j)表示取A矩阵的第j列全部元素;A(i,:)表示A矩阵第i行的全部元素;A(i,j)表示取A矩阵第i行、第j列的元素。
& && &②A(i:i+m,:)表示取A矩阵第i~i+m行的全部元素;A(:,k:k+m)表示取A矩阵第k~k+m列的全部元素,A(i:i+m,k:k+m)表示取A矩阵第i~i+m行内,并在第k~k+m列中的所有元素。
此外,还可利用一般向量和end运算符来表示矩阵下标,从而获得子矩阵。end表示某一维的末尾元素下标。
& & (2)利用空矩阵删除矩阵的元素
& &在MATLAB中,定义[]为空矩阵。给变量X赋空矩阵的语句为X=[]。注意,X=[]与clearX不同,clear是将X从工作空间中删除,而空矩阵则存在于工作空间中,只是维数为0。
&&特殊矩阵
1.通用的特殊矩阵
常用的产生通用特殊矩阵的函数有:
zeros:产生全0矩阵(零矩阵)。
ones:产生全1矩阵(幺矩阵)。
eye:产生单位矩阵。
rand:产生0~1间均匀分布的随机矩阵。
randn:产生均值为0,方差为1的标准正态分布随机矩阵。
例2-3 分别建立3×3、3×2和与矩阵A同样大小的零矩阵。
(1) 建立一个3×3零矩阵。
(2) 建立一个3×2零矩阵。
zeros(3,2)
(3)设A为2×3矩阵,则可以用zeros(size(A))建立一个与矩阵A同样大小零矩阵。
A=[1 2 3;4 56];& &%产生一个2×3阶矩阵A
zeros(size(A))& &&&%产生一个与矩阵A同样大小的零矩阵
例2-4 建立随机矩阵:
(1) 在区间[20,50]内均匀分布的5阶随机矩阵。
(2) 均值为0.6、方差为0.1的5阶正态分布随机矩阵。
命令如下:
x=20+(50-20)*rand(5)
y=0.6+sqrt(0.1)*randn(5)
此外,常用的函数还有reshape(A,m,n),它在矩阵总元素保持不变的前提下,将矩阵A重新排成m×n的二维矩阵。
2.用于专门学科的特殊矩阵
(1) 魔方矩阵
魔方矩阵有一个有趣的性质,其每行、每列及两条对角线上的元素和都相等。对于n阶魔方阵,其元素由1,2,3,…,n2共n2个整数组成。MATLAB提供了求魔方矩阵的函数magic(n),其功能是生成一个n阶魔方阵。
例2-5 将101~125等25个数填入一个5行5列的表格中,使其每行每列及对角线的和均为565。
M=100+magic(5)
(2) 范得蒙矩阵
范得蒙(Vandermonde)矩阵最后一列全为1,倒数第二列为一个指定的向量,其他各列是其后列与倒数第二列的点乘积。可以用一个指定向量生成一个范得蒙矩阵。在MATLAB中,函数vander(V)生成以向量V为基础向量的范得蒙矩阵。例如,A=vander([1;2;3;5])即可得到上述范得蒙矩阵。
(3) 希尔伯特矩阵
在MATLAB中,生成希尔伯特矩阵的函数是hilb(n)。
使用一般方法求逆会因为原始数据的微小扰动而产生不可靠的计算结果。MATLAB中,有一个专门求希尔伯特矩阵的逆的函数invhilb(n),其功能是求n阶的希尔伯特矩阵的逆矩阵。
例2-6 求4阶希尔伯特矩阵及其逆矩阵。
命令如下:
formatrat& & %以有理形式输出
H=invhilb(4)
(4) 托普利兹矩阵
托普利兹(Toeplitz)矩阵除第一行第一列外,其他每个元素都与左上角的元素相同。生成托普利兹矩阵的函数是toeplitz(x,y),它生成一个以x为第一列,y为第一行的托普利兹矩阵。这里x,y均为向量,两者不必等长。toeplitz(x)用向量x生成一个对称的托普利兹矩阵。例如
T=toeplitz(1:6)
(5) 伴随矩阵
MATLAB生成伴随矩阵的函数是compan(p),其中p是一个多项式的系数向量,高次幂系数排在前,低次幂排在后。例如,为了求多项式的x3-7x+6的伴随矩阵,可使用命令:
p=[1,0,-7,6];
(6) 帕斯卡矩阵
我们知道,二次项(x+y)n展开后的系数随n的增大组成一个三角形表,称为杨辉三角形。由杨辉三角形表组成的矩阵称为帕斯卡(Pascal)矩阵。函数pascal(n)生成一个n阶帕斯卡矩阵。
例2-7 求(x+y)5的展开式。
在MATLAB命令窗口,输入命令:
矩阵次对角线上的元素1,5,10,10,5,1即为展开式的系数。
MATLAB运算
1.基本算术运算
& &MATLAB的基本算术运算有:+(加)、-(减)、*(乘)、/(右除)、\(左除)、^(乘方)。
注意,运算是在矩阵意义下进行的,单个数据的算术运算只是一种特例。
& & (1)矩阵加减运算
& &假定有两个矩阵A和B,则可以由A+B和A-B实现矩阵的加减运算。运算规则是:若A和B矩阵的维数相同,则可以执行矩阵的加减运算,A和B矩阵的相应元素相加减。如果A与B的维数不相同,则MATLAB将给出错误信息,提示用户两个矩阵的维数不匹配。
& & (2)矩阵乘法
假定有两个矩阵A和B,若A为m×n矩阵,B为n×p矩阵,则C=A*B为m×p矩阵。
& & (3)矩阵除法
在MATLAB中,有两种矩阵除法运算:\和/,分别表示左除和右除。如果A矩阵是非奇异方阵,则A\B和B/A运算可以实现。A\B等效于A的逆左乘B矩阵,也就是inv(A)*B,而B/A等效于A矩阵的逆右乘B矩阵,也就是B*inv(A)。
对于含有标量的运算,两种除法运算的结果相同,如3/4和4\3有相同的值,都等于0.75。又如,设a=[10.5,25],则a/5=5\a=[2.]。对于矩阵来说,左除和右除表示两种不同的除数矩阵和被除数矩阵的关系。对于矩阵运算,一般A\B≠B/A。
& & (4)矩阵的乘方
& &一个矩阵的乘方运算可以表示成A^x,要求A为方阵,x为标量。
& &在MATLAB中,有一种特殊的运算,因为其运算符是在有关算术运算符前面加点,所以叫点运算。点运算符有.*、./、.\和.^。两矩阵进行点运算是指它们的对应元素进行相关运算,要求两矩阵的维参数相同。
&&关系运算
& &MATLAB提供了6种关系运算符:&(小于)、&=(小于或等于)、&(大于)、&=(大于或等于)、==(等于)、~=(不等于)。它们的含义不难理解,但要注意其书写方法与数学中的不等式符号不尽相同。
& &关系运算符的运算法则为:
& & (1)当两个比较量是标量时,直接比较两数的大小。若筽arty闪ⅲ?叵当泶锸浇峁?
本帖子中包含更多资源
才可以下载或查看,没有帐号?
14:06:02  
下载了打不开呀。。求高手助我
12:14:50  
19:44:29  
很好 支持一下
21:02:13  
很好,支持一下
Powered by
供应链服务
版权所有 (C) 深圳华强聚丰电子科技有限公司有关matlab循环怎么改成矩阵运算? - 知乎25被浏览<strong class="NumberBoard-itemValue" title="分享邀请回答n = 3e3;
popSize = 3e3;
mDmat = 3e3;
nDmat = 3e3;
dmat = rand(mDmat,nDmat);
pop = randi(min(mDmat,nDmat),popSize,n);
你原始的方法是:totalDist = zeros(popSize,1);
for p = 1:popSize
d = dmat(1,pop(p,1));
for k = 2:n
d = d + dmat(pop(p,k-1),pop(p,k));
totalDist(p) = d;
% Elapsed time is 1.136523 seconds.
如果dmat和pop如假定一般都是数组,那么这种和索引有关的向量化一般会考虑转化为线性索引.将二维索引转化为一维索引(即线性索引)可以用sub2ind也可以自己根据索引的顺序计算,但是sub2ind会有overhead,所以我们选择直接计算,例如M-by-N的矩阵A中,A(i,j)的线性索引是:i+(j-1)*M
应用到问题中,内层循环可以向量化为:totalDist = zeros(popSize,1);
for p = 1:popSize
totalDist(p) = dmat(1,pop(p,1))+sum(dmat(pop(p,1:n-1)+(pop(p,2:n)-1)*mDmat));
% Elapsed time is 0.395223 seconds.
但这样显然不过瘾,那就把内层外层一起向量化吧:totalDist = sum(dmat([ones(popSize,1) pop(:,1:end-1)]+(pop-1)*mDmat),2);
% Elapsed time is 0.256587 seconds.
这里有大块的索引运算(pop(:,1:end-1))和cat运算([]),通常这样的运算会比较消耗时间,可以考虑避免,首先将求和的两部分分开来写避免cat运算:totalDist = dmat((pop(:,1)-1)*mDmat+1)+...
sum(dmat(pop(:,1:end-1)+(pop(:,2:end)-1)*mDmat),2);
% Elapsed time is 0.254859 seconds.
这样虽然避免了cat运算,但是又引入了一个大块的索引运算(pop(:,2:end)),所以可以看到性能并没有什么变化,可以进一步考虑消除索引运算:totalDist2 = dmat((pop(:,1)-1)*mDmat+1)+...
sum(dmat(conv2(pop,[mDmat 1],'valid')-mDmat),2);
% Elapsed time is 0.227807 seconds.
可以看到性能提升了10%,另外需要注意上边两种分块求和再相加的运算与放在一起求和的计算结果略有不同,浮点数计算误差导致的,这种相对误差很小,一般不影响运算其实索引部分的运算还可以写的更紧凑一些:totalDist = sum(dmat(filter([mDmat 1],1,pop,1,2)-mDmat),2);
% Elapsed time is 0.298399 seconds.
但是可以看到这种方法是以上几种向量化方法中性能最低的,但是还是明显要快于原始的循环方法。不过在这个问题中向量化有个问题,就是要生成一个和pop差不多大的矩阵用于求和,当pop足够大的时候开辟这么大的空间也是很消耗时间的,所以重新考虑下循环的方法。由于MATLAB的矩阵存储顺序是列优先,所以沿着列方向运算通常要快一些,自然想到下边的方法:totalDist = dmat(1,pop(:,1)).';
for k = 2:n
totalDist = totalDist + dmat(pop(:,k-1)+mDmat*(pop(:,k)-1));
% Elapsed time is 0.186153 seconds.
可以看到这样的循环比上边任何一种向量化方法都要快。不过你可以发现这里的循环次数为n-1,于是可以预见,如果n远大于popSize时上述循环性能就会不如其他方法,在我这里测试,上述例子中其他参数不变,将n改为3e4,popSize取300,两者相差100倍时,该方法性能与第三种向量化算法性能差不多,而当n取3e5,popsize取30的时候这种方法就明显比向量化方法慢了所以说优化MATLAB程序时向量化只是一种手段,并不是目标。上边的例子说明循环并不一定比向量化慢,当然你有可能找到一种新的向量化方法比上边最快的那个循环在任何情况下都快,但是你不能保证每次遇到问题你都能找到这样的向量化方法。所以优化的目标归根结底是提升程序的性能,对于性能敏感的程序最好还是具体情况具体分析(例如这里的pop的size),而不是一味的追求向量化。134 条评论分享收藏感谢收起% 标量与矢量
d = dmat(1, pop(:,1)); % 返回d为列向量
% 矢量与矢量
d = dmat(pop(:,1), pop(:,2)); % 返回d为列向量
改矩阵运算并非没有缺点,缺点就是得多生成一个数据,计算使用内存加倍。现在电脑内存都够大,只要给Matlab足够内存应该就行n = size(pop, 1);
pop_m1 = [ones(n,1), pop(:, 1:end-1)];
d = dmat(pop_m1, pop);
totalDist = sum(d, 2);
凭经验写的,没有运行,有哪些不对的欢迎指正1添加评论分享收藏感谢收起写回答网站已改版,请使用新地址访问:
entropy 信息论中用matlab编程来计算熵,此程序可以修改输入的矩阵,进行新的
238万源代码下载- www.pudn.com
&文件名称: entropy
& & & & &&]
&&所属分类:
&&开发工具: Visual C++
&&文件大小: 5 KB
&&上传时间:
&&下载次数: 26
&&提 供 者:
&详细说明:信息论中用matlab编程来计算熵,此程序可以修改输入的矩阵,进行新的计算-To calculate the entropy of information theory using Matlab programming, this program can modify the input matrix, a new calculation
文件列表(点击判断是否您需要的文件,如果是垃圾请在下面评价投诉):
&&entropy.doc
&[]:纯粹是垃圾
&近期下载过的用户:
&输入关键字,在本站238万海量源码库中尽情搜索:
&[] - Qt 设计入门资料,详细解释 具体到每句语句 适合入门级的学习
&[] - 使用vc++实现仿QQ的超酷界面,是界面编程中相当不错的学习资料。
&[] - 数据流中计算熵的算法以及对数据流的分析实例,供参考
&[] - 使用matlab函数,,,实现用熵值法求出任意矩阵的行或列的权重和每个值的综合参数
&[] - matlab的纹理计算程序,能够计算熵、对比度、均值、方差
&[] - 计算图像灰度共生矩阵重要属性:能量 熵 惯性矩和相关性。
&[] - 分析图象中的能量及熵、相关性等参数
&[] - 计算香浓信息熵,方便快捷的matlab代码,可以简单直接调用
&[] - 灰度共生矩阵提取特征值,最近邻算法,进行纹理图像分类。creat_apprentissage用来训练样本,cooccurence是灰度共生矩阵提取特征值,knn是进行k最近邻算法,classif是纹理图像分类
&[] - 图像分割中霍夫变换检测直线,先看效果,左上角为原图,左下角为找到的直线,右图为hough变换后的图求一个MATLAB计算矩阵的程序_百度知道
求一个MATLAB计算矩阵的程序
知道X2矩阵计算 X1矩阵,其中R矩阵已知,X2取值有很多,能在窗口输出所有X1,求这个程序的一个示例,我要用它来计算一组数
我有更好的答案
你好!这个是不是有点太简单了?你假设一个函数:function f=fun1(X2)R=[];f=R*X2end主函数:clear alli=1;while i&0X2=input(&#39;请输入X2:&#92;n&#39;);X1=fun1(X2)i=input(&#39;还需要输入X2吗?(输入正数表示是的):&#39;);end
为您推荐:
其他类似问题
matlab的相关知识
&#xe675;换一换
回答问题,赢新手礼包&#xe6b9;
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。后使用快捷导航没有帐号?
查看: 1290|回复: 0
Matlab矩阵运算
新手上路, 积分 25, 距离下一级还需 25 积分
论坛徽章:2
& & & & & & & & & & & & 第2章&&MATLAB矩阵及其运算
2.1&&变量和数据操作
2.2&&MATLAB矩阵
2.3&&MATLAB运算
2.4&&矩阵分析
2.5&&矩阵的超越函数
2.6&&字符串
2.7&&结构数据和单元数据
2.8&&稀疏矩阵
2.1&&变量和数据操作
2.1.1&&变量与赋值
1.变量命名
在MATLAB6.5中,变量名是以字母开头,后接字母、数字或下划线的字符序列,最多63个字符。在MATLAB中,变量名区分字母的大小写。
2.赋值语句
(1) 变量=表达式&&
(2) 表达式
其中表达式是用运算符将有关运算量连接起来的式子,其结果是一个矩阵。
例2-1&&计算表达式的值,并显示计算结果。
在MATLAB命令窗口输入命令:
y=3-sqrt(17);
z=(cos(abs(x+y))-sin(78*pi/180))/(x+abs(y))
其中pi和i都是MATLAB预先定义的变量,分别代表代表圆周率π和虚数单位。
输出结果是:
& & 2.1.2&&预定义变量
在MATLAB工作空间中,还驻留几个由系统本身定义的变量。例如,用pi表示圆周率π的近似值,用i,j表示虚数单位。
预定义变量有特定的含义,在使用时,应尽量避免对这些变量重新赋值。
2.1.3&&内存变量的管理
1.内存变量的删除与修改
MATLAB工作空间窗口专门用于内存变量的管理。在工作空间窗口中可以显示所有内存变量的属性。当选中某些变量后,再单击Delete按钮,就能删除这些变量。当选中某些变量后,再单击Open按钮,将进入变量编辑器。通过变量编辑器可以直接观察变量中的具体元素,也可修改变量中的具体元素。
clear命令用于删除MATLAB工作空间中的变量。who和whos这两个命令用于显示在MATLAB工作空间中已经驻留的变量名清单。who命令只显示出驻留变量的名称,whos在给出变量名的同时,还给出它们的大小、所占字节数及数据类型等信息。
2.内存变量文件
利用MAT文件可以把当前MATLAB工作空间中的一些有用变量长久地保留下来,扩展名是.mat。MAT文件的生成和装入由save和load命令来完成。常用格式为:
save 文件名 [变量名表]&&[-append][-ascii]
load 文件名&&[变量名表]&&[-ascii]
其中,文件名可以带路径,但不需带扩展名.mat,命令隐含一定对.mat文件进行操作。变量名表中的变量个数不限,只要内存或文件中存在即可,变量名之间以空格分隔。当变量名表省略时,保存或装入全部变量。-ascii选项使文件以ASCII格式处理,省略该选项时文件将以二进制格式处理。save命令中的-append选项控制将变量追加到MAT文件中。
2.1.4&&MATLAB常用数学函数
MATLAB提供了许多数学函数,函数的自变量规定为矩阵变量,运则是将函数逐项作用于矩阵的元素上,因而运算的结果是一个与自变量同维数的矩阵。
函数使用说明:
(1) 三角函数以弧度为单位计算。
(2) abs函数可以求实数的值、复数的模、字符串的ASCII码值。
(3) 用于取整的函数有fix、floor、ceil、round,要注意它们的区别。
(4) rem与mod函数的区别。rem(x,y)和mod(x,y)要求x,y必须为相同大小的实矩阵或为标量。
2.1.5&&数据的输出格式
& & MATLAB用十进制数表示一个常数,具体可采用日常记数法和科学记数法两种表示方法。
& & 在一般情况下,MATLAB内部每一个数据元素都是用双精度数来表示和存储的。数据输出时用户可以用format命令设置或改变数据输出格式。format命令的格式为:
& & format&&格式符
其中格式符决定数据的输出格式
2.2&&MATLAB矩阵
2.2.1&&矩阵的建立
1.直接输入法
& & 最简单的建立矩阵的方法是从键盘直接输入矩阵的元素。具体方法如下:将矩阵的元素用方括号括起来,按矩阵行的顺序输入各元素,同一行的各元素之间用空格或逗号分隔,不同行的元素之间用分号分隔。
2.利用M文件建立矩阵
& & 对于比较大且比较复杂的矩阵,可以为它专门建立一个M文件。下面通过一个简单例子来说明如何利用M文件创建矩阵。
& & 例2-2&&利用M文件建立MYMAT矩阵。
(1) 启动有关编辑程序或MATLAB文本编辑器,并输入待建矩阵:
(2) 把输入的内容以纯文本方式存盘(设文件名为mymatrix.m)。
(3) 在MATLAB命令窗口中输入mymatrix,即运行该M文件,就会自动建立一个名为MYMAT的矩阵,可供以后使用。
3.利用冒号表达式建立一个向量
& & 冒号表达式可以产生一个行向量,一般格式是:
& & e1:e2:e3
其中e1为初始值,e2为步长,e3为终止值。
在MATLAB中,还可以用linspace函数产生行向量。其调用格式为:
linspace(a,b,n)
其中a和b是生成向量的第一个和最后一个元素,n是元素总数。
显然,linspace(a,b,n)与ab-a)/(n-1):b等价。
4.建立大矩阵
大矩阵可由方括号中的小矩阵或向量建立起来。
2.2.2&&矩阵的拆分
1.矩阵元素
& & 通过下标引用矩阵的元素,例如
A(3,2)=200
采用矩阵元素的序号来引用矩阵元素。矩阵元素的序号就是相应元素在内存中的排列顺序。在MATLAB中,矩阵元素按列存储,先第一列,再第二列,依次类推。例如
A=[1,2,3;4,5,6];
显然,序号(Index)与下标(Subscript)是一一对应的,以m×n矩阵A为例,矩阵元素A(i,j)的序号为(j-1)*m+i。其相互转换关系也可利用sub2ind和ind2sub函数求得。
2.矩阵拆分
& & (1) 利用冒号表达式获得子矩阵
& && &① A(:,j)表示取A矩阵的第j列全部元素;A(i,表示A矩阵第i行的全部元素;A(i,j)表示取A矩阵第i行、第j列的元素。
& && &② A(i:i+m,:)表示取A矩阵第i~i+m行的全部元素;A(:,k:k+m)表示取A矩阵第k~k+m列的全部元素,A(i:i+m,k:k+m)表示取A矩阵第i~i+m行内,并在第k~k+m列中的所有元素。
此外,还可利用一般向量和end运算符来表示矩阵下标,从而获得子矩阵。end表示某一维的末尾元素下标。
& & (2) 利用空矩阵删除矩阵的元素
& & 在MATLAB中,定义[]为空矩阵。给变量X赋空矩阵的语句为X=[]。注意,X=[]与clearX不同,clear是将X从工作空间中删除,而空矩阵则存在于工作空间中,只是维数为0。
2.2.3&&特殊矩阵
1.通用的特殊矩阵
常用的产生通用特殊矩阵的函数有:
zeros:产生全0矩阵(零矩阵)。
ones:产生全1矩阵(幺矩阵)。
eye:产生单位矩阵。
rand:产生0~1间均匀分布的随机矩阵。
randn:产生均值为0,方差为1的标准正态分布随机矩阵。
例2-3&&分别建立3×3、3×2和与矩阵A同样大小的零矩阵。
(1) 建立一个3×3零矩阵。
(2) 建立一个3×2零矩阵。
zeros(3,2)
(3) 设A为2×3矩阵,则可以用zeros(size(A))建立一个与矩阵A同样大小零矩阵。
A=[1 2 3;4 56];& & %产生一个2×3阶矩阵A
zeros(size(A))& && &%产生一个与矩阵A同样大小的零矩阵
例2-4 建立随机矩阵:
(1) 在区间[20,50]内均匀分布的5阶随机矩阵。
(2) 均值为0.6、方差为0.1的5阶正态分布随机矩阵。
命令如下:
x=20+(50-20)*rand(5)
y=0.6+sqrt(0.1)*randn(5)
此外,常用的函数还有reshape(A,m,n),它在矩阵总元素保持不变的前提下,将矩阵A重新排成m×n的二维矩阵。
2.用于专门学科的特殊矩阵
(1) 魔方矩阵
魔方矩阵有一个有趣的性质,其每行、每列及两条对角线上的元素和都相等。对于n阶魔方阵,其元素由1,2,3,…,n2共n2个整数组成。MATLAB提供了求魔方矩阵的函数magic(n),其功能是生成一个n阶魔方阵。
例2-5&&将101~125等25个数填入一个5行5列的表格中,使其每行每列及对角线的和均为565。
M=100+magic(5)
(2) 范得蒙矩阵
范得蒙(Vandermonde)矩阵最后一列全为1,倒数第二列为一个指定的向量,其他各列是其后列与倒数第二列的点乘积。可以用一个指定向量生成一个范得蒙矩阵。在MATLAB中,函数vander(V)生成以向量V为基础向量的范得蒙矩阵。例如,A=vander([1;2;3;5])即可得到上述范得蒙矩阵。
(3) 希尔伯特矩阵
在MATLAB中,生成希尔伯特矩阵的函数是hilb(n)。
使用一般方法求逆会因为原始数据的微小扰动而产生不可靠的计算结果。MATLAB中,有一个专门求希尔伯特矩阵的逆的函数invhilb(n),其功能是求n阶的希尔伯特矩阵的逆矩阵。
例2-6&&求4阶希尔伯特矩阵及其逆矩阵。
命令如下:
formatrat& &&&%以有理形式输出
H=invhilb(4)
(4) 托普利兹矩阵
托普利兹(Toeplitz)矩阵除第一行第一列外,其他每个元素都与左上角的元素相同。生成托普利兹矩阵的函数是toeplitz(x,y),它生成一个以x为第一列,y为第一行的托普利兹矩阵。这里x,y均为向量,两者不必等长。toeplitz(x)用向量x生成一个对称的托普利兹矩阵。例如
T=toeplitz(1:6)
(5) 伴随矩阵
MATLAB生成伴随矩阵的函数是compan(p),其中p是一个多项式的系数向量,高次幂系数排在前,低次幂排在后。例如,为了求多项式的x3-7x+6的伴随矩阵,可使用命令:
p=[1,0,-7,6];
(6) 帕斯卡矩阵
我们知道,二次项(x+y)n展开后的系数随n的增大组成一个三角形表,称为杨辉三角形。由杨辉三角形表组成的矩阵称为帕斯卡(Pascal)矩阵。函数pascal(n)生成一个n阶帕斯卡矩阵。
例2-7&&求(x+y)5的展开式。
在MATLAB命令窗口,输入命令:
矩阵次对角线上的元素1,5,10,10,5,1即为展开式的系数。
2.3 MATLAB运算
2.3.1算术运算
1.基本算术运算
& & MATLAB的基本算术运算有:+(加)、-(减)、*(乘)、/(右除)、/(左除)、^(乘方)。
注意,运算是在矩阵意义下进行的,单个数据的算术运算只是一种特例。
& & (1) 矩阵加减运算
& & 假定有两个矩阵A和B,则可以由A+B和A-B实现矩阵的加减运算。运算规则是:若A和B矩阵的维数相同,则可以执行矩阵的加减运算,A和B矩阵的相应元素相加减。如果A与B的维数不相同,则MATLAB将给出错误信息,提示用户两个矩阵的维数不匹配。
& & (2) 矩阵乘法&&
假定有两个矩阵A和B,若A为m×n矩阵,B为n×p矩阵,则C=A*B为m×p矩阵。
& & (3) 矩阵除法
在MATLAB中,有两种矩阵除法运算:/和/,分别表示左除和右除。如果A矩阵是非奇异方阵,则A/B和B/A运算可以实现。A/B等效于A的逆左乘B矩阵,也就是inv(A)*B,而B/A等效于A矩阵的逆右乘B矩阵,也就是B*inv(A)。
对于含有标量的运算,两种除法运算的结果相同,如3/4和4/3有相同的值,都等于0.75。又如,设a=[10.5,25],则a/5=5/a=[2.]。对于矩阵来说,左除和右除表示两种不同的除数矩阵和被除数矩阵的关系。对于矩阵运算,一般A/B≠B/A。
& & (4) 矩阵的乘方
& & 一个矩阵的乘方运算可以表示成A^x,要求A为方阵,x为标量。
& & 在MATLAB中,有一种特殊的运算,因为其运算符是在有关算术运算符前面加点,所以叫点运算。点运算符有.*、./、./和.^。两矩阵进行点运算是指它们的对应元素进行相关运算,要求两矩阵的维参数相同。
2.3.2&&关系运算
& & MATLAB提供了6种关系运算符:&(小于)、&=(小于或等于)、&(大于)、&=(大于或等于)、==(等于)、~=(不等于)。它们的含义不难理解,但要注意其书写方法与数学中的不等式符号不尽相同。
& & 关系运算符的运算法则为:
& & (1) 当两个比较量是标量时,直接比较两数的大小。若关系成立,关系表达式结果为1,否则为0。
& & (2) 当参与比较的量是两个维数相同的矩阵时,比较是对两矩阵相同位置的元素按标量关系运算规则逐个进行,并给出元素比较结果。最终的关系运算的结果是一个维数与原矩阵相同的矩阵,它的元素由0或1组成。
& & (3) 当参与比较的一个是标量,而另一个是矩阵时,则把标量与矩阵的每一个元素按标量关系运算规则逐个比较,并给出元素比较结果。最终的关系运算的结果是一个维数与原矩阵相同的矩阵,它的元素由0或1组成。
& & 例2-8&&产生5阶随机方阵A,其元素为[10,90]区间的随机整数,然后判断A的元素是否能被3整除。
& & (1) 生成5阶随机方阵A。
A=fix((90-10+1)*rand(5)+10)
& & (2) 判断A的元素是否可以被3整除。
P=rem(A,3)==0
其中,rem(A,3)是矩阵A的每个元素除以3的余数矩阵。此时,0被扩展为与A同维数的零矩阵,P是进行等于(==)比较的结果矩阵。
2.3.3&&逻辑运算
& & MATLAB提供了3种逻辑运算符:&(与)、|(或)和~(非)。
& & 逻辑运算的运算法则为:
(1) 在逻辑运算中,确认非零元素为真,用1表示,零元素为假,用0表示。
(2) 设参与逻辑运算的是两个标量a和b,那么,
& & a&b&&a,b全为非零时,运算结果为1,否则为0。
& & a|b&&a,b中只要有一个非零,运算结果为1。
& & ~a&&当a是零时,运算结果为1;当a非零时,运算结果为0。
(3) 若参与逻辑运算的是两个同维矩阵,那么运算将对矩阵相同位置上的元素按标量规则逐个进行。最终运算结果是一个与原矩阵同维的矩阵,其元素由1或0组成。
(4) 若参与逻辑运算的一个是标量,一个是矩阵,那么运算将在标量与矩阵中的每个元素之间按标量规则逐个进行。最终运算结果是一个与矩阵同维的矩阵,其元素由1或0组成。
(5) 逻辑非是单目运算符,也服从矩阵运算规则。
(6) 在算术、关系、逻辑运算中,算术运算优先级较高,逻辑运算优先级较低。
例2-9&&建立矩阵A,然后找出大于4的元素的位置。
(1) 建立矩阵A。
A=[4,-65,-54,0,6;56,0,67,-45,0]
(2) 找出大于4的元素的位置。
2.4 矩阵分析
2.4.1&&对角阵与三角阵
只有对角线上有非0元素的矩阵称为对角矩阵,对角线上的元素相等的对角矩阵称为数量矩阵,对角线上的元素都为1的对角矩阵称为单位矩阵。
(1) 提取矩阵的对角线元素
设A为m×n矩阵,diag(A)函数用于提取矩阵A主对角线元素,产生一个具有min(m,n)个元素的列向量。
diag(A)函数还有一种形式diag(A,k),其功能是提取第k条对角线的元素。
(2) 构造对角矩阵
设V为具有m个元素的向量,diag(V)将产生一个m×m对角矩阵,其主对角线元素即为向量V的元素。
diag(V)函数也有另一种形式diag(V,k),其功能是产生一个n×n(n=m+)对角阵,其第k条对角线的元素即为向量V的元素。
例2-10&&先建立5×5矩阵A,然后将A的第一行元素乘以1,第二行乘以2,…,第五行乘以5。
A=[17,0,1,0,15;23,5,7,14,16;4,0,13,0,22;10,12,19,21,3;...
11,18,25,2,19];
D=diag(1:5);
D*A& && && && && & %用D左乘A,对A的每行乘以一个指定常数
三角阵又进一步分为上三角阵和下三角阵,所谓上三角阵,即矩阵的对角线以下的元素全为0的一种矩阵,而下三角阵则是对角线以上的元素全为0的一种矩阵。
(1) 上三角矩阵
求矩阵A的上三角阵的MATLAB函数是triu(A)。
triu(A)函数也有另一种形式triu(A,k),其功能是求矩阵A的第k条对角线以上的元素。例如,提取矩阵A的第2条对角线以上的元素,形成新的矩阵B。
(2) 下三角矩阵
在MATLAB中,提取矩阵A的下三角矩阵的函数是tril(A)和tril(A,k),其用法与提取上三角矩阵的函数triu(A)和triu(A,k)完全相同。
2.4.2&&矩阵的转置与旋转
1.矩阵的转置
转置运算符是单撇号(‘)。
2.矩阵的旋转
利用函数rot90(A,k)将矩阵A旋转90&#186;的k倍,当k为1时可省略。
3.矩阵的左右翻转
对矩阵实施左右翻转是将原矩阵的第一列和最后一列调换,第二列和倒数第二列调换,…,依次类推。MATLAB对矩阵A实施左右翻转的函数是fliplr(A)。
4.矩阵的上下翻转
MATLAB对矩阵A实施上下翻转的函数是flipud(A)。
2.4.3&&矩阵的逆与伪逆
1.矩阵的逆
对于一个方阵A,如果存在一个与其同阶的方阵B,使得:
A·B=B·A=I (I为单位矩阵)
则称B为A的逆矩阵,当然,A也是B的逆矩阵。
求一个矩阵的逆是一件非常烦琐的工作,容易出错,但在MATLAB中,求一个矩阵的逆非常容易。求方阵A的逆矩阵可调用函数inv(A)。
例2-11&&用求逆矩阵的方法解线性方程组。
2.矩阵的伪逆
如果矩阵A不是一个方阵,或者A是一个非满秩的方阵时,矩阵A没有逆矩阵,但可以找到一个与A的转置矩阵A‘同型的矩阵B,使得:
此时称矩阵B为矩阵A的伪逆,也称为广义逆矩阵。在MATLAB中,求一个矩阵伪逆的函数是pinv(A)。
2.4.4 方阵的行列式
把一个方阵看作一个行列式,并对其按行列式的规则求值,这个值就称为矩阵所对应的行列式的值。在MATLAB中,求方阵A所对应的行列式的值的函数是det(A)。
2.4.5&&矩阵的秩与迹
1.矩阵的秩
矩阵线性无关的行数与列数称为矩阵的秩。在MATLAB中,求矩阵秩的函数是rank(A)。
2.矩阵的迹
矩阵的迹等于矩阵的对角线元素之和,也等于矩阵的特征值之和。在MATLAB中,求矩阵的迹的函数是trace(A)。
2.4.6&&向量和矩阵的范数
矩阵或向量的范数用来度量矩阵或向量在某种意义下的长度。范数有多种方法定义,其定义不同,范数值也就不同。
1.向量的3种常用范数及其计算函数
在MATLAB中,求向量范数的函数为:
(1) norm(V)或norm(V,2):计算向量V的2—范数。
(2) norm(V,1):计算向量V的1—范数。
(3) norm(V,inf):计算向量V的∞—范数。
2.矩阵的范数及其计算函数
MATLAB提供了求3种矩阵范数的函数,其函数调用格式与求向量的范数的函数完全相同。
2.4.7&&矩阵的条件数
在MATLAB中,计算矩阵A的3种条件数的函数是:
(1)cond(A,1)& &计算A的1—范数下的条件数。
(2)cond(A)或cond(A,2)& &计算A的2—范数数下的条件数。
(3)cond(A,inf)& &计算A的 ∞—范数下的条件数。
2.4.8&&矩阵的特征值与特征向量
在MATLAB中,计算矩阵A的特征值和特征向量的函数是eig(A),常用的调用格式有3种:
(1) E=eig(A):求矩阵A的全部特征值,构成向量E。
(2) [V,D]=eig(A):求矩阵A的全部特征值,构成对角阵D,并求A的特征向量构成V的列向量。
(3)[V,D]=eig(A,‘nobalance’):与第2种格式类似,但第2种格式中先对A作相似变换后求矩阵A的特征值和特征向量,而格式3直接求矩阵A的特征值和特征向量。
例2-12&&用求特征值的方法解方程。
3x5-7x4+5x2+2x-18=0
p=[3,-7,0,5,2,-18];
A=compan(p);& && && &&&%A的伴随矩阵
x1=eig(A)& && && && &&&%求A的特征值
x2=roots(p)& && && && && &&&%直接求多项式p的零点
2.5 矩阵的超越函数
1.矩阵平方根sqrtm
sqrtm(A)计算矩阵A的平方根。
2.矩阵对数logm
logm(A)计算矩阵A的自然对数。此函数输入参数的条件与输出结果间的关系和函数sqrtm(A)完全一样
3.矩阵指数expm、expm1、expm2、expm3
expm(A)、expm1(A)、expm2(A)、expm3(A)的功能都求矩阵指数eA。
4.普通矩阵函数funm
funm(A,‘fun’)用来计算直接作用于矩阵A的由‘fun’指定的超越函数值。当fun取sqrt时,funm(A,‘sqrt’)可以计算矩阵A的平方根,与sqrtm(A)的计算结果一样。
2.6&&字符串
& & 在MATLAB中,字符串是用单撇号括起来的字符序列。
MATLAB将字符串当作一个行向量,每个元素对应一个字符,其标识方法和数值向量相同。也可以建立多行字符串矩阵。
字符串是以ASCII码形式存储的。abs和double函数都可以用来获取字符串矩阵所对应的ASCII码数值矩阵。相反,char函数可以把ASCII码矩阵转换为字符串矩阵。
例2-13&&建立一个字符串向量,然后对该向量做如下处理:
(1) 取第1~5个字符组成的子字符串。
(2) 将字符串倒过来重新排列。
(3) 将字符串中的小写字母变成相应的大写字母,其余字符不变。
(4) 统计字符串中小写字母的个数。
命令如下:
ch=‘ABc123d4e56Fg9’;
subch=ch(1:5)& && && &&&%取子字符串
revch=ch(end:-1:1)& && & %将字符串倒排
k=find(ch&=‘a’&ch&=‘z’);& &&&%找小写字母的位置
ch(k)=ch(k)-(‘a’-‘A’);& && && &%将小写字母变成相应的大写字母
char(ch)& && && && && &
length(k)& && && && && && &%统计小写字母的个数
& & 与字符串有关的另一个重要函数是eval,其调用格式为:
& & eval_r(t)
其中t为字符串。它的作用是把字符串的内容作为对应的MATLAB语句来执行。
2.7&&结构数据和单元数据
2.7.1&&结构数据
1.结构矩阵的建立与引用
结构矩阵的元素可以是不同的数据类型,它能将一组具有不同属性的数据纳入到一个统一的变量名下进行管理。建立一个结构矩阵可采用给结构成员赋值的办法。具体格式为:
结构矩阵名.成员名=表达式
其中表达式应理解为矩阵表达式。
2.结构成员的修改
可以根据需要增加或删除结构的成员。例如要给结构矩阵a增加一个成员x4,可给a中任意一个元素增加成员x4:
a(1).x4=‘410075’;
但其他成员均为空矩阵,可以使用赋值语句给它赋确定的值。
要删除结构的成员,则可以使用rmfield函数来完成。例如,删除成员x4:
a=rmfield(a,‘x4’);
3.关于结构的函数
除了一般的结构数据的操作外,MATLAB还提供了部分函数来进行结构矩阵的操作。
2.7.2&&单元数据
1.单元矩阵的建立与引用
建立单元矩阵和一般矩阵相似,只是矩阵元素用大括号括起来。
可以用带有大括号下标的形式引用单元矩阵元素。例如b{3,3}。单元矩阵的元素可以是结构或单元数据。
可以使用celldisp函数来显示整个单元矩阵,如celldisp(b)。还可以删除单元矩阵中的某个元素。2.关于单元的函数
MATLAB还提供了部分函数用于单元的操作。
2.8 稀疏矩阵
2.8.1&&矩阵存储方式
MATLAB的矩阵有两种存储方式:完全存储方式和稀疏存储方式。
1.完全存储方式
完全存储方式是将矩阵的全部元素按列存储。以前讲到的矩阵的存储方式都是按这个方式存储的,此存储方式对稀疏矩阵也适用。
2.稀疏存储方式
稀疏存储方式仅存储矩阵所有的非零元素的值及其位置,即行号和列号。在MATLAB中,稀疏存储方式也是按列存储的。
注意,在讲稀疏矩阵时,有两个不同的概念,一是指矩阵的0元素较多,该矩阵是一个具有稀疏特征的矩阵,二是指采用稀疏方式存储的矩阵。
2.8.2&&稀疏存储方式的产生
1.将完全存储方式转化为稀疏存储方式
函数A=sparse(S)将矩阵S转化为稀疏存储方式的矩阵A。当矩阵S是稀疏存储方式时,则函数调用相当于A=S。
sparse函数还有其他一些调用格式:
sparse(m,n):生成一个m×n的所有元素都是0的稀疏矩阵。
sparse(u,v,S)&#173;&#173;:u,v,S是3个等长的向量。S是要建立的稀疏矩阵的非0元素,u(i)、v(i)分别是S(i)的行和列下标,该函数建立一个max(u)行、max(v)列并以S为稀疏元素的稀疏矩阵。
此外,还有一些和稀疏矩阵操作有关的函数。例如
[u,v,S]=find(A):返回矩阵A中非0元素的下标和元素。这里产生的u,v,S可作为sparse(u,v,S)的参数。
full(A):返回和稀疏存储矩阵A对应的完全存储方式矩阵。
2.产生稀疏存储矩阵
只把要建立的稀疏矩阵的非0元素及其所在行和列的位置表示出来后由MATLAB自己产生其稀疏存储,这需要使用spconvert函数。调用格式为:
B=spconvert(A)
其中A为一个m×3或m×4的矩阵,其每行表示一个非0元素,m是非0元素的个数,A每个元素的意义是:
(i,1)&&第i个非0元素所在的行。
(i,2)&&第i个非0元素所在的列。
(i,3)&&第i个非0元素值的实部。
(i,4)&&第i个非0元素值的虚部,若矩阵的全部元素都是实数,则无须第四列。
该函数将A所描述的一个稀疏矩阵转化为一个稀疏存储矩阵。
例2-15&&根据表示稀疏矩阵的矩阵A,产生一个稀疏存储方式矩阵B。
命令如下:
A=[2,2,1;3,1,-1;4,3,3;5,3,8;6,6,12];
B=spconvert(A)
3.带状稀疏存储矩阵
用spdiags函数产生带状稀疏矩阵的稀疏存储,调用格式是:
A=spdiags(B,d,m,n)
其中,参数m,n为原带状矩阵的行数与列数。B为r×p阶矩阵,这里r=min(m,n),p为原带状矩阵所有非零对角线的条数,矩阵B的第i列即为原带状矩阵的第i条非零对角线。
4.单位矩阵的稀疏存储
单位矩阵只有对角线元素为1,其他元素都为0,是一种具有稀疏特征的矩阵。函数eye产生一个完全存储方式的单位矩阵。MATLAB还有一个产生稀疏存储方式的单位矩阵的函数,这就是speye。函数speye(m,n)返回一个m×n的稀疏存储单位矩阵。
2.8.3&&稀疏矩阵应用举例
稀疏存储矩阵只是矩阵的存储方式不同,它的运算规则与普通矩阵是一样的。所以,在运算过程中,稀疏存储矩阵可以直接参与运算。当参与运算的对象不全是稀疏存储矩阵时,所得结果一般是完全存储形式。
& & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & &
dataguru.cn All Right Reserved.
扫一扫加入本版微信群}

我要回帖

更多关于 设计自己的运算程序 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信