How to compute the moving average of a signal with 6-hour window length and shifted 15 min at a time?
    조회 수: 3 (최근 30일)
  
       이전 댓글 표시
    
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
  KALYAN ACHARJYA
      
      
 2019년 9월 22일
				
      편집: KALYAN ACHARJYA
      
      
 2019년 9월 22일
  
			I am working on ECG signal and I want to determine the HR.
채택된 답변
  Dimitris Kalogiros
      
 2019년 9월 22일
        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');
추가 답변 (1개)
  Steven Lord
    
      
 2019년 9월 22일
        Use movmean with a datetime or duration SamplePoints input. Specify the window using a duration array.
참고 항목
카테고리
				Help Center 및 File Exchange에서 Data Preprocessing에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!