滑动平均滤波法
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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); } } 运行结果