平滑滤波算法
设置一个数据缓存区,每新采集一个数据便存入暂存区中,同时去掉一个最老数据,保存这N个数据始终是最新更新的数据。采用环型队列结构可以方便地实现这种数据存放方式。
#define Data_unm 10
float fifter(float Data_New)
{
static float Data_buff[Data_unm];
float Result = 0;
char i;
Data_buff[0] = Data_New;
for(i=Data_unm-1;i>=1;i--)
{
Data_buff[i]=Data_buff[i-1];
Result +=(Data_buff[i]/9);
}
return Result;
}
算术平均滤波算法
该算法通过连续读取几个数据的方式来求取平均值的方法实现滤波。代码也是相当简单。
#define N 5 //连续读取多少个值取平均值
int filter()
{
int sum=0,data;
char count;
for(count=0;count<N;count++)
{
printf("请输入一个数:");
scanf("%d",&data); //获取新的数据
sum+=data;
}
return (int)(sum/N);
}
|