Слияние кода завершено, страница обновится автоматически
#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 )