0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何實(shí)現(xiàn)單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣?

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-10 14:25 ? 次閱讀
首發(fā):嵌入式客棧
作者:逸珺

導(dǎo)讀

相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)較高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC去實(shí)現(xiàn)??墒歉叻直媛释庵肁DC往往價(jià)格都不便宜,這就帶來一對矛盾:高指標(biāo)與低成本。其實(shí)利用單片機(jī)片上的ADC利用過采樣技術(shù)就能很好的解決這樣一對矛盾體,本文來聊聊這個(gè)話題。

什么是過采樣?

信號(hào)處理中,過采樣是指以明顯高于奈奎斯特速率的采樣頻率對信號(hào)進(jìn)行采樣。從理論上講,如果以奈奎斯特速率或更高的速率進(jìn)行采樣,則可以完美地重建帶寬受限的信號(hào)。奈奎斯特頻率定義為信號(hào)帶寬的兩倍。過采樣能夠提高分辨率和信噪比SNR,并且通過放寬抗混疊濾波器的性能要求,有助于避免混疊和相位失真。

在很多項(xiàng)目應(yīng)用中,需要測量信號(hào)的動(dòng)態(tài)范圍較大,且需要參數(shù)的微小變化。例如,ADC需要測量很大的溫度范圍(比如工業(yè)中甚至要求從-200℃~500℃),但仍要求系統(tǒng)對小于1度的變化做出響應(yīng)。常見的單片機(jī)片上ADC位數(shù)為12位,如要實(shí)現(xiàn)高于12位分辨率要怎么做呢?我們知道奈奎斯特-香農(nóng)采樣定理可知:

其中:

  • 為輸入待采樣信號(hào)最高頻率
  • 為奈奎斯特頻率。

如果實(shí)際采樣頻率高于奈奎斯特頻率,即為過采樣。那么低于奈奎斯特采樣頻率進(jìn)行采樣就稱為欠采樣。

或許你會(huì)問,常規(guī)的應(yīng)用都是過采樣,怎么也沒見分辨率提高了呀?如果僅僅過采樣,要實(shí)現(xiàn)更高分辨率顯然是不夠的,那么要怎么利用過采樣實(shí)現(xiàn)更高的分辨率呢?要知道所采用的ADC硬件核分辨率是固定的,難道還會(huì)變不成?

過采樣提高分辨率

如果對一模擬信號(hào),采用過采樣,然后再進(jìn)行一定的軟件后處理,理論上是可以得到更高分辨率的:

為增加有效位數(shù)(ENOB :effective number of bits),對信號(hào)進(jìn)行過采樣,所需的過采樣率可以由下面公式確定(省略理論推導(dǎo),過于枯燥):

其中:

  • 為過采樣頻率
  • 產(chǎn)品所需實(shí)際采樣頻率
  • W為額外所需增加的分辨率位數(shù)

假設(shè)系統(tǒng)使用12位ADC每100 ms輸出一次采樣值也即(10 Hz)。為了將測量的分辨率提高到16位,我們按上述公式計(jì)算過采樣頻率:

因此,如果我們以f對信號(hào)進(jìn)行過采樣,然后在所需的采樣周期內(nèi)收集足夠的樣本以對它們進(jìn)行平均,現(xiàn)在可以將16位輸出數(shù)據(jù)用于16位測量。

具體怎么做呢?

  • 首先將256個(gè)連續(xù)采樣累加
  • 然后將總數(shù)除以16(或?qū)⒖倲?shù)右移4位)。該過程通常稱為抽取,也即將速率采樣。
  • 在類似進(jìn)行下一次16位樣本處理

注意:用于累積過采樣數(shù)據(jù)并執(zhí)行除法抽取數(shù)據(jù)類型必須具有足夠的字節(jié)寬度,以防止溢出和截?cái)噱e(cuò)誤。比如這里累積和可以采樣32位無符號(hào)整型。

