矩阵及其运算.ppt

上传人:本田雅阁 文档编号:2556545 上传时间:2019-04-07 格式:PPT 页数:102 大小:1.69MB
返回 下载 相关 举报
矩阵及其运算.ppt_第1页
第1页 / 共102页
矩阵及其运算.ppt_第2页
第2页 / 共102页
矩阵及其运算.ppt_第3页
第3页 / 共102页
亲,该文档总共102页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《矩阵及其运算.ppt》由会员分享,可在线阅读,更多相关《矩阵及其运算.ppt(102页珍藏版)》请在三一文库上搜索。

1、第2章 MATLAB矩阵及其运算,张登峰,第2章 MATLAB矩阵及其运算,2.1 变量和数据操作 2.2 MATLAB矩阵 2.3 MATLAB运算 2.4 矩阵分析 2.5 矩阵的超越函数 2.6 字符串 2.7 结构数据和单元数据 2.8 稀疏矩阵,Matlab命令窗口常用标点与命令,MATLAB的程序设计主要是在命令窗或M文件编辑器(生成的文件称为M文件/脚本文件)中编写解决问题的指令集合的知识,一般将其也称之为MATLAB的源代码程序。 P9: MATLAB表达式基本运算符,书写规则与“手写算式”几乎相同; P15:MATLAB常用标点的功能. 代码可在命令窗口、M文件编辑窗口、记事

2、本编写。,基本算术运算符,数值表达式书写规则,表达式由变量名、运算符、函数名等组成; 表达式按照与常规相同的优先级自左至右执行运算; 优先级:指数运算级别最高,乘除次之,加减运算最低; 括号可改变运算次序; 书写表达式时,赋值符“=”和运算符两侧允许有空格,以增加可读性。,MATLAB部分常用标点的功能,2.1 变量和数据操作,2.1.1 变量与赋值 1变量命名 在MATLAB 6.5中,变量名是以字母开头,后接字母、数字或下划线的字符序列,最多63个字符。变量名区分字母的大小写。,2.1.1 变量与赋值(续),2赋值语句 (1) 变量=表达式 (2) 表达式 其中表达式是用运算符将有关运算量

