我正在尝试制作一个简单的过滤传入数据(保存最大和最小选择),例如:每秒 44100 个样本,但屏幕必须显示 1000。我选择 44.1 个样本范围内的最大值或最小值,并且输出画面。但是,这个算法不是很准确。在代码中,它看起来像这样:
示例伪算法
float max = 0;
float min = 0;
float filter = 0;
float step = 44100/1000;
for(int i = 0 ; i < 44100; i++){
if(input[i] > 0)
if(max < input[i])
max = input[i];
if(input[i] < 0)
if(min > input[i])
min = input[i];
filter++;
if(filter >= step){
filter = filter - step;
//1st version (bad version)
memory[count] = max + min;
//2nd version (bad version)
if(max > abs(min))
memory[count] = max;
else if(max < abs(min))
memory[count] = min;
//3nd version (only maximum)
memory[count] = max; //work great, but only > 0
//4nd version (only minimum)
memory[count] = min; //work great, but only < 0
max = 0;
min = 0;
count++;
if(count >= 1000)
count = 0;
};
};
我究竟做错了什么?单独地,一切正常(最大或最小),但是当连接在一起时,结果很糟糕。
我有图片,但我不能在这里粘贴它们。链接到这篇文章下的图片。