ADC也有不同的分类,你知道多少?(adc有哪些类型)
lipiwang 2025-03-26 13:50 11 浏览 0 评论
在如今的电路设计中,绝大部分的场景都是数字和模拟的混合电路设计,而混合电路的中间连接通道一定离不开ADC和DAC。
比如我们日常使用的遥控器,其摇杆的内部就是一个滑动变阻器的原理,有些高档一点的设计会使用线性霍尔的设计来提高可靠性和性能,但这些摇杆的信号最终要想进入到数字系统中参与运算,那么就一定需要对变阻器或者霍尔输出的模拟信号进行量化,这个量化过程就需要用到ADC。
大多数工程师对ADC的了解可能都集中在单片机的ADC外设,比如对于STM32F103RC,它就集成了三路独立的ADC,其采样速率可以达到1MHz,量化精度可以到12bit(实际采样精度只有10.9bit)。
事实上,ADC还有很多其他的封装形式,比如在电子秤应用中,我们需要一个超高精度的ADC对应变片的阻值变化进行采样,这个精度达到了24bit,那么这一类的ADC最开始都是以单芯片的形式出现的,后来在电子秤应用的广泛推动下,才出现了一些24bitADC和mcu合并在一起的芯片。
再比如,我们对于视频信号,或者雷达应用中,我们对于ADC的采样速率要求达到了上GHz,这样的ADC基本上都是单独设计成一个IC,留出并口或者SPI等高速接口。
举了很多例子,不知道大家是否知道,这些不同应用中的ADC虽然看起来都是将模拟信号量化成数字信号,但是其内部原理却不尽相同,他们的原理设计有的是为了实现高速度,有的是为了实现高精度,有的是为了达到一个平衡,比如像STM32中集成的ADC那样。
下面我们先来看一下ADC都有哪些分类:
- 直接转换模拟数字转换器(Direct-conversion ADC),或称Flash模拟数字转换器(Flash ADC)
- 循序渐进式模拟数字转换器(Successive approximation Register ADC),俗称SAR ADC
- 跃升-比较模拟数字转换器(Ramp-compare ADC)
- 威尔金森模拟数字转换器(Wilkinson ADC)
- 集成模拟数字转换器(Integrating ADC)
- Delta编码模拟数字转换器(Delta-encoded ADC)
- 管道模拟数字转换器(Pipeline ADC)
- Sigma-Delta模拟数字转换器(Sigma-delta ADC)
- 时间交织模拟数字转换器(Time-interleaved ADC)
每一种ADC类型的工作原理和适用场景都不同。
今天我们就以比较常见的三类ADC架构来探寻一下他们的实现原理。
SAR ADC:
SAR ADC是一种获得高精度ADC转换的方法,它采用逐步逼近的方法进行比较。它首先将输入信号与一个参考电压进行比较,然后将比较结果与参考电压的一半进行比较,再根据比较结果确定下一步比较的阈值。通过不断重复此过程,逼近输出的精度越来越高,最终得到目标的数字化结果,这个比较的次数正好是ADC的量化深度,也就是位数。
由于SAR ADC结构简单,转换速度快,且精度高,在数字信号处理中广泛应用。同时,由于其需要逐步逼近,所以在处理不稳定的、干扰较大的信号时可能出现收敛慢、精度下降等问题,因此需要在实际应用中仔细评估和设计。
STM32的ADC属于 SAR ADC。STM32系列芯片内置了多个ADC模块,不同型号的芯片支持的ADC模块数量和通道数也有所不同。
FLASH ADC
FLASH ADC是快闪式模拟数字转换器(Flash Analog-to-Digital Converter)的缩写[[1]]。
FLASH ADC是一种基于比较器和多个参考电压的模拟信号转换器。它使用一个线性电压阶梯和每个阶梯上的比较器来将输入电压与连续的参考电压进行比较,从而实现ADC转换。相比其他ADC转换方式,FLASH ADC具有转换速度快、精度高等优点。由于其电路结构复杂,电路设计难度大,因此在实际应用中需要考虑诸多因素的影响。
FLASH ADC常用于需要高速数字化处理的应用场合,例如高速数据采集系统、高速通信网络和超高清视频等领域。
Sigma-delta ADC
Sigma-delta ADC是Σ-Δ调制器模拟数字转换器(Sigma-Delta Modulator Analog-to-Digital Converter)的简称[[1]]。
Sigma-delta ADC的工作原理是将输入信号连续地通过一个Σ-Δ(sigma-delta)调制器进行调制,再通过数字滤波器把高频调制噪声滤除,最后通过一个采样保持电路进行采样,实现模拟信号到数字信号的转换。由于该架构可以在较低的分辨率下获得高精度的结果,因此广泛用于音频、视频、加速度计以及温度测量等领域。
实际上,对于Sigma-delta ADC的理解可以通俗的认为是多次采样进行平均以达到更高的精度,比如我们采样1V的电压,可能当前的12bit精度不够,但是我们可以采样1000次,这样累加的电压1000V进行量化,然后在平均获得的精度会更高。
需要注意的是,Sigma-delta ADC的转换速度通常比其他ADC方法慢,并且需要更高的时钟频率和更高的系统性能。
Pipeline ADC
Pipeline ADC是管线式模拟数字转换器(Pipelined Analog-to-Digital Converter)的简称[[1]]。
Pipeline ADC是一种高速ADC,它采用多级管线结构,将整个ADC转换过程分为多个单元阶段,每个单元阶段负责对前一级的输出进行处理和采样,并输出到后一级。由于每个单元阶段只需要处理部分位数,因此可以大幅提高转换速度。 使用 pipeline ADC 可以实现高精度、高速的模拟信号转换,在工业、通信系统、医疗电子、航空航天等领域得到广泛应用。
需要注意的是,Pipeline ADC在设计实现时较为复杂,而且由于多级采样和量化误差噪声的传递,最终输出的数字化信号可能会受到比较强的噪声干扰,因此需要进一步处理这些干扰以实现更高的信噪比。
相关推荐
- 小程序-如何获取用户表单控件中的值
-
背景在小程序开发中,经常有用到表单,我们往往需要在小程序端获取用户表单输入框中的值(通常用户输入的有:switch,input,checkbox,slider,radio,picker)等,通过触发事...
- Js基础7:表单元素属性
-
一、封装获取元素的方法封装思想——函数封装——代码复用 function get_id(id){ //这个函数是专门来通过id获...
- 泰媒:到泰国曼谷旅游,注意别被嘟嘟车司机坑!
-
据泰国《世界日报》微信公众号报道,近日,一名导游投诉称,3名外籍游客在泰国曼谷搭载嘟嘟车时,被嘟嘟车司机坑。该导游认为嘟嘟车司机坑害外国游客的行为,破坏泰国的旅游形象,希望能以此为戒。当地时间25日上...
- 快速了解JavaScript的表单操作
-
前言在HTML中使用<form>表单元素在JavaScript中对应的是HTMLFormElement类型,而HTMLFormElement继承了HTMLElement接口...
- 10《Vue 入门教程》Vue 双向绑定指令
-
1.前言本小节我们将介绍Vue中数据的双向绑定指令v-model。v-model的学习相对简单。我们可以用v-model指令在表单<input>、<textarea&...
- 手把手教你搭建消防安全答题小程序-实现答题及提交答卷到数据库
-
手把手教你搭建答题活动小程序系列,第一阶段为界面设计篇,分别描写了如何搭建答题小程序界面。第二阶段为功能交互篇。而上两篇文章分别描写了,如何用云开发实现查询题库功能,以及将获取到的题目数据动态更新到答...
- 你还在使用Guava的Lists.newArrayList()吗
-
Guava说起Guava,做Java开发的应该没人不知道吧,毕竟“google出品,必属精品”。虽然应该没有Spring那样让Javaer无法避开,但是其中很多工具类的封装还是让人欲罢不能。而我们今天...
- Mybatis参数传递
-
1.概述Mybatis的sql参数传递就是将接口方法中定义的参数传输到sql中。sql有两种形式,一种是XML格式(Mapper映射器)中的sql;一种是注解方式的sql。常用参数的类型主要包括:基...
- python中的map和filter避坑指南
-
Pythonic的方式使用map和filter列表迭代在python中是非常pythonic的使用方式definc(x):returnx+1>>>list(map...
- 2025 年 Object 和 Map 如何选择?
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。1.什么是...
- 如何使用Java读取Excel文件到List>格式
-
引言在开发过程中,我们经常会遇到需要读取Excel文件并将数据转换成Java对象的需求。ApachePOI是一个强大的库,它提供了读取和写入MicrosoftOffice格式文件的功能,包括Exc...
- Nginx L4 stream Solution white list map
-
nginx正向透明代理nginx正向透明代理安全方面的一些限制对于代理而已,有时候可能还不够安全,而且这个是基于4层的,所以想要在http上,或者所谓的http头上做限制还是比较难实现了。所以变...
- Java响应式编程 第五篇 flatMap vs map
-
1作用不同1.2映射?展平?map只执行映射flatMap既执行映射,也执行展平什么叫只能执行映射?我理解是把一个数据执行一个方法,转换成另外一个数据。举个例子:mapper函数把输入的字符...
- Java对象拷贝原理剖析及最佳实践
-
作者:宁海翔1前言对象拷贝,是我们在开发过程中,绕不开的过程,既存在于Po、Dto、Do、Vo各个表现层数据的转换,也存在于系统交互如序列化、反序列化。Java对象拷贝分为深拷贝和浅拷贝,目前常用的...
- mybatis手把手教学,希望大家能拿下它
-
目录1.jdbc封装中的问题12.mybatis介绍43.框架搭建41)导包52)配置文件6配置dtd约束73)创建SqlSessionFactory对象94.入门案例91.部门实体...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- maven镜像 (69)
- undefined reference to (60)
- zip格式 (63)
- oracle over (62)
- date_format函数用法 (67)
- 在线代理服务器 (60)
- shell 字符串比较 (74)
- x509证书 (61)
- localhost (65)
- java.awt.headless (66)
- syn_sent (64)
- settings.xml (59)
- 弹出窗口 (56)
- applicationcontextaware (72)
- my.cnf (73)
- httpsession (62)
- pkcs7 (62)
- session cookie (63)
- java 生成uuid (58)
- could not initialize class (58)
- beanpropertyrowmapper (58)
- word空格下划线不显示 (73)
- jar文件 (60)
- jsp内置对象 (58)
- makefile编写规则 (58)