历史上的今天
返回首页

历史上的今天

今天是:2025年12月09日(星期二)

正在发生

2022年12月09日 | 提高单片机设计的10个细节

2022-12-09 来源:zhihu

前言

随着单片机的发展,单片机在家用电器、工业自动化、生产过程控制、智能仪器仪表等领域的应用越来越广泛。


然而处于同一电力系统中的各种电气设备通过电或磁的联系彼此紧密相连,相互影响,由于运行方式的改变,故障,开关操作等引起的电磁振荡会波及很多电气设备。


这对我们单片机系统的可靠性与安全性构成了极大的威胁。单片机测控系统必须长期稳定、可靠运行,否则将导致控制误差加大,严重时会使系统失灵,甚至造成巨大损失。


因此单片机的抗干扰问题已经成为不容忽视的问题。


1 干扰对单片机应用系统的影响

1.1测量数据误差加大

干扰侵入单片机系统测量单元模拟信号的输入通道,叠加在测量信号上,会使数据采集误差加大。特别是检测一些微弱信号,干扰信号甚至淹没测量信号。


1.2 控制系统失灵

单片机输出的控制信号通常依赖于某些条件的状态输入信号和对这些信号的逻辑处理结果。若这些输入的状态信号受到干扰,引入虚假状态信息,将导致输出控制误差加大,甚至控制失灵。


1.3 影响单片机RAM存储器和E2PROM等

在单片机系统中,程序及表格、数据存在程序存储器EPROM或FLASH中,避免了这些数据受干扰破坏。但是,对于片内RAM、外扩RAM、E2PROM 中的数据都有可能受到外界干扰而变化。


1.4 程序运行失常

外界的干扰有时导致机器频繁复位而影响程序的正常运行。若外界干扰导致单片机程序计数器PC值的改变,则破坏了程序的正常运行。

由于受干扰后的PC 值是随机的,程序将执行一系列毫无意义的指令,最后进入“死循环”,这将使输出严重混乱或死机。


2 如何提高我们设备的抗干扰能力

2.1 解决来自电源端的干扰

单片机系统中的各个单元都需要使用直流电源,而直流电源一般是市电电网的交流电经过变压、整流、滤波、稳压后产生的,因此电源上的各种干扰便会引入系统。

除此之外,由于交流电源共用,各电子设备之间通过电源也会产生相互干扰,因此抑制电源干扰尤其重要。电源干扰主要有以下几类:


2.1.1电源线中的高频干扰(传导骚扰)

供电电力线相当于一个接受天线,能把雷电、电弧、广播电台等辐射的高频干扰信号通过电源变压器初级耦合到次级,形成对单片机系统的干扰;

解决这种干扰,一般通过接口防护;在接口增加滤波器、或者使用隔离电源模块解决。


2.1.2 感性负载产生的瞬变噪音(EFT)

切断大容量感性负载时,能产生很大的电流和电压变化率,从而形成瞬变噪音干扰,成为电磁干扰的主要形式;

解决这种干扰,一般通过屏蔽线与双胶线,或在电源接口、信号接口进行滤波处理。

这二种方法都需要在系统接地良好的情况下进行,滤波器、接口滤波电路都必须良好的接地,这样才能有效的将干扰泄放。


2.2 模拟信号采样抗干扰技术

单片机应用系统中通常要对一个或多个模拟信号进行采样,并将其通过A/D转换成数字信号进行处理。

为了提高测量精度和稳定性;

  1. 要保证传感器本身的转换精度;

  2. 传感器供电电源的稳定;

  3. 测量放大器的稳定;

  4. A/D转换基准电压的稳定;

  5. 要防止外部电磁感应噪声的影响;

如果处理不当,微弱的有用信号可能完全被无用的噪音信号淹没。

在实际工作中,可以采用具有差动输入的测量放大器,采用屏蔽双胶线传输测量信号,或将电压信号改变为电流信号,以及采用阻容滤波等技术。

2.3 数字信号传输通道的抗干扰技术

数字输出信号可作为系统被控设备的驱动信号(如继电器等),数字输入信号可作为设备的响应回答和指令信号(如行程开关、启动按钮等)。

数字信号接口部分是外界干扰进入单片机系统的主要通道之一。

