第6講:MATLAB數(shù)據(jù)分析與應(yīng)用_第1頁
第6講:MATLAB數(shù)據(jù)分析與應(yīng)用_第2頁
第6講:MATLAB數(shù)據(jù)分析與應(yīng)用_第3頁
第6講:MATLAB數(shù)據(jù)分析與應(yīng)用_第4頁
第6講:MATLAB數(shù)據(jù)分析與應(yīng)用_第5頁
已閱讀5頁,還剩50頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

第6講:MATLAB數(shù)據(jù)分析與應(yīng)用6.1多項式運算6.2線性方程組的求解6.3非線性方程組的數(shù)值求解6.4函數(shù)的零點和極值6.5基本統(tǒng)計處理6.6數(shù)據(jù)插值和曲線擬合16.1多項式運算matlab語言把多項式表達(dá)成一個行向量,該向量中的元素是按多項式降冪排列的。f(x)=anxn+an-1xn-1+……+a0

可用行向量p=[anan-1……a1a0]表示。1.poly(x)——x是矩陣或向量,產(chǎn)生首元素是1的n+1維的特征多項式的系數(shù)向量。2例1:

a=[12.1229-5.7345-0.3884];p=poly(a)

p=1.00-6.00-72.00-27.00例2:

a=[123;456;780];p=poly(a)

p=1.00-6.00-72.00-27.00友矩陣:poly(compan(p))3p是多項式p(x)=x3-6x2-72x-27的matlab描述方法,可用:p1=poly2str(p,'x')—函數(shù),顯示多項式的數(shù)學(xué)形式:

p1=x^3-6x^2-72x-27matlab指令為

p=[1,-6,-72,-27];

p1=poly2str(p,'x')4例3:

a=[123;456;780];p=poly(a)

p=1.00-6.00-72.00-27.00r=roots(p)

r=12.12-5.73——顯然r是矩陣a的特征值-0.392.roots(A)——A是多項式的系數(shù),求多項式的根

5當(dāng)然我們可用poly令其返回多項式形式p2=poly(r)

p2=1.00-6.00-72.00-27.00

matlab規(guī)定多項式系數(shù)向量用行向量表示,一組根用列向量表示。6Y=polyval(P,x):代數(shù)多項式求值,若x為一數(shù)值,則求在該點的值;若x為向量或矩陣,則對向量或矩陣中的每個元素求其值。polyvalm(P,A):矩陣多項式求值,A為方陣,它以方陣為自變量求多項式的值。設(shè)A為方陣,P代表多項式x3-5x2+8,則后者含義是:A^3-5*A^2+8*eye(size(A)),而前者是:A.^3-5*A.^2+8*ones(size(A))。實驗:p=[1,-5,0,8];A=compan(p);polyvalm(p,A)3.求多項式的值7例4:

a(x)=x2+2x+3;b(x)=4x2+5x+6;c=(x2+2x+3)(4x2+5x+6)a=[123];b=[456];c=conv(a,b)=conv([123],[456])

c=4.0013.0028.0027.0018.00p=poly2str(c,'x')

p=4x^4+13x^3+28x^2+27x+184.conv(),convs()——多項式乘運算8a=[1,2,3];c=[4.00,13.00,28.00,27.00,18.00]d=deconv(c,a)

d=4.005.006.00[d,r]=deconv(c,a)余數(shù)c除a后的整數(shù)5.deconv()——多項式除運算9命令格式:

polyder(p):求p的微分polyder(a,b):求多項式a,b乘積的微分[p,q]=polyder(a,b):求多項式a,b商的微分例5:a=[12345];poly2str(a,'x')

ans=x^4+2x^3+3x^2+4x+5b=polyder(a)

b=4664poly2str(b,'x')

ans=4x^3+6x^2+6x+46.polyder函數(shù)——多項式微分10

