Matlab 第四章

合集下载

MATLAB-第4章

MATLAB-第4章

v
i 1
n
2 i


max { vi } 。
1 ≤i ≤n
设 A 是一个 m ×n 的矩阵,矩阵的 3 种常用范数如下。 1-范数: A 1 max { aij } 。
1 ≤ j ≤n i 1 m
2-范数: A 2 1 ,其中 λ 1 为 A'A 最大特征值。 ∞-范数: A max { aij } 。
【例4.6】先建立5 × 5矩阵A,然后将A的第一行元素乘以1, 第二行乘以2,…,第五行乘以5。 用一个对角矩阵左乘一个矩阵时,相当于用对角阵的第一个 元素乘以该矩阵的第一行,用对角阵的第二个元素乘以该 矩阵的第二行……依此类推,因此,只需按要求构造一个 对角矩阵D,并用D左乘A即可。命令如下: A=[1:5;2:6;3:7;4:8;5:9] D=diag(1:5); D*A %用D左乘A,对A的每行乘以一个指定常数
(2)构造对角矩阵 设V为具有m个元素的向量,diag(V,k)的功能是产生一个 n × n(n = m + k|)对角阵,其第k条对角线的元素即为 向量V的元素。 例如: diag(1:3,-1) ans = 0 0 0 0 1 0 0 0 0 2 0 0 0 0 3 0 省略k时,相当于k为0,其主对角线元素即为向量V的元素。
2.矩阵的秩与迹 (1)矩阵的秩 rank(A) (2)矩阵的迹 矩阵的迹即矩阵的对角线元素之和。 trace(A)。
3.向量和矩阵的范数
设向量 V = (v1 ,v2 ,…,vn ),向量的 3 种常用范数如下。 1-范数: V 2-范数: V ? -范数: V
1
vi 。
i 1
n
2

3.矩阵的转置 所谓转置,即把源矩阵的第一行变成目标矩阵第一列,第二 行变成第二列……依此类推。显然,一个m行n列的矩阵 经过转置运算后,变成一个n行m列的矩阵。MATLAB中, 转置运算符是单撇号(')。

matlab讲义第四章

matlab讲义第四章

图4.11 函数PEAKS的带洞孔曲面图
MATLAB的surf也有两个同种函数:surfc,它画出具有 基本等值线的曲面图。surfl,它画出一个有亮度的曲面 图。例如:
» [X,Y,Z]=peaks(30); » surfc(X,Y,Z) % surf plot with contour plot » grid,xlabel('x-axis'),ylabel('yaxis'),zlabel('z-axis') » title('SURFC of PEAKS')
图4.3 正弦曲线图
利用在x-y平面的矩形网格点上的z轴坐标值,MATLAB 定义了一个网格曲面。MATLAB通过将邻接的点用直线连接起 来形成网状曲面 ,其结果好象在数据点有结点的鱼网。例 如,用MATLAB的函数peaks可以画一个简单的曲面。 » [X,Y,Z]=peaks(30); » mesh(X,Y,Z) » grid on » xlabel('x-axis'),ylabel('y-axis'),zlabel('zaxis') » title('MESH of PEAKS')
图4.4 函数PEAKS的网格图
在显示器上要注意到线的颜色与网格的高度有关。一般情况下, 函数mesh有可选的参量来控制绘图中所用的颜色。关于MATLAB如何 使用、改变颜色在下面讨论。在任何情况下,由于颜色用于增加图 形有效的第四维,这样使用的颜色被称做伪彩色。 上图所示,网格线条之间的区域是不透明的。MATLAB命令 hidden控制网格图的这个特性。例如,用MATLAB的函数sphere产生 两个球面如下: » [X,Y,Z]=sphere(12); » subplot(1,2,1) » mesh(X,Y,Z),title('Opaque') » hidden on; » axis off; » subplot(1,2,2),title('Transparent'); » mesh(X,Y,Z); » hidden off; » axis off;

matlab第四章课件

matlab第四章课件

4.1.1 M文件的分类
M文件是由若干 Matlab 命令组合在一起构成的,它可 以完成某些操作,也可以实现某种算法
事实上,Matlab 提供的内部函数以及各种工具箱,都是利用 Matlab 语言编写的 M文件 用户也可以结合自己的工作需要,开发自己的程序或工具箱
M文件根据调用方式的不同可以分为两类: Script file:命令文件/脚本文件 Function file:函数文件
例2 输入x,y的值,并将它们的值互换后输出(swap.m)。 x=input('Input x please.'); y=input('Input y please.'); z=x; x=y; y=z; disp(x); disp(y); 例3 求一元二次方程ax2 +bx+c=0的根(root.m)。 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)),',x2=',num2str(x(2))]);
例如:
s=0; a=[12 13 14;15 16 17;18 19 20;21 22 23] for k=a s=s+k; end disp(s); 该程序的功能是求矩阵各行元素之和,执行结果是: 39 48 57 66
while语句
while expr (条件) statement(循环体语句) end 若expr成立,则执行循环体的内容,执行后 再判断条件是否为真,如果不成立则跳出循环体。

