smoothing a graph using matlab

1 次查看(过去 30 天)
how can I smooth data imported from one column (Excel sheet) using Matlab
how to smooth the corners?

采纳的回答

Star Strider
Star Strider 2022-2-20
A frequency-selective filter can preseerve the essential shape of the signal, eliminating only the high-frequency oscillations in the ‘valleys’.
Try this —
V1 = readmatrix('https://www.mathworks.com/matlabcentral/answers/uploaded_files/900720/data.xlsx');
L = numel(V1);
t = linspace(0, L-1, L);
Ts = t(2)-t(1);
Fs = 1/Ts;
Fn = Fs/2;
NFFT = 2^nextpow2(L);
FTV1 = fft(V1,NFFT);
Fv = linspace(0, 1, NFFT/2+1)*Fn;
Iv = 1:numel(Fv);
figure
plot(Fv, abs(FTV1(Iv))*2)
grid
xlabel('Frequency')
ylabel('Amplitude')
title('Fourier Transform (Detail)')
xlim([0 0.05])
UpperPassband = 0.023;
V1F = lowpass(V1, UpperPassband, Fs, 'ImpulseResponse','iir');
figure
subplot(2,1,1)
plot(t, V1)
grid
title('Original')
subplot(2,1,2)
plot(t, V1F)
grid
xlabel('Time')
title('Filtered')
Adjust the ‘UpperPassband’ frequency to produce the desired result.
.
  2 个评论
Image Analyst
Image Analyst 2022-2-20
This looks like it maintains the shape of the "good" part better than the Savistky-Golay filter.
Star Strider
Star Strider 2022-2-20
I like the sgolayfilt function and use it to filter broadband noise. However, this is band-limited noise (the reason I did the fft was to determine that) so a frequency-selective filter works best in this instance.

请先登录,再进行评论。

更多回答(1 个)

Image Analyst
Image Analyst 2022-2-20
You could use sgolayfilt() to fit a sliding window to the data. Window width would be about the width of one of those humps. It looks kind of like a sine or cosine wave thus you can fit it to a 4th or 5th order polynomial. Attach your data if you need more help.
  6 个评论
Image Analyst
Image Analyst 2022-2-20
编辑:Image Analyst 2022-2-20
If it worked, can you click "Accept this answer" for the best answer? Thanks in advance.

请先登录,再进行评论。

标签

Community Treasure Hunt

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

Start Hunting!

Translated by