3、连接起来的式子,其结果是一个矩阵。 例:x=5*(6-1/0.5); 5*(6-1/0.5)+3; MATLAB的基本算术运算符有:(加)、(减)、*(乘)、/(右除)、(左除)、(乘方),等等。 注: 运算是在矩阵意义下进行的,单个数据的算术运算只是一种特例。,例2-1 计算表达式的值,并显示计算结果。 在MATLAB命令窗口输入命令: x=1+2i; y=3-sqrt(17); z=(cos(abs(x+y)-sin(78*pi/180)/(x+abs(y) 其中pi和i都是MATLAB的预定义变量,分别代表圆周率和虚数单位。 输出结果是: z = -0.3488 + 0.3286i,任何

4、MATLAB语句的执行结果都可以在屏幕上显示,同时赋值给指定的变量,没有指定变量时,默认赋值给一个特殊变量ans,数据的显示格式由format命令控制。 format只是影响结果的显示,不影响其计算精度与存储;MATLAB总是以双字长浮点数(双精度)来执行所有的运算。(见下页p14),2.1.1 变量与赋值(续),短格式(Short):默认格式 1.3333 0.0000 短格式e方式(Short e):1.3333e+00 1.2345e-06 短格式g方式(Short g):1.3333 0.0 长格式(Long):1.33333333333333 0.00000123450000 长格式

5、e方式(Long e):1.33333333333333e+00 1.2345000000000e-06 长格式g方式(Long g):1.33333333333333 0.0000012345 银行格式(Bank):1.33 0.00 十六进制格式(Hex):3ff555555555 3eb46231abfd71 +格式(+):显示大矩阵用,+ 有理数(Rational):1/3 2469/2000000000,2.1.1 变量与赋值(续),2.1.2 预定义变量,在MATLAB工作空间中,还驻留一些由系统本身定义的变量。预定义变量有特定的含义,在使用时,应尽量避免对这些变量重新赋值。,2.

6、1.3 内存变量的管理,1内存变量的删除与修改 MATLAB工作空间窗口专门用于内存变量的管理。在工作空间窗口中可以显示所有内存变量的属性。 当选中某些变量后,再单击Delete按钮,就能删除这些变量。 当选中某些变量后,再单击Open按钮,将进入变量编辑器。通过变量编辑器可以直接观察变量中的具体元素,可修改变量中的具体元素,也可用于创建大数组/矩阵。,2.1.3 内存变量的管理(续),clear命令用于删除MATLAB工作空间中的变量。who和whos这两个命令用于显示在MATLAB工作空间中已经驻留的变量名清单。who命令只显示出驻留变量的名称,whos在给出变量名的同时,还给出它们的大小

7、、所占字节数及数据类型等信息。,2内存变量文件(数据文件) 利用MAT文件可以把当前MATLAB工作空间中的一些有用变量长久地保留下来,扩展名是.mat。MAT文件的生成和装入由save和load命令来完成。常用格式为: save 文件名 变量名表 -append-ascii load 文件名 变量名表 -ascii 说明如下:,2.1.3 内存变量的管理(续),2.1.3 内存变量的管理(续),其中,文件名可以带路径,但不需带扩展名.mat,命令默认是对.mat文件进行操作。 变量名表中的变量个数不限,只要内存或文件中存在即可,变量名之间以空格分隔。 当变量名表省略时,保存或装入全部变量。

8、-ascii选项使文件以ASCII格式处理,省略该选项时文件将以二进制格式处理。save命令中的-append选项控制将变量追加到MAT文件中。,MATLAB提供的许多数学函数,其自变量规定为矩阵变量,运算法则是将函数逐项作用于矩阵的元素上,故运算的结果是与自变量同维数的矩阵。 例如,以下几个函数使用说明: (1) 三角函数以弧度为单位计算。 (2) abs函数可以求实数的绝对值、复数的模、字符串的ASCII码值。 (3) 用于取整的函数有fix、floor、ceil、round,详见说明帮助。 (4)求余函数 rem与mod函数。rem(x,y)和mod(x,y)要求x,y必须为相同大小的实

9、矩阵或为标量。,2.1.4 数学函数的数据操作,2.1.5 数据的输出格式,MATLAB用十进制数表示一个常数,具体可采用日常记数法和科学记数法两种表示方法。 在一般情况下,MATLAB内部每一个数据元素都是用双精度数来表示和存储的。数据输出时用户可以用format命令设置或改变数据输出格式。format命令的格式为: format 格式符 其中格式符决定数据的输出格式 前面已讲。,如果结果为整数,则显示没有小数;如果结果不是整数,则用户可以用format命令设置或改变输出格式。 短格式(Short):默认格式 1.3333 0.0000 短格式e方式(Short e):1.3333e+00

10、1.2345e-06 短格式g方式(Short g):1.3333 0.0 长格式(Long):1.33333333333333 0.00000123450000 长格式e方式(Long e):1.33333333333333e+00 1.2345000000000e-06 长格式g方式(Long g):1.33333333333333 0.0000012345 银行格式(Bank):1.33 0.00 十六进制格式(Hex):3ff555555555 3eb46231abfd71 +格式(+):+ 有理数(Rational):1/3 2469/2000000000,2.2 MATLAB矩阵,

11、2.2.1 矩阵的建立 1直接输入法 直接输入需遵循以下基本规则: 整个矩阵应以“ ”为首尾,即整个输入矩阵必须包含在方括号中; 矩阵中,行与行之间必须用分号“ ;”或Enter键(按Enter键)分隔; 每行中的元素用逗号“ ,”或空格分隔; 矩阵中的元素可以是数字或表达式,但表达式中不可包含未知的变量,MATLAB用表达式的值为该位置的矩阵元素赋值。 当矩阵中没有任何元素时,该矩阵被称作“ 空阵”(Empty Matrix)。,例2-2直接输入矩阵 A=1,2,3,4;5,6,7,8;9,10,11,12;13,14,15,16 A = 1 2 3 4 5 6 7 8 9 10 11 12

12、 13 14 15 16,利用表达式输入 B=1,sqrt(25),9,13 2,6,10,7*2 3+sin(pi),7,11,15 4,abs(-8),12,16 B = 1 5 9 13 2 6 10 14 3 7 11 15 4 8 12 16,2利用M文件建立矩阵 对于比较大且比较复杂的矩阵,可以为它专门建立一个M文件。下面通过一个简单例子来说明如何利用M文件创建矩阵。,2.2.1 矩阵的建立(续),3利用冒号表达式建立一个向量 冒号表达式可以产生一个行向量,一般格式是: e1:e2:e3 其中e1为初始值,e2为步长,e3为终止值。 在MATLAB中,还可以用linspace函数产

13、生行向量。其调用格式为: linspace(a,b,n) 其中a和b是生成向量的第一个和最后一个元素,n是元素总数。 显然,linspace(a,b,n)与a:(b-a)/(n-1):b等价。 4建立大矩阵 大矩阵可由方括号中的小矩阵或向量建立起来。(自学),2.2.1 矩阵的建立(续),1矩阵元素与引用 通过下标引用矩阵的元素,例如 命令 A(3,2)=200 采用矩阵元素的序号来引用矩阵元素。矩阵元素的序号就是相应元素在内存中的排列顺序。在MATLAB中,矩阵元素按列存储,先第一列,再第二列,依次类推。例如 A=1,2,3;4,5,6; 内存中依次存储为1,4,2,5,3,6. 则:命令:

14、A(3) ans = 2 显然,序号(Index)与下标(Subscript )是一一对应的。,2.2.2 矩阵的引用与拆分,2矩阵拆分 (1) 利用冒号表达式获得子矩阵 A(:,j)表示取A矩阵的第j列全部元素;A(i,:)表示A矩阵第i行的全部元素;A(i,j)表示取A矩阵第i行、第j列的元素。 A(i:i+m,:)表示取A矩阵第ii+m行的全部元素;A(:,k:k+m)表示取A矩阵第kk+m列的全部元素,A(i:i+m,k:k+m)表示取A矩阵第ii+m行内,并在第kk+m列中的所有元素。 此外,还可利用一般向量和end运算符来表示矩阵下标,从而获得子矩阵。end表示某一维的末尾元素下标

15、。 例:A(m:end, n)表示提取从第m行到最末行和第n列的子块。,2.2.2 矩阵的引用与拆分(续),(2) 利用空矩阵删除矩阵的元素 在MATLAB中,定义为空矩阵。给变量X赋空矩阵的语句为X=。注意,X=与clear X不同,clear是将X从工作空间中删除,而空矩阵则存在于工作空间中,只是维数为0。,2.2.2 矩阵的引用与拆分(续),MATLAB中矩阵和数组的区别,1通用的特殊矩阵 常用的产生通用特殊矩阵的函数有: zeros:产生全0矩阵(零矩阵)。 ones:产生全1矩阵(幺矩阵)。 eye:产生单位矩阵。 rand:产生01间均匀分布的随机矩阵。 randn:产生均值为0,

16、方差为1的标准正态分布随机矩阵。,2.2.3 特殊矩阵,例2-3 分别建立33、32和与矩阵A同样大小的零矩阵。 (1) 建立一个33零矩阵。 zeros(3) (2) 建立一个32零矩阵。 zeros(3,2) (3) 设A为23矩阵,则可以用zeros(size(A)建立一个与矩阵A同样大小零矩阵。 A=1 2 3;4 5 6; %产生一个23阶矩阵A zeros(size(A) %产生一个与矩阵A同样大小的零矩阵。,例2-4 建立随机矩阵: (1) 在区间20,50内均匀分布的5阶随机矩阵。 (2) 均值为0.6、方差为0.1的5阶正态分布随机矩阵。 命令如下: x=20+(50-20)

17、*rand(5) y=0.6+sqrt(0.1)*randn(5) 此外,常用的函数还有reshape(A,m,n),它在矩阵总元素保持不变的前提下,按列将矩阵A重新排成mn的二维矩阵。,2.2.3 特殊矩阵(续),2用于专门学科的特殊矩阵 (1) 魔方矩阵 魔方矩阵有一个有趣的性质,其每行、每列及两条对角线上的元素和都相等。对于n阶魔方阵,其元素由1,2,3,n2共n2个整数组成。 MATLAB提供了求魔方矩阵的函数magic(n),其功能是生成一个n阶魔方阵。,例2-5 将101125等25个数填入一个5行5列的表格中,使其每行每列及对角线的和均为565。 M=100+magic(5),2

18、.2.3 特殊矩阵(续),(2) 范得蒙矩阵 范得蒙(Vandermonde)矩阵最后一列全为1,倒数第二列为一个指定的向量,其他各列是其前列与倒数第二列的点乘积。可以用一个指定向量生成一个范得蒙矩阵。在MATLAB中,函数vander(V)生成以向量V为基础向量的范得蒙矩阵。例如,A=vander(1;2;3;5)即可得到上述范得蒙矩阵。,2.2.3 特殊矩阵(续),(3) 希尔伯特矩阵 在MATLAB中,生成希尔伯特矩阵的函数是hilb(n)。 使用一般方法求逆会因为原始数据的微小扰动而产生不可靠的计算结果。MATLAB中,有一个专门求希尔伯特矩阵的逆的函数invhilb(n),其功能是求

19、n阶的希尔伯特矩阵的逆矩阵。,例2-6 求4阶希尔伯特矩阵及其逆矩阵。 命令如下: format rat %以有理形式输出 H=hilb(4) H=invhilb(4),2.2.3 特殊矩阵(续),(4) 托普利兹矩阵 托普利兹(Toeplitz)矩阵除第一行第一列外,其他每个元素都与左上角的元素相同。 函数toeplitz(x,y)生成托普利兹矩阵的,它生成一个以x为第一列,y为第一行的托普利兹矩阵,x, y均为向量,不必等长。toeplitz(x)用向量x生成一个对称的托普利兹阵。例如 T=toeplitz(1:6) T = 1 2 3 4 5 6 2 1 2 3 4 5 3 2 1 2

20、3 4 4 3 2 1 2 3 5 4 3 2 1 2 6 5 4 3 2 1,2.2.3 特殊矩阵(续),(5) 伴随矩阵 MATLAB生成伴随矩阵的函数是compan(p),其中p是一个多项式的系数向量,高次幂系数排在前,低次幂排在后。 例如:为了求多项式的x3-7x+6的伴随矩阵,可使用命令: p=1,0,-7,6; compan(p) ans = 0 7 -6 1 0 0 0 1 0,2.2.3 特殊矩阵(续),(6) 帕斯卡矩阵 二次项(x+y)n展开后的系数随n的增大组成一个三角形表,称为杨辉三角形。由杨辉三角形表组成的矩阵称为帕斯卡(Pascal)矩阵。函数pascal(n)生成

21、一个n阶帕斯卡矩阵。,例2-7 求(x+y)5的展开式。 在MATLAB命令窗口,输入命令: pascal(6) 矩阵反对角线上的元素1,5,10,10,5,1即为展开式的系数。 ans = 1 1 1 1 1 1 1 2 3 4 5 6 1 3 6 10 15 21 1 4 10 20 35 56 1 5 15 35 70 126 1 6 21 56 126 252,2.3 MATLAB运算,2.3.1算术运算 1基本算术运算 MATLAB的基本算术运算有:(加)、(减)、*(乘)、/(右除)、(左除)、(乘方)、 (矩阵转置运算符)。 注意,运算是在矩阵意义下进行的,单个数据的算术运算只是

22、一种特例。,2.3.1 算术运算(续),(1) 矩阵加减运算 假定有两个矩阵A和B,则可以由A+B和A-B实现矩阵的加减运算。运算规则是:若A和B矩阵的维数相同,则可以执行矩阵的加减运算,A和B矩阵的相应元素相加减。如果A与B的维数不相同,则MATLAB将给出错误信息,提示用户两个矩阵的维数不匹配。,2.3.1 算术运算(续),(2) 矩阵乘法 假定有两个矩阵A和B,若A为mn矩阵,B为np矩阵,则C=A*B为mp矩阵。,(3) 矩阵除法 在MATLAB中,有两种矩阵除法运算:和/,分别表示左除和右除。如果A矩阵是非奇异方阵,则AB和B/A运算可以实现。AB等效于A的逆左乘B矩阵,也就是inv

23、(A)*B,而B/A等效于A的逆矩阵右乘B矩阵,也就是B*inv(A)。 对于含有标量的运算,两种除法运算的结果相同,如3/4和43有相同的值,都等于0.75。又如,设a=10.5,25,则a/5=5a=2.1000 5.0000。对于矩阵来说,左除和右除表示两种不同的除数矩阵和被除数矩阵的关系。对于矩阵运算,一般ABB/A。,2.3.1 算术运算(续),例:用左除求解线性方程组,2.3.1 算术运算(续),(4) 矩阵的乘方 一个矩阵的乘方运算可以表示成Ax,要求A为方阵,x为标量。,2.3.1 算术运算(续),2点运算 在MATLAB中,有一种特殊的运算,因为其运算符是在有关算术运算符前面

24、加点,所以叫点运算。点运算符有.*、./、.和.。两矩阵进行点运算是指它们的对应元素进行相关运算,要求两矩阵的维、参数相同。 点运算实际是一种元素对元素的运算。,2.3.1 算术运算(续),例: x=1 2 3; 4 5 6; 7 8 9; y=9 8 7; 6 5 4; 3 2 1; x+y %数组和矩阵的加法规则相同 ans = 10 10 10 10 10 10 10 10 10 x.*y %数组乘法:对应元素相乘 ans = 9 16 21 24 25 24 21 16 9 x*y %矩阵乘法:按照矩阵理论进行 ans = 30 24 18 84 69 54 138 114 90,2.

25、3.1 算术运算(续),3. 向量的乘法运算函数 1)点积:dot函数 2)叉积:cross函数 例: a = 1 2 3; b = 4 5 6; c = dot(a, b) d = cross(a, b) c = 32 d = -3 6 -3,2.3.2 关系运算,MATLAB提供了6种关系运算符:(大于)、=(大于或等于)、=(等于)、=(不等于)。它们的含义不难理解,但要注意其书写方法与数学中的不等式符号不尽相同。,2.3.2 关系运算(续),关系运算符的运算法则为: (1) 当两个比较量是标量时,直接比较两数的大小。若关系成立,关系表达式结果为1,否则为0。 (2) 当参与比较的量是两

26、个维数相同的矩阵时,比较是对两矩阵相同位置的元素按标量关系运算规则逐个进行,并给出元素比较结果。最终的关系运算的结果是一个维数与原矩阵相同的矩阵,它的元素由0或1组成。,2.3.2 关系运算(续),(3) 当参与比较的一个是标量,而另一个是矩阵时,则把标量与矩阵的每一个元素按标量关系运算规则逐个比较,并给出元素比较结果。最终的关系运算的结果是一个维数与原矩阵相同的矩阵,它的元素由0或1组成。,例2-8 产生5阶随机方阵A,其元素为10,90区间的随机整数,然后判断A的元素是否能被3整除。 (1) 生成5阶随机方阵A。 A=fix(90-10+1)*rand(5)+10) (2) 判断A的元素是

27、否可以被3整除。 P= rem(A,3)= =0 其中,rem(A,3)是矩阵A的每个元素除以3的余数矩阵。此时,0被扩展为与A同维数的零矩阵,P是进行等于(= =)比较的结果矩阵。,MATLAB提供了3种逻辑运算符:&(与)、|(或)和(非)。 逻辑运算的运算法则为: (1) 在逻辑运算中,确认非零元素为真,用1表示,零元素为假,用0表示。 (2) 设参与逻辑运算的是两个标量a和b,那么, a&b a,b全为非零时,运算结果为1,否则为0。 a|b a,b中只要有一个非零,运算结果为1。 a 当a是零时,运算结果为1;当a非零时,运算结果为0。,2.3.3 逻辑运算,2.3.3 逻辑运算(续

28、),(3) 若参与逻辑运算的是两个同维矩阵,那么运算将对矩阵相同位置上的元素按标量规则逐个进行。最终运算结果是一个与原矩阵同维的矩阵,其元素由1或0组成。 (4) 若参与逻辑运算的一个是标量,一个是矩阵,那么运算将在标量与矩阵中的每个元素之间按标量规则逐个进行。最终运算结果是一个与矩阵同维的矩阵,其元素由1或0组成。,2.3.3 逻辑运算(续),(5) 逻辑非是单目运算符,也服从矩阵运算规则。 (6) 在算术、关系、逻辑运算中,算术运算优先级最高,逻辑运算优先级最低。 MATLAB提供了一些逻辑函数,例2-9 建立矩阵A,然后找出大于4的元素的位置。 (1) 建立矩阵A。 A=4,-65,-5

29、4,0,6;56,0,67,-45,0 (2) 找出大于4的元素的位置。 find(A4),2.3.4 数值运算中部分常用数学函数,2.4 矩阵分析,常用简单矩阵函数,2.4 矩阵分析(续),2.4.1 对角阵与三角阵 1对角阵 只有对角线上有非0元素的矩阵称为对角矩阵,对角线上的元素相等的对角矩阵称为数量矩阵,对角线上的元素都为1的对角矩阵称为单位矩阵。,提取矩阵的对角线元素 设A为mn矩阵,diag(A)函数用于提取矩阵A主对角线元素,产生一个具有min(m,n)个元素的列向量。 diag(A)函数还有一种形式diag(A,k),其功能是提取第k条对角线的元素。 构造对角矩阵 设V为具有m

30、个元素的向量,diag(V)将产生一个mm对角矩阵,其主对角线元素即为向量V的元素。 diag(V)函数也有另一种形式diag(V,k),其功能是产生一个nn(n=m+k)对角阵,其第k条对角线的元素即为向量V的元素。,2.4.1 对角阵与三角阵(续),例2-10 先建立55矩阵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的每行乘以一个指定常数,2.4.1 对角阵与三角阵(续),2三

31、角阵 三角阵又进一步分为上三角阵和下三角阵,所谓上三角阵,即矩阵的对角线以下的元素全为0的一种矩阵,而下三角阵则是对角线以上的元素全为0的一种矩阵。,上三角矩阵 求矩阵A的上三角阵的MATLAB函数是triu(A)。 triu(A)函数也有另一种形式triu(A,k),其功能是求矩阵A的第k条对角线以上的元素。例如,提取矩阵A的第2条对角线以上的元素,形成新的矩阵B。 下三角矩阵 在MATLAB中,提取矩阵A的下三角矩阵的函数是tril(A)和tril(A,k),其用法与提取上三角矩阵的函数triu(A)和triu(A,k)完全相同。,2.4.1 对角阵与三角阵(续),2.4.2 矩阵的转置与

32、旋转,1矩阵的转置 转置运算符是单撇号( )。 2矩阵的旋转 利用函数rot90(A,k)将矩阵A逆时针旋转90的k倍,当k为1时可省略。,3矩阵的左右翻转 对矩阵实施左右翻转是将原矩阵的第一列和最后一列调换,第二列和倒数第二列调换,依次类推。MATLAB对矩阵A实施左右翻转的函数是fliplr(A)。 4矩阵的上下翻转 MATLAB对矩阵A实施上下翻转的函数是 flipud(A)。,2.4.2 矩阵的转置与旋转(续),1矩阵的逆 对于一个方阵A,如果存在一个与其同阶的方阵B,使得: AB=BA=I (I为单位矩阵) 则称B为A的逆矩阵,当然,A也是B的逆矩阵。 求一个矩阵的逆是一件非常烦琐的

33、工作,容易出错,但在MATLAB中,求一个矩阵的逆非常容易。求方阵A的逆矩阵可调用函数inv(A)。 例2-11 用求逆矩阵的方法解线性方程组。 Ax=b 其解为:x=A-1b,2.4.3 矩阵的逆与伪逆,2矩阵的伪逆 如果矩阵A不是一个方阵,或者A是一个非满秩的方阵时,矩阵A没有逆矩阵,但可以找到一个与A的转置矩阵A同型的矩阵B,使得: ABA=A BAB=B 此时称矩阵B为矩阵A的伪逆,也称为广义逆矩阵。在MATLAB中,求一个矩阵伪逆的函数是pinv(A)。,2.4.3 矩阵的逆与伪逆(续),2.4.4 方阵的行列式,把一个方阵看作一个行列式,并对其按行列式的规则求值,这个值就称为矩阵所

34、对应的行列式的值。在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):计算向量

35、V的2-范数。 (2) norm(V,1):计算向量V的1-范数。 (3) norm(V,inf ):计算向量V的-范数。 2矩阵的范数及其计算函数 MATLAB提供了求3种矩阵范数的函数,其函数调用格式与求向量的范数的函数完全相同。,2.4.6 向量和矩阵的范数(续),在MATLAB中,计算矩阵A的3种条件数的函数是: (1) cond(A,1) 计算A的1-范数下的条件数。 (2) cond(A)或cond(A,2) 计算A的2-范数数下的条件数。 (3) cond(A,inf) 计算A的 -范数下的条件数。,2.4.7 矩阵的条件数,在MATLAB中,计算矩阵A的特征值和特征向量的函数是

36、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.4.8 矩阵的特征值与特征向量,例2-12 用求特征值的方法解方程。 3x5-7x4+5x2+2x-18=0 p=3,-7,0,5,2,-18; A=compan(p); %A的伴随矩阵 x1=eig(A) %求A的特征值 x

37、2=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)的计

