那曲檬骨新材料有限公司

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

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

3天內不再提示

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

電子設計 ? 作者:電子設計 ? 2018-11-14 08:02 ? 次閱讀

引言

FPGA 作為可編程的邏輯器件,它具有功耗低、便于修改、調試等特點,并能在上面實時完成大量的算法,平方根運算作為信號和圖像處理中的常見算法,目前在FPGA上有許多實現,但是這些實現方法通常采用目前硬件設計中普遍采用的Verilog和VHDL語言進行硬件設計,這種設計方法存在著仿真和校驗效率低,對于復雜的算法和軟件設計者之間的溝通較為困難等問題。

Python是一種簡單易學并且功能強大的編程語言,并具有強大的軟硬件描述能力,MyHDL采用Python擴展包的形式使其能支持硬件設計和仿真并在仿真結果符合要求后可將軟件算法自動轉換為相應的Verilog 或VHDL硬件描述。

本文試圖采用這種新的基于Python的軟硬件設計方法在FPGA上實現定點平方根。

1 方法

1.1 定點數表示

通常在FPGA 上的運算可以采用定點和浮點兩種方式來實現,定點運算和浮點運算相比盡管數表示的范圍較小,設計較為復雜,但是速度較快,占用FPGA資源較小,本設計采用定點來完成。平方根的輸入為非負數,包括符號位為定點32位輸入,其中高16位為整數部分,低15位為小數部分,可以直接計算的平方根范圍為(65 536,0],結果采用32位輸出,最高位為符號位,接著的高8位為整數部分,低23位為小數部分。

1.2 平方根實現

平方根的FPGA實現方法很多,有的算法為了減少片上資源的使用,邏輯實現上盡量避免使用乘法,比如CORDIC,逐位計算,non-restoring 等,現在FPGA上通常都有硬件乘法器,可采用迭代法和泰勒級數展開,本文采用泰勒級數展開的方法,級數采用5級,系數采用3.15的定點表示形式,小數部分15位,整數部分2位為了保證后續計算結果不溢出,整個位寬為18位,計算公式如式(1)所示:

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

對于輸入x 位于(65 536,0]之間,由于數的范圍較大,通常進行歸一化處理,采用的方法通過左移運算去掉二進制定點數的所有前導零,將輸入的數轉換為定點小數[0.5,1)之間,在完成平方根運算之后,然后根據前導零個數的奇、偶性不同分別進行去歸一化處理,原理如式(2)所示,將輸入數y 分為sx,s=2n,n 即為y 的二進制前導零的個數。

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

整個過程的設計模塊如圖1所示。

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

1.3 Python軟硬件協同設計

基于Python 的軟硬件協同設計的過程如圖2 所示,由于本設計最終要在硬件上實現,在設計時Python的硬件設計部分采用MyHDL 可綜合子集,最后使用MyHDL的toVerilog()函數將MyHDL設計自動轉換為相應的Verilog 代碼,由于MyHDL 支持與Verilog 混合仿真,設計時的測試平臺可以重用,仿真速度和設計效率大大提高。在完成基于Python軟硬件設計并仿真正確之后,就可以回到進行傳統的FPGA 設計流程,進行后續的下載,綜合和測試工作。

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

2 結果

2.1 實驗環境

采用MyHDL 0.8,采用GTKWAVE 查看仿真波形,FPGA 器件采用Altera公司CycloneⅡ 2C35F672C6,編譯綜合采用Quartus 12.1sp1 webpack.

2.2 仿真波形

在設計過程中生成的VCD仿真波形可以隨時采用GTKWAVE 查看,可以便于校驗設計是否正確,最終完成的仿真波形如圖3所示。

2.3 測試數據,精度及誤差

由于整個過程采用Python設計,Python存在大量的軟件包可以使用,平方根完成的測試數據結果如表1所示,采用基于Python 的繪圖包matplotlib 繪制的當x 在[0.5,1.0]之間時的平方根誤差如圖4所示。

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

采用Python語言在FPGA上實現定點平方根算法的硬件系統協同設計

2.4 綜合結果

在上面仿真校驗符合設計要求后,將Python自動轉換為Verilog描述,采用Quartus編譯綜合,并使用Model-sim仿真的波形如圖5所示,與圖3的Python環境下仿真波形相似,由此可見采用Python的軟硬件協同設計方法能有效地進行FPGA 設計。綜合后FPGA 資源使用情況:LE共1 506個,寄存器64個,嵌入式9位硬件乘法器10個。

3 結論

本文采用基于Python的擴展包MyHDL的軟硬件協同設計方法,在FPGA 上完成了定點平方根算法,設計仿真過程僅使用Python語言,所以仿真校驗和傳統的設計方法相比效率更高,仿真速度也更快,另外此方法還可以方便,有效地將一個軟件算法快速地轉換為其相應的硬件實現,從而完成軟硬件系統協同設計。

現代系統的算法越來越復雜,傳統的軟硬件設計方法越來越不適應市場對設計的要求,采用Python進行系統設計,仿真和校驗的速度會大大地提高,也能夠自動將算法轉換為對應的硬件實現,所以采用Python來進行軟硬件協同設計的產品能更快地進入市場,并且隨著設計復雜性的進一步增強和這種設計方法本身的發展和完善,基于Python的軟硬件協同設計方法將會有更加廣闊的應用前景。

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

    關注

    1630

    文章

    21796

    瀏覽量

    605998
  • 可編程
    +關注

    關注

    2

    文章

    874

    瀏覽量

    39932
  • 編程語言
    +關注

    關注

    10

    文章

    1950

    瀏覽量

    34983
