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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

調(diào)制器及測試平臺的Matlab實現(xiàn) 復位/不復位時兩種濾波器的轉換誤差對比

CHANBAEK ? 來源:臣揚 ? 作者:陳陽 ? 2022-12-02 16:59 ? 次閱讀

前言

眾所周知,增量式SD-ADC相比傳統(tǒng)結構而言,需要在每次測量開始之前進行復位,以此清零積分器積分電容上的剩余電荷以及數(shù)字濾波器中寄存器。然后,在ADC連續(xù)轉換時,清零這一操作需要額外操作一次。如果不進行清零直接進行轉換,ADC的精度會損失多少?本文針對這個問題進行了Matlab建模,分析了在兩種常用數(shù)字濾波器,級聯(lián)積分濾波器(CoI)和SINC濾波器下這一情況的影響。

調(diào)制器及測試平臺的Matlab實現(xiàn)

本文Matlab建模了一個常用的二階Sigma-Delta調(diào)制器模型,在這個模型中沒有進行系數(shù)縮放,具體代碼如下:

clear
format long

Vref=2.5;
M=256; % Sinc濾波器抽取率
L=3;   % Sinc濾波器階數(shù)
N=10000; % 測試的直流輸入點數(shù)

for j=1:N;
Vin(j)=3/N*j-1.5;

% Second_order SD Modulator
Vout1=0;
Vout2=0;
Vout1(1)=0;%rand(1)*5-2.5;
Vout2(1)=0;%rand(1)*5-2.5;
bs=0;
for i=2:M*L;
    if bs(i-1)>0.5;
        Vout1(i)=Vout1(i-1)+(Vin(j)-Vref);
        Vout2(i)=Vout2(i-1)+Vout1(i-1)+(Vin(j)-Vref)*2;
    else
        Vout1(i)=Vout1(i-1)+(Vin(j)+Vref);
        Vout2(i)=Vout2(i-1)+Vout1(i-1)+(Vin(j)+Vref)*2;
    end

    if Vout2(i)>0;
        bs(i)=1;
    else
        bs(i)=0;
    end
end

Dout1(j)=sinc3_filter(M,L,bs);
Dout2(j)=coi_filter(M*L,bs);
end

E_sinc=Vin-(Dout1*5-2.5);
E_coi =Vin-(Dout2*5-2.5);
figure(1)
plot(Vin,E_sinc,'r');
title('使用SINC3濾波器的轉換誤差')
figure(2)
plot(Vin,E_coi,'b');
title('使用CoI濾波器的轉換誤差')

這個代碼實現(xiàn)的功能包括:

  • 一個二階單比特量化的Sigma-Delta調(diào)制器;
  • 產(chǎn)生N個從-1.5~1.5的直流值輸入調(diào)制器;
  • 分別使用Sinc3濾波器和CoI濾波器對調(diào)制器輸出進行處理;
  • 計算ADC在兩種濾波器下分別的轉換誤差。

其中,兩種濾波器Matlab函數(shù)的實現(xiàn)代碼分別為:

Sinc3濾波器

function Dout=sinc3_filter(M,L,bs)

sigma1=0;
sigma2=0;
sigma3=0;
delta1=0;
delta2=0;
delta3=0;
sigma3_reg=0;

for i=1:length(bs)
  sigma1=sigma1+bs(i);
  sigma2=sigma2+sigma1;
  sigma3=sigma3+sigma2;
    delta1_temp=sigma3-sigma3_reg;
    delta2_temp=delta1_temp-delta1;
    delta3_temp=delta2_temp-delta2;
  if(mod(i,M)==0)
    sigma3_reg=sigma3;
    delta1=delta1_temp;
    delta2=delta2_temp;
    delta3=delta3_temp;
  end
end

Dout=delta3/M^3;
end

CoI濾波器

function Dout=coi_filter(N,bs)

sigma1=0;
sigma2=0;

for i=1:N
  sigma2=sigma2+sigma1;
  sigma1=sigma1+bs(i);
end
Dout=sigma2/(N*(N-1)/2);

end

復位/不復位時兩種濾波器的轉換誤差對比

存在復位時,在代碼中每次轉換開始之前將兩個積分器的輸出的初值設置為0,如下代碼所示:

Vout1(1)=0;
Vout2(1)=0;

這種情況下,兩種濾波器的轉換誤差如下圖所示:

