嵌入式硬件之ADC/DAC
嵌入式硬件之ADC/DAC
写在前面
这几天在做一个寒假练项目,其中涉及到了音频的处理,ADC、DAC再次进入到了我的视野,并引起了我新的思考。
1、初次相识
记得去年七月份,本科毕业刚离校,就到研究生学校这边打杂,导师让我参与了一个小项目,那个控制器电路中有一个让我印象很深的的电路——ADC采样电路。

这个电路目的很简单,就是读出P35的AD采样值,借此来估算VDD的大小,进行监测。
它的模拟信号就是电阻两端的电压,数字信号是通过P35读取到的数值,再根据相应的计算公式,就可以得出VDD的大小。

这里是对模拟信号——电压的数模转换。
其实对于AD转换来讲,大家从小都在接触,比如家家户户都有的水银温度计。

利用水银的热涨冷缩原理,把人的体温以具体的数值显示出来。
再比如手机,大家用其播放音乐时,就是把比特流转化成电压信号,再通过扬声器播放出来。
再比如打电话时,不管是你这边听到声音,又或者你的声音被另一方听到,其中都离不开ADC、DAC。
2、为什么要有ADC/DAC?
万事万物的产生都是自有其道理,都有一种内在驱动力在驱动,那么是什么促成了ADC/DAC的出现呢?
大家都知道在我们的日常生活中有一种信号叫——模拟信号。比如上面提到的:温度、电压、电流、声音等。
模拟信号虽然很容易被人类接收,但有很多的缺点,比如很容易被各种“噪声”影响,又比如很难去存储和传输。
而数字信号正好与其相反,不仅能大程度上隔绝外部的干扰,又便于存储。
所以把模拟信号转化为数字信号是为了更好的去处理和存储。
3、ADC模数转换器
ADC——Analog to Digital Converter

只要是转换,就会有损耗,在ADC转换期间,有些模拟信号不可避免的会丢失。

举例来说0~5V的电压信号,你可以取这个范围的任意一个数值,你可以取到无数个数据,也就是说从理论上来讲,模拟信号的分辨率是无限大的。所以信号的丢失不可避免。
3.1模数转换流程
首先对模拟信号以特定的速率采样;采样之后,对其进行量化;量化后,对其进行二进制编码。

所以你会看到,在芯片技术手册上常有的一句话:我们的处理器ADC是几位几位的。

这里的分辨率用位数来表示,位数越多分辨率越高,以2的n次方倍。
举例来讲,0~1V的电压范围,如果是3位的ADC,那么1除以2的3次方等于0.125V,这就是这个ADC所能达到的精度。
上面那个0.125就表示ADC所能感受到的模拟信号输入的最小变化。

电压值每变化0.125V的数值,如上图橙色那条线,就会上升一个台阶,以此对应一个二进制的数值。

以上便是ADC工作的流程:采样、量化、编码。
4、DAC数模转换器
DAC——Digital to Analog Converter

通过数字比特流来产生模拟信号。
因此对模拟信号重构的精确度取决于DAC的分辨率,12位的要好于3位的。
分辨率、基准电压和重构的时间是DAC的重要参数。
5、如何使用ADC/DAC?
如何使用ADC/DAC?其实很简单。
因为现在大多的处理器都会内置相应的片上ADC/DAC,而且都是通过外部总线与处理器相连的,故外部接口也比较简单,直接连接即可。如下图所示。

再配置好相关的寄存器使能,按照芯片技术手册的要求进行软件设计。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!