在工程设计中,对数字信号的输入/输出过程采取的抗干扰措施有:

  1. 传输线的屏蔽技术,如采用屏蔽线、双胶线等;

  2. 采用信号隔离措施;

  3. 合理接地,由于数字信号在电平转换过程中形成公共阻抗干扰,选择合适的接地点可以有效抑制地线噪声。


    2.4 硬件监控电路

在单片机系统中,为了保证系统可靠、稳定地运行,增强抗干扰能力,需要配置硬件监控电路,硬件监控电路从功能上包括以下几个方面:

  1. 上电复位:保证系统加电时能正确地启动;

  2. 掉电复位:当电源失效或电压降到某一电压值以下时,产生复位信号对系统进行复位;

  3. 电源监测:供电电压出现异常时,给出报警指示信号或中断请求信号;

  4. 硬件看门狗:当处理器遇到干扰或程序运行混乱产生“死锁”时,对系统进行复位。

2.5 PCB电路合理布线

PCB板设计的好坏对抗干扰能力影响很大。因此,在进行PCB 设计时,必须遵守PCB 设计的一般原则,并应符合抗干扰设计的要求。下面着重说明两点:


2.5.1关键器件放置

在器件布置方面与其它逻辑电路一样,应把相互有关的器件尽量放得靠近些,这样可以获得较好的抗噪声效果。

  1. 时钟发生器、晶振和CPU 的时钟输入端都易产生噪声,要相互靠近些;

  2. CPU 复位电路、硬件看门狗电路要尽量靠近CPU相应引脚;

  3. 易产生噪声的器件、大电流电路等应尽量远离逻辑电路。

2.5.2 D/A、A/D 转换电路地线的正确连接

D/A、A/D 芯片及采样芯片均提供了数字地和模拟地,分别有相应的管脚。

在线路设计中,必须将所有器件的数字地和模拟地分别相连,但数字地与模拟地仅在一点上相连。另外,也可以采用屏蔽保护,屏蔽可用来隔离空间辐射。

对噪声特别大的部件(如变频电源、开关电源)可以用金属盒罩起来以减少噪声源对单片机的干扰,对容易受干扰的部分,可以增加屏蔽罩并接地,使干扰信号被短路接地。

2.6 软件抗干扰原理及方法

尽管我们采取了硬件抗干扰措施,但由于干扰信号产生的原因错综复杂,且具有很大的随机性,很难保证系统完全不受干扰。

因此,往往在硬件抗干扰措施的基础上,采取软件抗干扰技术加以补充,作为硬件措施的辅助手段。软件抗干扰方法具有简单、灵活方便、耗费低等特点,在系统中被广泛应用。


2.6.1 数字滤波方法

数字滤波是在对模拟信号多次采样的基础上,通过软件算法提取最逼近真值数据的过程。数字滤波的的算法灵活,可选择权限参数,其效果往往是硬件滤波电路无法达到的。


2.6.2 输入信号重复检测方法

输入信号的干扰是叠加在有效电平信号上的一系列离散尖脉冲,作用时间很短。

当控制系统存在输入干扰,又不能用硬件加以有效抑制时,可用软件重复检测的方法,达到“去伪存真”的目的,直到连续两次或连续两次以上的采集结果完全一致时方为有效。

若信号总是变化不定,在达到最高次数限额时,则可给出报警信号。对于来自各类开关型传感器的信号,如限位开关、行程开关、操作按钮等,都可采用这种输入方式。

如果在连续采集数据之间插入延时,则能够对付较宽的干扰。


2.6.3 输出端口数据刷新方法

开关量输出软件抗干扰设计,主要是采取重复输出的方法,这是一种提高输出接口抗干扰性能的有效措施。对于那些用锁存器输出的控制信号,这些措施很有必要。

在尽可能短的周期内,将数据重复输出,受干扰影响的设备在还没有来得及响应时,正确的信息又到来,这样就可以及时防止误动作的产生。在程序结构的安排上,可为输出数据建立一个数据缓冲区,在程序的周期性循环体内将数据输出。

对于增量控制型设备不能这样重复送数,只有通过检测通道,从设备的反馈信息中判断数据传输的正确与否。在执行重复输出功能时,对于可编程接口芯片,工作方式控制字与输出状态字一并重复设置,使输出模块可靠地工作。


