1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/seanwei-ECG-analyzer

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
MovingAverage.cpp 947
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
Piotr Matuszkiewicz Отправлено 24.01.2013 08:20 6580b09
#include "MovingAverage.h"
void MovingAverage::removeBaseline(ECGSignalChannel &inputSignal, ECGSignalChannel &outputSignal, int span)
{
auto signalLength = outputSignal-> signal -> size;
for(long index = 0; index < signalLength; index++)
{
auto edge = ceil((float)span/2);
auto inputValue = gsl_vector_get (inputSignal -> signal, index);
if(index < edge || index > signalLength - edge)
{
gsl_vector_set(outputSignal -> signal, index, inputValue);
}
else
{
auto avgValue = this->calculateAvgValueOfNeighbours(inputSignal -> signal, index, span);
gsl_vector_set (outputSignal -> signal, index, -(inputValue-avgValue));
}
}
}
double MovingAverage::calculateAvgValueOfNeighbours(gsl_vector *signal, int currentIndex, int span)
{
double sum = 0.00;
for(int i = 1; i <= span/2; i++)
{
sum += gsl_vector_get (signal, currentIndex - i);
sum += gsl_vector_get (signal, currentIndex + i);
}
return sum/span;
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/seanwei-ECG-analyzer.git
git@api.gitlife.ru:oschina-mirror/seanwei-ECG-analyzer.git
oschina-mirror
seanwei-ECG-analyzer
seanwei-ECG-analyzer
master