滑动平均值滤波

     关于数据采集的滑动平均值滤波的算法
         —王超杰
        以ADC为例,采集口的模拟量可能夹杂着不同频段,不同峰值的干扰信号,这些干扰信号和要采集的模拟量互相干扰,那么ADC采集的数据量就会偏移原有的真实结果。那么通过硬件与数字滤波两种手段可大大减少采集误差,提高精度。
        一般滤波均通过程序算法滤除,其包括去极值滤波、算术平均值滤波、滑动平均值滤波、加权平均滤波等。
        今天重点讲一下滑动平均值滤波。其重要的是将**本次转化的结果与过去的N-1次的值之和一起求平均值 **,将此值作为本次AD的采集结果。

以下为一种滑动滤波小程序:

#define     N    5;

typedef unsigned int uint;

uint    ValueIAddress[N], *Ap, RealAD_Value;  /**AD采集数字量临时存储区 , 中间存储长度指针变量 , AD值**/

/**AD采集函数**/

void AD_Collect(void)

{       

        Ap = ValueIAddress;/**初始化指向数组的首元素**/

        RealAD_Value = AD_Filter(Value);/**此Value为实采数据**/

}

/**滑动滤波**/

uint AD_Filter(Value);

{

    uint Sum , *P;

    *Ap = Value;/**给当前ValueIAddress[N]数组赋值,因为Ap的首地址就是ValueIAddress的首地址**/

     Ap++;/**地址++ ,准备好向数组的下一个元素赋值**/

    if(Ap >= ValueIAddress+N)/**如果数组超N界,回到首数组首元素**/

        Ap = ValueIAddress;

    for(P = ValueIAddress;P < ValueIAddress+N;P++)

    {

         Sum = Sum + *P;/**数组N个元素求和**/

    }

    Sum = Sum/N;

    return Sum;

}

猜你喜欢

转载自blog.csdn.net/Wangchaojie222/article/details/83657701