資料介紹
如果數(shù)字信號(hào)處理器內(nèi)核沒有您需要的確切功能,可使用插值查找表(ILUT)來解決這一問題。
作為賽靈思的現(xiàn)場(chǎng)工程師,我常常問這樣的問題:我們是否能夠提供一款其功能可滿足客戶所有獨(dú)特設(shè)計(jì)要求的DSP內(nèi)核。有時(shí)候內(nèi)核會(huì)太大,太小或者不夠快。有時(shí),我們會(huì)開發(fā)一款能確切滿足客戶需求的內(nèi)核,并迅速以CORE Generator商標(biāo)推出。不過即便在這種情況下,客戶仍然想要一套特定的DSP功能,而且刻不容緩。在這些情況下,我常常建議他們使用我們器件中的插值查找表來定制他們的DSP功能。
查找表(LUT)實(shí)質(zhì)上是一個(gè)存儲(chǔ)元件,能夠根據(jù)任何給定的輸入狀態(tài)組合,“查找”輸出,以確保每個(gè)輸入都有確切的輸出。采用LUT來實(shí)現(xiàn)DSP功能具有一些重大優(yōu)勢(shì):
● 可用諸如MATLAB或Simulink等高抽象層編程語言改變LUT內(nèi)容。
● 可以設(shè)計(jì)一項(xiàng)DSP功能來運(yùn)行那些采用離散邏輯運(yùn)算將極度困難的數(shù)學(xué)函數(shù),比如y=log(x)、y=exp(x)、y=1/x、y=sin(x)等。
● LUT還可輕松執(zhí)行在可配置邏輯塊(CLB)芯片,以及嵌入式乘法單元或DSP48可編程乘法累加(MAC)單元方面可能要求過多FPGA資源的復(fù)雜數(shù)學(xué)函數(shù)。
不過,以這種方式使用LUT當(dāng)然也會(huì)存在一些弊端。當(dāng)您使用LUT來實(shí)現(xiàn)DSP功能時(shí),您必須使用塊RAM(BRAM)元件。若執(zhí)行函數(shù)y=sqrt(x)(其中x表示16位輸入,y表示18位輸出),每個(gè)變量則需要約64個(gè)18KB BRAM單元。如果,比如說,您的目標(biāo)是實(shí)現(xiàn)小型化Spartan器件,或者您有太多的運(yùn)算需要執(zhí)行,無法為每個(gè)變量省出64個(gè)BRAM單元,建議您放棄這種需要如此大量BRAM單元的方法,從系統(tǒng)架構(gòu)的角度來看,這種方法代價(jià)太大。
插值LUT方法不僅具有LUT方法在實(shí)現(xiàn)DSP功能時(shí)所帶來的各種優(yōu)勢(shì),而且無需使用太多BRAM單元。采用這種方法,您可以使用來自容量較小的LUT(比如,1000字LUT)的連續(xù)輸出,線性地對(duì)其內(nèi)插,以模擬更大容量的LUT。這樣,您就可以實(shí)現(xiàn)比1000字LUT更高的數(shù)值分辨率。此外,通過這種方法,僅需1個(gè)BRAM、1個(gè)嵌入式乘法器(或DSP48),以及少數(shù)幾個(gè)CLB芯片便可實(shí)施控制邏輯,因此LUT的使用成本變得更加合理化。而且,從信噪比的角度來看,其數(shù)值精度也是非常讓人滿意。
當(dāng)然,應(yīng)用插值LUT(ILUT)方法需要一定的技巧。舉例來說,采用該方法執(zhí)行y=sqrt(x)函數(shù)時(shí),可以清楚地顯示ILUT在空間占用、時(shí)序和數(shù)值精度方面的性能。我們先大致看一下這個(gè)示例,然后我再講解部分實(shí)例,說明如何使用這種方法來滿足客戶截然不同的需求,比如讓傳遞函數(shù)呈非線性的傳感器實(shí)現(xiàn)線性化,以及實(shí)施自適應(yīng)有限脈沖響應(yīng)(FIR)濾波器以消除合成孔徑雷達(dá)(SAR)圖像上的斑點(diǎn)噪聲。
使用System Generator for DSP進(jìn)行設(shè)計(jì)
為在賽靈思FPGA上實(shí)施DPS算法,我借助了采用MathWorks Simulink基于模型設(shè)計(jì)方法的System Generator for DSP設(shè)計(jì)與綜合工具。 System Generator得益于賽靈思在Simulink環(huán)境中的DSP模塊組,可自動(dòng)調(diào)用CORE Generator為DSP構(gòu)建塊生成高度優(yōu)化的網(wǎng)表。Simulink是一種雙精度浮點(diǎn)設(shè)計(jì)工具,而System Generator則是一款定點(diǎn)運(yùn)算工具。不管怎樣,您只要將這兩種工具協(xié)同使用,就可以定義每個(gè)信號(hào)的總位數(shù)以及每個(gè)信號(hào)的二進(jìn)制位置,從而在定點(diǎn)運(yùn)算中巧妙處理分?jǐn)?shù)。仿真結(jié)果周期精確、位真,因此您可以方便地將它們與MATLAB腳本或Simulink模塊生成的浮點(diǎn)參考值相比較,以檢查量化誤差。
圖1顯示了System Generator中ILUT方案的頂層結(jié)構(gòu)圖。為讓這個(gè)方法盡可能一般化,假設(shè)nx=16位中的輸入變量x的取值范圍為0≤x《1,因此其格式為 “無符號(hào)16位加上二進(jìn)制點(diǎn)右邊的16位”,也稱為Ufix_16_16格式。最高有效位(MSB)和最低有效位(LSB)模塊分別對(duì)應(yīng)輸入數(shù)據(jù) nb=10的最高位和nx-nb=6的最低位。這些信號(hào)被命名為x0和dx。y=sqrt(x)輸出則以ny=17位二進(jìn)制數(shù)表示,格式為:Ufix_17_17。
圖2顯示了1000字小容量LUT通過雙端口RAM模塊的部署步驟。由于該模塊系只讀存儲(chǔ)器,布爾常數(shù)模塊We_const強(qiáng)制將寫入歸零。信號(hào)X0和X0+1則用作ROM表上后續(xù)的兩個(gè)地址。Data_const模塊的零常數(shù)定義了任何ROM字的大?。幢纠械膎y)。
作為賽靈思的現(xiàn)場(chǎng)工程師,我常常問這樣的問題:我們是否能夠提供一款其功能可滿足客戶所有獨(dú)特設(shè)計(jì)要求的DSP內(nèi)核。有時(shí)候內(nèi)核會(huì)太大,太小或者不夠快。有時(shí),我們會(huì)開發(fā)一款能確切滿足客戶需求的內(nèi)核,并迅速以CORE Generator商標(biāo)推出。不過即便在這種情況下,客戶仍然想要一套特定的DSP功能,而且刻不容緩。在這些情況下,我常常建議他們使用我們器件中的插值查找表來定制他們的DSP功能。
查找表(LUT)實(shí)質(zhì)上是一個(gè)存儲(chǔ)元件,能夠根據(jù)任何給定的輸入狀態(tài)組合,“查找”輸出,以確保每個(gè)輸入都有確切的輸出。采用LUT來實(shí)現(xiàn)DSP功能具有一些重大優(yōu)勢(shì):
● 可用諸如MATLAB或Simulink等高抽象層編程語言改變LUT內(nèi)容。
● 可以設(shè)計(jì)一項(xiàng)DSP功能來運(yùn)行那些采用離散邏輯運(yùn)算將極度困難的數(shù)學(xué)函數(shù),比如y=log(x)、y=exp(x)、y=1/x、y=sin(x)等。
● LUT還可輕松執(zhí)行在可配置邏輯塊(CLB)芯片,以及嵌入式乘法單元或DSP48可編程乘法累加(MAC)單元方面可能要求過多FPGA資源的復(fù)雜數(shù)學(xué)函數(shù)。
不過,以這種方式使用LUT當(dāng)然也會(huì)存在一些弊端。當(dāng)您使用LUT來實(shí)現(xiàn)DSP功能時(shí),您必須使用塊RAM(BRAM)元件。若執(zhí)行函數(shù)y=sqrt(x)(其中x表示16位輸入,y表示18位輸出),每個(gè)變量則需要約64個(gè)18KB BRAM單元。如果,比如說,您的目標(biāo)是實(shí)現(xiàn)小型化Spartan器件,或者您有太多的運(yùn)算需要執(zhí)行,無法為每個(gè)變量省出64個(gè)BRAM單元,建議您放棄這種需要如此大量BRAM單元的方法,從系統(tǒng)架構(gòu)的角度來看,這種方法代價(jià)太大。
插值LUT方法不僅具有LUT方法在實(shí)現(xiàn)DSP功能時(shí)所帶來的各種優(yōu)勢(shì),而且無需使用太多BRAM單元。采用這種方法,您可以使用來自容量較小的LUT(比如,1000字LUT)的連續(xù)輸出,線性地對(duì)其內(nèi)插,以模擬更大容量的LUT。這樣,您就可以實(shí)現(xiàn)比1000字LUT更高的數(shù)值分辨率。此外,通過這種方法,僅需1個(gè)BRAM、1個(gè)嵌入式乘法器(或DSP48),以及少數(shù)幾個(gè)CLB芯片便可實(shí)施控制邏輯,因此LUT的使用成本變得更加合理化。而且,從信噪比的角度來看,其數(shù)值精度也是非常讓人滿意。
當(dāng)然,應(yīng)用插值LUT(ILUT)方法需要一定的技巧。舉例來說,采用該方法執(zhí)行y=sqrt(x)函數(shù)時(shí),可以清楚地顯示ILUT在空間占用、時(shí)序和數(shù)值精度方面的性能。我們先大致看一下這個(gè)示例,然后我再講解部分實(shí)例,說明如何使用這種方法來滿足客戶截然不同的需求,比如讓傳遞函數(shù)呈非線性的傳感器實(shí)現(xiàn)線性化,以及實(shí)施自適應(yīng)有限脈沖響應(yīng)(FIR)濾波器以消除合成孔徑雷達(dá)(SAR)圖像上的斑點(diǎn)噪聲。
使用System Generator for DSP進(jìn)行設(shè)計(jì)
為在賽靈思FPGA上實(shí)施DPS算法,我借助了采用MathWorks Simulink基于模型設(shè)計(jì)方法的System Generator for DSP設(shè)計(jì)與綜合工具。 System Generator得益于賽靈思在Simulink環(huán)境中的DSP模塊組,可自動(dòng)調(diào)用CORE Generator為DSP構(gòu)建塊生成高度優(yōu)化的網(wǎng)表。Simulink是一種雙精度浮點(diǎn)設(shè)計(jì)工具,而System Generator則是一款定點(diǎn)運(yùn)算工具。不管怎樣,您只要將這兩種工具協(xié)同使用,就可以定義每個(gè)信號(hào)的總位數(shù)以及每個(gè)信號(hào)的二進(jìn)制位置,從而在定點(diǎn)運(yùn)算中巧妙處理分?jǐn)?shù)。仿真結(jié)果周期精確、位真,因此您可以方便地將它們與MATLAB腳本或Simulink模塊生成的浮點(diǎn)參考值相比較,以檢查量化誤差。
圖1顯示了System Generator中ILUT方案的頂層結(jié)構(gòu)圖。為讓這個(gè)方法盡可能一般化,假設(shè)nx=16位中的輸入變量x的取值范圍為0≤x《1,因此其格式為 “無符號(hào)16位加上二進(jìn)制點(diǎn)右邊的16位”,也稱為Ufix_16_16格式。最高有效位(MSB)和最低有效位(LSB)模塊分別對(duì)應(yīng)輸入數(shù)據(jù) nb=10的最高位和nx-nb=6的最低位。這些信號(hào)被命名為x0和dx。y=sqrt(x)輸出則以ny=17位二進(jìn)制數(shù)表示,格式為:Ufix_17_17。
圖2顯示了1000字小容量LUT通過雙端口RAM模塊的部署步驟。由于該模塊系只讀存儲(chǔ)器,布爾常數(shù)模塊We_const強(qiáng)制將寫入歸零。信號(hào)X0和X0+1則用作ROM表上后續(xù)的兩個(gè)地址。Data_const模塊的零常數(shù)定義了任何ROM字的大?。幢纠械膎y)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 新型雙聲道音頻-+DAC小面積插值濾波器的設(shè)計(jì)實(shí)現(xiàn)
- 基于預(yù)測(cè)緩存的OpenFlow虛擬流表查找方法 11次下載
- 如何使用查找表和Newton插值算法實(shí)現(xiàn)正余弦函數(shù)的FPGA 29次下載
- FPGA查找表LUT和編程方式的基礎(chǔ)知識(shí)說明 16次下載
- 如何使用LUT實(shí)現(xiàn)FPGA中的DSP功能 19次下載
- 高速并行成型濾波器的FPGA實(shí)現(xiàn)方法 0次下載
- OpenFlow流表查找方法 0次下載
- 局部多項(xiàng)式的方法對(duì)圖像進(jìn)行插值 1次下載
- 基于CFA插值的圖像拼接篡改檢測(cè)方法 9次下載
- 基于AIS線性插值的綜合插值方法 13次下載
- 基于小波變換的分形插值圖像放大方法 0次下載
- 基于多項(xiàng)式插值函數(shù)的翼型參數(shù)化設(shè)計(jì)方法 2次下載
- CCD圖像的顏色插值算法研究及其FPGA實(shí)現(xiàn) 12次下載
- 基于B樣條插值的圖像邊緣檢測(cè)實(shí)現(xiàn) 40次下載
- 插值查找表:實(shí)現(xiàn)DSP功能的簡(jiǎn)便方法
- 中性點(diǎn)接地10 kV線路故障的查找方法 131次閱讀
- 什么是線性插值?一維線性插值和雙線性插值在BMS開發(fā)中的應(yīng)用 5879次閱讀
- 圖像插值理論研究之雙三次插值 827次閱讀
- DS1847/DS1848查找表的考慮因素 531次閱讀
- CIC插值濾波器與直接頻率合成器DDS的FPGA實(shí)現(xiàn) 1120次閱讀
- 基于深度學(xué)習(xí)構(gòu)造DL-SR網(wǎng)絡(luò)結(jié)構(gòu)和實(shí)現(xiàn)方法 2030次閱讀
- 直插式元器件的焊接方法,有哪些注意事項(xiàng)? 1.6w次閱讀
- 固定連接器插針的三種方法 1.1w次閱讀
- 一種不同于雙線性插值的上采樣方法 6239次閱讀
- 常用的插值算法盤點(diǎn) 7964次閱讀
- 如何利用LUT來實(shí)現(xiàn)FPGA中的DSP功能 1.2w次閱讀
- matlab-插值 1665次閱讀
- 基于FPGA的雙線性CFA插值算法的設(shè)計(jì) 4199次閱讀
- FPGA查找表實(shí)現(xiàn)原理分析 1.3w次閱讀
- 用插值查找表實(shí)現(xiàn)FPGA的DSP功能 1954次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1489次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 91次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 9次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7基于單片機(jī)和 SG3525的程控開關(guān)電源設(shè)計(jì)
- 0.23 MB | 3次下載 | 免費(fèi)
- 8基于單片機(jī)的紅外風(fēng)扇遙控
- 0.23 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30319次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論
查看更多