1.利用左除運算符的直接解法對于方程ax=b,a為an×m矩陣,有三種情況:當(dāng)n=m時,此方程成為“恰定”方程當(dāng)n>m時,此方程成為“超定”方程當(dāng)n<m時,此方程成為“欠定”方程matlab定義的左除運算可以很方便地解上述三種方程。6.2線性方程組的求解11方程ax=b(a為非奇異),x=a-1b矩陣逆兩種解:x=inv(a)

b—求逆運算解方程x=a\b—左除運算解方程(等價)例6:x1+2x2=82x1+3x2=13a=[12;23];b=[8;13];

x=inv(a)*b

x=a\bx=x=2.002.003.003.00

1)“恰定”方程組12方程ax=b,m<n時,不存在唯一解。方程解(a'a)x=a'b,x=(a'a)-1a'b——求逆法x=a\b——最小二乘法

(等價)例7:

x1+2x2=12x1+3x2=23x1+4x2=3,a=[12;23;34];b=[1;2;3];

x=a\b

x=inv(a'

a)

a'

b

x=x=1.001.0000.00

2)“超定”方程組13方程ax=b,m>n時,即不定情況,有無窮多個解存在。matlab可求出兩個解:1)具有最多零元素的解——除法求解2)具有最小長度或范數(shù)的解——偽逆pinv例8:x1+2x2+3x3=12x1+3x2+4x3=2,a=[123;234];b=[1;2];

x=a\b

x=pinv(a)

b

x=1.00x=0.8300.330-0.173)“欠定”方程組14

矩陣分解是指根據(jù)一定的原理用某種算法將一個矩陣分解成若干個矩陣的乘積。

(1)LU分解:將非奇異的矩陣分解為一個下三角矩陣L和一個上三角矩陣U的乘積,即A=L*U。Ax=b可變換為x=U\(L\b)或x=U\(L\Pb)。

分解格式(矩陣A必須是方陣):[L,U]=lu(A):產(chǎn)生一個上三角陣U和一個下三角陣L。[L,U,P]=lu(A):產(chǎn)生一個上三角陣U和一個下三角陣L以及一個置換矩陣P2.利用矩陣分解的直接解法15命令如下: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\(L\b)或采用LU分解的第2種格式,命令如下:[L,U,P]=lu(A);x=U\(L\P*b)例9

用LU分解求解例7-1中的線性方程組。16

(2)QR分解:把矩陣A分解為一個正交矩陣Q和一個上三角矩陣R的乘積,即A=Q*R。Ax=b可變換為x=R\(Q\b)或x=E(R\(Q\b))。

