




已阅读5页,还剩43页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
MATLAB程式設計進階篇曲線擬合與迴歸分析,張智星(RogerJang)/jang清大資工系多媒體檢索實驗室,資料擬和簡介,資料擬合(DataFitting)給定一組資料(含輸入及輸出),建立一個數學模型,來逼近此資料的輸入輸出特性如果此資料包含一維輸入及輸出,則此數學模型可以表示成一條曲線,在此情況下又稱為曲線擬合(CurveFitting)迴歸分析(RegressionAnalysis)使用統計的方法來進行資料擬和,並分析每一個變數的統計特性,此過程稱為迴歸分析,曲線擬合簡介,曲線擬合(CurveFitting)欲建立的數學模型是單輸入、單輸出(Single-inputSingle-output,簡稱SISO),其特性可用一條曲線來表示迴歸分析之分類若模型是線性模型,則此類問題稱為線性迴歸(LinearRegression)若模型是非線性模型,則稱為非線性迴歸(NonlinearRegression)。,觀察資料是美國自1790至1990年(以10年為一單位)的總人口,此資料可由載入檔案census.mat得到:範例10-1:censusPlot01.m,曲線擬合:美國人口範例,loadcensus.mat%載入人口資料plot(cdate,pop,o);%cdate代表年度,pop代表人口總數xlabel(年度);ylabel(美國人口總數);,模型選取由上圖資料分佈,可猜測這適合的曲線可能是二次拋物線其中y為輸出,x為輸入,則為此模型的參數。由於參數相對於y呈線性關係,所以此模型為稱線性模型目標找出最好的參數值,使得模型輸出與實際資料越接近越好,此過程即稱為線性迴歸,曲線擬合之模型選取,曲線擬和的平方誤差假設觀察資料可寫成,i=121。當輸入為時,實際輸出為。模型的預測值為平方誤差:總平方誤差是參數的函數,這也是我們要最小化的目標函數,可表示如下:,曲線擬合之目標函數,求得參數、的最佳值求出對、的導式,令其為零,即可解出、的最佳值。總平方誤差為的二次式導式、及為的一次式令上述導式為零之後,我們可以得到一組三元一次線性聯立方程式,就可以解出參數、的最佳值。,目標函數之求解,假設21個觀察點均通過此拋物線,將這21個點帶入拋物線方程式,得到下列21個等式:亦可寫成其中、為已知,為未知向量。,矩陣表示法,觀察上述21個方程式,只有3個未知數,所以通常不存在一組解來滿足這21個方程式。在一般情況下,只能找到一組,使得等號兩邊的差異為最小,此差異可寫成此即為前述的總平方誤差MATLAB提供一個簡單方便的左除()指令,來解出最佳的,使得總平方誤差為最小。,MATLAB的最小平方解,利用左除來算出最佳的參數值,並同時畫出具有最小平方誤差的二次曲線範例10-2:census01.m,曲線擬合運算範例,loadcensus.mat%載入人口資料plot(cdate,pop,o);%cdate代表年度,pop代表人口總數A=ones(size(cdate),cdate,cdate.2;y=pop;theta=Ay;%利用左除,找出最佳的theta值plot(cdate,pop,o,cdate,A*theta,-);legend(實際人口數,預測人口數);xlabel(年度);ylabel(美國人口總數);,曲線擬合結果,由上述範例,我們可以找出最佳的因此具有最小平方誤差的拋物線可以寫成:,提示:左除及右除,左除的概念,可記憶如下:原先的方程式是A*theta=y,我們可將A移項至等號右邊,而得到theta=Ay。必須小心的是:原先A在乘式的第一項,所以移到等號右邊後,A仍然必須是除式的第一項。若我們要解的方程式是theta*A=y,則同樣的概念可得到最小平方解theta=y/A。,根據上拋物線數學模型,我們可以預測美國在2000年的人口總數為:範例10-3:census02.m,以模型預測人口總數,loadcensus.mat%載入人口資料A=ones(size(cdate),cdate,cdate.2;theta=Apop;%利用左除,找出最佳的theta值t=2000;pop2000=1,t,t2*theta;%在2000年美國人口線數預測值t=2010;pop2010=1,t,t2*theta;%在2010年美國人口線數預測值fprintf(美國人口在2000年的預測值=%g(百萬人)n,pop2000);fprintf(美國人口在2010年的預測值=%g(百萬人)n,pop2010);,美國人口在2000年的預測值=274.622(百萬人)美國人口在2010年的預測值=301.824(百萬人),上述例子推廣,得到一個n次多項式:利用多項式的數學模型來進行曲線擬合,通稱為多項式擬合(PolynomialFitting)由於多項式擬和的應用面很廣,MATLAB提供polyfit指令來找出多項式最佳參數Polyval指令來進行多項式的求值,多項式擬和,使用polyfit%進行二次多項式擬合,找出theta值fprintf(2000年的預測值=%g(百萬人)n,polyval(theta,2000);fprintf(2010年的預測值=%g(百萬人)n,polyval(theta,2010);,在2000年的預測值=274.622(百萬人)在2010年的預測值=301.824(百萬人),使用polyfitxx,yy,zz=peaks(pointNum);zz=zz+randn(size(zz);%加入雜訊surf(xx,yy,zz);axistight,現在我們要用已知的基底函數,來找出最佳的、和範例10-6:peaks02.m由此找出的值和最佳值相當接近。,曲面擬合範例(4/6),pointNum=10;xx,yy,zz=peaks(pointNum);zz=zz+randn(size(zz)/10;%加入雜訊x=xx(:);%轉為行向量y=yy(:);%轉為行向量z=zz(:);%轉為行向量A=(1-x).2.*exp(-(x.2)-(y+1).2),(x/5-x.3-y.5).*exp(-x.2-y.2),exp(-(x+1).2-y.2);theta=Az%最佳的theta值,theta=3.0088-10.0148-0.2924,根據上求得之參數,可以輸入較密的點,得到迴歸後的曲面範例10-7:peaks03.m,曲面擬合範例(5/6),pointNum=10;xx,yy,zz=peaks(pointNum);zz=zz+randn(size(zz)/10;%加入雜訊x=xx(:);y=yy(:);z=zz(:);%轉為行向量A=(1-x).2.*exp(-(x.2)-(y+1).2),(x/5-x.3-y.5).*exp(-x.2-y.2),exp(-(x+1).2-y.2);theta=Az;%最佳的theta值%畫出預測的曲面pointNum=31;xx,yy=meshgrid(linspace(-3,3,pointNum),linspace(-3,3,pointNum);,在上圖中,我們猜對了基底函數,因此得到非常好的曲面擬合。只要基底函數正確,而且雜訊是正規分佈,那麼當資料點越來越多,上述的最小平方法就可以逼近參數的真正數值。,曲面擬合範例(6/6),x=xx(:);y=yy(:);%轉為行向量A=(1-x).2.*exp(-(x.2)-(y+1).2),(x/5-x.3-y.5).*exp(-x.2-y.2),exp(-(x+1).2-y.2);zz=reshape(A*theta,pointNum,pointNum);surf(xx,yy,zz);axistight,非線性迴歸(NonlinearRegression)是一個比較困難的問題,原因如下:無法一次找到最佳解。無法保證能夠找到最佳解。須引用各種非線性最佳化的方法。各種相關數學性質並不明顯。以數學來描述,假設所用的數學模型是其中是輸入向量,是可變非線性函數,y是輸出變數。總平方誤差為,非線性迴歸,用一般最佳化(Optimization)的方法,來找出的最小值,例如梯度下降法(GradientDescent)Simplex下坡式搜尋(SimplexDownhillsearch):此方法即為fminsearch指令所採用的方法假設所用的數學模型為其中、為線性參數,但1、2為非線性參數總平方誤差可表示:欲找出使為最小的、1及2,需將E寫成一函式,並由其它最佳化的方法來求出此函式的最小值。,非線性迴歸:誤差值的最小化,我們使用errorMeasure1.m來計算誤差值範例10-8:errorMeasure01.m其中theta是參數向量,包含了、1及2,data則是觀察到的資料點,傳回的值則是總平方誤差。,使用fminsearch的範例(1/3),functionsquaredError=errorMeasure1(theta,data)x=data(:,1);y=data(:,2);y2=theta(1)*exp(theta(3)*x)+theta(2)*exp(theta(4)*x);squaredError=sum(y-y2).2);,欲求出的最小值,我們可使用fminsearch指令範例10-9:nonlinearFit01.m,使用fminsearch的範例(2/3),loaddata.txttheta0=0000;tictheta=fminsearch(errorMeasure1,theta0,data);fprintf(計算時間=%gn,toc);x=data(:,1);y=data(:,2);y2=theta(1)*exp(theta(3)*x)+theta(2)*exp(theta(4)*x);plot(x,y,ro,x,y2,b-);legend(Sampledata,Regressioncurve);fprintf(誤差平方和=%dn,sum(y-y2).2);,上圖的曲線為fminsearch指令產生的迴歸曲線。fminsearch指令是一個使用Simplex下坡式搜尋法(DownhillSimplexSearch)的最佳化方法,用來找出errorMeasure1的極小值,並傳回theta的最佳值。,使用fminsearch的範例(3/3),計算時間=0.03誤差平方和=5.337871e-001,改良方向上述方法把所有參數全部視為非線性參數。混成法將線性與非線性參數分開,各用不同的方法來處理。上例數學模型為、線性參數:最小平方法,即左除或1、2非線性參數:Simplex下坡式搜尋(即fminsearch)混成法的優點最小平方法能夠在非線性參數固定的情況下,一次找到最好的線性參數的值,因為搜尋空間的維度由4降為2,最佳化會更有效率,上述範例的改良,使用上述混成(Hybrid)的方法,函式errorMeasure1須改寫成errorMeasure2範例10-10:errorMeasure2.mlambda是非線性參數向量,data仍是觀察到的資料點,a是利用最小平方法算出的最佳線性參數向量,傳回的squareError仍是總平方誤差,混成法範例(1/3),functionsquaredError=errorMeasure2(lambda,data)x=data(:,1);y=data(:,2);A=exp(lambda(1)*x)exp(lambda(2)*x);a=Ay;y2=a(1)*exp(lambda(1)*x)+a(2)*exp(lambda(2)*x);squaredError=sum(y-y2).2);,欲用此混成法求出誤差平方和的最小值範例10-11:nonlinearFit02.m,混成法範例(2/3),loaddata.txtlambda0=00;ticlambda=fminsearch(errorMeasure2,lambda0,data);fprintf(計算時間=%gn,toc);x=data(:,1);y=data(:,2);A=exp(lambda(1)*x)exp(lambda(2)*x);a=Ay;y2=A*a;plot(x,y,ro,x,y2,b-);legend(Sampledata,Regressioncurve);fprintf(誤差平方和=%dn,sum(y-y2).2);,此種混成法可以產生較低的誤差平方和,同時所需的計算時間也比較短。,混成法範例(3/3),計算時間=0.02誤差平方和=1.477226e-001,我們亦可利用變形法(Transformation),將一數學模型轉換成只包含線性參數的模型。假設一模型為:取自然對數,可得:ln(a)及b成為線性參數,我們即可用最小平方法找出其最佳值範例10-12:transformFit01.m,變形法,loaddata2.txtx=data2(:,1);%已知資料點的x座標y=data2(:,2);%已知資料點的y座標A=ones(size(x)x;,a=4.3282b=-1.8235誤差平方和=8.744185e-001,變形法範例(1/2),theta=Alog(y);subplot(2,1,1)plot(x,log(y),o,x,A*theta);xlabel(x);ylabel(ln(y);title(ln(y)vs.x);legend(Actualvalue,Predictedvalue);a=exp(theta(1)%辨識得到之參數b=theta(2)%辨識得到之參數y2=a*exp(b*x);subplot(2,1,2);plot(x,y,o,x,y2);xlabel(x);ylabel(y);legend(Actualvalue,Predictedvalue);title(yvs.x);fprintf(誤差平方和=%dn,sum(y-y2).2);,第一個小圖是ln(y)對x的作圖,第二個小則是y對x的作圖。經由變形法之後,此最小平方法所得到的最小總平方誤差是而不是原模型的總平方誤差:通常E為最小值時,E不一定是最小值,但亦離最小值不遠矣!,變形法範例(2/2),若要求取原始E的最小值,可再用fminsearch,並以變形法得到的a及b為搜尋的起點範例10-13:transformFit02.m,變形法之改進範例(1/2),loaddata2.txtx=data2(:,1);%已知資料點的x座標y=data2(:,2);%已知資料點的y座標A=ones(size(x)x;theta=Alog(y);a=exp(theta(1)%辨識得到之參數b=theta(2)%辨識得到之參數theta0=a,b;%fminsearch的啟始參數theta=fminsearch(errorMeasure3,theta0,data2);x=data2(:,1);y=data2(:,2);y2=theta(1)*exp(theta(2)*x);,誤差平方和=1.680455e-001,變形法之改進範例(2/2),plot(x,y,o,x,y2);xlabel(x);ylabel(y);legend(Actualvalue,Predictedvalue);title(yvs.x);fprintf(誤差平方和=%dn,sum(y-y2).2);,由上述範例可以看出,我們可以先使用變形法,先找出大略的參數值,再用fminsearch來對誤差平方和進行最小化,因此得到的誤差平方和,比只用變形法還要小。,以下是一些變形法可用的非線性模型,以及相關的轉換方法:,可使用變形法的數學模型(1/3),可使用變形法的數學模型(2/3)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025至2031年中国2MM格法玻璃行业投资前景及策略咨询研究报告
- 2025至2030年中国过滤槽数据监测研究报告
- 2025木材采购合同协议范本下载
- 2025至2030年中国组合螺钉旋具数据监测研究报告
- 2025至2030年中国碾米设备数据监测研究报告
- 2025至2030年中国电位器式位移传感器数据监测研究报告
- 2025至2030年中国消防腰斧数据监测研究报告
- 新建轻质砖墙体施工方案
- 齐河简易轻钢房施工方案
- 梁平酒店铝单板施工方案
- 新时代社区治理存在的问题及对策研究-以XX社区为例
- 《西方经济学》说课
- 安标受控件采购管理制度
- 《针灸神奇作用》课件
- 美国医疗的社会变迁
- 亚低温的治疗与护理
- 2023全新混凝土罐车运输安全协议
- 防高坠自查自纠台账
- 市政工程消耗量定额 zya1-31-2015
- 汽车托管租赁合同
- 国家开放大学《土木工程力学(本)》形考作业1-5参考答案
评论
0/150
提交评论