2.6.4 软件拦截技术

当窜入单片机系统的干扰作用在CPU 部位时,后果更加严重,将使系统失灵。

最典型的故障是破坏程序计数器PC 的状态,导致程序从一个区域跳转到另一个区域,或者程序在地址空间内“乱飞”,或者陷入“死循环”。

使用软件拦截技术可以拦截“乱飞”的程序或者使程序摆脱“死循环”,并将运行程序纳入正轨,转到指定的程序入口。


2.6.5 “软件看门狗”技术

PC 受到干扰而失控,引起程序“乱飞”,也可能使程序陷入“死循环”。当软件拦截技术不能使失控的程序摆脱“死循环”的困境时,通常采用程序监视技术WDT TIMER(WDT),又称看门狗技术,使程序脱离“死循环”。

WDT 是一种软、硬件结合的抗程序跑飞措施,其硬件主体是一个用于产生定时T 的计数器或单稳,该计数器或单稳基本独立运行,其定时输出端接至CPU 的复位线,而其定时清零则由CPU 控制。

在正常情况下,程序启动WDT 后,CPU 周期性的将WDT 清零,这样WDT 的定时溢出就不会发生,如同睡眠一般不起任何作用。在受到干扰的异常情况下,CPU 时序逻辑被破坏,程序执行混乱,不可能周期性的将WDT 清零,这样当WDT 的定时溢出时,其输出使系统复位,避免CPU因一时干扰而陷入瘫痪的状态。


3 总结

随着单片机系统的广泛应用和技术的进步,电磁干扰问题越来越突出,推广现有的、成熟的抗干扰技术,研究抗干扰的新技术、新方向是单片机应用技术的当务之急。在单片机应用系统设计及应用中,只要充分考虑设备的电磁兼容性,并通过各种技术措施来消除干扰,就可以大大提高设备的稳定性和可靠性。


推荐阅读

史海拾趣

EFINIX公司的发展小趣事

EFINIX公司成立于2012年,由一群来自知名FPGA企业的创始人团队创立。他们拥有丰富的FPGA设计经验,并致力于在可编程逻辑行业实现突破性的创新。公司总部位于美国加利福尼亚州圣克拉拉市,计划采用一种全新的现场可编程门阵列(FPGA)技术——量子可编程技术,来设计芯片。这种技术旨在实现芯片尺寸仅为传统芯片的四分之一,能耗减少一半,同时结构更加简化。EFINIX公司相信,这种技术将推动人工智能和深度学习的发展,使数据处理更加高效。

Baneasa SA公司的发展小趣事

面对日益增长的市场需求,Baneasa SA意识到必须提升产能以满足客户的需求。于是,公司投入大量资金对生产线进行升级改造,引进了先进的生产设备和技术。这些举措使得Baneasa SA的产能得到了大幅提升,同时也保证了产品质量的稳定性和可靠性。

B.B. Battery公司的发展小趣事

在国内市场取得一定成绩后,B.B. Battery公司开始积极拓展国际市场。他们参加国际电池展会,与全球知名企业建立合作关系,将产品打入国际市场。同时,公司还注重品牌建设,通过提升产品质量和服务水平,树立了良好的品牌形象。这些努力使得B.B. Battery公司的品牌在全球范围内都享有较高的知名度和美誉度。

DREMEL公司的发展小趣事

在电子行业的快速发展中,Dremio公司以其独特的数据治理技术崭露头角。他们开发了一种新型的数据处理引擎,能够直接在云数据湖中查询和分析数据,无需将数据复制到专有数据仓库中。这一创新技术大大提高了数据处理效率,降低了成本,并为企业提供了更灵活的数据管理方式。Dremio凭借这一技术,迅速在电子行业中树立了领先地位。

HDP_Power公司的发展小趣事

为了进一步扩大市场份额,Dremio公司积极寻求与电子行业的跨界合作。他们与一家知名电子设备制造商达成战略合作,共同开发了一款集成了Dremio数据处理技术的智能设备。这款设备能够实时收集和分析设备使用数据,为企业提供更精准的市场分析和产品优化建议。通过这一合作,Dremio成功将技术应用于电子设备的全生命周期管理,进一步巩固了其在市场中的地位。