由上面公式可得出一個(gè)重要結(jié)論:每提高W位分辨率,需要提高采樣率倍。

過采樣提高ADC的信噪比

ADC測量的SNR理論極限基于量化噪聲,這是基于在沒有過采樣和平滑濾波情況下模數(shù)轉(zhuǎn)換過程中固有的量化誤差所致。而量化誤差取決于ADC分辨率的位數(shù),其中N為ADC的位數(shù),為參考電壓。

SNR理論情況下極限值的計(jì)算方式是數(shù)據(jù)轉(zhuǎn)換的有效位數(shù),如下所示:

這個(gè)公式?jīng)]必要去記,用到的時(shí)候參考計(jì)算一下即可。從公式中可看出,要提升一個(gè)模數(shù)轉(zhuǎn)換器的理論SNR的一種可行方案可以通過提升采樣位數(shù),但是需要注意的是這里的信噪比是度量模數(shù)轉(zhuǎn)換器本身的,就一個(gè)真實(shí)系統(tǒng)的信噪比還與整個(gè)信號(hào)鏈相關(guān)!

從上式中不難算出,12位ADC的理論SNR極限值為74dB,而通過過采樣提升4位分辨率后,其SNR理論極限提高至96 dB!

到底怎么實(shí)現(xiàn)呢?

這里以偽代碼的方式給出編程思路:

voidinit_adc(void){/*配置ADC的采樣率為過采樣率連續(xù)中斷模式*/}voidstart_adc(void){/*控制ADC啟動(dòng)采樣*/}/*不同的開發(fā)平臺(tái)中斷函數(shù)寫法略有差異,比如51需要指定向量*//*OVERSAMPLE_FACTOR=4^RSHIFT_BITS下面兩個(gè)宏一起修改*/#defineRSHIFT_BITS(4)#defineOVERSAMPLE_FACTOR(256)staticunsignedshortadc_result=0U;voidadc_isr(void){staticunsignedshortadc_index=OVERSAMPLE_FACTOR;staticunsignedintaccumulator=0U;/*ADC_REGADC轉(zhuǎn)換結(jié)果寄存器,不同平臺(tái)名稱不同*/accumulator+=ADC_REG;adc_index--;if(adc_index==0){/*加和按因子抽取*/adc_result=accumulator>>RSHIFT_BITS;accumulator=0;adc_index=OVERSAMPLE_FACTOR;}}

該方案有一個(gè)缺陷,就是每次ADC中斷都需要CPU參與,在過采樣率很高的情況下,上述方案消耗很多CPU資源,那么如果單片機(jī)內(nèi)存資源足夠的情況下可以考慮采用DMA模式,采集很多數(shù)據(jù)并將數(shù)據(jù)暫存下來,然后再做累加平均抽取。這是空間換時(shí)間的策略的體現(xiàn)。這個(gè)編代碼也很容易,只需要申請一片內(nèi)存區(qū),內(nèi)存區(qū)的大小可以定為256的倍數(shù),這是因?yàn)樵谔嵘?位分辨率情況下,一個(gè)16位的輸出樣本需要256個(gè)12位樣本。

總結(jié)一下

在成本受限的情況下,可以通過單片機(jī)片內(nèi)ADC過采樣以及累積抽取的技術(shù)來提升采樣分辨率,這種技術(shù)的特點(diǎn):

  • 可以使用過采樣和平均來提高測量分辨率,而無需增加昂貴的片外ADC。
  • 過采樣和加和抽取將以提高CPU利用率和降低吞吐量為代價(jià)來提高SNR和測量分辨率。
  • 過采樣和加和抽取可以改善白噪聲的信噪比。

審核編輯 黃昊宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6023

    文章

    44376

    瀏覽量

    628345
  • adc
    adc
    +關(guān)注

    關(guān)注

    97

    文章

    6300

    瀏覽量

    542425
  • 高分辨率
    +關(guān)注

    關(guān)注

    0

    文章

    43

    瀏覽量

    15283