分解格式:[Q,R]=qr(A):產(chǎn)生一個正交矩陣Q和一個上三角矩陣R。[Q,R,E]=qr(A):產(chǎn)生一個正交矩陣Q、一個上三角矩陣R以及一個置換矩陣E。QR分解17(3)Cholesky分解:把對稱正定的矩陣A分解成一個上三角矩陣R和其轉(zhuǎn)置矩陣R'的乘積,即A=R'R。Ax=b可變成x=R\(R'\b)。分解格式:R=chol(A):產(chǎn)生一個上三角陣R。[R,p]=chol(A):A對稱正定時,p=0;否則p為一個正整數(shù)。如果A滿秩,則R為一個滿足R‘R=A(1:p-1,1:p-1)的階為p-1的上三角陣。Cholesky分解18@函數(shù)Matlab6.0以后的版本中可以用@函數(shù)進行函數(shù)調(diào)用,其調(diào)用格式:handle=@function這類似于C++語言中的引用。實例:利用句柄傳遞數(shù)據(jù)。fhandle=@humps;%為hump函數(shù)創(chuàng)建一個函數(shù)句柄,并將它指定為fhandle變量x=fminbnd(@humps,0,1)%傳遞humps句柄給fminbnd函數(shù),傳遞所有變量匿名函數(shù)19對于非線性方程組F(X)=0,用fsolve函數(shù)求其數(shù)值解。fsolve函數(shù)的調(diào)用格式為:X=fsolve('fun',X0)

X=fsolve('fun',X0,options)其中X為返回的解,fun是用于定義需求解的非線性方程組的函數(shù)文件名,X0是初值,options為選項設(shè)定,默認(rèn)缺省。如果想改變其中某個選項,則可以調(diào)用optimset()函數(shù)來完成。6.3非線性方程組的求解20例10:求解方程在[-1,10]內(nèi)的解。

首先作圖如下:

fplot(‘[5*x^2*sin(x)-exp(-x),0]’,[0,10])發(fā)現(xiàn)在[0,10]區(qū)間中有4個解,分別在0,3,6,9附近,所以用命令:

fun=inline(‘5*x.^2.*sin(x)-exp(-x)’);fsolve(fun,[0369],1e-6)

ans=0.50183.14076.28329.4248注意:用inline建立的函數(shù)fun調(diào)用時不加單引號;而用M函數(shù)文件建立的函數(shù)則要加單引號或用@函數(shù)。21

首先編制函數(shù)文件fc.m如下:functiony=fc(x)y=[x(1)-0.7*sin(x(1))-0.2*cos(x(2));x(2)-0.7*cos(x(1))+0.2*sin(x(2))];

在MATLAB命令窗口輸入:x0=[0.50.5];fsolve(‘fc’,x0)或fsolve(@fc,x0)ans=0.52650.5079例11:求非線性方程組在(0.5,0.5)附近的解。22對于函數(shù)f(x)的零點,用fzero函數(shù)求解?;靖袷綖椋簒=fzero('fun',X0)[x,fval]=fzero(fun,X0,options)求函數(shù)零點x和該點的函數(shù)值fval,fun可以是字符串、內(nèi)聯(lián)函數(shù)或M函數(shù)文件名的函數(shù)句柄。X0是初值,options為選項設(shè)定,默認(rèn)缺省。6.4函數(shù)的零點23例12:求的零點。首先作圖確定零點范圍:x=-5:0.1:5;f=x.^3-2*x-5;plot(x,f,x,0);發(fā)現(xiàn)零點大致在2附近,編寫M文件,函數(shù)名zero1.m

functionf=zeros(x)f=x.^3-2*x-5;計算2附近的零點和該點的函數(shù)值[xz,yz]=fzero(@zero1,2)

xz=yz=2.0946-8.8818e-01624對于函數(shù)f(x)的極值,用fmidbnd函數(shù)求解極小值?;靖袷綖椋?/p>

x=fmidbnd('fun',x1,x2)[x,fval]=fmidbnd(fun,x1,x2,options)求函數(shù)fun在(x1,x2)間的極小點x及該點函數(shù)值fval,用法同fzero。6.5函數(shù)的極值25例13:求的極小值。首先作圖確定極小值范圍:x=-5:0.1:5;f=(x-3).^2-1;plot(x,f);發(fā)現(xiàn)在(2,4)間有極小值,編M文件,函數(shù)名為m1.m

functionf=m1(x)

f=(x-3).^2-1;計算(2,4)間的極小點和該點的函數(shù)值[xm,ym]=fminbnd(‘m1’,2,4)xm=ym=3-1261、查取最大值——max函數(shù)[Y,I]=max(X):返回矩陣X的各列中的最大元素值及其該元素的位置并賦予行向量Y與I;當(dāng)X為向量時,則Y與I為單變量。[Y,I]=max(X,[],DIM):按數(shù)組X的第DIM維的方向查取其最大的元素值及其該元素的位置賦予向量Y與I。6.6基本統(tǒng)計處理27U=max(A,B):A,B是兩個同型的向量或矩陣,結(jié)果U是與A,B同型的向量或矩陣,U的每個元素等于A,B對應(yīng)元素的較大者。U=max(A,n):n是一個標(biāo)量,結(jié)果U是與A同型的向量或矩陣,U的每個元素等于A對應(yīng)元素和n中的較大者。28例14

查找下面數(shù)列x的最大值。

x=[359618]%產(chǎn)生數(shù)列xx=359618

y=max(x)%查出數(shù)列x中的最大值賦予yy=9

[y,l]=max(x)%查出數(shù)列x中的最大值及其該元素的位置賦予y,ly=9l=329例15

分別查找下面3×4的二維數(shù)組x中各列和各行元素中的最大值。

x=[1842;9625;3671]%產(chǎn)生二維數(shù)組xx=184296253671

y=max(x)%查出二維數(shù)組x中各列元素的最大值產(chǎn)生賦予行向量yy=987530

[y,l]=max(x)%查出二維數(shù)組x中各列元素的最大值,元素的行下標(biāo)賦予y,ly=9875l=2132[y,l]=max(x,[],1)%本命令的結(jié)果同上

y=9875l=2132

[y,l]=max(x,[],2)%DIM=2,在各行中查找y=8l=29173

31例16

試取下面兩個2×3的二維數(shù)組x、y所有同一位置上的元素值大者構(gòu)成一個新矩陣p。

x=[456;148];%產(chǎn)生二維數(shù)組x

y=[175;457];%產(chǎn)生二維數(shù)組y

p=max(x,y)%在x,y同一位置上的兩個元素中查找出最大值,賦予與x,y同樣大小的二維數(shù)組pp=476458322、查取最小值MIN函數(shù)用來查取數(shù)據(jù)序列的最小值。3、求中值Y=median(X):將median(X)返回矩陣X各列元素的中值;若X為向量,則Y為單變量。Y=median(X,DIM):按數(shù)組X的第DIM維方向的元素求其中值賦予向量Y。若DIM=1,為按列操作;若DIM=2,為按行操作。若X為二維數(shù)組,則Y為一個向量;若X為一維數(shù)組,則Y為單變量。33例17

對二維數(shù)組x試從不同維方向求出其中值。x=[1842;9625;3671];y0=median(x)%按列操作y0=3642y1=median(x,1)%按列操作,結(jié)果為行向量y1=3642y2=median(x,2)%按行操作,結(jié)果為列向量y2=3.00005.50004.5000344、求和Y=sum(X):將sum(X)返回矩陣X各列元素之和賦予行向量Y;若X為向量,則Y為單變量。Y=sum(X,DIM):按數(shù)組X的第DIM維的方向的元素求其和賦予Y。若DIM=1,為按列操作;若DIM=2,為按行操作。若X為二維數(shù)組,Y為一個向量;若X為一維數(shù)組,則Y為單變量。355、求平均值Y=mean(X):將mean(X)返回矩陣X各列元素之和的平均值賦予行向量Y。若X為向量,則Y為單變量。Y=mean(X,DIM):按數(shù)組X的第DIM維的方向的元素求其平均值賦予向量Y。若DIM=1,為按列操作;若DIM=2,為按行操作。若X為二維數(shù)組,Y為一個向量;若X為一維數(shù)組,則Y為單變量。36例18x=[456;148];y=sum(x,1)y=5914y=sum(x,2)y=1513y1=mean(x,1)y1=2.504.507.00y2=mean(x,2)y2=5.00004.3333376、求積Y=prod(X):將prod(X)返回矩陣X各列元素之積賦予行向量Y。若X為向量,則Y為單變量。Y=prod(X,DIM):按數(shù)組X的第DIM維的方向的元素求其積賦予向量Y。若DIM=1,為按列操作;若DIM=2,為按行操作。若X為二維數(shù)組,Y為一個向量;若X為一維數(shù)組,則Y為單變量。38例19x=[456;148];y1=prod(x,1)y1=42048y2=prod(x,2)

y2=12032397、累加和、累乘積cumsum(X):求向量或矩陣X的累加和。cumprod(X):求向量或矩陣X的累加積。cumsum(A,dim):當(dāng)dim為1時,該函數(shù)等同于cumsum(A);當(dāng)dim為2時,其第i行是A的第i行的累加和向量。cumprod(A,dim):同上。408、標(biāo)準(zhǔn)方差std(X):求向量或矩陣X的標(biāo)準(zhǔn)方差。Y=std(A,flag,dim):當(dāng)dim=1時,求各列元素的標(biāo)準(zhǔn)方差;當(dāng)dim=2時,求各行元素的標(biāo)準(zhǔn)方差。flag取0或1,當(dāng)flag=0時,按σ=1計算;當(dāng)flag=1時,按σ=2計算。缺省flag=0,dim=1。419、相關(guān)系數(shù)

corrcoef(X):返回從矩陣X形成的一個相關(guān)系數(shù)矩陣。此相關(guān)系數(shù)矩陣的大小與矩陣X一樣。它把矩陣X的每列作為一個變量,然后求它們的相關(guān)系數(shù)。

corrcoef(X,Y):在這里,X,Y是向量,它們與corrcoef([X,Y])的作用一樣。

42例20

生成滿足正態(tài)分布的10000×5隨機矩陣,然后求各列元素的均值和標(biāo)準(zhǔn)方差,再求這5列隨機數(shù)據(jù)的相關(guān)系數(shù)矩陣。命令如下:X=randn(10000,5);M=mean(X)D=std(X)R=corrcoef(X)4310、升序排序sort(X):返回對向量X中的元素按升序排列的新向量。[Y,I]=sort(A,dim):對矩陣A的各列或各行重新排序,其中dim指明對A的列還是行進行排序。若dim=1,則按列排;若dim=2,則按行排。Y是排序后的矩陣,而I記錄Y中的元素在A中位置。441、一維數(shù)據(jù)插值Y1=interp1(X,Y,X1,‘method’):根據(jù)X,Y的值計算函數(shù)在X1處的值。X,Y是兩個等長的已知向量,分別描述采樣點和樣本值,X1是一個向量或標(biāo)量,描述欲插值的點,Y1是一個與X1等長的插值結(jié)果。method是插值方法,允許的取值有l(wèi)inear(線性插值)、nearest(最近鄰點)、cubic(三次函數(shù))、spline(三次樣條)。6.4數(shù)據(jù)插值和曲線擬合(cftool)45例21

某觀測站測得某日6:00時至18:00時之間每隔2小時的室內(nèi)外溫度(℃),用3次樣條插值分別求得該日室內(nèi)外6:30至17:30時之間每隔2小時各點的近似溫度(℃)。h=6:2:18;%時間變量t=[18,20,22,25,30,28,24;15,19,24,28,34,32,30]’;%已知數(shù)據(jù)XI=6.5:2:17.5%欲插值點YI=interp1(h,t,XI,‘spline’)%3次樣條插值46Z1=interp2(X,Y,Z,X1,Y1,‘method’):向量X,Y分別是描述兩個參數(shù)的采樣點,Z是與采樣點對應(yīng)的函數(shù)值,X1,Y1是兩個向量或標(biāo)量,描述欲插值的點。Z1是根據(jù)相應(yīng)的插值方法得到的插值結(jié)果。method的取值與一維插值函數(shù)相同。X,Y,Z也可以是矩陣形式。同樣,X1,Y1的取值范圍不能超出X,Y的給定范圍,否則,會給出“NaN”錯誤。2、二維數(shù)據(jù)插值47例22

某實驗對一根長10米的鋼軌進行熱源的溫度傳播測試。x表示測量點0:2.5:10(米),h表示測量時間0:30:60(秒),T表示測試所得各點的溫度(℃)。試用線性插值求出在一分鐘內(nèi)每隔20秒、鋼軌每隔1米處的溫度TI。x=0:2.5:10;h=[0:30:60]';T=[95,14,0,0,0;88,48,32,12,6;67,64,54,48,41];xi=[0:10];hi=[0:20:60]';TI=interp2(x,h,T,xi,hi)483、曲線擬合[P,S]=polyfit(X,Y,m):根據(jù)采樣點X和采樣點函數(shù)值Y,產(chǎn)生一個m次多項式P及其在采樣點的誤差向量S。其中X,Y是等長的向量,P是一個長

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論