欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

滑动平均算法

程序员文章站 2022-07-13 14:50:45
...

这里提到的滑动平均滤波算法对于实时采样的一些单片机,传感器之类的,要对实时动态获取的所有值做一个求平均的运算,当然这里所说的实时数据的平均值要有一个步长(比如说最近20次最新取值算平均)。如果取N个采样值求平均,存储区中必须开辟N个数据的暂存区。每新采集一个数据便存入暂存区中,同时去掉一个最老数据,保存这N个数据始终是最新更新的数据。采用环型队列结构可以方便地实现这种数据存放方式。

滑动平均算法

两个循环遍历两个判断清空

程序代码如下:
char value_buff[N];                     //N相当于选定一个窗口大小,对窗口数据做平均!
char i=0;
char filter()
{
     char count;
     int sum=0;
     value_buff[i++]=get_data;  //get_data为实时获取的数据
     if(i==N)
         i=0;              //当数据大于数组长度,替换数据组的一个数据  相当于环形队列更新,先进先出!
if(count==5)sum=0;        //注意清空和
for(count=0;count<N;count++)
       sum+=value_buff[count];
return (char)(sum/N);
}

 

相关标签: 实时