0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

常见的ADC滤波算法、优缺点及代码

strongerHuang 来源:strongerHuang 作者:strongerHuang 2022-11-16 09:25 次阅读

如今传感器的种类越来越多,数量也越来越多,而这些传感器很多都会用到模拟量,模拟量就离不开ADC

然而,我们单片机ADC采集的模拟量基本都会经过“滤波”处理才能使用,下面给大家分享一些常见的ADC滤波算法

一、限幅滤波

1、方法

根据经验判断两次采样允许的最大偏差值A

每次采新值时判断:若本次值与上次值之差<=A,则本次有效;若本次值与上次值之差>A,本次无效,用上次值代替本次。

2、优缺点

克服脉冲干扰,无法抑制周期性干扰,平滑度差。

3、代码

/* A值根据实际调,Value有效值,new_Value当前采样值,程序返回有效的实际值*/
#defineA10
charValue;
charfilter()
{
charnew_Value;
new_Value=get_ad();//获取采样值
if(abs(new_Value-Value)>A)returnValue;//abs()取绝对值函数
returnnew_Value;
}

二、中位值滤波

1、方法

连续采样N次,按大小排列

取中间值为本次有效值

2、优缺点

克服波动干扰,对温度等变化缓慢的被测参数有良好的滤波效果,对速度等快速变化的参数不宜。

3、代码

#defineN11
charfilter()
{
charvalue_buf[N];
charcount,i,j,temp;
for(count=0;count< N;count++)                                //获取采样值
 {
  value_buf[count] = get_ad();
  delay();
 }
 for(j = 0;j<(N-1);j++)
  for(i = 0;i<(n-j);i++)
  if(value_buf[i]>value_buf[i+1])
{
temp=value_buf[i];
value_buf[i]=value_buf[i+1];
value_buf[i+1]=temp;
}
returnvalue_buf[(N-1)/2];
}

三、算数平均滤波

1、方法

连续采样N次,取平均

N较大时平滑度高,灵敏度低

N较小时平滑度低,灵敏度高

一般N=12

2、优缺点

适用于存在随机干扰的系统,占用RAM多,速度慢。

3、代码