38、算结果一样。,2.5 矩阵的超越函数(续),上机练习与指导,工作空间与内存变量 变量的查看 变量的文件保存与获取,应用举例,应用举例,提 示,学好计算机的唯一途径是 你的编程能力与你在计算机上投入的时间成,上机练习,正比,MATLAB中,字符串是用单撇号括起来的字符序列。 MATLAB将字符串当作一个行向量,每个元素对应一个字符,其标识方法和数值向量相同。也可以建立多行字符串矩阵。 字符串是以ASCII码形式存储的。abs和double函数都可以用来获取字符串矩阵所对应的ASCII码数值矩阵。相反,char函数可以把ASCII码矩阵转换为字符串矩阵。,2.6 字符串,例2-13 建立一个字符串

39、向量,然后对该向量做如下处理: (1) 取第15个字符组成的子字符串。 (2) 将字符串倒过来重新排列。 (3) 将字符串中的小写字母变成相应的大写字母,其余字符不变。 (4) 统计字符串中小写字母的个数。,命令如下: ch=ABc123d4e56Fg9; subch=ch(1:5) %取子字符串 revch=ch(end:-1:1) %将字符串倒排 k=find(ch=a %将小写字母变成相应的大写字母 char(ch) length(k) %统计小写字母的个数,与字符串有关的另一个重要函数是eval,其调用格式为: eval(t) 其中t为字符串。它的作用是把字符串的内容作为对应的MATL

40、AB语句来执行。,上机练习,第一讲上机练习 本节例题,2.7.1 结构数据(结构体/结构矩阵) 1结构矩阵的建立与引用 结构矩阵的元素可以是不同的数据类型,它能将一组具有不同属性的数据纳入到一个统一的变量名下进行管理。建立一个结构矩阵可采用给结构成员赋值的办法。具体格式为: 结构矩阵名.成员名=表达式 其中表达式应理解为矩阵表达式。,2.7 结构数据和单元数据,2结构成员的修改 可以根据需要增加或删除结构的成员。例如要给结构矩阵a增加一个成员x4,可给a中任意一个元素增加成员x4: a(1).x4=410075; 但其他成员均为空矩阵,可以使用赋值语句给它赋确定的值。 要删除结构的成员,则可以

41、使用rmfield函数来完成。例如,删除成员x4: a=rmfield(a,x4); 3关于结构的函数 除了一般的结构数据的操作外,MATLAB还提供了部分函数来进行结构矩阵的操作,如struct等(自学)。,2.7.1 结构数据(续),例:建立温室数据,包含温室名、容积、温度、湿度等 1)建立11的结构数组 Green_house.name=no.1 green house.; Green_house.volume=2000 m3; Green_house.parameter.temperature=31.2,30.4,31.6,28.7,29,31,30,29.6; Green_house

