单片机的滤波算法(C语言版)
Posted 青柠一笑
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了单片机的滤波算法(C语言版)相关的知识,希望对你有一定的参考价值。
废话不多说,直接上干货!!!如果正好帮到你,请给我一个赞😄😄。
平滑滤波算法
设置一个数据缓存区,每新采集一个数据便存入暂存区中,同时去掉一个最老数据,保存这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);
}
以上是关于单片机的滤波算法(C语言版)的主要内容,如果未能解决你的问题,请参考以下文章