滑动平均滤波法

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

递推平均滤波法(又称滑动平均滤波法)

方法:

把连续取N个采样值看成一个队列

队列的长度固定为N

每次采样到一个新数据放入队尾,并扔掉原来队首的一次数据.(先进先出原则)

把队列中的N个数据进行算术平均运算,就可获得新的滤波结果N值的选取:流量,N=12;压力:N=4;液面,N=4~12;温度,N=1~4

优点:

对周期性干扰有良好的抑制作用,平滑度高

适用于高频振荡的系统

缺点:

灵敏度低

对偶然出现的脉冲性干扰的抑制作用较差

不易消除由于脉冲干扰所引起的采样值偏差

不适用于脉冲干扰比较严重的场合

比较浪费RAM

程序

#include

#define N 3

char value[N];

char

data[15]={10,14,13,12,16,11,10,15,18,11,13,12,14,16,10};

int i=0,j=0;

float filter(void){

int count;

float sum=0;

value[i++]=data[j++];

if(i>2) {

i=0;

sum=0;

}

for(count=0;count

return (float)(sum/N);

}

void main(void){

float data_a=0;

char num=0;

for(num=0;num<15;num++)

{

data_a=filter();

printf("%.3f\n",data_a);

}

}

运行结果

相关文档
最新文档