控制系统仿真及MATLAB语言--第四章 连续系统的离散化方法

控制系统仿真及MATLAB语言--第四章 连续系统的离散化方法

t2 0.2, y2 y1 1 0.1y1 0.9 0.91 0.819 t10 1.0, y10 y9 1 0.1y9 0.4628
t3 0.3, y3 y2 1 0.1y2 0.8191 0.1 0.819 0.7519
状态方程的四阶龙格-库塔公式如下:
h xk +1 xk (K 1 2K 2 2K 3 K 4 ) 6 K 1 Axk Bu (tk ) K 2 A(xk h K 1 ) Bu (tk h ) 2 2 K A (x h K ) Bu (t h ) k 2 k 3 2 2 K A(x hK ) Bu (t h) k 3 k 4 y k +1 Cxk +1
41常微分方程的数值解法数值求解的基本概念设微分方程为则求解方程中函数xt问题的常微分方程初值问题所谓数值求解就是要在时间区间ab中取若干离散点求出微分方程在这些时刻的近似值这种方法的几何意义就是把ftx在区间tk1内的曲边面积用矩形面积近似代替
第四章 连续系统的离散化方法
4.1
常微分方程的数值解法
h xk 1 xk h f k ( ftk ' f xk ' f k ) 2!
f 'tk f 'xk 等各阶导数不易计算,用下式中 ki的线性组合代替
xk 1 xk h ai ki
i 1
r
线性组合
r为精度阶次,ai为待定系数,由精度确定;ki用下 式表示 i 1
ki f (tk b1h, xk hb2 k j ) , i 2,3
将 f tk b1h,xk hb2k1 在点 tk , xk 展成Taylor级数

matlab数值分析第四章

matlab数值分析第四章

在图4-2中,用‘x’标记了上述解对应的点(ξ,J0(ξ))。
在MATLAB第6版中,可以使用feval对函数参数求值。表达式 feval(F,x,...) 等价于F(x,...) 它们的区别在于,使用feval时,允许F作为一个被传递来的参 数。在MATLAB第7版中,feval就丌再需要了。 fzerotx秳序开始的一段注释内容如下:
y = bessj0(x); plot(z,zeros(1,10),'o',x,y,'-') line([0 10*pi],[0 0],'color','black') axis([0 10*pi -0.5 1.0])
从图中可以看出,J0 (x)的图形很像是cos (x)的幅值和频率经 过调制后的版本,相邻 两个零解的距离近似等 于π。
• 第一段代码对定义搜索区间的变量a、b和c初始化,在初 始区间的端点处对函数F求值。
• 下面是主循环的开始。在每次迭代步的开始,先对a、b和 c重新排列,使它们满足zeroin算法中描述的条件。
• 返部分是收敛条件判断,并可能从循环中退出。
• 下部分代码是在二分法和两种基于揑值的方法间迕行选择。
第一类的零阶贝塞尔函数J0(x)
• 第一类贝塞尔函数(Bessel function of the first kind), 又称贝塞尔函数(Bessel function),简称为J函数, 记作Jα。 • 第一类α阶贝塞尔函数Jα(x)是贝塞尔方秳当α为整数戒 α非负时的解,须满足在x = 0 时有限。另一种定义方 法是通过它在x = 0 点的泰勒级数展开(戒者更一般地 通过幂级数展开,返适用于α为非整数):
Байду номын сангаас

MATLAB数学实验 第四章 函数和方程

MATLAB数学实验 第四章 函数和方程
• 假设已知经验公式y=f(c,x)(c为参数, x为自变量), 要求根据 一批有误差的数据(xi,yi), i=0,1,…,n, 确定参数c.这样的问 题称为数据拟合。 • 最小二乘法就是求c使得均方误差最小化 Q(c)=
2 ( y f ( c , x )) i i i 0 n
• 当f关于c是线性函数,问题转化为一个线性方程组求解。 • 如果f关于c是非线性函数,问题转化为函数极值问题
3387/1943*x^2-7637646031980105/4503599627370496*x+4886217849135065/4503599627370496
• >> vpa(fun,5) ans = 1.7432*x^2-1.6959*x+1.0850
• >> xi=-0.2:0.01:0.3; • >> yi=polyval(p,xi); • >> plot(x,y,‘ro’,xi,yi)%拟合效果作图
c= lsqnonlin (Fun,c0) non-linear least squares problems.
使用迭代法搜索最优参数c. 其中Fun是以参数c(可 以是向量)为自变量的函数,表示误差向量yf(c,x)(x, y为数据),c0为参数c的近似初值(与c同 维向量),具体使请看帮助文件。
c=lsqcurvefit(Fun2,c0, x, y) 从外部输入数据, 这里Fun2为两变量c和x的函数 f(c, x)

