代码拉取完成,页面将自动刷新
#include "../include/convolution_filter.h"
#include <assert.h>
#include <string.h>
ConvolutionFilter::ConvolutionFilter() {
m_shiftRegister = nullptr;
m_impulseResponse = nullptr;
m_shiftOffset = 0;
m_sampleCount = 0;
}
ConvolutionFilter::~ConvolutionFilter() {
assert(m_shiftRegister == nullptr);
assert(m_impulseResponse == nullptr);
}
void ConvolutionFilter::initialize(int samples) {
m_sampleCount = samples;
m_shiftOffset = 0;
m_shiftRegister = new float[samples];
m_impulseResponse = new float[samples];
memset(m_shiftRegister, 0, sizeof(float) * samples);
memset(m_impulseResponse, 0, sizeof(float) * samples);
}
void ConvolutionFilter::destroy() {
delete[] m_shiftRegister;
delete[] m_impulseResponse;
m_shiftRegister = nullptr;
m_impulseResponse = nullptr;
}
float ConvolutionFilter::f(float sample) {
m_shiftRegister[m_shiftOffset] = sample;
float result = 0;
for (int i = 0; i < m_sampleCount - m_shiftOffset; ++i) {
result += m_impulseResponse[i] * m_shiftRegister[i + m_shiftOffset];
}
for (int i = m_sampleCount - m_shiftOffset; i < m_sampleCount; ++i) {
result += m_impulseResponse[i] * m_shiftRegister[i - (m_sampleCount - m_shiftOffset)];
}
m_shiftOffset = (m_shiftOffset - 1 + m_sampleCount) % m_sampleCount;
return result;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。