MATLAB解方程和函数极值.ppt
《MATLAB解方程和函数极值.ppt》由会员分享,可在线阅读,更多相关《MATLAB解方程和函数极值.ppt(52页珍藏版)》请在三一办公上搜索。
1、第三讲解方程与函数极值,方程问题和极值问题始终是数学问题中的核心问题!,学习内容,多项式运算线性方程组求解非线性方程数值求解常微分方程初值问题的数值解法函数极值线性插值,(一)多项式的表示方法,对于多项式的表达式约定如下对于多项式对于上述多项式一般用以下行向量表示,(二)多项式的创建,1.系数向量直接输入法由于MATLAB中多项式是以向量形式存储的,因此最简单的多项式输入即向量输入。例:输入多项式p=1-5 6-33;poly2sym(p)%此函数将多项式转换换为符号多项式,(二)多项式的创建,2.特征多项式输入法 多项式创建的另一途径是从矩阵求其特征多项式获得,由函数poly实现例如:a=1
2、 2 3;2 3 4;3 4 5p1=poly(a)%矩阵a对应的特征多项式poly2sym(p1)%将多项式p1转换为符号多 项式,(二)多项式的创建,3.由根创立多项式 给定的根也可产生其相应的多项式,此功能还是由函数poly实现例:root=-5-3+4i-3-4i;p=poly(root)poly2sym(p)注:若要生成实系数多项式,则根中的复数比为对称共轭复数,(三)多项式运算,1.求多项式的值求多项式的值可以由两种形式(1)输入变量值代入多项式计算时是以数组为单元的,此时函数为polyval(2)以矩阵为计算单元,进行矩阵式运算以求的多项式的值,此时的函数为polyvalm注:这
3、两种计算在数值上由很大差别。当进行矩阵运算时,变量矩阵须为方阵。,实例演示,p=1 11 55 125;b=1 1;1 1;c=5poly2sym(p)polyval(p,b)poly(p,c)polyvalm(p,b),(三)多项式运算,2.求多项式的根求多项式的根可以由两种方法(1)直接调用MATLAB的函数roots求解多项式的所有根(2)通过建立多项式的伴随矩阵再求其特征值的方法得到多项式的所有根,实例演示,用两种方法解方程 的所有根p=2-5 6-1 9;roots(p)a=compan(p)%求多项式的特征矩阵eig(a)%求特征矩阵a的特征根,(三)多项式运算,3.多项式的乘除法
4、(1)多项式的乘法由函数conv来实现,此函数同用于向量的卷积(2)多项式的除法由函数deconv来实现,此函数与向量的解卷函数相同,实例演示,计算两多项式的乘除法p=2-5 6-1 9;poly2sym(p);d=3-90-18;ploy2sym(d)pd=conv(p,d)%多项式p与d相乘poly2sym(pd)pl=deconv(pd,d)%多项式pd除以d,(三)多项式运算,4.多项式微分多项式的微分可以用函数polyer进行例:p=2-5 6-1 9;poly2sym(p);Dp=polyer(p),(三)多项式运算,5.多项式的拟合 多项式拟合是多项式运算的一个重要组成部分,在工
5、程及科研工作中得到了广泛的应用,其一方面可以由矩阵的除法解超定方程来进行;另一方面在MATLAB中还提供了专门的拟合函数polyfit,其调用格式如下:(1)polyfit(X,Y,n)%其中X,Y为拟合数据,n为你和多项式的阶数(2)p,s=polyfit(X,Y,n)%其中p为拟合多项式的系数向量,s为拟合多项式系数向量的结构信息,实例演示,例:用五阶多项式对0,pi/2上的正弦函数进行最小二乘拟合x=0:pi/20:pi/2;y=sin(x);a=ployfit(x,y,5);%用五阶多项式拟合y=sin(x),a为你和多项式的系数x1=0:pi/30:pi/2;y1=sin(x1);y
6、2=a(1)*x1.5+a(2)*x1.4+a(3)*x1.3+a(4)*x1.2+a(5)*x1.+a(6)plot(x1,y1,b-,x2,y2,r*)legend(原曲线,拟合曲线)axis(0,7,-1.2,4)%坐标轴的限制,学习内容,多项式运算线性方程组求解非线性方程数值求解常微分方程初值问题的数值解法函数极值线性插值,线性方程组解的结构,一、齐次线性方程组解的结构齐次线性方程组的矩阵形式为AX=0其中A是mn阶矩阵;X为未知向量,二、线性方程组求解,1.直接解法(1)利用左除运算符的直接解法 对于线性方程组Ax=b,可以利用左除运算符“”求解:x=Ab例:用直接解法求解下列线性方
7、程组。命令如下:A=2,1,-5,1;1,-5,0,7;0,2,1,-1;1,6,-1,-4;b=13,-9,6,0;x=Ab,二、线性方程组求解,(2)利用矩阵的分解求解线性方程组 矩阵分解是指根据一定的原理用某种算法将一个矩阵分解成若干个矩阵的乘积。常见的矩阵分解有:特征值分解,奇异值分解,LU分解,QR分解,Cholesky分解,Schur分解 Hessenberg分解 等 下面将对他们一一介绍,a)特征值分解,矩阵的特征值分解也调用函数eig,其调用格式为(1)V,D=eig(X)%得到矩阵X的特征值对角矩阵D和其列为对应特征值的特征向量矩阵V,矩阵的特征值分解为XV=VD(2)V,D
8、=eig(X,nobalance)%此形式为关闭平衡算法的求解方法.平衡算法对于某些问题可以得到更高的准确度。(3)V,D=eig(A,B)%对矩阵A和B做广义特征值分解,即AV=BVD,实例演示-矩阵的特征值分解,单位阵的特征值分解a=-149-50-154;537 180 546;-27-9-25v,d=eig(a)双矩阵的特征值分解b=2 10 2;10 5-8;2-8 11;v,d=eig(a,b),附:复数特征值对角阵与实数特征值对角阵的转换,即使对于实阵,其特征值也可能出现复数.而在实际使用中,常需要把这些共轭复数特征值转换为实数块.MATLAB提供两个函数进行转换(1)V,D=c
9、df2rdf(V,D)%将复数对角型转换为实数块对角型(2)U,T=rdf2cdf(U,T)%将实数对角块转换为复数对角型,实例演示-复数对角型矩阵与实数对角型矩阵的转换,a=1-3;2 2/3;v,d=eig(a)%将矩阵a进行特征值分解,其结果复对角型vs,ds=cdf2rdf(v,d)%将复对角型转换为实对角型b=vs*ds/vs%其结果与a相等,b)奇异值分解,设矩阵A为一个mn阶的(实)矩阵(mn),则存在正交矩阵V和U,使得:此式称为A的奇异值分解矩阵奇异值分解可由函数svd实现,其调用格式为(1)U,S,V=svd(X)(2)U,S,V=svd(X,0)作用:生成U,S,和V使得
10、X=USV实例演示例:对矩阵a进行奇异值分解a=1;1;U,S,V=svd(a)注:进行奇异值分解时,矩阵的维数没有限制,c)LU分解,LU分解是高斯消去法的基础,它将一矩阵表示为一个交换下三角矩阵和一个上三角矩阵的乘积形式.线性代数中已经证明,只要方阵A是非奇异的,LU分解总是可以进行的。lu函数用于对矩阵进行LU分解,其调用格式为(1)L,U=lu(X)-产生一个上三角阵U和一个变换形式的下三角阵L(行交换),使之满足X=LU。注意,这里的矩阵X必须是方阵。(2)L,U,P=lu(X)-产生一个上三角阵U和一个下三角阵L以及一个置换矩阵P,使之满足PX=LU。当然矩阵X同样必须是方阵。实现
11、LU分解后,线性方程组Ax=b的解x=U(Lb)或x=U(LPb),这样可以大大提高运算速度。,实例演示,例:用LU分解求解例1中的线性方程组。命令如下:A=2,1,-5,1;1,-5,0,7;0,2,1,-1;1,6,-1,-4;b=13,-9,6,0;L,U=lu(A);X=U(Lb)或采用LU分解的第2种格式,命令如下:L,U,P=lu(A);X=U(LP*b),d)QR分解,在求解矩阵的特征值时,引入一种分解方法,即实阵A可以写成A=QR,其中Q为一个正交矩阵和R为一个上三角矩阵.QR分解只能对方阵进行.QR分解由函数qr实现,其调用格式为:(1)Q,R=qr(X):产生一个一个正交矩
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MATLAB 方程 函数 极值

链接地址:https://www.31ppt.com/p-6512120.html