的调用格式
x= -3 y= -2.7183
• (3) • >> fun3=inline('100*(v(2)-v(1)^2)^2+(1-v(1))^2','v') fun3 = Inline function: fun3(v) = 100*(v(2)-v(1)^2)^2+(1-v(1))^2 • >> [v,fv]=fminsearch(fun3,[1 1]) v= 1 1 fv = 0

第四章_MATLAB的数值计算功能

第四章_MATLAB的数值计算功能

第四章MATLAB 的数值计算功能Chapter 4: Numerical computation of MATLAB数值计算是MATLAB最基本、最重要的功能,是MATLAB最具代表性的特点。

MATLAB在数值计算过程中以数组和矩阵为基础。

数组是MATLAB运算中的重要数据组织形式。

前面章节对数组、矩阵的特征及其创建与基本运算规则等相关知识已作了较详尽的介绍,本章重点介绍常用的数值计算方法。

一、多项式(Polynomial)`多项式在众多学科的计算中具有重要的作用,许多方程和定理都是多项式的形式。

MATLAB提供了标准多项式运算的函数,如多项式的求根、求值和微分,还提供了一些用于更高级运算的函数,如曲线拟合和多项式展开等。

1.多项式的表达与创建(Expression and Creating of polynomial)(1) 多项式的表达(expression of polynomial)_Matlab用行矢量表达多项式系数(Coefficient)和根,系数矢量中各元素按变量的降幂顺序排列,如多项式为:P(x)=a0x n+a1x n-1+a2x n-2…a n-1x+a n则其系数矢量(V ector of coefficient)为:P=[a0 a1… a n-1 a n]如将根矢量(V ector of root)表示为:ar=[ ar1 ar2… ar n]则根矢量与系数矢量之间关系为:(x-ar1)(x- ar2) … (x- ar n)= a0x n+a1x n-1+a2x n-2…a n-1x+a n(2)多项式的创建(polynomial creating)a,系数矢量的直接输入法利用poly2sym函数直接输入多项式的系数矢量,就可方便的建立符号形式的多项式。

例1:创建给定的多项式x3-4x2+3x+2poly2sym([1 -4 3 2])ans =x^3-4*x^2+3*x+2也可以用poly2str.求一个方阵对应的符号形式的多项式。

matlab第4章

matlab第4章

行向量元素为按降幂排列的多项式系数。
1.多项式乘法函数 conv ( )
格式:C= conv (A, B) %求多项式A和B的乘积
A、B是两个多项式的系数向量,按降幂排列。 conv( ) 把两个多项式相乘合并成一个多项式。
2
p1 2s 3;
2
p2 s 2 4
3 2
A (2s 3)(s 4) 2s 3s 8s 12
x:操作点处的状态向量
u:操作点处的输入向量
x,u缺省值为0。
20
( s 1)(s 2 2s 6) 2 【例4.4】 求传递函数 G(s) 2 s (s 3)(s 3 2s 2 3s 4)
的分子和分母多项式,并求传递函数的特征 根。
21
% num 分子多项式 % conv( ) 采用嵌套形式
G (s)
5s 3 s 3 6 s 2 11s 6
13
3.部分分式展开函数residue ( ) 功能:对两个多项式的比进行部分展开。 格式:[r, p, k]=residue(b, a) 求B(s)/A(s)的部分分式展开式 向量b和a是按s降幂排列的多项式系数。
14
B( s) bn s n bn1s n1 ...b0 F ( s) A( s) an s n an1s n1 ...a0
38
2.并联 G(s)=G1(s)+G2(s) 模型并联函数 parallel 格式:[num, den]=parallel(num1, den1, num2, den2) num1, den1:G1(s) 的分子、分母多项式 num2, den2:G2(s)的分子、分母多项式 num, den:G(s) 的分子、分母多项式

《MATLAB程序设计》第4章数组及应用

《MATLAB程序设计》第4章数组及应用
数组在内 存中的地 址
0x0012FF68 a[0] 0x0012FF6C a[1] 0x0012FF70 a[2] 0x0012FF74 a[3]
数组元素
0x0012FF78 a[4]
0x0012FF7C a[5]
8
一维数组在内存中的存储形式
说明:
(1)数组名a表示内存首地址,是地址常量。
(2)数组a中每个数组元素占的内存空间根据 数组类型确定,整个数组占的内存为:数组元 素个数乘以每个元素所占内存空间如: int a[10]; 4×10=40 float b[20]; 4×20=80 double c[5]; 8×5=40 char d[8]; 1×8=8
第4章 数组
教学内容
数组的定义及应用
字符串处理函数
几个常用算法:排序算法(选择排序、
冒泡排序)
1
第4章 数组
重点、难点
数组的定义及应用
常用算法的设计(选择排序、
冒泡排序)
2
第4章 数组
教学目标
熟练掌握数组的定义及应用
掌握字符数组的定义及应用
掌握常用的字符串处理函数
熟练掌握几个常用算法:排序
算法(选择排序、冒泡排序)
分析:所谓转置就是将矩阵的行列互换,即将 a矩阵 的a[i][j]元素变成b矩阵的b[j][i]。
24
#include <iostream> using namespace std; int main() { int a[3][4] ={{1,2,3,4},{3,4,5,6},{5,6,7,8}}; int b[4][3],i,j; for(i=0;i<3;i++) //输出二维数组a[3][4] { for(j=0;j<4;j++) cout<<a[i][j]<<" "; cout<<endl; } for(i=0;i<4;i++) //将矩阵a转置给矩阵b for(j=0;j<3;j++) b[i][j]=a[j][i]; for(i=0;i<4;i++) //输出二维数组b[4][3] { for(j=0;j<3;j++) cout<<b[i][j]<<" "; cout<<endl; } return 0;}

Matlab第四章详细讲解

Matlab第四章详细讲解
v21 v2 = v22
v11 v21 V = v12 v22
λ 1 v11 A .v1 = λ 1 v1 = λ 1 v12
λ 2 v 21 A.v 2 = λ 2 v 2 = λ 2 v 22
A .v1
A .v 2
a11 a12 v11 v21 a11v11 + a12v12 a11v21 + a12v22 A*V = v v = a v + a v a v + a v a21 a22 12 22 21 11 22 12 21 21 22 22
2 − at
f ( t ) = (sin
t )e
−b=fzero(fun ,x0 ,option,p1,p2)
%(1)使用字符串表示被处理函数 P1=0.1;P2=0.5;
%按泛函指令要求,这里参数必须用P1,P2表示
y_C='sin(x).^2.*exp(-P1*x)-P2*abs(x)';
1、求函数的零点 (1)字符串表达式 q=quad(fun,a,b) 2、数值积分 (2)内联函数 3、解微分方程 q=quadl(fun,a,b) (3)“M函数文件”的函数句柄
[t,y]=ode45(fun ,tspan,y0)
4.3.1 求函数的零点
例:求以下函数的零点。
零点初始 猜测值
向函数fun传 递的参数
4.4 多项式和卷积
4、多项式的根
功能:计算多 项式P的根。
R=roots(P)
p1 x + p2 x
n
n −1
+ ... + pn x + p
-27 ];

第4章MATLAB程序设计

第4章MATLAB程序设计

例 求一个值n,使n!最大但小于1050。 MATLAB程序如下: %初始化 r=1;k=1; 执行后结果如下: %做循环 The 41!Is while r<1e50 3.345253e+049 r=r*k; k=k+1; end k=k-1;r=r/k;k=k-1; % 输出结果 disp(['The',num2str(k),'!is',num2str(r)])
4.2.3 循环结构 for 循环:可完成指定次重复的循环,且在循环开 始之前,就知道代码重复的次数。
while 循环:while语句可完成不定次重复的循 环,与for语句不同,每次循环前要先判断条件 是否满足,再决定循环是否进行。
例 利用rand函数产生10个随机数,然后利用嵌套 for循环进行从小到大排序。
2 1.5 1 0.5 0 150 100 50
然后通过调用函数fun计算出z, 并利用mesh绘制出网格线。 编写的脚本文件如下: % 坐标系准备 x=[0:.02:2]; y=[-2:.02:0]; % 调用函数计算函数值 z=fun(x,y); % 绘图 figure mesh(z)
150 100 50
4.3.2 函数的调用 函数调用的一般格式如下: [输出实参表] = 函数名(输入实参表) 要注意的是,函数调用时各实参出现的顺 序、个数,应与函数定义时形参的顺序、 个数一致,否则会出错。函数调用时,先 将实参传递给相应的形参,从而实现参数 传递,然后再执行函数的功能。
例 对于函数
z ( x 1)2 ( y 1)2
fprintf函数中,format字符中常常会使用到一些特 殊字符来灵活的实现一些显示功能 format string 结果 %d %e %f %g 把值作为整数来处理 用科学记数法来显示数据 用于格式化浮点数,并显示这个 数 用科学记数格式,或浮点数格式, 根据那个表示的数位短,显示那 个 转到新的一行

MATLAB第四章(刘卫国编)

MATLAB第四章(刘卫国编)

25
例4.9 求定积分。 以梯形法为例,程序如下: a=0;b=3*pi; n=1000; h=(b-a)/n; x=a; s=0; f0=exp(-0.5*x)*sin(x+pi/6); for i=1:n x=x+h; f1=exp(-0.5*x)*sin(x+pi/6); s=s+(f0+f1)*h/2; f0=f1; end s

例4.13 求[100,200]之间第一个能被21整除 的整数。 程序如下: for n=100:200 if rem(n,21)~=0 continue end break end n
2
例4.1 建立一个命令文件将变量a,b的值互换,然后 运行该命令文件。 程序1: 首先建立命令文件并以文件名exch.m存盘: clear; a=1:10; b=[11,12,13,14;15,16,17,18]; c=a;a=b;b=c; a b 然后在MATLAB的命令窗口中输入exch,将会执行 该命令文件。
16
当表达式的值等于表达式1的值时,执行 语句组1, 当表达式的值等于表达式2的值时,执行 语句组2,…, 当表达式的值等于表达式m的值时,执 行语句组m, 当表达式的值不等于case所列的表达式 的值时,执行语句组n。 当任意一个分支的语句执行完后,直接 执行switch语句的下一句。
17
例4.5 某商场对顾客所购买的商品实行打折 销售,标准如下(商品价格用price来表示): price<200 没有折扣 200≤price<500 3%折扣 500≤price<1000 5%折扣 1000≤price<2500 8%折扣 2500≤price<5000 10%折扣 5000≤price 14%折扣 输入所售商品的价格,求其实际销售价格。

第4章 MATLAB 绘图

第4章 MATLAB 绘图

4.图例标注
菜单Insert---legend 命令legend('string1','string2',...)
4.1.6 一个图形窗口多个子图的绘制
subplot(m,n,i)把图形窗口分为m*n个子图,并在第i个子图 中画图 例 4-11 在同一坐标系中画出两个函数,y=cos2x,y=sinxsin6x 的图形,自变量的范围为0≤ x ≤π,函数y=cos2x用红色星号,函数 y=sinxsin6x用蓝色实线,并加图名、坐标轴、图形、图例标注 解 MATLAB命令为: x=0:pi/50:pi; y1=cos(2*x);y2=sin(x).*sin(6*x); plot(x,y1,'r*',x,y2,'b-'),grid on title(‘曲线y1=cos(2x)曲线y2=sin(x)sin(6x)') xlabel('x轴'),ylabel('y轴') gtext('y1=cos(2x)'),gtext('y2=sin(x)sin(6x)') legend('y1=cos(2x)','y2=sin(x)sin(6x)')
group 8 6 4 2 0 10 30 20
stack
1
2
3
4 stack
5
6
0
1
2
3
4 stack
5
6
8 6 5 4 3 2 1 0 10 20 30 6 4 2 0
其它特殊绘图略(见教科书 )
1
2
3
4
5
6
4.3 三维曲线绘图

第四章Matlab语言数据结构1

第四章Matlab语言数据结构1

例3:将二进制按每3位转为十进制数 clc,clear
Xfram=[0 1 1 1 1 1]; Xfram_re=reshape(Xfram,3,2);
%每3位转为十进制数
NumTrans=zeros(1,2);%放转换后的十进制数
for i=1:2
NumTrans(i)=bin2dec(num2str(Xfram_re(:,i)'));
Thank you for your cooperation
4.1.2 结构和单元阵列
在工程和管理系统中,常常需要分层次地 把一些有一定联系但不同类型、不同规模 的数据组织起来成为一个变量。 如:要为一个班的学生建立一套student管 理档案,记录每个学生的三个项目:姓名 (字符串)、出生日期(字符串)、四门 课(高数,英语,马列,体育)的成绩 (数组)。
单元型:cell
结构型:struct Jave类 函数句柄型
§4.1 Matlab语言的数据结构
MATLAB的数据类型
array char numeric double sparse cell struct user- object -
storage
各种数据类型的层次关系
常用基本数据类型 double(双精度数值) char(字符) storage(存储型):只用于内存的有效存储 sparse(稀疏数据):专门用于处理稀疏矩阵 cell(单元数组):
结构阵列的数据索引举例
clc,clear ='John'; student.birthday='1985.06.15'; student.score=[85,85,87,97]; student(2).name=' Alice '; student(2).birthday=' 1986.01.20 '; student(2).score=[77,71,75,76]; ans = 85 85 ans = 77 71 87 97 75 76

matlab入门经典教程--第四章 数值计算

matlab入门经典教程--第四章 数值计算

第四章数值计算4.1引言本章将花较大的篇幅讨论若干常见数值计算问题:线性分析、一元和多元函数分析、微积分、数据分析、以及常微分方程(初值和边值问题)求解等。

但与一般数值计算教科书不同,本章的讨论重点是:如何利用现有的世界顶级数值计算资源MATLAB。

至于数学描述,本章将遵循“最低限度自封闭”的原则处理,以最简明的方式阐述理论数学、数值数学和MATLAB计算指令之间的在联系及区别。

对于那些熟悉其他高级语言(如FORTRAN,Pascal,C++)的读者来说,通过本章,MATLAB 卓越的数组处理能力、浩瀚而灵活的M函数指令、丰富而友善的图形显示指令将使他们体验到解题视野的豁然开朗,感受到摆脱烦琐编程后的眉眼舒展。

对于那些经过大学基本数学教程的读者来说,通过本章,MATLAB精良完善的计算指令,自然易读的程序将使他们感悟“教程”数学的基础地位和局限性,看到从“理想化”简单算例通向科学研究和工程设计实际问题的一条途径。

对于那些熟悉MATLAB基本指令的读者来说,通过本章,围绕基本数值问题展开的容将使他们体会到各别指令的运用场合和在关系,获得综合运用不同指令解决具体问题的思路和借鉴。

由于MATLAB的基本运算单元是数组,所以本章容将从矩阵分析、线性代数的数值计算开始。

然后再介绍函数零点、极值的求取,数值微积分,数理统计和分析,拟合和插值,Fourier分析,和一般常微分方程初值、边值问题。

本章的最后讨论稀疏矩阵的处理,因为这只有在大型问题中,才须特别处理。

从总体上讲,本章各节之间没有依从关系,即读者没有必要从头到尾系统阅读本章容。

读者完全可以根据需要阅读有关节次。

除特别说明外,每节中的例题指令是独立完整的,因此读者可以很容易地在自己机器上实践。

MATLAB从5.3版升级到6.x版后,本章容的变化如下:●MATLAB从6.0版起,其矩阵和特征值计算指令不再以LINPACK和EISPACK库为基础,而建筑在计算速度更快、运行更可靠的LAPACK和ARPACK程序库的新基础上。

第四章 MATLAB程序设计

第四章 MATLAB程序设计

第二节 选择结构
2.1 if 语句
在MATLAB中,if 语句有三种格式
1、单分支if 语句
语句格式为: if 条件 语句组 end 当逻辑表达式的值为真时,执行该结 构中的执行语句,执行完之后继续向 下进行;若为假,则跳过结构中的内 容,向下执行。
实例分析
例4.4 当x是整数矩阵时,输出x的值。
程序3:
x=input('输入x='); y=cos(x+1)+sqrt(x*x+1);
u=cos(x+1);
v= sqrt(x*x+1); y=u+v end if x~=10
if x~=10
y=x*sqrt(x+sqrt(x));
end
y
y=x*sqrt(x+sqrt(x))
end
第二节 选择结构
if 条件1 语句组1 elseif 条件2 语句组2 …… elseif 条件m 语句组m else if-elseif的执行方式为:如果逻辑表达式1 的值为真,则执行语句1;如果为假,则判 语句组m+1 断逻辑表达式2,如果为真,则执行语句2, end 否则向下执行。
3、多分支if语句
实例分析
y
实例分析
例4.11 求
ye
0.5 x
sin( x

6
)
定积分。
a=0;b=3*pi;n=1000; h=(b-a)/n; x=a:h:b; f=exp(-0.5*x).*sin(x+pi/6);
for i=1:n
s(i)= (f(i)+f(i+1))*h/2; end s=sum(s)

matlab(第四章 函数和方程)

matlab(第四章 函数和方程)

4.1 预备知识:零点
非线性方程(组)f (x) = 0, x=(x1, x2, …, xn), f=(f1, f2, …, fm) • 数值方法主要是综合运用线性方程组和非线性方程求 解方法,常用的方法是Newton法、拟Newton法、最 小二乘法等。
4.1 预备知识:极值
设x为标量或向量,y=f(x)是xD上的标量值函数。
如果对于包含x=a的某个邻域 ,有 f(a)f(x) (f(a)f(x))对任意x成立, 则称a为f(x)的一个局 部极小(大)值点。 如果对任意xD,有f(a)f(x)(f(a)f(x))成立, 则称a为f(x)在区域D上的一个全局极小(大)值点。
4.1 预备知识:极值
4.1 预备知识:最次代数方程 (n次多项式方程) 1. 代数学基本定理可知,n次方程在复数 域上有n个根; 2. n<=4,有求根公式; n>=5无求根公式,只能借助数值解法;
代数方程的解法
• 远在公元前1700年的古巴比伦人就已有关于一、 二次方程的解法。《九章算术》(公元前50~100年) 其中“方程术”有联立一次方程组的一般解法。 • 1535年意大利数学家坦特格里亚(TorTaglia)发现 了三次方程的解法,卡当(H· Cardano)从他那里改 进了这种解法,于1545年在其名著《大术》中公 布了三次方程的公式解,称为卡当算法。
4.2 多项式MATLAB指令
• 多项式
y=polyval(p,x) 求得多项式p在x处的值y,x可以是一个 或多个点 p3=conv(p1,p2) 返回多项式p1和p2的乘积 [p3,r]=deconv(p1,p2) p3返回多项式p1除以p2的商,r返 回余项 x=roots(p) 求得多项式p的所有复根. p=polyfit(x,y,k)用k次多项式拟合向量数据(x, y),返回多 项式的降幂系数
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

%多项式相乘
p1_divide_p2 =deconv(p1,p2);
%多项式除法
p1=poly2sym(p1)
%显示多项式p1
p2=poly2sym(p2)
%显示多项式p2
p1_plus_p2=poly2sym(p1_plus_p2)
p1_minus_p2=poly2sym(p1_minus_p2)
度是否相等
p1_plus_p2=p1+p2;
%多项式相加
p1_minus_p2=p1-p2;
%多项式相减
elseif length_of_p1<length_of_p2
temp_p1=[zeros(length_of_p2-length_of_p1) p1];
p1_plus_p2= temp_p1+p2;
多项式的表示 在MATLAB中,多项式用一个行向量表示,向量中的元素为
该多项式的系数,按照降序排列。如多项式9+7+4x+3可以表示 为向量p=[9 7 4 3]。用户可用创建 向量的方式创建多项式,再 将其显示为多项式,如: >> p=[9 ,7,4,3]; >> y=poly2sym(p) y= 9*x^3 + 7*x^2 + 4*x + 3
2
例4-1 编写脚本文件,实现多项式的四则运算。
>> %polynomial operation
>> p1=[1,2,1];
%定义多项式
>> p2=[1,1];
>> length_of_p1=length(p1);
>> length_of_p2=length(p2);
>> if length_of_p1==length_of_p2 %判断两个多项式的长
功能 多项式求根 多项式求值 矩阵多项式求值 多项式求导 求矩阵的特征多项式;或者求一个多项 式,其根为指定的数值 多项式曲线拟合 求解余项
5
有时不仅多项式运算,还需要根据已知数据推断未知数据,即需 要数据插值。MATLAB提供了对数组的任意一维进行插值的工具, 这些工具大多需要用到多维数组的操作。一维插值在曲线拟合和数 据分析中具有重要的地位。在MATLAB中,一维插值主要是用interp 函数实现。该函数的调用格式:
8
例4-2 dblquad函数积分应用。
>> F=@(x,y)y*sin(x)+x*cos(y); >> Q=dblquad(F,pi,2*pi,0,pi)
Q= -9.8696
9
Hale Waihona Puke 题例4-1 一个抛射物的高度和速率。以速率v。、水平夹 角A投掷的哟个抛射物(例如一个球),其高度和速率为:
h(t)= tsinA-0.5g v(t)= 其中,g是重力加速度。当h(t)=0时,抛射物将撞击到 地面,并由此可以得到撞击时间: = 2(。假设A= 、 =20m/s和g= 9.81m/。使用MATLAB关系运算符和逻辑 运算符找出当高度低于6米并且在速率不大于16m/s时 的撞击时间
1
四则运算
因为多项式可以用向量来表示,多项式的四则运算也可以转 化为向量的运算。多项式的加减对应项系数的加减,即向量的 加减。但向量加减之前必须保证两个向量需要有相同的长度, 因此在进行多项式加减时,需要将短的向量前面补0。多项式的 乘法运算就是多项式系数向量之间的卷积运算,即用conv函数。 多项式的除法运算时乘法的逆运算,可以通过反卷积函数 deconv()来实现。
11
Thank you!
对应方法 最近邻插值 线性插值 三次样条插值 三次插值
6
fzero函数可以用来寻找一元函数的零点,要先指定一个初
始点或者一个区间。该函数调用格式如下: x=fzero(fun,x0), x=fzero(fun,[x1,x2]):用来寻找x0附近或者 区间内fun的零点,返回该点的x坐标。 x=fzero(fun,x0,options), x=fzero(fun,[x1,x2],options):设置options参数。 [x,fval]=fzero(…):返回零点的同时返回该点的函数值。 [x,fval,exitflag]=fzero(…):返回零点、该点的函数值及程序退 出的标志。 [x,fval,exitflag,output]=fzero(…):返回零点、该点的函数值、 程序退出的标志及选定的输出结果。
10
例题
%Set the values for initial speed, gravity,and angle.(设置初始速率、重力加 速度、角度的值) v0=20;g=9.81;A=40*pi/180; %Compute the time to hit.(计算碰撞时间) t_hit=2*v0*sin(A)/g; %Compute the arrays containing time,height,and speed.(计算包含时间、 高度和速率的数组) t=[0:t_hit/100:t_hit]; h=v0*t*sin(A)-0.5*g*t.^2; v=sqrt(v0^2-2*v0*g*sin(A)*t+g^2*t.^2); %Determine when the height is no less than 6,(确定当高度低于6米) %and the speed is no greater than 16.(并且速度不大于16) u=find(h>=6&v<=16); %Compute the corresponding times.(计算对应的时间) t_1=(u(1)-1)*(t_hit/100); t_2=u(length(u)-1)*(t_hit/100) 结果是t1= 0.8649和t2= 1.7560。在这两个时间之间,h>=6m和v<=16m/s。
p1_multiply_p2=poly2sym(p1_multiply_p2)
p1_divide_p2 =poly2sym(p1_divide_p2)
4
除了四则运算之外,其他一些函数名称和功能如下表:
函数 roots polyval polyvalm polyder poly
polyfit residue
Matlab 程序设计及在土木工程中的应用
主讲人:张静 副教授 合肥工业大学土木与水利学院桥梁工程系
2015.09
第四章 MATLAB的数学运算
本章主要内容
4.1 多项式与插值 4.2 条件语句 4.3 Switch 结构 4.4 循环结构
4.1 多项式与插值
现在MATLAB中专门用于处理多项式的函数能够解决很多工程 和应用经常遇到的问题,用户可以应用这些函数对多项式进行 操作。MATLAB中对多项式的操作包括多项式求根、多项式的 四则运算及多项式的微积分。
yi=interp1(x,y,xi,method)
其 中 , x 、 y 分 别 为 采 用 数 据 的 x 和 y 坐 标 , xi 为 待 插 值 的 位 置 , method为采用的插值方法。该语句返回函数在点xi处的插值结果。 参数method可以选择的方法如表:
参数 ‘nearest’ ‘linear’ ‘spline’ ‘hchip’或 ‘cubic’
7
4.2 数值积分
这里主要讲的是一元函数积分、二重积分和三重积分。
MATLAB中一元函数对的积分用quad和quadl实现,调用格式:
q=quad(fun,a,b), 采 用 递 归 自 适 应 方 法 计 算 fun 函 数 在 区 间 [a,b] 上 的 积 分 。 q=quad(fun,a,b),指定允许的误差,该命令运行更快,但结果精确度低。 q=quad(fun,a,b,tol,trace),跟踪迭代过程,分别为计算机函数值的次数、当前 积分区间的左边界、步长和该区间的积分值。 [q,fcnt]=quadl(fun,a,b,…),输出函数值的同时输出计算函数值的次数。 MATLAB中二重积分和三重积分分别由dblquad函数和triplequad函数来实现。 二重积分调用格式: q=dblquad(fun,xmin,xmax,ymin,ymax),函数的参数分别为函数句柄、两个自 变量的积分限,返回积分结果。 q=dblquad(fun,xmin,xmax,ymin,ymax,tol),指定积分结果的精度。 q=dblquad ( fun,xmin,xmax,ymin,ymax,tol,method ) , 指 定 结 果 精 度 和 积 分 方法,method的取值可以是@quadl,也可以是用户自定义的积分函数句柄, 该函数的调用格式必须与quad函数的调用格式相同。
p1_minus_p2= temp_p1-p2;
else
3
temp_p2=[zeros(length_of_p1-length_of_p2) p2];
p1_plus_p2=p1+ temp_p2;
p1_minus_p2=p1- temp_p2;
end
p1_multiply_p2=conv(p1,p2);
相关文档
最新文档