收藏 人收藏

    評論

    相關(guān)推薦

    如何利用單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣

    相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    發(fā)表于 01-28 07:37

    ADC信噪比要怎么分析?高速高分辨率ADC電路要怎么實(shí)現(xiàn)?

    在雷達(dá)、導(dǎo)航等軍事領(lǐng)域中,由于信號(hào)帶寬寬(有時(shí)可能高于10MHz),要求ADC采樣率高于30MSPS,分辨率大于10位。目前高速高分辨率ADC
    發(fā)表于 04-14 06:16

    如何實(shí)現(xiàn)DCP的高分辨率控制?

    實(shí)現(xiàn)高分辨率的原理是什么如何使用X9241實(shí)現(xiàn)高分辨率?
    發(fā)表于 04-27 06:54

    單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣的方法

    關(guān)注+星標(biāo)公眾號(hào),不錯(cuò)過精彩內(nèi)容轉(zhuǎn)自 | 嵌入式客棧相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置
    發(fā)表于 12-06 07:25

    單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣的方法

    關(guān)注、星標(biāo)嵌入式客棧,精彩及時(shí)送達(dá)[導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置
    發(fā)表于 12-08 07:03

    請問一下單片機(jī)內(nèi)置ADC是如何去實(shí)現(xiàn)高分辨率采樣

    相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一...
    發(fā)表于 12-09 07:26

    單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣?

    [導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    的頭像 發(fā)表于 10-14 14:48 ?2629次閱讀
    <b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?

    利用單片機(jī)片內(nèi)ADC實(shí)現(xiàn)高分辨率采樣

    [導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    的頭像 發(fā)表于 10-19 17:15 ?3227次閱讀
    利用<b class='flag-5'>單片機(jī)</b>片內(nèi)<b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b>較<b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>

    利用單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣

    [導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    的頭像 發(fā)表于 11-03 09:40 ?2411次閱讀
    利用<b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>

    單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣

    相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    的頭像 發(fā)表于 02-09 14:40 ?2114次閱讀
    <b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>

    太秀了!單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣?

    相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    發(fā)表于 01-25 06:58 ?8次下載
    太秀了!<b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?

    單片機(jī)內(nèi)置ADC如何實(shí)現(xiàn)高分辨率采樣?

    關(guān)注+星標(biāo)公眾號(hào),不錯(cuò)過精彩內(nèi)容轉(zhuǎn)自 | 嵌入式客棧相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置
    發(fā)表于 11-23 18:06 ?8次下載
    <b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b>如何<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?

    太秀了!單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣?

    關(guān)注、星標(biāo)嵌入式客棧,精彩及時(shí)送達(dá)[導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置
    發(fā)表于 11-25 11:36 ?13次下載
    太秀了!<b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?

    太秀了!單片機(jī)內(nèi)置 ADC 實(shí)現(xiàn)高分辨率采樣?

    作者|逸珺來源 |嵌入式客棧(ID:embInn)頭圖 | CSDN下載自東方IC[導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一...
    發(fā)表于 11-26 13:51 ?20次下載
    太秀了!<b class='flag-5'>單片機(jī)內(nèi)置</b> <b class='flag-5'>ADC</b> <b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?

    太秀了!單片機(jī)內(nèi)置ADC實(shí)現(xiàn)高分辨率采樣?

    相信ADC的應(yīng)用或多或少都會(huì)用到,在很多場合都有分辨率要求,要實(shí)現(xiàn)高分辨率時(shí),第一時(shí)間會(huì)想到采用一個(gè)較高位數(shù)的外置ADC
    發(fā)表于 01-26 17:35 ?0次下載
    太秀了!<b class='flag-5'>單片機(jī)內(nèi)置</b><b class='flag-5'>ADC</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>高分辨率</b><b class='flag-5'>采樣</b>?