声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2539|回复: 2

[共享资源] 广义最小二乘算法程序

[复制链接]
发表于 2007-6-20 14:52 | 显示全部楼层 |阅读模式

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

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

x
:@) 下面这个程序是关于广义最小二乘算法的,希望大家共同讨论,多多提出改进意见。

%之前先运行input_output和LS程序%
fid=fopen('input.txt','r+');
U=fscanf(fid,'%f',a);
fclose(fid);
fid1=fopen('output1.txt','r+');
Y=fscanf(fid1,'%f',a);
fclose(fid1);
for i=1:a;
%计算系统模型的残差及参数%
y1=Y(3:a);
y2=Y(2:a);
u1=U(2:a);
H1=[y2;0];
H2=Y;
H3=-1*[u1;0];
H4=-1*U;
H=[H1 H2 H3 H4];
e=[y1;0;0]+H*Q;
e1=e(1:a-1);
e2=e(1:a-2);
E1=-1*[0;e1];
E2=-1*[0;0;e2];
E=[E1 E2];
F=inv(E'*E)*E'*e;
%使用估计参数对y、u进行滤波%
Y1=Y(1:a-1);
Y2=Y(1:a-2);
Z1=[0;Y1];
Z2=[0;0;Y2];
Z=[Z1 Z2];
Y=Y+Z*F;
U1=U(1:a-1);
U2=U(1:a-2);
Z1=[0;U1];
Z2=[0;0;U2];
Z=[Z1 Z2];
U=U+Z*F;
Y3=Y(1:a-1);
Y4=Y(1:a-2);
U3=U(1:a-1);
U4=U(1:a-2);
%根据滤波后的输入输出数据再次进行最小二乘参数估计,求Q%
D1=-1*[0;Y3];
D2=-1*[0;0;Y4];
D3=[0;U3];
D4=[0;0;U4];
D=[D1 D2 D3 D4];
QQ=inv(D'*D)*D'*Y;
q=norm(QQ-Q)/norm(Q);
Q=QQ;
if q<10e-14
    i
    q
    F
    Q
    break
end
end
ppp='help me'

[ 本帖最后由 eight 于 2007-6-20 15:24 编辑 ]

评分

1

查看全部评分

回复
分享到:

使用道具 举报

发表于 2011-9-11 08:21 | 显示全部楼层
没看懂的说哦
发表于 2012-11-25 23:02 | 显示全部楼层

先看到了程序,现在去找书籍,谢谢了
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-5-21 22:12 , Processed in 0.057113 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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