首页 MATLAB教程_部分10

MATLAB教程_部分10

举报
开通vip

MATLAB教程_部分10 下载 第1 0章 函数、插值和曲线拟合分析 M AT L A B可以处理有估值和没有估值的多项式,还有一些强大的数值分析命令,如求零 值和最小值。M AT L A B中还有数据集合的插值、曲线拟合的命令和函数,还提到了经典的贝 赛尔( B e s s e l )函数。 10.1 MAT L A B中的多项式 M AT L A B将阶为n的多项式p ( x )存储在长度为n+ 1的行向量p中。元素为多项式的系数,并 按x的幂降序排列,表示为: 代表的多项式为: 令A是一个稀疏矩阵,向量 p和q的...

MATLAB教程_部分10
下载 第1 0章 函数、插值和曲线拟合 分析 定性数据统计分析pdf销售业绩分析模板建筑结构震害分析销售进度分析表京东商城竞争战略分析 M AT L A B可以处理有估值和没有估值的多项式,还有一些强大的数值分析命令,如求零 值和最小值。M AT L A B中还有数据集合的插值、曲线拟合的命令和函数,还提到了经典的贝 赛尔( B e s s e l )函数。 10.1 MAT L A B中的多项式 M AT L A B将阶为n的多项式p ( x )存储在长度为n+ 1的行向量p中。元素为多项式的系数,并 按x的幂降序排列, 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 示为: 代表的多项式为: 令A是一个稀疏矩阵,向量 p和q的长度分别为n+ 1和m+ 1,它们分别表示次数为 n和m的多 项式。M AT L A B中处理多项式的命令如下: 命令集9 9 多项式 p o l y v a l ( p , x ) 计算多项式 p。如果x是一个标量,则计算出多项式在 x点 的值;如果x是一个向量或者一个矩阵,则计算出多项式 在x中所有元素上的值。 [ y , e r r ] = 计算向量x的多项式p的值。同上,计算结果在y中,同时 p o l y v a l ( p , x , E ) 还根据p o l y f i t 命令给出的矩阵E返回一个误差估计向量 e r r。见help polyval 和help polyfit ,参见1 0 . 4节。 p o l y v a l m ( p , A ) 直接对矩阵A进行多项式计算。不是象上个命令一样对每个 元素进行多项式计算,而是计算p(A) =p1An+p2An-1+⋯+pn + 1I。 p o l y ( A ) 计算矩阵A的特征多项式向量。 p o l y ( x ) 给出一个长度为n+ 1的向量,其中的元素是次数为 n的多项 式的系数。这个多项式的根是长度为 n的向量x中元素。 c o m p a n ( p ) 计算带有系数 p的多项式的友矩阵 A,这个矩阵的特征多 项式为p。 r o o t s ( p ) 计算特征多项式p的根,是一个长度为n的向量,也就是方程 p(x) = 0的解。表达式p o l y ( r o o t s ( p ) ) = p 为真。结果可以是复数。 c o n v ( p , q ) 计算多项式p和q的乘积,也可以认为是p和q的卷积。 [ k , r ] = d e c o n v ( p , q ) 计算多项式 p除q。k是商多项式, r是残数多项式。这个 计算等价于p和q的逆卷积。 = …˘¸ªp ( x ) / q ( x )µ˜†¿•ÖÕ„¿“˚‰£” r e s i d u e ( p , q ) ˇò`¿ p”˝ q•Ö–ð˚˙¶àˇî˚‰ p ( x )”˝ q ( x )µ˜ˇ µ˚ ý¡£µˆ µ‰µ˜Ó à˚ ý Ô Ú ˇò`¿ u Ö—£‹…«µªÔÚ`—ˇò`¿ v Ö—£‹É̶àˇî˚‰ÔÚˇò`¿ k Ö—¡£ [p q]=residue(u,v,x) ·Ó˝‹Éˇµ˜†¿•ÖÕ„¿“˚‰ u¡¢v”˝ x…˘¸ªµˆµ‰¶àˇî˚‰ p”˝ q¡£ m p o l e s ‚ł‡ö…«µª¶àÑø—Ôµ˜ˇà„Ø—¯ˇ¢£‹…ß help mpoles¡£ p o l y d e r ( p ) …˘¸ªµˆ µ‰‡⁄¶¨˛“ nµ˜ ˛¢•Ö¶àˇ î˚ ‰ ò`ˇ ¿£‹¶àˇ î˚ ‰µ˜ µ˚ˇ ýÔÚˇ ò` ¿ p Ö—¡£ p o l y d e r ( p , q ) •µ»ØÒ»‚öˇò`¿£‹¸ü–í˚¾Ó É c o n v ( p , q ) ¶¤Ò嵘¶àˇî˚‰˛¢•Ö¡£ [ u , v ] = p o l y d e r ( p , q ) •µ»Ø`‰‚öˇò`¿£‹¸üˆ˙–í˚¾Ó É d e c o n v ( p , q ) ¶¤Òå µ˜¶àˇî˚‰ ˛¢•Ö£‹–í·ï—˛˚‰˛“ u/v¡£ ¡ö Àý 1 0 . 1 ‰«Ò»—'¶àˇî˚‰ˆü`îÓƒÓˆÔÚˇ´`—µ˜¶àˇî˚‰Éˇ£” M AT L A B Óˆˇ´`—ˇò`¿À·–í˚¾Õ â`‰‚ö¶àˇî˚‰£” (a) …˘¸ª¶àˇî˚‰ÔÚ x= 1·ƒµ˜Ö µ£‹˚䨺£” ‰Æ„߲“£” (b) ”Ü¨Ý Ò ×¶Ôˇò`¿»òÕ ß ¾ Ø Õ ó…˘¸ª¶àˇî˚‰µ˜Öµ£‹˚䨺£” ‰Æ„߲“£” p(x) q(x) = u(1) x - n(1)+ u(2) x - n(2)+ × × × + u(j) x - n(j) + k(x). 1 3 6 M ATLAB 5 ˚ Ö†Æ 下载 (c) 两个多项式相乘,得到一个新的多项式: p5=conv(p2, p3) 给出: (d) 用r o o t s命令求多项式的根: r o o t s 2 = r o o t s ( p 2 ) ,r o o t s 3 = r o o t s ( p 3 ) 给出: 图1 0 - 1中显示出两个多项式的图形。 图10-1 多项式p2 (x) = 3x2+ 2x-4和p3 (x) = 2 x3-2 (e) 多项式p(x)的牛顿-拉普森迭代,多项式的系数在向量 p中: (f) 命令r o o t s ( p o l y ( A ) )求得矩阵A的特征值。假设矩阵A为: 运行命令: u s e d R o o t s = r o o t s ( p o l y ( A ) ) 结果为: 第1 0章 函数、插值和曲线拟合分析 1 3 7 下载 然而这样得到的特征值没有用 M AT L A B命令e i g ( A ) 得到的特征值的精度高,而且有效 性也差些: u s e d E i g = e i g ( A ) 给出: 结果是一样的,但是顺序正好相反。 (g) 对于所有的矩阵A都有:polyvalm(poly(A), A)=0。 这是C a y l e y - H a m i l t o n法则。这个法则对于秩为5的方阵来说: ■ 10.2 函数的零值 M AT L A B的M文件可以表示数学函数;参见 2 . 9节。函数: 如果输入下面的M文件g . m,这个函数就可以在M AT L A B中调用: 使用元素运算符. *、. /、. ^、+和-定义M AT L A B函数g。结果是如果这个函数被一个向量调用, 那么得到的结果也是一个向量。本章中提到的所有M AT L A B函数需要以这种方式来定义数学函数。 用p l o t 命令可以画出函数的图形: x=linspace(0, 2); % 生成向量x p l o t ( x , g ( x ) ) ; % 画g ( x ) 图形 g r i d ; % 画格栅 t i t l e ( 'The g(x) funct ion ') % 给出图标题 或者使用f p l o t 命令: f p l o t ( 'g', [0 2]); % 画g ( x ) 图形 g r i d ; % 画格栅 t i t l e ( 'The g(x) funct ion ') % 给出图标题 1 3 8M ATLAB 5 手册 下载 结果如图1 0 - 2所示。命令p l o t 和f p l o t 都定义在13.1 节中。 求函数 f ( x )的零值就等于求方程 f ( x )= 0的解。单变量函数的零值可以用 M AT L A B命令 f z e r o 来求。对于多项式可以用 r o o t s 命令来求,参见1 0 . 1节。f z e r o 用迭代法来求解,使 得初始的估计值接近理想的零值。 图10-2 用f p l o t 画的g ( x )图形 命令集1 0 0 函数的零值 f z e r o ( f c n , x 0 ) 求函数的一个零值, f c n为函数的名字。要求给出一 个初始值x0,近似值的相对误差为e p s。 f z e r o ( f c n , x 0 , t o l ) 求函数的一个零值, f c n为函数的名字。要求给出一 个初始值x 0,由用户定义近似值的相对误差 t o l。 f z e r o ( f c n , x 0 , t o l , p i c ) 求函数的一个零值,同上。如果p i c不为零,则给出迭 代过程。 f z e r o ( f c n , x 0 , t o l , 求多变量函数的零值,f c n=f c n(x0, p1, p2,. . .)。如果t o l和p i c pic p1 p2,. . .) 没有给出,则令它们为空矩阵,如 f z e r o ( f c n , x 0 , [ ] , [ ] , p 1 ) 。 z e r o d e m o命令给出了一个演示实列。 ■ 例1 0 . 2 (a) 求本节开头定义的函数g(x)的零值: 第1 0章 函数、插值和曲线拟合分析 1 3 9 下载 g(x)函数 结果为: (b) 求函数s i nx和2x-2的交集,也就是求方程 sin x= 2x- 2的解。先定义函数 s i n m ( x ),将它 存放在M文件s i n m . m中,如下: 画出曲线是找到初始值的一个好方法,所以: 结果如图1 0 - 3所示。可以看出2是一个可接受的估计值,输入: xzero=fzero( 's inm', 2) 结果为: xzero = 1 . 4 9 8 7 这就是方程s i nx= 2x-2的解。 图10-3 s i n m(x)函数 ■ 1 4 0M ATLAB 5 手册 sin(x)-2*x+2函数 下载 10.3 函数的最小值和最大值 最优化是求最优解,也就是在某个区间内有条件约束或者无条件约束地找到函数的最大 值或者最小值。M AT L A B使用数字方法求函数的最小值。使用迭代算法,也就是有些步骤要 重复许多次。现在,假设要求函数 f在某个区间内的最小值xm i n。 迭代方法需要一个初始估计值 x0。从x0开始找到一个更接近 xm i n的新值x1,这个值的好坏取 决于使用的数学方法。直到找到有足够精度的近似值 xi才停止迭代,也就是绝对值 |xm i n-xi|足 够小。 如果函数有多个局部最小值, f m i n 可以找到它们中的一个。也可用 M AT L A B的最优化工 具箱来求得,参见附录C。 这里提到了标准 M AT L A B系统的两个最优化命令, f m i n 命令可以求单变量函数的最小 值;f m i n s 命令可以求多变量函数的最小值,同时它还要求有一个初始向量。 没有求函数 f的最大值的命令,相反函数h=-f 的最小值可以求得。 命令集1 0 1 函数的最小值 f m i n ( f c n , x 1 , x 2 ) 求函数在区间(x1,x2 )内的最小值,f c n是目标函数名。如 果没有局部最小值,则返回区间内的最小 x值。相对误差 小于10-4。 f m i n ( f c n , x 1 , x 2 , 求函数在区间(x1,x2 )内的最小值,f c n是目标函数名。 o p t i o n s ) 如果没有局部最小值,则返回区间内的最小 x值。向量 o p t i o n s为控制参数,如 o p t i o n s( 1 ) = 1,显示中间结果; o p t i o n s( 2 )表示得到的结果 x的精度,缺省为 1 0-4。输入 help fopt ions 可得更多信息。 f m i n s ( f c n , x 0 ) 求函数f c n的最小值。由用户自己给出一个初始估计向量 x 0,相对误差为1 0-4。 f m i n s ( f c n , x 0 , 带优化参数求函数f c n的最小值,同上。输入help fmins 和 o p t i o n s ) help f o p t i o n s 可得更多信息。例如,优化参数可以控 制迭代次数和计算结果的精度。 ■ 例1 0 . 3 (a) 在区间[ 0,2 ]内求函数c o s的最小值: cosmin=fmin('cos' , 0, 2 * pi) % 求c o s 的最小值 c o s m i n = 3 . 1 4 1 6 这就是期望得到的结果。 (b) 同样可以简单地求高级函数的最小值。对定义在 1 0 . 2节中的函数g(x),求在区间 [ 0,2 ] 内的最小值。 第1 0章 函数、插值和曲线拟合分析 1 4 1 下载 注意,这是一个局部最小值,不一定是函数在这个区间内的最小值。从图 1 0 - 2上可以看 出在一个更小区间内可以得到第二个最小值,这个值比第一个值还小: (c) 还可以用f m i n 命令来求函数的最大值,但是要先编写一个返回- g(x)的函数,这个函 数保存在M文件m i n u s g . m中。 求这个函数的最小值就等于求函数 g的最大值。 gmax=fmin('minusg', 0, 2) 结果为: 在这个区间内有若干个最大值, M AT L A B求出的最大值不一定是函数的全局最大值。 (d) 用f m i n s 命令来求多个变量函数的最小值,假设函数为: 编写M文件f x 1 x 2 . m: 函数f m i n s 要求有一个初始估计向量,假设给 ( 1,0 ): 结果为: 用下面的程序画出函数的图形来: x = l i n s p a c e ( -1, 1 50); % 新建向量x,假设y = x for i=1: 50 % 计算f x 1 x 2 在每一点的值 for j=1: 50 Z(i , j )=fx1x2([x( i) x( j )]) ; e n d end meshc(x ,x, Z); % 带有基本等值线的网格图 view(80, 10); % 指定观察点 1 4 2M ATLAB 5 手册 下载 命令m e s h c 画出函数的表面图形,同时在x y平面画出图形的等值线。命令m e s h c 和v i e w 定 义在1 3 . 5节中,在4 . 2节中提到了命令l i n s p a c e 。结果如图1 0 - 4所示,从图上可以看出最小值。 图10-4 函数x 1 2+ x 2 2-0 . 5x 1 x 2 - s i nx 1 在区间[-1,1 ]×[-1,1 ]上的图形 ■ 10.4 插值、曲线拟合和曲面拟合 如果在有限个数据点内给出函数,那么利用插值的方法就可以找到中间点的近似值。最 简单的插值就是对两个相邻数据点进行线性插值。 i n t e r p 1 和i n t e r p 2 命令用特殊的算法来 进行等距离数据点的快速插值。使用时,必须在方法的名字前加上一个星号, ’ * ’,如 interp1(x, Y, xx ,’*cubic’) 。 M AT L A B中有几个函数可以用不同的方法来进行数据插值。 命令集1 0 2 插值 i n t e r p 1 ( x , y , x x ) 返回一个长度和向量x x相同的向量f(x x)。函数f 由向量x和y定义,形式为 y=f ( x ),用线性插值 的方法来计算值。为了得到正确的结果,向量 x 必须按升序或降序排列。 i n t e r p 1 ( x , Y , x x ) 返回一个相应向量的矩阵 F(x x),同上。矩阵 Y 的每列是一个关于x的函数,对于每个这样的函 数x x的值通过插值得到。矩阵 F ( x x )的行数和向 量x x的长度相同,列数和矩阵Y的相同。 i n t e r p 1 ( x , y , x x , 进行一维插值,字符串m e t s t r规定不同的插值方 m e t s t r ) 法,可用的方法有: 第1 0章 函数、插值和曲线拟合分析 1 4 3 下载 ‘l i n e a r ’ 线性插值。 ‘n e a r e s t ’ 最邻近插值。 ‘s p l i n e ’ 三次样条插值。也叫外推法。 ‘c u b i c ’ 三次插值,要求x的值等距离。 所有插值方法均要求x是单调的。 i n t e r p 1 q ( x , y , x x ) 和i n t e r p 1 相同,但是对于非均匀空间的数据插 值更快。 i n t e r p 2 ( X , Y , Z , X x , 进行矩阵X x和Y y的二维插值,并由X、Y和Z Y y ) 所描述的函数Z=f(X,Y)内的插值所决定。如果X、 Y和Z中任何一个是一个向量,则它的元素被认 为应用于相应的行和列。 i n t e r p 2 ( X , Y , Z , X x , 进行二维插值,字符串m e t s t r规定了不同的插 Y y ,m e t s t r ) 值方法,可用的方法有: ‘l i n e a r ’ 线性插值。 ‘n e a r e s t ’ 最邻近插值。 ‘s p l i n e ’ 三次样条插值。 ‘c u b i c ’ 三次插值。 V V = i n t e r p 3 ( X , Y , Z , 进行由X,Y和Z所描述的函数V的插值,X X、 V , X X , Y Y , Z Z , Y Y和Z Z是插值点。字符串m e t s t r规定了不同 m e t s t r ) 的插值方法,可用的方法有: ‘n e a r e s t ’ 使用最邻近点的值。 ‘l i n e a r ’ 使用8个最邻近点进行线性插值。 ‘s p l i n e ’ 三次样条插值。 ‘c u b i c ’ 使用6 4个最邻近点进行三次插值。 V V = i n t e r p n ( X 1 , X 2 , 和i n t e r p 3相同,但是V和V V可以是多维数组。 X 3 ,. . . , V , Y 1 , ,Y 2 , 如果X1,X2,X3,.. .是等距离的,使用星号*如 Y 3 , . . . , m e t h o d ) ’ * c u b i c ’可以加快计算速度。 I n t e r p f t ( y , n ) 快速傅利叶变换插值,返回一个长度为n,从y计 算得到的向量。要求 y的值是等距离的,结果在 与y相同区间内计算。 g r i d d a t a ( x , y , z , 返回相同大小的矩阵X x和Y y,它们表示一个网 X x , Y y , ’m e t h o d ’) 格,由函数z=f(x, y)的插值得到。向量 x、y和z 包含的是三维空间的 x、y和z坐标。字符串 m e t h o d规定了不同的插值方法,可用的方法如 下: ‘l i n e a r ’ 基于三角的线性插值。 ‘n e a r e s t ’ 最邻近插值。 1 4 4M ATLAB 5 手册 下载 ‘c u b i c ’ 基于三角的三次插值。 ‘v 4 ’使用M ATLAB 4的插值方法。 [ X 1 , X 2 , X 3 , . . . ] = 变换由向量x 1,x 2,x 3. . .给出的域。对于矩阵 n d g r i d ( x 1 , x 2 , x 3 , X 1,X 2,X 3,. . .来说,可以用做多变量函数的 . . . ) 估计值和多维插值。矩阵 X n的第n维和向量x n 的元素相同。 [ X 1 X 2 , . . . ] 等同于[ X 1 , X 2 , . . . ] = n d g r i d ( x , x , x , . . . ) 。 = n d g r i d ( x ) ■ 例1 0 . 4 做一个函数s i nx2在区间[ 0,2 ]上4 0个函数值的表。 (a) 用i n t e r p 1来计算中间点的s i nx2函数值,而不用s i n 求,命令为: 结果为: 和用s i n 计算得到的正确结果比较: 在表中用更多的数据点可以使精度更好。 (b) 用样条插值可得更高精度的结果。假设向量 x和y定义如上,那么: 结果为: 这是一个更好的近似值。 命令g r i d d a t a可以在三维空间内建立任意数据点外的函数。 ■ 例1 0 . 5 先生成三个有1 0个元素的向量,它们的值随机分布在 0~1之间: 建立一个网格来计算内部曲面之后,可以用命令 g r i d d a t a 来对这些点之间的曲面进行 插值。下面的图1 0 - 5给出了不同的插值方法之间的区别: 第1 0章 函数、插值和曲线拟合分析 1 4 5 下载 ■ 图10-5 用g r i d d a t a 对1 0个随机点的插值,左上图用的是 ‘l i n e a r ’,右上图用 的是‘c u b i c ’,右下图用的是 ‘n e a r e s t ’,右下图用的是 ‘ v 4 ’ s t p s = 0 : 0 . 0 3 : 1 ; % 向量A的值在[ 0 ,1 ] 之间 [ X , Y ] = m e s h g r i d ( s t p s ) ; % 生成一个[ 0 , 1 ] ×[ 0 , 1 ] 坐标网格 Z1=griddata(x, y, z, X, Y); % 线性插值 Z2=griddata(x, y, z , X, Y, ’c u b i c ’) ; % 三次插值 Z3=griddata(x, y, z , X, Y, ’n e a r e s t ’) ; % 最邻近插值 Z4=griddata(x, y, z , X, Y, ’v 4 ’) ; % MATLAB 4中的插值方法 subplot(2, 2, 1); % 画第1个子图 mesh(X, Y, Z1); % 画曲面网格 hold on % 保持当前图形 plot3(x, y, z, ’o’) ; % 画出数据点 hold off % 释放图形 subplot(2 2 2); % 画第2个子图 mesh(X, Y ,Z2); % 画曲面网格 hold on % 保持当前图形 plot3(x, y, z , ’o’) ; % 画出数据点 hold off % 释放图形 subplot(2, 2, 3); % 画第3个子图 mesh(X, Y, Z3); % 画曲面网格 hold on; plot3(x, y, z, ’o’) ; % 画出数据点 hold off subplot(2, 2, 4); % 画第4个子图 mesh(X, Y, Z4); % 画曲面网格 hold on plot3(x, y, z , ’o’) ; % 画出数据点 hold off 命令h o l d 和s u b p l o t 在1 3 . 3节进行了说明,命令 m e s h g r i d 在1 3 . 4节中,命令m e s h 和 p l o t 3 可以在1 3 . 5节中找到。结果如图1 0 - 5所示。 1 4 6M ATLAB 5 手册 下载 ■ 用s p l i n e 命令可以求得三次样条的近似值,还可以求得三次样条插值 p p形式的向量,向 量的元素是三次样条函数的系数。用 p p v a l 命令可以求得三次样条函数的估计值。 命令集1 0 3 三次样条数据插值 s p l i n e ( x , y , x x ) 等同于interp1(x, y, xx, ’s p l i n e ’),但是参数必须是向量。 s p l i n e ( x , y ) 返回三次样条插值向量的 p p形式,它是函数y=f ( x )的近似值。 p p是’piecewise polynomial’的缩写,得到的向量元素包含 计算的三次样条系数。这个命令可以被 p p v a l 函数使用。 Y I = 在细胞数组X的函数Y内进行n维数据的插值,得到一个新集 s p l n c o r e ( X , Y , X I ) 合X I。函数可以被 i n t e r p 2 、i n t e r p 3 和i n t e r p n使用。 p p v a l ( p p , x x ) 计算三次样条函数。如果三次样条定义为pp=spline(x, y) , 那么p p v a l ( p p , x x ) 得到的结果和s p l i n e ( x , y , x x ) 一样。 p = m k p p ( p o i n t s , 通过用给定点建立 p p函数来求分段多项式,其中 c o e ff(i, :)包 含第i个多项式的系数。 c o e f f , d ) 多项式的个数由 l = l e n g t h ( p o i n t s ) -1确定,第 i个多项 式的阶数为n = l e n g t h ( c o e f f ( : ) ) / l 。 [ p o i n t s , c o e f f , l , 给出分段多项式相关信息,见上。 n , d ] = u n m k p p ( p ) 多项式可以使用最小二乘法来进行数据拟合 (也可见7 . 7节),用的命令是p o l y f i t。 命令集1 0 4 多项式曲线拟合 p o l y f i t ( x , y , n ) 找到次数为n的多项式系数,对于数据集合{ (xi, yi) }, 满足差的平方和最小。 [ p , E ] = p o l y f i t ( x , y , n ) 返回同上的多项式 P和矩阵E。多项式系数在向量 p 中,矩阵E用在p o l y v a l 函数中来计算误差。 ■ 例1 0 . 6 下面给出了对向量x和y拟合不同阶的多项式图形,阶分别为 3,4,5。 p3=polyf i t(x, y, 3); % 用向量x和y中元素拟合不同 p4=polyf i t(x, y, 4); % 次数的多项式 p5=polyf i t(x, y, 5); xcurve= -3.5:0.1:7.2; % 生成x值 p3curve=polyval(p3, xcurve); % 计算在这些x点的多项式值 p4curve=polyval(p4, xcurve); p5curve=polyval(p5, xcurve); 第1 0章 函数、插值和曲线拟合分析 1 4 7 下载 结果如图1 0 - 6所示。 图10-6 不同次数的多项式拟合曲线图 可以看出,次数越高的多项式精度越好。 5次的多项式经过所有的 6个点。对于这个特殊 的数据集合来说,这个多项式可称为内部插值多项式。 在M AT L A B中,用 l e g e n d r e 命令来计算标量或者向量的勒让德函数,它是在选定的区 间内形成完全直交集合的直交多项式系统。勒让德多项式是阶为零的勒让德函数,可以在给 定的数据集合内进行曲线拟合。贝塞尔函数是一个经典的特殊函数,它用在数学物理学中。 命令集1 0 5 勒让德函数和贝塞尔函数 l e g e n d r e ( n , x ) 返回一个矩阵,它的元素是在 x内计算得到的 n阶, m= 0 , 1,. . .,n的相关勒让德函数值。 x的元素要求在区间 [-1,1 ]内。矩阵的第1行对应m= 0,并包含根据x计算得 到的n阶勒让德多项式。 b e s s e l j ( o r d e r , z ) 计算第1类贝塞尔函数,变量 o rd e r指定函数的阶, z用来 进行函数运算。 b e s s e l y ( n , x ) 计算第2类贝塞尔函数,变量 o rd e r指定函数的阶, z用来 进行函数运算。 b e s s e l h ( o r d e r , k , z ) 计算向量z中元素的H a n k e l函数值(第3类贝塞尔函数 ),变 量k定义使用哪一类H a n k e l函数。 b e s s e l i ( o r d e r , z ) 计算改良型第 1类贝塞尔函数,变量 o rd e r指定函数的阶, z用来进行函数运算。 1 4 8M ATLAB 5 手册 下载 ■ b e s s e l k ( o r d e r , z ) 计算改良型第 2类贝塞尔函数,变量 o rd e r指定函数的阶, z用来进行函数运算。 w = a i r y ( k, z ) k= 0或者不给出k,计算A i r y函数w= A i (z); k= 1,计算导 数A i ´ (z);k= 2,计算第2类A i r y函数B i (z); k= 3,计算导 数B i ´ (z)。 [ w , e r r ] = a i r y ( . . . ) 返回一个错误标志数组e rr。 10.5 信号分析 这里简短地介绍一些M AT L A B中用作信号分析的命令。通过h e l p和d e m o命令可以得到更多 信息,也可参见‘信号过程工具箱’和它的手册。复数命令( 2 . 4节)和卷积命令( 1 0 . 1节)也要涉及。 命令集1 0 6 信号分析 f f t ( x ) 进行向量x的离散傅立叶变换。如果 x的长度是2的幂,则用快速 傅立叶变换,F F T。注意,变换没有规格化。 f f t ( x , n ) 得到一个长度为n的向量。它的元素是x中前n个元素离散傅立叶变 换值。如果x有m 2 ),则返回一个同等大小的数组, 将A的每一维内的左右半部互换。 第1 0章 函数、插值和曲线拟合分析 1 4 9 下载 i f f t s h i f t ( A ) f f t s h i f t ( A ) 命令的逆变换。 f i l t e r ( b , a , x ) 由向量a和b所描述形成的滤波器对 x向量进行数字滤波,产生滤 波后的数据。输入help f i l ter 可得更多信息。 Y = f i l t e r 2 ( h , X ) 用在矩阵h中的F I R滤波器处理x中的数据。结果 Y由二维卷积计 算得到,包含卷记的中心部分,且与 X的大小相同。 Y = f i l t e r 2 ( h , Y由二维卷积计算得出,其维数由参数 f o r m规定,f o r m是下列字 X , f o r m ) 符串之一: ‘f u l l ’ 返回二维卷积的全部,这样Y就比X大。 ‘s a m e ’ 等同于Y = f i l t e r 2 ( h , X ) 。 ‘v a l i d ’ 仅仅返回卷积的一部分,这部分是不带零插值边缘 计算的。这样Y就比X小。 ■ 例1 0 . 7 新建一个名为 ‘hat funtion’的函数,之后对其进行傅立叶变换。这个函数在 0 , 1处值为0, 在0 . 5处值为1。 用l i n s p a c e建立这个函数: 用下列命令画出函数的图形,如图 1 0 - 7所示: 进行傅立叶变换: 这个傅立叶变换得到复数值,但是只显示出实数部分。最后,对它进行逆傅立叶变换得 到原来函数: 图10-7 函数的傅立叶变换图 所有的画图命令都定义在第1 3章中。 1 5 0M ATLAB 5 手册 下载 ■
本文档为【MATLAB教程_部分10】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_547174
暂无简介~
格式:pdf
大小:526KB
软件:PDF阅读器
页数:16
分类:互联网
上传时间:2012-05-01
浏览量:19