声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 896|回复: 1

[编程技巧] 擦鸟提问(全部程序)

[复制链接]
发表于 2011-1-4 21:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
clear;clc;%清理工作间变量
L=100;% M序列的周期
y1=1;y2=1;y3=1;y4=0;%四个移位积存器的输出初始值
for i=1:L;%开始循环,长度为L
    x1=xor(y3,y4);%第一个移位积存器的输入是第3个与第4个移位积存器的输出的“或”
    x2=y1;%第二个移位积存器的输入是第3个移位积存器的输出
    x3=y2;%第三个移位积存器的输入是第2个移位积存器的输出
    x4=y3;%第四个移位积存器的输入是第3个移位积存器的输出
    y(i)=y4;%取出第四个移位积存器幅值为"0"和"1"的输出信号,
    if y(i)>0.5,u(i)=-0.5;%如果M序列的值为"1"时,辨识的输入信号取“-0.03”
    else u(i)=0.5;%当M序列的值为"0"时,辨识的输入信号取“0.03”
    end%小循环结束
    y1=x1;y2=x2;y3=x3;y4=x4;%为下一次的输入信号做准备
end%大循环结束,产生输入信号u
figure(1);%第1个图形
stem(u),grid on%以径的形式显示出输入信号并给图形加上网格
v=wgn(1,100,1);%1行15列   强度为1
stem(v),grid on
z(2)=0;z(1)=0;%取z的前两个初始值为零
for k=3:L;%循环变量从3到25   
    z(k)=1.5*z(k-1)-0.7*z(k-2)+u(k-1)+0.5*u(k-2)+0.85*v(k-1)+0.5*v(k-2);
end
%RLS递推最小二乘辨识
c0=[0.001 0.001 0.001 0.001 0.001 0.001]';%直接给出被辨识参数的初始值,即一个充分小的实向量
p0=10^6*eye(6,6);%直接给出初始状态P0,即一个充分大的实数单位矩阵
E=0.000000005;%相对误差E=0.000000005
c=[c0,zeros(6,100)];%被辨识参数矩阵的初始值及大小
e=zeros(5,100);%相对误差的初始值及大小
for k=3:L; %开始求K
    h1=[-z(k-1),-z(k-2),u(k-1),u(k-2),v(k-1),v(k-2)]'; x=h1'*p0*h1+1; x1=inv(x); %开始求K(k)
    k1=p0*h1*x1;%求出K的值
    d1=z(k)-h1'*c0; c1=c0+k1*d1;%求被辨识参数c
    e1=c1-c0;%求参数当前值与上一次的值的差值
    e2=e1./c0;%求参数的相对变化
    e(:,k)=e2; %把当前相对变化的列向量加入误差矩阵的最后一列      
    c0=c1;%新获得的参数作为下一次递推的旧参数
    c(:,k)=c1;%把辨识参数c 列向量加入辨识参数矩阵的最后一列
    p1=p0-k1*k1'*[h1'*p0*h1+1];%求出 p(k)的值
    p0=p1;%给下次用
    if e2<=E break;%若参数收敛满足要求,终止计算
    end%小循环结束
end%大循环结束
c%显示被辨识参数
e%显示辨识结果的收敛情况
%分离参数
a1=c(1,:); a2=c(2,:); b1=c(3,:); b2=c(4,:); ea1=e(1,:); ea2=e(2,:); eb1=e(3,:); eb2=e(4,:);
figure(2);%第2个图形
i=1:L;%横坐标从1到15
plot(i,a1,'r',i,a2,':',i,b1,'g',i,b2,':') %画出a1,a2,b1,b2的各次辨识结果
title('Parameter Identification with Recursive Least Squares Method')%图形标题
figure(3); %第3个图形
i=1:L; %横坐标从1到15
plot(i,ea1,'r',i,ea2,'g',i,eb1,'b',i,eb2,'r:') %画出a1,a2,b1,b2的各次辨识结果的收敛情况
title('Identification Precision') %图形标题


报错   ??? Subscripted assignment dimension mismatch.

Error in ==> Mgenerator at 35
    e(:,k)=e2; %把当前相对变化的列向量加入误差矩阵的最后一列

请大家多多指教   今晚就要   在线等  麻烦大家了
回复
分享到:

使用道具 举报

 楼主| 发表于 2011-1-4 22:16 | 显示全部楼层
v=wgn(1,100,1);%1行15列   强度为1
stem(v),grid on
本来没有这两句  是理想输出    我想加个白噪声
能加好后  测试好给我传一下吗   明天急需   546770711@qq.com
不胜感激
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-16 10:42 , Processed in 0.090261 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表