Degson Electronics Co Ltd公司的发展小趣事

为了提高产品的品质和可靠性,Degson积极引进国际先进的管理体系和技术标准。公司通过了ISO9001、ISO14001等国际管理体系认证,并严格按照相关标准进行生产和质量管理。此外,Degson还建立了亚洲首家获得美国UL和德国VDE认可的专业实验室,以确保产品的性能和品质符合国际标准。这些举措使Degson的产品在品质上得到了显著提升,赢得了客户的信任和好评。

问答坊 | AI 解惑

有人有“射频模拟电路”和“射频模拟电路与系统”这2本书的朋友进来看下

杭州地区,有人有“射频模拟电路”和“射频模拟电路与系统”这2本书的朋友进来看下; 射频模拟电路,咖啡色封面,作  者:张玉兴 编著出 版 社:电子工业出版社   射频模拟电路与系统,深蓝色封面,作/译者:张玉兴 杨玉梅 敬守钊 陈 ...…

查看全部问答>

PXA270,windows CE5.0下读取MMC/SD卡的硬件ID问题.

各位大虾好:      我用VirtualAlloc,VirtualCopy影射了PXA270的关于SD/MMC的硬件寄存器的物理地址,想这样通过发送指令CMD2来获得卡的128位的唯一ID.目前情况为: 物理地址已经成功映射.但是发送了指令后,等待SD/MMC响应指令的 ...…

查看全部问答>

请问各位Win Ce 开发高手,如何用C#在win ce5.0下实现拨号上网?

如题。。。windows xp下有rasapi32.dll可以调用ras相关函数实现 可是wince下没有,该怎么办?…

查看全部问答>

印制电路板的电磁兼容性

电路的合理布局 􀁡地线的设计 􀁡信号走线的设计 􀁡线路板层数的选择 􀁡器件的安排 PCB的EMC分析基本定律 􀁡克希霍夫定律: 任何时域信号由源到负载的传输都必须构成一个完 整的回路,一个频域 ...…

查看全部问答>

帮忙看下,纠结几天了,关于ds1302的

#include <reg52.h>#define uchar unsigned char  #define uint unsigned int #define WRITE_SECOND 0x80#define WRITE_MINUTE 0X82#define WRITE_HOUR 0X84#define READ_SECOND 0X81#define READ_MINUTE 0X83#define READ_HOUR 0X85 ...…

查看全部问答>

请问下TCP_CM3.lib在哪里?

本人菜鸟一只,想问下TCP_CM3.lib和TCPD_CM3.lib这两个库在哪个文件夹?我找了很久没找到。还是要另外装的?麻烦各位大侠了谢谢 [ 本帖最后由 RogerKing 于 2011-4-25 10:12 编辑 ]…

查看全部问答>

GPRS 断线自动重连

OS:WinCE6.0 平台:S3C2443 GPRS:SIM900   在程序中如何才能知道GPRS掉线并且能够重新链接? 网上说的RasEnumConnections,这种方式好像不行。…

查看全部问答>

如何看懂英文版的规格书?

各位大侠,本人英语水平特烂。烂的不能再烂了。 去看元器件的规格书,都是英文,看不懂,怎么才能看懂呢? 英文规格书一般是怎么排版的?有没有通用的排版方式? 在网路上没有找到。所以才来问的…

查看全部问答>

卢有亮《嵌入式实时操作系统UCOS原理与实践》教学视频跟踪贴

:carnation: 《嵌入式实时操作系统μC/OS原理与实践》 电子科技大学卢有亮老师专著,采用循序渐进,逐层深入的方法 一步一步教您学习UCOS原理和源码,通过源码再掌握原理 2-2之后直接在搜酷高清,方法 http://www.soku.com/search_video/q_%E5% ...…

查看全部问答>

新手问题啊,跪求各位大神解答

最近刚开始接触MSP430,发现它是3.3V供电,而且IO的拉灌电流都很小,所以驱动力很小,驱动外围电路都要接上拉电阻或者用74HC573,那用它的IO口作输入或者双向口的话要怎么做缓冲呢?   比如一个TLC549,它的逻辑信号是5V的,要读这个逻辑 ...…

查看全部问答>