#defineN12
charfilter()
{
intsum=0;
for(count=0;count

四、递推平均滤波

1、方法

取N个采样值形成队列,先进先出

取均值

一般N=4~12

2、优缺点

对周期性干扰抑制性好,平滑度高

适用于高频振动系统

灵敏度低,RAM占用较大,脉冲干扰严重

3、代码

/* A值根据实际调,Value有效值,new_Value当前采样值,程序返回有效的实际值*/
#defineA10
charValue;
charfilter()
{
charnew_Value;
new_Value=get_ad();//获取采样值
if(abs(new_Value-Value)>A)returnValue;//abs()取绝对值函数
returnnew_Value;
}

五、中位值平均滤波

1、方法

采样N个值,去掉最大最小

计算N-2的平均值

N= 3~14

2、优缺点

融合了中位值,平均值的优点

消除脉冲干扰

计算速度慢,RAM占用大

3、代码

charfilter()
{
charcount,i,j;
charValue_buf[N];
intsum=0;
for(count=0;countValue_buf[i+1])
{
temp=Value_buf[i];
Value_buf[i]=Value_buf[i+1];
Value_buf[i+1]=temp;
}
for(count=1;count

六、限幅平均滤波

1、方法

每次采样数据先限幅后送入队列

取平均值

2、优缺点

融合限幅、均值、队列的优点

消除脉冲干扰,占RAM较多

3、代码

#defineA10
#defineN12
charvalue,i=0;
charvalue_buf[N];
charfilter()
{
charnew_value,sum=0;
new_value=get_ad();
if(Abs(new_value-value)

七、一阶滞后滤波

1、方法

取a=0~1

本次滤波结果=(1-a)* 本次采样 + a * 上次结果

2、优缺点

良好一直周期性干扰,适用波动频率较高场合

灵敏度低,相位滞后

3、代码

/*为加快程序处理速度,取a=0~100*/
#definea30
charvalue;
charfilter()
{
charnew_value;
new_value=get_ad();
return((100-a)*value+a*new_value);
}

八、加权递推平均滤波

1、方法

对递推平均滤波的改进,不同时刻的数据加以不同权重,通常越新的数据权重越大,这样灵敏度高,但平滑度低。

2、优缺点

适用有较大滞后时间常数和采样周期短的系统,对滞后时间常数小,采样周期长、变化慢的信号不能迅速反应其所受干扰。

3、代码


/*coe数组为加权系数表*/
#defineN12
charcodecoe[N]={1,2,3,4,5,6,7,8,9,10,11,12};
charcodesum_coe={1+2+3+4+5+6+7+8+9+10+11+12};
charfilter()
{
charcount;
charvalue_buf[N];
intsum=0;
for(count=0;count

九、消抖滤波

1、方法

设置一个滤波计数器

将采样值与当前有效值比较

若采样值=当前有效值,则计数器清0

若采样值不等于当前有效值,则计数器+1

若计数器溢出,则采样值替换当前有效值,计数器清0

2、优缺点

对变化慢的信号滤波效果好,变化快的不好

避免临界值附近的跳动,计数器溢出时若采到干扰值则无法滤波

3、代码

#defineN12
charfilter()
{
charcount=0,new_value;
new_value=get_ad();
while(value!=new_value)
{
count++;
if(count>=N)returnnew_value;
new_value=get_ad();
}
returnvalue;
}

十、限幅消抖滤波

1、方法

先限幅 后消抖

2、优缺点

融合了限幅、消抖的优点

避免引入干扰值,对快速变化的信号不宜

3、代码


#defineA10
#defineN12
charvalue;
charfilter()
{
charnew_value,count=0;
new_value=get_ad();
while(value!=new_value)
{
if(Abs(value-new_value))>
;count++)> )> ;count++)>;count++)> ;count++)>
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 传感器
    +关注

    关注

    2545

    文章

    50411

    浏览量

    750793
  • 单片机
    +关注

    关注

    6030

    文章

    44482

    浏览量

    631769
  • adc
    adc
    +关注

    关注

    97

    文章

    6384

    浏览量

    543679

原文标题:单片机ADC常见的几种滤波方法

文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    不同类型adc优缺点

    型和Flash型等。每种类型的ADC都有其独特的优缺点,适用于不同的应用场景。 1. 逐次逼近型(SAR)ADC 优点: 精度高: SAR ADC通常提供较高的分辨率,适合需要高精度测
    的头像 发表于 10-31 11:06 186次阅读

    STM32的ADC采样及各式滤波算法实现

    本文为手把手教学ADC采样及各式滤波算法的教程,本教程的MCU采用STM32F103ZET6。以HAL库的ADC采样函数为基础进行教学,通过各式常见
    的头像 发表于 10-28 10:51 515次阅读
    STM32的<b class='flag-5'>ADC</b>采样及各式<b class='flag-5'>滤波</b><b class='flag-5'>算法</b>实现

    不同类型UPS电源的优缺点

    不间断电源(UPS)是为关键设备提供稳定、不间断电力供应的重要设备。根据设计和功能的不同,UPS可以分为几种类型,每种类型都有其独特的优缺点。以下是一些常见的UPS类型及其优缺点的概述: 在线式
    的头像 发表于 10-28 10:45 257次阅读

    常用的ADC滤波算法有哪些

    ADC(模数转换器)滤波算法在信号处理中起着至关重要的作用,它们能够帮助我们提取出有用的信号,同时滤除噪声和干扰。以下是常用的ADC滤波
    的头像 发表于 10-08 14:35 215次阅读

    图像识别算法优缺点有哪些

    图像识别算法是一种利用计算机视觉技术对图像进行分析和理解的方法,它在许多领域都有广泛的应用,如自动驾驶、医疗诊断、安全监控等。然而,图像识别算法也存在一些优缺点。 一、图像识别算法的优
    的头像 发表于 07-16 11:09 1164次阅读

    AI大模型与小模型的优缺点

    在人工智能(AI)的广阔领域中,模型作为算法与数据之间的桥梁,扮演着至关重要的角色。根据模型的大小和复杂度,我们可以将其大致分为AI大模型和小模型。这两种模型在定义、优缺点及应用场景上存在着显著的差异。本文将从多个维度深入探讨AI大模型与小模型的特点,并分析其各自的
    的头像 发表于 07-10 10:39 2158次阅读

    神经网络反向传播算法优缺点有哪些

    神经网络反向传播算法(Backpropagation Algorithm)是一种广泛应用于深度学习和机器学习领域的优化算法,用于训练多层前馈神经网络。本文将介绍反向传播算法优缺点
    的头像 发表于 07-03 11:24 586次阅读

    神经网络算法优缺点有哪些

    神经网络算法是一种模拟人脑神经元结构的计算模型,广泛应用于机器学习、深度学习、图像识别、语音识别等领域。然而,神经网络算法也存在一些优缺点。本文将详细分析神经网络算法
    的头像 发表于 07-03 09:47 951次阅读

    nbiot和lora的优缺点是什么?

    nbiot和lora的优缺点
    发表于 06-04 06:37

    STM32的ADC项目应用,用什么算法滤波和稳定数据抖动?

    STM32的ADC项目应用,大家都用什么算法滤波和稳定数据抖动。 ADC数据的抖动有时候应用在项目上让人很是头疼,什么度娘十大滤波
    发表于 04-17 08:20

    储能元件的分类和优缺点

    常见的PCS储能用的是电池,有磷酸铁锂,锂电池等材料,但是也有用电容储能的,比如用无极性大电容和超级法拉电容的。 1、请问用电池储能和电容储能那种效率更高?两者各有什么优缺点? 2、在储能过程中,储
    发表于 03-11 23:03

    数组和链表在内存中的区别 数组和链表的优缺点

    数组和链表在内存中的区别 数组和链表的优缺点  数组和链表是常见的数据结构,用于组织和存储数据。它们在内存中的存储方式以及优缺点方面存在一些显著的差异。本文将详细探讨这些差异以及它们的优缺点
    的头像 发表于 02-21 11:30 833次阅读

    滤波电容不同补偿方式优缺点对比

    滤波电容不同补偿方式优缺点对比  滤波电容是电子电路中常用的元件,用于对信号进行滤波处理。不同的补偿方式可以帮助提高滤波电容的性能和稳定性。
    的头像 发表于 01-04 16:00 1024次阅读

    常见开关电源优缺点对比

    常见开关电源优缺点对比
    的头像 发表于 12-07 15:30 648次阅读
    <b class='flag-5'>常见</b>开关电源<b class='flag-5'>优缺点</b>对比

    简单介绍不同类型滤波器的优缺点

    滤波器种类繁多,按实现方式可以分为:LC滤波器、腔体滤波器、声表面波/体声波滤波器、螺旋滤波器、介质滤波
    的头像 发表于 11-14 09:39 6998次阅读
    简单介绍不同类型<b class='flag-5'>滤波</b>器的<b class='flag-5'>优缺点</b>