42、.parameter.humidity=62,59,57,61,62,61,59,57; 注:此处结构体的域parameter又有2个子域。,2) 显示该结构数据的结构和内容 Green_house % display the structure of the structure array. Green_house.parameter %display the content of the parameter region of the structure array. Green_house.parameter.temperature %display the content of the

43、 temperature gegion of the structure array. 3)增加/删除成员:光照度“sunlight” Green_house.sunlight=72,59,57,71,72,71,59,67; %add in. Green_house=rmfield(Green_house,sunlight); % delete.,如同银行的保险箱库。 1单元矩阵的建立与引用 建立单元矩阵和一般矩阵相似,只是矩阵元素用大括号括起来。 可以用带有大括号下标的形式引用单元矩阵元素。例如b3,3。单元矩阵的元素可以是结构体或单元数据。 可以使用celldisp函数来显示整个单元矩阵

44、,如celldisp(b)。还可以删除单元矩阵中的某个元素。 2关于单元的函数 MATLAB还提供了部分函数用于单元的操作,如cell创建单元数组、deal调取元素(自学)。,2.7.2 单元数据(cell data/cell array),例:建立22的cell array,% 给出cell数组的各个元素 C_str=char(this is, an example of cell array.); % give a character string. R=reshape(1:9,3,3); %give a 33 matrix. Cn=1+2i; % give a complex value

