《矩阵及其基本运算》PPT课件.ppt

上传人:sh****n 文档编号:12752865 上传时间:2020-05-22 格式:PPT 页数:68 大小:208.50KB
返回 下载 相关 举报
《矩阵及其基本运算》PPT课件.ppt_第1页
第1页 / 共68页
《矩阵及其基本运算》PPT课件.ppt_第2页
第2页 / 共68页
《矩阵及其基本运算》PPT课件.ppt_第3页
第3页 / 共68页
点击查看更多>>
资源描述
本章内容:变量类型;基本表达式;数据类型;运算符与操作符;关系运算与逻辑运算;三种程序结构;程序流控制语句;两种M文件;M文件的调试。矩阵创建、保存和提取方法;矩阵元素标识、矩阵函数、矩阵运算、数组运算、数组函数、数据的输出。,第二章矩阵及其基本运算,本章练习:表达式、流程控制练习;矩阵基本运算练习,一、变量和数据操作,1.变量变量命名在MATLAB6.5中,变量名是以字母开头,后接字母、数字或下划线的字符序列,最多63个字符。在MATLAB中,变量名区分字母的大小写。,2赋值语句(1)变量=表达式(2)表达式其中表达式是用运算符将有关运算量连接起来的式子,其结果是一个矩阵。,例2-1计算表达式的值,并显示计算结果。在MATLAB命令窗口输入命令:x=(0:0.1:10000).*pi./360;y1=sin(x);y2=sin(1.05*x);y3=sin(0.1*x);y4=sin(5*x);plot(x,y1+y2);plot(x,y3.*y4);,拍现象,信号调制,3.预定义变量,在MATLAB工作空间中,还驻留几个由系统本身定义的变量。例如,用pi表示圆周率的近似值,用i,j表示虚数单位。预定义变量有特定的含义,在使用时,应尽量避免对这些变量重新赋值。,二、MATLAB常用数学函数,MATLAB提供了许多数学函数,函数的自变量规定为矩阵变量,运算法则是将函数逐项作用于矩阵的元素上,因而运算的结果是一个与自变量同维数的矩阵。,函数使用说明:(1)三角函数以弧度为单位计算。(2)abs函数可以求实数的绝对值、复数的模、字符串的ASCII码值。(3)用于取整的函数有fix、floor、ceil、round,要注意它们的区别。(4)rem与mod函数的区别。rem(x,y)和mod(x,y)要求x,y必须为相同大小的实矩阵或为标量。,三、矩阵的建立和引用,1矩阵的建立直接输入法最简单的建立矩阵的方法是从键盘直接输入矩阵的元素。具体方法如下:将矩阵的元素用方括号括起来,按矩阵行的顺序输入各元素,同一行的各元素之间用空格或逗号分隔,不同行的元素之间用分号分隔。,利用冒号表达式建立一个向量冒号表达式可以产生一个行向量,一般格式是: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等价。,2.引用矩阵的元素,通过下标引用矩阵的元素,例如A(3,2)=200采用矩阵元素的序号来引用矩阵元素。矩阵元素的序号就是相应元素在内存中的排列顺序。在MATLAB中,矩阵元素按列存储,先第一列,再第二列,依次类推。例如A=1,2,3;4,5,6;A(3)ans=2显然,序号(Index)与下标(Subscript)是一一对应的,以mn矩阵A为例,矩阵元素A(i,j)的序号为(j-1)*m+i。其相互转换关系也可利用sub2ind和ind2sub函数求得。,3矩阵拆分(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表示某一维的末尾元素下标。,4.特殊矩阵的生成常用的产生通用特殊矩阵的函数有:zeros:产生全0矩阵(零矩阵)。ones:产生全1矩阵(幺矩阵)。eye:产生单位矩阵。rand:产生01间均匀分布的随机矩阵。randn:产生均值为0,方差为1的标准正态分布随机矩阵。,例2-2分别建立33、32和与矩阵A同样大小的零矩阵。(1)建立一个33零矩阵。zeros(3)(2)建立一个32零矩阵。zeros(3,2)(3)设A为23矩阵,则可以用zeros(size(A)建立一个与矩阵A同样大小零矩阵。A=123;456;%产生一个23阶矩阵Azeros(size(A)%产生一个与矩阵A同样大小的零矩阵,例2-3建立随机矩阵:(1)在区间20,50内均匀分布的5阶随机矩阵。(2)均值为0.6、方差为0.1的5阶正态分布随机矩阵。命令如下:x=20+(50-20)*rand(5)y=0.6+sqrt(0.1)*randn(5),用于专门学科的特殊矩阵(1)魔方矩阵魔方矩阵有一个有趣的性质,其每行、每列及两条对角线上的元素和都相等。对于n阶魔方阵,其元素由1,2,3,n2共n2个整数组成。MATLAB提供了求魔方矩阵的函数magic(n),其功能是生成一个n阶魔方阵。,例2-5将101125等25个数填入一个5行5列的表格中,使其每行每列及对角线的和均为565。M=100+magic(5),(2)帕斯卡矩阵我们知道,二次项(x+y)n展开后的系数随n的增大组成一个三角形表,称为杨辉三角形。由杨辉三角形表组成的矩阵称为帕斯卡(Pascal)矩阵。函数pascal(n)生成一个n阶帕斯卡矩阵。,例2-7求(x+y)5的展开式。在MATLAB命令窗口,输入命令:pascal(6)矩阵次对角线上的元素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为mn矩阵,B为np矩阵,则C=A*B为mp矩阵。,(3)矩阵除法在MATLAB中,有两种矩阵除法运算:和/,分别表示左除和右除。如果A矩阵是非奇异方阵,则AB和B/A运算可以实现。AB等效于A的逆左乘B矩阵,也就是inv(A)*B,而B/A等效于A矩阵的逆右乘B矩阵,也就是B*inv(A)。对于含有标量的运算,两种除法运算的结果相同,如3/4和43有相同的值,都等于0.75。又如,设a=10.5,25,则a/5=5a=2.10005.0000。对于矩阵来说,左除和右除表示两种不同的除数矩阵和被除数矩阵的关系。对于矩阵运算,一般ABB/A。,(4)矩阵的乘方一个矩阵的乘方运算可以表示成Ax,要求A为方阵,x为标量。,2点运算在MATLAB中,有一种特殊的运算,因为其运算符是在有关算术运算符前面加点,所以叫点运算。点运算符有.*、./、.和.。两矩阵进行点运算是指它们的对应元素进行相关运算,要求两矩阵的维参数相同。,3.关系运算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是进行等于(=)比较的结果矩阵。,4.逻辑运算MATLAB提供了3种逻辑运算符:56,0,67,-45,0(2)找出大于4的元素的位置。find(A4),5.矩阵的转置与旋转矩阵的转置转置运算符是单撇号()。矩阵的旋转利用函数rot90(A,k)将矩阵A旋转90的k倍,当k为1时可省略。,6矩阵的翻转,矩阵的左右翻转对矩阵实施左右翻转是将原矩阵的第一列和最后一列调换,第二列和倒数第二列调换,依次类推。MATLAB对矩阵A实施左右翻转的函数是fliplr(A)。矩阵的上下翻转MATLAB对矩阵A实施上下翻转的函数是flipud(A)。,五、字符串,在MATLAB中,字符串是用单撇号括起来的字符序列。MATLAB将字符串当作一个行向量,每个元素对应一个字符,其标识方法和数值向量相同。也可以建立多行字符串矩阵。,字符串是以ASCII码形式存储的。abs函数可以用来获取字符串矩阵所对应的ASCII码数值矩阵。相反,char函数可以把ASCII码矩阵转换为字符串矩阵。,例2-13建立一个字符串向量,然后对该向量做如下处理:(1)取第15个字符组成的子字符串。(2)将字符串倒过来重新排列。(3)将字符串中的小写字母变成相应的大写字母,其余字符不变。(4)统计字符串中小写字母的个数。,命令如下:ch=ABc123d4e56Fg9;subch=ch(1:5)%取子字符串revch=ch(end:-1:1)%将字符串倒排k=find(ch=a%将小写字母变成相应的大写字母char(ch)length(k)%统计小写字母的个数,六、结构数据和单元数据,结构数据结构矩阵的建立与引用结构矩阵的元素可以是不同的数据类型,它能将一组具有不同属性的数据纳入到一个统一的变量名下进行管理。建立一个结构矩阵可采用给结构成员赋值的办法。具体格式为:结构矩阵名.成员名=表达式其中表达式应理解为矩阵表达式。,结构成员的修改可以根据需要增加或删除结构的成员。例如要给结构矩阵a增加一个成员x4,可给a中任意一个元素增加成员x4:a(1).x4=410075;但其他成员均为空矩阵,可以使用赋值语句给它赋确定的值。要删除结构的成员,则可以使用rmfield函数来完成。例如,删除成员x4:a=rmfield(a,x4);,2单元数据单元矩阵的建立与引用建立单元矩阵和一般矩阵相似,只是矩阵元素用大括号括起来。可以用带有大括号下标的形式引用单元矩阵元素。例如b3,3。单元矩阵的元素可以是结构或单元数据。可以使用celldisp函数来显示整个单元矩阵,如celldisp(b)。还可以删除单元矩阵中的某个元素。,七.M文件的编辑与调试,用MATLAB的程序文件是以.m为扩展名的文本文件,称为M文件。其语句的执行相当于依次在命令窗口输入相应的命令.M文件中,说明性的文字(注释)用%开头,用Help命令可以显示说明文字的内容,例Hello.m%programhello.m%Hello,Students!%Goodmorning!%Studyhardandmakeprogresseveryday!%Goodgoodstudy,daydayup!%,上段程序运行结果:无任何显示.将%Hello,Students!修改成disp(Hello,Students!)重新运行,理解注释的作用,注意编程风格:必要的注释;分进缩写;模块化;做研究笔记,记下各个文件的功能及注意事项.,八.文件内容的输入与修改,输入修改保存程序的调试,九.流程控制之循环结构,For循环语法:for循环变量=初值:步长:终值循环体end,例:连加算法,%multiplus1.ms=0fori=1:1000s=s+I;endsprintf(s=%d,s),例:累乘算法,%multitime1.mp=1;forn=1:1:10p=p*n;endsprintf(p=%dn,p),例:连加算法和累乘算法的合用:求e的值。,%programee1.m%GivestheexpnumbereE=1;forn=1:100p=1;form=1:np=p*m;endE=E+1/p;endsprintf(p=%fn,p),例:在非线性物理中的应用举例。画出logistic映射图,迭代函数:,%programebug.m虫口模型x=0.6;u=2.6:0.001:4;forj=1:150%迭代150次可稳定x=u.*(x-x.2);endfori=1:100 x=u.*(x-x.2);plot(u,x,r,marker,.,markersize,1);holdonend,3.流程控制之循环结构,(2)While循环语法:while条件表达式循环体语句end,while语句的一般格式为:while(条件)循环体语句end,例:用While循环实现连加算法,%multiplus1.ms=0fori=1:1000s=s+i;endsprintf(s=%d,s),%multiplus2.ms=0;N=1;Whilen=1000s=s+n;n=n+1;endsprintf(s=%d,s),十.流程控制之分支结构,(1)if-else-end语句语法:if逻辑表达式语句体1else语句体2end说明:当条件成立时,执行语句组1,否则执行语句组2。,扩展:,精简:,例:分段函数的取值,x=input(请输入x的值:);ifx=0y=(x+sqrt(pi)/exp(2);elsey=log(x+sqrt(1+x*x)/2;endy,(2)switch-case语句switch语句根据表达式的取值不同,分别执行不同的语句,其语句格式为:switch表达式case值1语句组1case值2语句组2case值m语句组motherwise语句组nend,十一.数据的输入输出,(1)键盘输入数据从键盘输入数据,可以用函数input实现.格式:A=input(提示信息,选项);,字符串,s时,输入为字符串,无此项时为数值.,例:,Xm=input(whatsyourname?,s);,(2)在命令窗口输出数据disp函数可提供在命令窗口输出数据的功能.格式:disp(输出项),可以是矩阵,也可以是字符串.有多项时用方括号括起.,例程:求一元二次方程的根,a=input(a=?);b=input(b=?);c=input(c=?);d=b*b-4*a*c;x=(-b+sqrt(d)/(2*a),(-b-sqrt(d)/(2*a);disp(x1=,num2str(x(1),x1=,num2str(x(2),(3)磁盘文件的打开与关闭打开文件语法:fid=fopen(filename,permission);,文件标识符(内存变量名),磁盘文件名,打开模式r读模式w写模式,(3)磁盘文件的打开与关闭关闭文件语法:fclose(fid);,例:打开一个文件,准备写入数据.,x=0:0.2:2;y=x;2*exp(x);fid=fopen(test1.txt,w)%fprintf(fid,%6.2f%12.8fn,y);fclose(fid);,(4)磁盘文件的写入命令fprintf语法:count=fprintf(fid,format,A,),(4)磁盘文件的读出命令fscanf语法:A,count=fscanf(fid,format,size)例:fid=fopen(test1.txt,r);A,c=fprintf(fid,%f%f,32);,十二.模块化的程序设计:函数文件,(1)函数文件的建立函数文件由function语句引导,其基本结构为Function输出形参表=函数名(输入形参表)注释说明部分函数体部分.例:利用函数文件实现直角坐标与极坐标之间的转换.,函数文件tran.mfunctionrho,theta=tran(x,y)rho=sqrt(x*x+y*y);theta=atan(y/x);,(2)函数文件的调用保证所建函数文件在搜索路径中,即可直接调用之.例:用main1.m调用tran.mx=input(pleaseinputx=);y=input(pleaseinputy=);rho,the=tran(x,y);rhothe,作业:P931,2学习小组:三人一组,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!