圖片

上圖中使用兩種濾波器的轉換誤差幾乎相近,這與文獻[1]中的結論相符,即:在相同的轉換時鐘周期下,Sinc3濾波器可以實現(xiàn)與CoI幾乎相同的轉換誤差。

不復位時,調(diào)制器的積分器1和積分器2的輸出會保持為上一次結束時的終態(tài)值,實際中這一值會和輸入電壓大小,熱噪聲等調(diào)制器的非理想因素相關,因此很難在模型中根據(jù)原理給出。為了簡便起見,本文模型通過產(chǎn)生一個±VREF的隨機數(shù)賦給積分器1和積分器2的輸出初態(tài)來實現(xiàn)近似的效果,代碼如下所示:

Vout1(1)=rand(1)*5-2.5;
Vout2(1)=rand(1)*5-2.5;

這種情況下,兩種濾波器的轉換誤差如下圖所示:

圖片

如上圖所示,不復位時,使用sinc3濾波器并未使轉換精度降低太多,而使用CoI濾波器轉換精度急劇下降。這是因為兩者對輸出碼處理的權重不同導致的。對Sinc3濾波器而言,在假設轉換周期數(shù)為N,那么第一個輸出碼的權重為1,所有輸出碼權重和為(N/3) ^3^ ,因此第一個輸出碼對最終輸出數(shù)據(jù)影響的比重為:1/((N/3) ^3^ )。而對CoI濾波器而言,第一個輸出碼的權重為(N-1),所有輸出碼權重和為N*(N-1)/2,因此第一個輸出碼對最終輸出數(shù)據(jù)影響的比重為:2/N. 當不進行復位操作時,直接的影響為第一個輸出碼(或前幾個輸出碼)所攜帶的量化噪聲很大,而相比采用CoI濾波器而言,采用Sinc3濾波器時第一個輸出碼的比重小了很多,因此這個因為沒有復位造成的超大量化噪聲被更好地稀釋,從而對輸出碼的影響相比采用CoI濾波器急劇降低,基本可以忽略不復位的影響。

(感興趣的讀者可以進一步證明,第一級積分器不復位對CoI濾波器的影響比第二級積分器不復位的影響大很多。)

總結

由上述模型可以發(fā)現(xiàn),設計增量式Sigma-Delta調(diào)制器時,如果采用Sinc濾波器,那么即使在開始轉換的時候不進行復位,積分器仍然保存上次轉換結束所殘余的輸出值,也不會對輸出結果造成太多的誤差。因此,如果設計者所設計的增量式SD-ADC采用了Sinc濾波器,那么可以不設計額外的復位操作,尤其是連續(xù)轉換時,這樣仍然不會影響ADC的精度。

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

    關注

    185

    文章

    2979

    瀏覽量

    230722
  • 濾波器
    +關注

    關注

    161

    文章

    7853

    瀏覽量

    178504
  • adc
    adc
    +關注

    關注

    98

    文章

    6524

    瀏覽量

    545201
  • 調(diào)制器

    關注

    3

    文章

    841

    瀏覽量

    45213