45、. Ss=sym(sin(-3*t)*exp(-t); %give a symbolic function. % 建立cell数组A法一 A(1,1)=C_str; A(1,2)=R; A(2,1)=Cn; A(2,2)=Ss; A % display the cell array.,建立cell数组A法二 A1,1=C_str; A1,2=R; A2,1=Cn; A2,2=Ss; celldisp(A) % display the A array. 删除cell数组A中的元素 A(2,:)=; % 删除第二行。 扩充cell数组A中的元素 %设C为已有的CELL数组,扩充后数组为AC。 AC

46、=A;C; %行扩充 AC=A C; % 列扩充。,2.8 稀疏矩阵,2.8.1 矩阵存储方式 MATLAB的矩阵有两种存储方式:完全存储方式和稀疏存储方式。 1完全存储方式 完全存储方式是将矩阵的全部元素按列存储。以前讲到的矩阵的存储方式都是按这个方式存储的,此存储方式对稀疏矩阵也适用。,2稀疏存储方式 稀疏存储方式仅存储矩阵所有的非零元素的值及其位置,即行号和列号。在MATLAB中,稀疏存储方式也是按列存储的。 注意,在讲稀疏矩阵时,有两个不同的概念,一是指矩阵的0元素较多,该矩阵是一个具有稀疏特征的矩阵,二是指采用稀疏方式存储的矩阵。,2.8.1 矩阵存储方式(续),1将完全存储方式转化

47、为稀疏存储方式 函数A=sparse(S)将矩阵S转化为稀疏存储方式的矩阵A。当矩阵S是稀疏存储方式时,则函数调用相当于A=S。 sparse函数还有其他一些调用格式: sparse(m,n):生成一个mn的所有元素都是0的稀疏矩阵。 sparse(u,v,S) :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.8.2 稀疏存储方式的产生,2产生稀疏存储矩阵 只把要建立的稀疏矩阵的非0元素及其所在行和列的位置表示出来后由MATLAB自己产生其稀疏存储,这需要使用spconvert函数。调用格式为: B=

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1