news 2026/5/26 7:15:41

资料: 软件滤波算法、数字滤波常用的算法, AD采集,数据采集等经常会遇到由于干扰、电路误差、...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
资料: 软件滤波算法、数字滤波常用的算法, AD采集,数据采集等经常会遇到由于干扰、电路误差、...

资料: 软件滤波算法、数字滤波常用的算法, AD采集,数据采集等经常会遇到由于干扰、电路误差、精度、抖动等带来的误差,这些误差往往影响我们单位计算或控制,在平常的设计中,我们会加各种软件滤波来让数据变得平滑,只要涉及到数据采集就离不开数字滤波。 keil,stm32工程,有写好的历程,使用简单方便, 滤波算法包括:限幅滤波,中位值滤波,算数平均滤波,递推平均滤波,中位值平均滤波,限幅平均滤波,一阶滞后滤波,加权递推滤波,消抖滤波,限幅消抖滤波。

在嵌入式开发里,ADC采集的数据就像青春期少年的心情——说变就变。上周调试温控系统时,ADC返回的温度值在25°C到30°C之间反复横跳,实际温度计却稳稳停在27°C。这时候就该祭出软件滤波大法了。

先看最直接的限幅滤波,适合处理突发性跳变。假设相邻两次采样间隔200ms,温度不可能突变5°C:

#define MAX_DIFF 2 //允许最大变化值 int limit_filter(int new_val, int old_val) { if(abs(new_val - old_val) > MAX_DIFF) return old_val; return new_val; }

这个暴力美学算法有个致命弱点:连续跳变时数据会卡死。于是中位值滤波登场,适合消除脉冲干扰。在STM32里可以这么玩:

int mid_filter(int *arr, uint8_t size) { // 冒泡排序虽然效率低,但代码简单 for(int i=0; i<size-1; i++) for(int j=0; j<size-1-i; j++) if(arr[j] > arr[j+1]) swap(&arr[j], &arr[j+1]); return size%2 ? arr[size/2] : (arr[size/2-1]+arr[size/2])/2; }

实际项目中发现,用3次采样取中值就能干掉80%的尖峰脉冲。不过频繁排序影响实时性,这时候递推平均滤波更合适:

#define FILTER_WIN 10 //滑动窗口大小 int filter_buf[FILTER_WIN]; uint8_t filter_index = 0; int moving_avg(int new_val) { filter_buf[filter_index++] = new_val; if(filter_index == FILTER_WIN) filter_index = 0; int sum = 0; for(int i=0; i<FILTER_WIN; i++) sum += filter_buf[i]; return sum / FILTER_WIN; }

这个算法的内存占用是硬伤,在内存吃紧的MCU上可以用移位平均代替:avg = avg - avg/FILTERWIN + newval/FILTER_WIN;,用一次乘法和两次加法搞定。

遇到既要消除脉冲又要平滑波动的场景,限幅平均滤波组合拳就派上用场了:

int combo_filter(int new_val) { static int last_val = 0; // 先限幅 if(abs(new_val - last_val) > MAX_DIFF) new_val = last_val; // 再递推平均 last_val = (last_val * 3 + new_val) / 4; //加权系数可调 return last_val; }

调试四轴飞行器时,陀螺仪数据既需要快速响应又不能抖动。这时候一阶滞后滤波表现出色:

float a = 0.3; //滤波系数 float first_order_filter(float new_val) { static float filtered = 0; filtered = a * new_val + (1 - a) * filtered; return filtered; }

把浮点运算改成Q格式定点数能提升速度:filtered = (anew_val + (0xFFFF - a)filtered) >> 16;

选择滤波算法就像选女朋友——没有最好,只有最合适。要快速响应的选限幅,求稳的用递推平均,内存紧张试试移位平均,对抗脉冲干扰必须中位值。下次遇到ADC抽风时,不妨把这些算法轮番伺候,总有一款能治住那不安分的数据。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 11:17:56

Kafka 技术架构与核心原理深度解析

本文将深入探讨 Apache Kafka 的核心概念、架构设计以及其在消息处理方面的优势。 1. Kafka 简介 Kafka 是一个高性能的分布式流媒体平台。它作为集群运行在多台服务器上&#xff0c;提供极高的可用性和容错性。 在 Kafka 中&#xff0c;数据是以**流&#xff08;Stream&#x…

作者头像 李华
网站建设 2026/5/26 2:16:43

【资深架构师亲授】:Rust-PHP扩展多版本适配的7大黄金法则

第一章&#xff1a;Rust-PHP扩展多版本适配的核心挑战在构建基于 Rust 编写的 PHP 扩展时&#xff0c;实现对多个 PHP 版本的兼容性支持是一项关键且复杂的技术任务。由于不同 PHP 版本&#xff08;如 7.4、8.0、8.1 及更高版本&#xff09;在 Zend 引擎 API 层面存在结构性差异…

作者头像 李华
网站建设 2026/5/26 2:18:21

Redis在秒杀业务中的应用

总结&#xff1a;本文探讨了Redis在秒杀业务中的应用&#xff0c;重点介绍了全局唯一ID生成方案和分布式锁的实现。首先提出基于Redis的全局ID生成器设计方案&#xff0c;通过时间戳序列号的组合方式保证ID唯一性。针对秒杀业务中的库存超卖问题&#xff0c;分析了悲观锁和乐观…

作者头像 李华
网站建设 2026/5/25 23:28:17

GPT-5.2震撼发布:职场AI新标杆,效率提升40%,收藏必学!

OpenAI发布GPT-5.2模型&#xff0c;回应Google Gemini竞争压力。模型分三版&#xff0c;专注职场实用主义。GPT-5.2 Thinking在44个职业任务中达到或超过人类专家水平&#xff0c;编程能力创业界新高&#xff0c;幻觉率降低30%&#xff0c;长文本处理接近完美&#xff0c;数学科…

作者头像 李华
网站建设 2026/5/25 6:36:42

Java学习日记——DAY9

今天学习了Java中的String类&#xff0c;学习内容如下&#xff1a;1.String类创建对象的两种方法&#xff1a;&#xff08;1&#xff09;静态创建&#xff1a;String s1 "abc";&#xff08;2&#xff09;动态创建&#xff1a;String s2 new String("abc"…

作者头像 李华
网站建设 2026/5/26 3:22:00

R与Python变量传递机制全解密(从传值到共享内存的终极指南)

第一章&#xff1a;R与Python变量传递机制全解密在数据分析和科学计算领域&#xff0c;R与Python是两大主流语言&#xff0c;它们在变量传递机制上存在显著差异。理解这些差异有助于避免副作用、优化内存使用并提升代码可预测性。变量作用域与绑定模型 R采用“传值复制”&#…

作者头像 李华