声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2218|回复: 0

[经典算法] 零阶局域预测如何matlab编程?给出算法,希望能得到帮助哦

[复制链接]
发表于 2009-6-1 10:12 | 显示全部楼层 |阅读模式

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

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

x
零阶局域预测如何编程?给出算法,希望能得到帮助哦算法:
第一步:建立相空间,选定嵌入维数m和延迟时间T,重构像空间。Xk={xk,xk+T,....,xk+(m-1)T}, k=1,2,..., n=N-(m-1)T
第二步:寻找最近邻点,在像空间中,通过计算各点与XN-(m-1)T之间的欧式距离,找出XN-(m-1)T的最近邻点。
第三步:求取X'n+1,如果Xn的最近的为i,则X'n+1=Xi+1
第四步:得到预测值x'N+1=X'n+1,m,由X'n+1={xn+1,xn+1+T,....,xn+1+(m-1)T},在进行一点预测时,如T=1,此时X'n+1的分量中,只有xN+1是未知的,将X'n+1的最后一维取出,即为预测值

部分算法
function [FChaosPredict] =FunctionChaosPredict(Data,N,mtbp,deltaT,tao,d,MaxStep)
%Data是一维信号时间序列,N是信号数据长度,mtbp,deltaT,tao,d分别是重构相空间的平均时间序列、采样周期、时延及嵌入维
roll=Data;%取横摇数据
M = N - (d - 1)*tao;
for i = 1 : M
    for j = 1 : d
        MatrixX(i,j) = roll(i + (j - 1)*tao);
    end
end
%计算相空间中第M点与各点的距离
for j = 1 : (M - 1)
    Dis(j) = norm(MatrixX(M,:) - MatrixX(j,:),2);
end
%排序计算相空间中第M点的(m+1)个参考邻近点
for i = 1 : (d + 1)
    NearDis(i) = Dis(i);
    NearPos(i) = i;
end
for i = (d + 2) : (M - mtbp)
    for j = 1 : (d + 1)
        if (abs(i-j)>mtbp) %& abs(i-j)<10*mtbp
            if(Dis(i) < NearDis(j))
                NearDis(j) = Dis(i);
                NearPos(j) = i;
               
                break;
            end
        end
    end
end
回复
分享到:

使用道具 举报

您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-12-29 17:31 , Processed in 0.054537 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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