<abbr id="kc8ii"><menu id="kc8ii"></menu></abbr>
  • <input id="kc8ii"><tbody id="kc8ii"></tbody></input><table id="kc8ii"><source id="kc8ii"></source></table><kbd id="kc8ii"></kbd>
    <center id="kc8ii"><table id="kc8ii"></table></center>
  • <input id="kc8ii"></input>
    <abbr id="kc8ii"></abbr>
  • <abbr id="kc8ii"></abbr>
  • <center id="kc8ii"><table id="kc8ii"></table></center>
    <abbr id="kc8ii"></abbr>
    你的位置:首頁(yè) > 電源管理 > 正文

    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根

    發(fā)布時(shí)間:2014-10-07 責(zé)任編輯:echolady

    【導(dǎo)讀】作為可編程的邏輯器件,F(xiàn)PGA便于調(diào)試、修改、功耗低,能夠完成大量算法。在處理圖像和信號(hào)時(shí)平方根運(yùn)算被廣泛使用。在FPGA上利用VHDL和Verilog等編程語(yǔ)言進(jìn)行硬件設(shè)計(jì),存在仿真和校驗(yàn)效率低、算法復(fù)雜等問(wèn)題。而Python以其簡(jiǎn)單、功能強(qiáng)大的特點(diǎn)在此次設(shè)計(jì)中起到關(guān)鍵作用。
      
    一、平方根實(shí)現(xiàn)
     
      平方根的FPGA實(shí)現(xiàn)方法很多,有的算法為了減少片上資源的使用,邏輯實(shí)現(xiàn)上盡量避免使用乘法,比如CORDIC,逐位計(jì)算,non-restoring 等,現(xiàn)在FPGA上通常都有硬件乘法器,可采用迭代法和泰勒級(jí)數(shù)展開,本文采用泰勒級(jí)數(shù)展開的方法,級(jí)數(shù)采用5級(jí),系數(shù)采用3.15的定點(diǎn)表示形式,小數(shù)部分15位,整數(shù)部分2位為了保證后續(xù)計(jì)算結(jié)果不溢出,整個(gè)位寬為18位,計(jì)算公式如式(1)所示:
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    對(duì)于輸入x 位于(65 536,0]之間,由于數(shù)的范圍較大,通常進(jìn)行歸一化處理,采用的方法通過(guò)左移運(yùn)算去掉二進(jìn)制定點(diǎn)數(shù)的所有前導(dǎo)零,將輸入的數(shù)轉(zhuǎn)換為定點(diǎn)小數(shù)[0.5,1)之間,在完成平方根運(yùn)算之后,然后根據(jù)前導(dǎo)零個(gè)數(shù)的奇、偶性不同分別進(jìn)行去歸一化處理,原理如式(2)所示,將輸入數(shù)y 分為sx,s=2n,n 即為y 的二進(jìn)制前導(dǎo)零的個(gè)數(shù)。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    整個(gè)過(guò)程的設(shè)計(jì)模塊如圖1所示。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    二、定點(diǎn)數(shù)表示
     
      通常在FPGA 上的運(yùn)算可以采用定點(diǎn)和浮點(diǎn)兩種方式來(lái)實(shí)現(xiàn),定點(diǎn)運(yùn)算和浮點(diǎn)運(yùn)算相比盡管數(shù)表示的范圍較小,設(shè)計(jì)較為復(fù)雜,但是速度較快,占用FPGA資源較小,本設(shè)計(jì)采用定點(diǎn)來(lái)完成。平方根的輸入為非負(fù)數(shù),包括符號(hào)位為定點(diǎn)32位輸入,其中高16位為整數(shù)部分,低15位為小數(shù)部分,可以直接計(jì)算的平方根范圍為(65 536,0],結(jié)果采用32位輸出,最高位為符號(hào)位,接著的高8位為整數(shù)部分,低23位為小數(shù)部分。
     
     三、實(shí)驗(yàn)環(huán)境
     
      采用MyHDL 0.8,采用GTKWAVE 查看仿真波形,F(xiàn)PGA 器件采用Altera公司CycloneⅡ 2C35F672C6,編譯綜合采用Quartus 12.1sp1 webpack.
     
     四、Python軟硬件協(xié)同設(shè)計(jì)
     
      基于Python 的軟硬件協(xié)同設(shè)計(jì)的過(guò)程如圖2 所示,由于本設(shè)計(jì)最終要在硬件上實(shí)現(xiàn),在設(shè)計(jì)時(shí)Python的硬件設(shè)計(jì)部分采用MyHDL 可綜合子集,最后使用MyHDL的toVerilog()函數(shù)將MyHDL設(shè)計(jì)自動(dòng)轉(zhuǎn)換為相應(yīng)的Verilog 代碼,由于MyHDL 支持與Verilog 混合仿真,設(shè)計(jì)時(shí)的測(cè)試平臺(tái)可以重用,仿真速度和設(shè)計(jì)效率大大提高。在完成基于Python軟硬件設(shè)計(jì)并仿真正確之后,就可以回到進(jìn)行傳統(tǒng)的FPGA 設(shè)計(jì)流程,進(jìn)行后續(xù)的下載,綜合和測(cè)試工作。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
    [page]
     
    五、仿真波形
     
      在設(shè)計(jì)過(guò)程中生成的VCD仿真波形可以隨時(shí)采用GTKWAVE 查看,可以便于校驗(yàn)設(shè)計(jì)是否正確,最終完成的仿真波形如圖3所示。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    六、測(cè)試數(shù)據(jù),精度及誤差
     
      由于整個(gè)過(guò)程采用Python設(shè)計(jì),Python存在大量的軟件包可以使用,平方根完成的測(cè)試數(shù)據(jù)結(jié)果如表1所示,采用基于Python 的繪圖包matplotlib 繪制的當(dāng)x 在[0.5,1.0]之間時(shí)的平方根誤差如圖4所示。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    七、綜合結(jié)果
     
      在上面仿真校驗(yàn)符合設(shè)計(jì)要求后,將Python自動(dòng)轉(zhuǎn)換為Verilog描述,采用Quartus編譯綜合,并使用Model-sim仿真的波形如圖5所示,與圖3的Python環(huán)境下仿真波形相似,由此可見采用Python的軟硬件協(xié)同設(shè)計(jì)方法能有效地進(jìn)行FPGA 設(shè)計(jì)。綜合后FPGA 資源使用情況:LE共1 506個(gè),寄存器64個(gè),嵌入式9位硬件乘法器10個(gè)。
     
    技術(shù)解析:在FPGA上利用Python 實(shí)現(xiàn)定點(diǎn)平方根
     
    結(jié)語(yǔ):本文在FPGA 上利用Python的擴(kuò)展包MyHDL完成了定點(diǎn)平方根算法,仿真校驗(yàn)和傳統(tǒng)的設(shè)計(jì)方法仿真速度更快,效率更高,實(shí)現(xiàn)了將軟件算法向硬件轉(zhuǎn)換,完成軟硬件系統(tǒng)協(xié)同設(shè)計(jì)。

    相關(guān)閱讀:

    專家分析:為何數(shù)字電源轉(zhuǎn)換被拋棄?
    簡(jiǎn)單電路讓數(shù)字電源控制器與模擬控制兼容
    電源設(shè)計(jì)技巧十例:多相數(shù)字電源解決方案應(yīng)對(duì)挑戰(zhàn)
    特別推薦
    技術(shù)文章更多>>
    技術(shù)白皮書下載更多>>
    熱門搜索
    ?

    關(guān)閉

    ?

    關(guān)閉

    无码播放一区二区三区| 日本公妇在线观看中文版 | 熟妇人妻中文字幕无码老熟妇| 国产精品VA在线观看无码不卡| 中文字幕无码久久精品青草| 最近高清中文在线字幕在线观看| AAA级久久久精品无码片| 最近完整中文字幕2019电影| 亚洲AV无码国产精品麻豆天美| 亚洲精品一级无码鲁丝片| 久久精品无码一区二区WWW| 久久亚洲精品无码播放| 伊人蕉久中文字幕无码专区| 国产成人无码A区在线观看视频| 中文字幕精品一区二区三区视频| 国产AV无码专区亚洲AV男同| 亚洲日韩中文在线精品第一| 无码人妻少妇伦在线电影| 国产成人精品无码一区二区三区| 中文字幕在线精品视频入口一区| 亚洲AV区无码字幕中文色| 中文字幕在线免费看线人| YY111111少妇无码理论片| 无码人妻精品一区二区三区蜜桃| 在线综合亚洲中文精品| 日韩丰满少妇无码内射| 久久亚洲AV成人无码| 久久亚洲精精品中文字幕| 成 人无码在线视频高清不卡| 久久人妻无码中文字幕| 日本中文字幕中出在线| 久久无码一区二区三区少妇| 无码伊人66久久大杳蕉网站谷歌| 日本久久中文字幕| 无码人妻精品中文字幕免费| 久久久久无码中| 国产a级理论片无码老男人| 亚洲精品无码精品mV在线观看| 精品久久久久久无码中文字幕 | 久久青青草原亚洲av无码| 日韩一区二区三区无码影院|