clear all;close all;clc format short g sigma = 0.2; p = 1; PlotLength =5000; length1=PlotLength+100+1000; a = [1,-0.56,0.42]; b = [0,0.9,0.6]; c = [1,-0.3,0.2]; d = [1,0.3,-0.2]; na=2;nb=2;nc=2;nd=2; n1=na+nb; n2=nc+nd; pr0=[a(2:na+1), b(2:nb+1), c(2:nc+1), d(2:nd+1)]'; n=length(pr0); p0=10^6; P2= eye(n)*p0; pr1=ones(n,1)/p0; pr2=pr1; rand('state',15); u=(rand(length1,1)-0.5)*sqrt(12); randn('state',15); v=randn(length1,1)*sigma; y=ones(10*n,1)/p0; w=zeros(n,1); for t=n:length1 w(t)=pr0(n1+1:n)'*[-w(t-1:-1:t-nc);v(t-1:-1:t-nd)]+v(t); y(t)=pr0(1:n1)'*[-y(t-1:-1:t-na);u(t-1:-1:t-nb)]+w(t); end w1=ones(10*n,1)/p0; w2=w1; v1=ones(10*n,1)/p0; v2=v1; j1=0;jj=0; for t=24:length1 jj=jj+1; % MI-RGELS i=1; for k=t:-1:t-p+1 varphi2=[-y(t-1:-1:t-na);u(t-1:-1:t-nb);-w2(t-1:-1:t-nc);v2(t-1:-1:t-nd)]; Phi2(:,i)=varphi2; i=i+1; end Y=y(t:-1:t-p+1); L2=P2*Phi2/(eye(p)+Phi2'*P2*Phi2); P2=P2-L2*(Phi2'*P2); pr2=pr2+L2*(Y-Phi2'*pr2); w2(t)=y(t)-Phi2(1:n1,1)'*pr2(1:n1); v2(t)=y(t)-Phi2(:,1)'*pr2; if jj==length1; break end end
时间: 2024-04-21 21:24:32 浏览: 185
ga_main_gamain_tic函数_遗传算法源码_AllClear_
这段代码实现了多新息递推最小二乘辨识算法(MI-RGELS)并进行了仿真实验。其中包括了参数初始化、随机序列生成、系统输出计算和MI-RGELS算法的迭代过程。
在这段代码中,首先对参数进行了初始化,然后生成随机序列`u`和噪声序列`v`。接着通过循环计算系统输出`y`和创新项`w`。
在MI-RGELS算法的迭代过程中,使用了矩阵形式的MI-RGELS算法来估计参数向量。通过迭代更新参数估计值`pr2`,同时更新创新项`w2`和噪声项`v2`。最后,通过循环进行多次迭代,直到达到指定的仿真长度。
请注意,这只是一个简单的示例,可能需要根据具体需求进行修改和优化。希望对您有所帮助!
阅读全文