Matlab for 循环语句 50

就是采用分段拟合拟合的方法,每次都用5阶傅立叶进行函数拟合,一共86400个数据,每次取2800个数据,需要循环30次,即调用30次,这循环语句如何写。附上函数代码:fu... 就是采用分段拟合拟合的方法,每次都用5阶傅立叶进行函数拟合,一共86400个数据,每次取2800个数据,需要循环30次,即调用30次,这循环语句如何写。附上函数代码:
function ovm=BcreateFit(x,y,n);
xdata=x(:);
ydata=y(:);
ft=fittype(['fourier',num2str(n)']);
options=fitoptions(ft);
opstions.Display='Off'
[fitresult,gof]=fit(xdata,ydata,ft,options);
ovm=fitresult(xdata);
end
自己写的代码是这样的:
for i=1:30
x(:,i)=xdata(2800*(i-1)+1:2800*i);y(:,i)=ydata(2800*(i-1)+1:2800*i);
x=x(:,i);y=y(:,i);n=5;
ovm(:,i)=BcreateFit(x,y,n);
plot(x(:,i),y(:,i),'r');
end
但只调用了一次,即i=1.求大神指导,深表感谢!
展开
 我来答
hqxz556
2017-07-06 · TA获得超过2831个赞
知道大有可为答主
回答量:1686
采纳率:93%
帮助的人:576万
展开全部

没仔细研究你那个拟合函数的用法。

不过像这种需要分段处理数据的情况很多,有种在 matlab 里很常用的技巧感觉你可以学学:

假设原始数据(xdata)是一列 100 个数,你需要一次处理 13 个,那么下面这段代码先将这 100 数“折叠”成一个 13 行的矩阵(x)。 我这个例子里是折叠成 13 * 8 的矩阵了。

因为 100 不能整除 13,所以会在最后补零。如果你不需要补零,而是把最后的零头扔掉,那么就把 

ncol = ceil(nxdata/n);

改成 

ncol = fix(nxdata/n);

最后就可以在循环里一列一列的处理数据了。我这个例子只是 y(:,i) = x(:,i) 而已,你的情况应该就是调用你自已写的拟合函数。

最后再用

y = y(:);

把数据还原成一维的。

如果你需要把之前补零的值删掉也可以在还原成一维的时候去掉。

以下是一个小例子,仔细研究一下就能学会这个小技巧了。

xdata = (1:100).';
nxdata = length(xdata);

nrow = 13;  % 假设你需要一次处理 13 个数据
ncol = ceil(nxdata/nrow);
x = zeros(nrow, ncol, 'like', xdata);
size(x)
x(1:nxdata) = xdata(:);

y = zeros(nrow, ncol, 'like', xdata);

for i = 1:ncol
    y(:,i) = x(:,i);
end

y = y(:);

如果你在处理数据之前,能保证折叠之后是整除的,即无需补零。还用我这个小例子,比如需要折叠成 10 行,也可以用 reshape(xdata, 10, [])。[] 是让 matlab 自己算整除后是多少列。如:

x2 = reshape(xdata, 10, []);
size(x2)
大蘑菇先森
2014-04-23
知道答主
回答量:1
采纳率:0%
帮助的人:1384
展开全部
x(:,i),y(:,i)改成x{1,i},y{1,i},下面的也一样,你试试
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
GP_CQ
推荐于2018-03-22 · TA获得超过381个赞
知道小有建树答主
回答量:222
采纳率:0%
帮助的人:157万
展开全部
x=x(:,i);y=y(:,i);n=5;
ovm(:,i)=BcreateFit(x,y,n);
改成:
u=x(:,i);v=y(:,i);n=5;
ovm(:,i)=BcreateFit(u,v,n);
试试
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式