最小二乘估计及模型阶次辨.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE PAGE 9 实验二 最小二乘估计及模型阶次辨识 一、实验目的 ① 通过实验,掌握最小二乘参数辨识方法 ② 通过实验,掌握模型阶次辨识方法 二、实验内容 1、仿真模型 实验所用的仿真模型如下: 框图表示 e(k) ++v(k)u(k) e(k) + + v(k) u(k) z(k) y y(k) 模型表示 其中u(k)和z(k)分别为模型的输入和输出变量;v(k)为零均值、方差为1、服从正态分布的白噪声;为噪声的标准差(实验时,可取0.0、0.1、0.5、1.0);输入变量u(k)采用M序列,其特征多项式取,幅度取1.0。 2、辨识模型 辨识模型的形式取 为方便起见,取,即 根据仿真模型生成的数据和,确定模型n,并辨识模型的参数; 3、辨识算法 模型阶次辨识 根据行列式比确定模型的阶次 令:,其中, 定义判别式子(行列式比): 其中: 若较有显著增加时,则取阶次估计值为。 ② 模型参数辨识: 最小二乘一次完成算法: 设输入信号的取值是从k =1到k =16的M序列,则待辨识参数为=。其中,被辨识参数、观测矩阵z L、H L的表达式为 , , 三、实验步骤 (1) 掌握最小二乘一次完成算法和根据行列式比确定模型的阶次的基本原理。 (2) 设计实验方案。 (3) 编制实验程序。 (4) 调试程序,研究实验问题,记录数据。 (5) 分析实验结果,完成实验报告。 四、实验结果 (1) 实验对象及参数 实验模型如下图所示: (2) 程序代码: a.主函数 function leastSquaresMainFuc a1 = 1.5;a2 = -0.7;b1 = 1; b2 = 0.5; DR = estModelOrder(a1,a2,b1,b2); display(DR); estimate = leastSquares(a1,a2,b1,b2); display(estimate); recursiveLeastSquares(a1,a2,b1,b2) end b.模型阶次辨识函数 function DR = estModelOrder(a1,a2,b1,b2) x=[0 1 0 1 1 0 1 1 1]; %initial value n=1003; %n为脉冲数目,L = 1000,且存在k-2,故取1003 M=[]; %存放M序列 for i=1:n temp=xor(x(4),x(9)); M(i)=x(9); for j=9:-1:2 x(j)=x(j-1); end x(1)=temp; end %产生高斯白噪声 v=randn(1,1003); z=[]; z(1)=-1; z(2)=0; L=1000; for i=3:L+3 z(i)=a1*z(i-1)+a2*z(i-2)+b1*M(i-1)+b2*M(i-2)+v(i); end % n=1 for i=1:L H1(i,1)=z(i); H1(i,2)=M(i); end A=H1*H1/L; % n=2 for i=1:L H2(i,1)=z(i+1); H2(i,2)=z(i); H2(i,3)=M(i+1); H2(i,4)=M(i); end B=H2*H2/L; %n=3 for i=1:L H3(i,1)=z(i+2); H3(i,2)=z(i+1); H3(i,3)=z(i); H3(i,4)=M(i+2); H3(i,5)=M(i+1); H3(i,6)=M(i); end C=H3*H3/L; %n=4 for i=1:L H4(i,1)=z(i+3); H4(i,2)=z(i+2); H4(i,3)=z(i+1); H4(i,4)=z(i); H4(i,5)=M(i+3); H4(i,6)=M(i+2); H4(i,7)=M(i+1); H4(i,8)=M(i); end D=H4*H4/L; DR(1)=det(A)/det(B); DR(2)=det(B)/det(C); DR(3)=det(C)/det(D); i=1:3; figure(1) stem(i,DR); %display(DR) title(利用行列式比估计模型阶次) xlabel(阶次) ylabel(行列式比) end c.批量最小二乘估计 function estimate = leastSquares(a1,a2,b1,b2) x=[0 1 0 1 1 0 1 1 1

文档评论(0)

_______ + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档