收藏 人收藏

    評論

    相關推薦

    Σ-Δ模數(shù)轉換器之數(shù)字濾波器類型與用途

    具有有限脈沖響應(FIR)。這些濾波器本質(zhì)上是穩(wěn)定的,易于通過線性相位響應進行設計。讓我們來對比Σ-Δ ADC中的兩種FIR濾波器。第一
    發(fā)表于 08-30 14:51

    Δ-Σ 調(diào)制器是如何工作的?

    Δ-Σ ADC由Δ-Σ調(diào)制器和數(shù)字濾波器構成。調(diào)制器將模擬輸入轉換為數(shù)字比特流,而數(shù)字濾波器將比特流轉換
    發(fā)表于 08-12 04:45

    了解這兩種濾波器原理,各式盡在掌握

    濾波器作為電子系統(tǒng)中十分常見的工具,在信號處理中占有重要地位。本文將對兩種典型的濾波器原理進行分析,并借以理解其他各式濾波器?! ?b class='flag-5'>濾波器是一
    發(fā)表于 12-01 08:00

    隔離型Σ-Δ調(diào)制器的簡化框圖

    進行采樣,以進一步濾波和抽取。在本文中,將詳細研究這類隔離Σ-Δ調(diào)制器的輸出數(shù)據(jù)信號完整性。并通過簡單的電磁干擾(EMI)測試設置、對由這
    發(fā)表于 10-21 16:12

    濾波器設計與信號處理的MATLAB實現(xiàn)

    2 步模擬濾波器的設計,我們主要學習的是巴特沃斯設計方法,因此這里以“巴特沃斯濾波器雙線性變換”設計法為例來闡述 IIR 濾波器的設計方法和 matlab
    發(fā)表于 09-26 07:22

    電光調(diào)制器,電光調(diào)制器工作原理是什么?

    電光調(diào)制器,電光調(diào)制器工作原理是什么? 電光調(diào)制器是利用某些晶體材料在外加電場的作用下所產(chǎn)生的電光效應而制成的器件。常用的有兩種
    發(fā)表于 04-02 15:50 ?2.1w次閱讀

    FPGA實現(xiàn)OFDM調(diào)制器設計

    提出一 OFDM 高性能數(shù)字調(diào)制器的FPGA實現(xiàn)方案;采用自頂向下的設計思想,將系統(tǒng)分成FIR濾波器、數(shù)控振蕩、移相器、乘法電路和加法電
    發(fā)表于 08-15 11:15 ?62次下載
    FPGA<b class='flag-5'>實現(xiàn)</b>OFDM<b class='flag-5'>調(diào)制器</b>設計

    CIC濾波器調(diào)制器應用中的性能研究

    為了補償級聯(lián)積分梳狀(B3B)濾波器固有的通帶衰減,提出在B3B濾波器之前插入脈沖成形濾波器(CDE)進行預補償?shù)男滤惴?,該算法不增加硬件復雜度9以多速率正交調(diào)制器為例分析了補
    發(fā)表于 08-26 15:11 ?26次下載
    CIC<b class='flag-5'>濾波器</b>在<b class='flag-5'>調(diào)制器</b>應用中的性能研究

    基于Matlab的FIR帶通濾波器設計與實現(xiàn)

    本文通過介紹一借助Matlab的FDATOOL濾波器設計分析軟件,設計了一FIR數(shù)字帶通濾波器,并對一段含噪語音信號進行
    發(fā)表于 07-26 10:45 ?2.9w次閱讀
    基于<b class='flag-5'>Matlab</b>的FIR帶通<b class='flag-5'>濾波器</b>設計與<b class='flag-5'>實現(xiàn)</b>

    基于Matlab/Simulink的FIR數(shù)字濾波器的設計與實現(xiàn)

    基于Matlab/Simulink的FIR數(shù)字濾波器的設計與實現(xiàn)
    發(fā)表于 01-15 15:16 ?39次下載

    單片機實現(xiàn)利用中斷復位兩種方式

    如果想要實現(xiàn)利用中斷復位,我所知道的有兩種方式:看門狗中斷和無中斷服務程序的中斷。
    的頭像 發(fā)表于 10-30 15:55 ?9697次閱讀

    LMS自適應濾波器MATLAB仿真和DSP實現(xiàn)

    LMS自適應濾波器MATLAB仿真和DSP實現(xiàn)
    發(fā)表于 06-09 10:47 ?65次下載

    電源濾波器安裝常見的兩種錯誤

    很多人在安裝電源濾波器時容易出現(xiàn)問題,這直接影響到濾波器的使用。今天,維愛普小編要給大家介紹一下電源濾波器安裝常見的兩種錯誤,希望大家能很好地規(guī)避。
    發(fā)表于 08-05 16:06 ?896次閱讀

    abb變頻怎么復位

    設置和調(diào)整的目的。那么,ABB變頻如何進行復位呢?本文將為大家詳細講解ABB變頻復位的方法和步驟。 一、ABB變頻
    的頭像 發(fā)表于 08-23 17:26 ?1.4w次閱讀

    ABB變頻怎么復位 | 復位時可能會出現(xiàn)哪些問題?

    ,ABB變頻如何進行復位呢?本文將為大家詳細講解ABB變頻復位的方法和步驟。 一、ABB變頻復位
    的頭像 發(fā)表于 02-21 10:50 ?8178次閱讀
    ABB變頻<b class='flag-5'>器</b>怎么<b class='flag-5'>復位</b> | <b class='flag-5'>復位</b>時可能會出現(xiàn)哪些問題?