收藏 人收藏

    評論

    相關推薦

    如何打印浮動閥以及平方根平方根函數?

    如何打印浮動閥以及平方根平方根函數。是否有任何庫來實現這些功能。
    發表于 09-20 12:45

    MCU裸系統下快速平方根實現相關資料推薦

    個快速平方根。以下是一個典型的逼近法實現的快速平方根函數,只用了整數乘法就可以做到32位范圍內的整數平方根計算,并且計算中邊界值始終按照二分法定位可以顯著縮短查找逼近時間,
    發表于 12-08 08:26

    硬件求解平方根運算的IP核,AHDL語言源代碼

    硬件求解平方根的IP# 進行平方根運算的IP核,由AHDL語言寫成,可在MaxplusII和QuartusII中使用,源代碼加密。# 使用方法# 1.將以下FEATURE行添加到Max
    發表于 06-14 09:36 ?28次下載

    平方根電路

    平方根電路
    發表于 02-23 21:56 ?1752次閱讀
    <b class='flag-5'>平方根</b>電路

    寬動態范圍的平方根電路

    寬動態范圍的平方根電路
    發表于 04-09 10:26 ?518次閱讀
    寬動態范圍的<b class='flag-5'>平方根</b>電路

    頻率平方根運算電路

    頻率平方根運算電路
    發表于 04-09 10:31 ?634次閱讀
    頻率<b class='flag-5'>平方根</b>運算電路

    平方根運算電路

    平方根運算電路
    發表于 04-09 10:33 ?1767次閱讀
    <b class='flag-5'>平方根</b>運算電路

    平方根運算電路圖

    平方根運算電路圖
    發表于 07-17 11:32 ?638次閱讀
    <b class='flag-5'>平方根</b>運算電路圖

    可在各種運算電路中使用的平方根電路

    可在各種運算電路中使用的平方根電路 電路的功能 平方根電路用在
    發表于 05-08 16:41 ?3011次閱讀
    可在各種運算電路中使用的<b class='flag-5'>平方根</b>電路

    電池SOC的自適應平方根無極卡爾曼濾波估計算法

    電池SOC的自適應平方根無極卡爾曼濾波估計算法,下來看看
    發表于 01-13 13:26 ?20次下載

    基于強跟蹤的平方根UKF的衛星姿態確定算法_王松艷

    基于強跟蹤的平方根UKF的衛星姿態確定算法_王松艷
    發表于 01-07 15:17 ?1次下載

    單片機C語言的求平方根怎么實現

    C語言中要求平方根,可以頭文件中加入#include .然后調用sqrt(n);函數即可。但在單片機中調用此函數無疑會耗費大量資源和時間,是極不合適的。
    發表于 07-13 09:36 ?3665次閱讀
    單片機C<b class='flag-5'>語言</b>的求<b class='flag-5'>平方根</b>怎么<b class='flag-5'>實現</b>

    采用MOSFET器件實現模擬平方根計算裝置的設計

    儀表和測量系統中廣泛使用了平方根計算電路,例如:用于計算任意波形rms (均方根)等任務。因此,設計師需要有一種高效的模擬平方根計算裝置。
    發表于 08-12 14:35 ?1499次閱讀
    <b class='flag-5'>采用</b>MOSFET器件<b class='flag-5'>實現</b>模擬<b class='flag-5'>平方根</b>計算裝置的設計

    MCU裸系統下快速平方根實現

    個快速平方根。以下是一個典型的逼近法實現的快速平方根函數,只用了整數乘法就可以做到32位范圍內的整數平方根計算,并且計算中邊界值始終按照二分法定位可以顯著縮短查找逼近時間,
    發表于 11-25 19:06 ?8次下載
    MCU裸<b class='flag-5'>系統</b>下快速<b class='flag-5'>平方根</b><b class='flag-5'>實現</b>

    如何使用Java來求解平方根

    在編程時,會遇到求平方根的問題,本次問題講到如何使用Java來求解平方根
    的頭像 發表于 03-03 09:39 ?1222次閱讀
    如何使用Java來求解<b class='flag-5'>平方根</b>
    大发888最新官方网址| 长城百家乐官网游戏| 百家乐官网在线娱乐平台| 香港百家乐玩法| 电子百家乐| 24山水口吉凶图| 大发888小陆| 百家乐官网高额投注| 鑫鼎百家乐娱乐城| 会理县| 百家乐官网视| 大发888下载ylc8| 百家乐官网好赌吗| 网络百家乐赚| 百家乐官网游戏资料网| 百家乐怎么| 百家乐官网赌牌技巧| 百家乐软件官方| 冠通棋牌世界| 正规百家乐官网平注法口诀| 大发888开户博盈国际| 百家乐官网娱乐城怎么样| 百家乐高命中打法| 百家乐官网存在千术吗| 澳门百家乐游戏说明| 陈巴尔虎旗| 百家乐三跳| 门赌场百家乐官网的规则| 可信百家乐的玩法技巧和规则| 真人百家乐官网什么平台| 威尼斯人娱乐城官网lm0| 金鼎百家乐官网局部算牌法| 威尼斯人娱乐欢迎您| 百家乐官网suncity| 大发888促销代码| 迷你百家乐官网的玩法技巧和规则| 大发888娱乐场是真是假| 八运24山阴阳| 3u娱乐城| 百家乐制胜秘| 百家乐官网破解方法技巧|