How to compute the moving average of a signal with 6-hour window length and shifted 15 min at a time?
2 views (last 30 days)
Show older comments
Mohanad Alkhodari
on 22 Sep 2019
Commented: Mohanad Alkhodari
on 27 Sep 2019
Hello,
I am working on ECG signal and I want to determine the HR.
How to compute the moving average of a signal with 6-hour window length and shifted 15 min at a time?
Sampling frequency is 200.
Thank you
2 Comments
KALYAN ACHARJYA
on 22 Sep 2019
Edited: KALYAN ACHARJYA
on 22 Sep 2019
I am working on ECG signal and I want to determine the HR.
Accepted Answer
Dimitris Kalogiros
on 22 Sep 2019
Hi Mohanad
Bellow, you will find an example, where a moving average corresponding to a 6h window, is applied upon a signal taken within an interval of 24h with Fsampling=200Hz
clearvars; close all; clc;
%% input data
Fs = 200; % 200 Hz sampling frequency
time = 0:(1/Fs):(24*3600-1); % data collected within 24 hours
data = sin(2*pi*(1/2E5).*time)+0.2*randn(size(time)); % an example of input data: a sine with some noise
%% averanging
Kstep = (15*60)*Fs; % step of 15 minutes
Kwindow = (6*3600)*Fs; % aneranging window is 6 hours
meanData=[]; meanTime=[];
for k=1:Kstep:length(data)-Kwindow
dataWindow=data(1:k+Kwindow);
meanData=[meanData mean(dataWindow)];
meanTime=[meanTime time(k+floor(Kwindow/2))];
end
figure;
%mean values are depocted at the middle of their corresponding 6h window
plot(time, data); hold on;
plot(meanTime, meanData, '-*'); zoom on; grid on;
xlabel('time'); ylabel('data values');
More Answers (1)
Steven Lord
on 22 Sep 2019
Use movmean with a datetime or duration SamplePoints input. Specify the window using a duration array.
See Also
Categories
Find more on Signal Generation and Preprocessing in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!