當(dāng)前位置:首頁 > 公眾號精選 > 嵌入式微處理器
[導(dǎo)讀]相信ADC的應(yīng)用或多或少都會用到,在很多場合都有分辨率要求,要實現(xiàn)較高分辨率時,第一時間會想到采用一個較高位數(shù)的外置ADC去實現(xiàn)??墒?,高分辨率外置ADC往往價格都不便宜,這就帶來一對矛盾: 高指標(biāo)與低成本。其實,利用單片機(jī)片上的ADC利用過采樣技術(shù)就能很好的解決這樣一對矛盾體,本文來聊聊這個話題。

[導(dǎo)讀] 相信ADC的應(yīng)用或多或少都會用到,在很多場合都有分辨率要求,要實現(xiàn)較高分辨率時,第一時間會想到采用一個較高位數(shù)的外置ADC去實現(xiàn)。 可是高分辨率外置ADC往往價格都不便宜,這就帶來一對矛盾: 高指標(biāo)與低成本。 其實利用單片機(jī)片上的ADC利用過采樣技術(shù)就能很好的解決這樣一對矛盾體,本文來聊聊這個話題。

什么是過采樣?

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

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

其中:

  • 為輸入待采樣信號最高頻率
  • 為奈奎斯特頻率。

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

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

過采樣提高分辨率

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

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

其中:

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

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


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

具體怎么做呢?

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

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

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

過采樣提高ADC的信噪比

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

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


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

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

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

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

void init_adc(void) { /*配置ADC的采樣率為過采樣率連續(xù)中斷模式*/ } void start_adc(void) { /*控制ADC啟動采樣*/ } /*不同的開發(fā)平臺中斷函數(shù)寫法略有差異,比如51需要指定向量???*/ /*OVERSAMPLE_FACTOR=4^RSHIFT_BITS?下面兩個宏一起修改?*/ #define RSHIFT_BITS????????(4) #define OVERSAMPLE_FACTOR??(256) static unsigned short adc_result=0U; void adc_isr(void) { static unsigned short adc_index?=?OVERSAMPLE_FACTOR; static unsigned int accumulator?= 0U; /*ADC_REG?ADC轉(zhuǎn)換結(jié)果寄存器,不同平臺名稱不同*/ accumulator?+=?ADC_REG;?
????adc_index--; if(?adc_index==0 )
????{ /*?加和按因子抽取?*/ adc_result??=?accumulator>>RSHIFT_BITS;
????????accumulator?= 0;
????????adc_index???=?OVERSAMPLE_FACTOR;
????}
}

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

總結(jié)一下

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

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

-END-


來源 | 嵌入式客棧

作者 | 逸珺


|?整理文章為傳播相關(guān)技術(shù),版權(quán)歸原作者所有 |

| 如有侵權(quán),請聯(lián)系刪除 |


【1】嵌入式研發(fā)10多年,工程師悟出這些道理

【2】當(dāng)談起嵌入式工程師,究竟在談些什么

【3】嵌入式工程師出路之我見:就業(yè),技術(shù),行業(yè)...

【4】為什么嵌入式工程師會對8位MCU有誤解?

【5】嵌入式工程師結(jié)合經(jīng)歷聊硬件工程師和軟件工程師哪個更有前途?


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

嵌入式ARM

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