How to smooth a curve with movmean with consideration of the start and end of an array?

3 次查看(过去 30 天)
Hello.
I am trying to smooth out a curve with movmean.
My current code looks like this:
Start_i_len = 8;
smooth_offset = cell(Start_i_len, 1);
for i = 1:1:Start_i_len
smooth_offset{i} = movmean(Offset_itpl_mean{i}, 301);
end
The cell array contains 8 cells, with each consisting of 8192 values. What I want to do is, as it samples 301 values, I want it to connect the beginning and the end of the array (If that makes sense). So that when it smoothes out the values at the nearing the end of the array, it does so with consideration of the values at the start of the array and vice versa. Any ideas on how to do it?

回答(1 个)

Matt J
Matt J 2022-3-16
编辑:Matt J 2022-3-16
k=ones(1,301); k(8192)=0;
for i = 1:1:8
tmp=fwd.Offset_itpl_mean{i}(:).';
tmp=ifft(fft(tmp).*fft(k),'symmetric');
fwd.smooth_offset{i} = tmp;
end
  4 个评论
Michael Arvin
Michael Arvin 2022-3-16
I tried it and it is now 1x8192, but the values inside are very different from the original values of Offset_itpl_mean{} when I plot it. I did attach a mat file the question for the value of Offset_itpl_mean{}. If you have any other solution to it, I'd greatly appreciate it. Thanks!
Matt J
Matt J 2022-3-16
编辑:Matt J 2022-3-16
load save1
k=ones(1,301)/301; k(8192)=0; k=circshift(k,-150);
for i = 1:1:8
tmp=Offset_itpl_mean{i}(:).';
tmp=ifft(fft(tmp).*fft(k),'symmetric');
smooth_offset{i} = tmp;
end
plot(Offset_itpl_mean{i}); hold on
plot(smooth_offset{i}); hold off

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Spline Postprocessing 的更多信息

产品

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by