模数转换

转载自https://blog.csdn.net/weixin_43866583/article/details/127599971?spm=1001.2014.3001.5502

理解模拟信号 & 数字信号

模拟信号:模拟信号是指信息参数在给定范围内表现为连续的信号

在一段连续的时间间隔内,其代表信息的特征量可以在任意瞬间呈现为任意数值(变动的)的信号。像那些电压/电流与声音这些都是模拟信号。

数字信号:数字信号指信号幅度的取值是离散的,幅值范围被限制在有限个数值之内

二进制就是一种数字信号。大多数情况下,二进制码受噪声的影响小,易于由数字电路进行处理,所以现在也是被广泛的应用在很多的产品和领域中

ADC & DAC

ADC英文名称 - Analog-to-Digital Converter(模数转换器),从字面理解,A 称为模拟信号(Analog signal),D 称为数字信号(digital signal)。

A/D 转换器也就是把模拟信号(A)转换成数字信号(D)的器件。

DAC英文名称- Digital-to- Analog Converter(数模转换器),D/A 转换器刚好与 A/D 功能相反,它是把数字信号(D)转换为模拟信号(A)。

常用ADC 种类介绍

1
2
3
4
5
6
1.逐次逼近型
2.积分型 ADC
3. 压频变换型 ADC

说明:
逐次逼近型、积分型、压频变换型等,主要应用于中速或较低速、中等精度的数据采集和智能仪器中。
1
2
3
4
1.流水线型 ADC

说明:
流水线型 ADC主要应用于高速情况下的瞬态信号处理、快速波形存储与记录等领域。
1
2
3
4
1.∑-Δ 型 ADC

说明:
∑-Δ 型 ADC 主应用于高精度数据采集特别是数字音响系统、多媒体、地震勘探仪器、声纳等电子测量领域。
1
1.并行比较 A/D 转换器

ADC 的工作原理

在芯片内,模拟信号传输进去的时候,通过和芯片内部的模拟信号部件进行比对之后,从而转换为数字信号保存到数字信号寄存器中,从而把一段模拟信号用数字的方式表达出来(0和1)的方式表达出来。

逐次逼近型模数转换器原理框图

Ui为需要进行转换的模拟量,Uo为AD比较器的输出电压,通过AD转换器的逐渐比较不断的逼近Ui,最终得到一个与Ui匹配的数字值。(注意:AD转换一般都是需要一个参考电压 Vrf 的)

逐次逼近型 A/D 转换器,就是将输入模拟信号与不同的参考电压作多次比较,使转换所得的数字量在数值上逐次逼近输入模拟量对应值。

1
2
3
4
5
6
7
1)转换开始前先将所有寄存器清零。
2)开始转换以后,时钟脉冲首先将寄存器最高位置成 1,使输出数字为 100…0。
这个数被数模转换器转换成相应的模拟电压 Uo,送到比较器中与 Ui 进行比较。
若 Uo>Ui,说明数字过大了,故将最高位的 1 清除;
若 Uo<Ui ,说明数字还不够大,应将最高位的 1 保留。
3)反复如此,再按同样的方式将次高位置成 1,并且经过比较以后确定这个 1 是否应该保留。
4)最终就可以得到一个逼近Ui的数值。

逐次逼近型ADC的工作流程

1
2
3
(1)采样
(2)保持
(3)量化

STM32的ADC的介绍

​ 目前市场上流行的单片机几乎都有ADC功能,精度有高有低,使用的较多的,当属STM32了。下面以STM32F1为例。

​ STM32F1的ADC是12位的逐次逼近型的模数转换器。

​ 它的AD的基本特点:

STM32F1的 ADC 开关控制

​ 通过设置ADC_CR2寄存器的ADON位可给ADC上电。当第一次设置ADON位时,它将ADC从断电状态下唤醒。

​ ADC上电延迟一段时间后(t STAB ),再次设置ADON位时开始进行转换。通过清除ADON位可以停止转换,并将ADC置于断电模式。在这个模式中,ADC几乎不耗电(仅几个μA)。

STM32F1的 ADC 时钟
1
2
由时钟控制器提供的ADCCLK时钟和PCLK2(APB2时钟)同步。
RCC控制器为ADC时钟提供一个专用的可编程预分频器。
STM32F1的 ADC 通道

​ 有16个多路通道。可以把转换组织成两组:规则组和注入组。在任意多个通道上以任意顺序进行的一系列转换构成成组转换。例如,可以如下顺序完成转换:通道3、通道8、通道2、通道2、通道0、通道2、通道2、通道15。

​ 如果ADC_SQRx或ADC_JSQR寄存器在转换期间被更改,当前的转换被清除,一个新的启动脉冲将发送到ADC以转换新选择的组。

ADC转换模式

1)单次转换模式下,ADC只执行一次转换。该模式既可通过设置ADC_CR2寄存器的ADON位(只适用于规则通道)启动也可通过外部触发启动(适用于规则通道或注入通道),这时CONT位为0。

2)在连续转换模式中,当前面ADC转换一结束马上就启动另一次转换。此模式可通过外部触发启动或通过设置ADC_CR2寄存器上的ADON位启动,此时CONT位是1。

ADC校准

​ ADC有一个内置自校准模式。校准可大幅减小因内部电容器组的变化而造成的准精度误差。在校准期间,在每个电容器上都会计算出一个误差修正码(数字值),这个码用于消除在随后的转换中每个电容器上产生的误差。

​ 通过设置ADC_CR2寄存器的CAL位启动校准。一旦校准结束,CAL位被硬件复位,可以开始正常转换。建议在上电时执行一次ADC校准。校准阶段结束后,校准码储存在ADC_DR中。

1
2
1 建议在每次上电后执行一次校准。
2 启动校准前, ADC 必须处于关电状态 (ADON=’0’) 超过至少两个 ADC 时钟周期。
ADC通道的采样时间

​ ADC使用若干个ADC_CLK周期对输入电压采样,采样周期数目可以通过ADC_SMPR1和ADC_SMPR2寄存器中的SMP[2:0]位更改。每个通道可以分别用不同的时间采样。

总转换时间

1
T CONV = 采样时间+ 12.5个周期
1
2
3
ADCCLK=14MHz,采样时间为1.5周期

T CONV = 1.5 + 12.5 = 14周期 = 1μs