兩種狀態機的寫法比較

来源:http://www.cnblogs.com/jaymyfriend/archive/2017/05/29/6918365.html
-Advertisement-
Play Games

在FPGA里想寫順序執行的語句沒有C語言來的簡便花哨,比如for迴圈,或者再厲害點的來個嵌套迴圈。FPGA里要實現順序執行某個操作功能需要藉助狀態機實現。下麵比較了下兩種狀態機的寫法。 test_fsm和test_fsm2是兩個工程。 test_fsm是仿順序寫法,即數節拍的寫法,行數多,看著繞人, ...


    在FPGA里想寫順序執行的語句沒有C語言來的簡便花哨,比如for迴圈,或者再厲害點的來個嵌套迴圈。FPGA里要實現順序執行某個操作功能需要藉助狀態機實現。下麵比較了下兩種狀態機的寫法。

test_fsm和test_fsm2是兩個工程。

    test_fsm是仿順序寫法,即數節拍的寫法,行數多,看著繞人,但是寫的時候不饒人,另外寫的時候仔細點,模擬的時序就是你寫好的時序,屬於磨刀不誤砍柴工的類型,當然有人覺得後序維護升級時麻煩,比如加狀態或加一個操作時,更改會很麻煩,這個確實是,因此這種寫法在一開始寫的時候如果能考慮到後序升級就會更好,本人偏好這種寫法,因為代碼寫好即模擬好。

    test_fsm2是三段式狀態機的寫法,行數少,代碼簡潔,後序升級便利,只需要在狀態機中增減狀態。但是寫代碼的時候需要劃分狀態,狀態切換時需要考慮時序節拍,因此寫好後需要模擬,當然老鳥可以一眼望穿。

    下麵比較兩種寫法的綜合報告,具體報告可以打開工程仔細看。概括幾點如下:

    兩種寫法的綜合報告顯示兩種寫法的資源利用量差不多,但是FF的利用率相差較大,且fanout不一樣。

    Number of fully used LUT-FF pairs這項,仿順序的寫法達到62%,而三段式狀態機的寫法只有42%。這項越高越好,表示資源的利用率。

    在fanout上三段式狀態機的寫法fanout較低,這樣就對信號的扇出要求較低,如時鐘信號,有利於時序收斂。

    兩種寫法各有千秋,仁者見仁智者見智吧,正所謂左貴人右貴人都不錯,各人根據需求選擇自己喜歡的姿勢而已。

    本人在FPGA方面還是一隻小鳥,周末閑著無聊瞎搞搞的,歡迎大俠批評指正,一起深入學習FPGA!謝謝!

                                                                                                                            By 我有風衣 

// test_fsm && test_fsm2工程鏈接:http://pan.baidu.com/s/1i5GDe8P

                                                                


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • mysql系統資料庫主要存儲了一些存儲MySQL服務的系統信息表。一般情況下mysql庫的表都是MYASIM引擎,除非個別情況。mysql庫的表的作用大致可以分為以下幾類: (1)授權系統表 (2)系統對象信息系統表 (3)日誌系統表 (4)伺服器端輔助系統表 (5)time zone系統表 (6) ...
  • Redis 小白指南(一) 目錄 簡介 安裝 入門指令 GUI 工具 C# 驅動介紹 簡介 ANSI C 編寫,開源,基於記憶體,可持久化,一個鍵值對的資料庫,用法簡單。 支持的類型:字元串、散列、列表、集合和有序集合。 因為 Redis 預設將所有數據都存儲到記憶體中,並且記憶體的讀寫速度遠遠高於硬碟, ...
  • 1. Oracle跟SQL Server 2005的區別? 巨集觀上: 1). 最大的區別在於平臺,oracle可以運行在不同的平臺上,sql server只能運行在windows平臺上,由於windows平臺的穩定性和安全性影響了sql server的穩定性和安全性 2). oracle使用的腳本語 ...
  • 下麵總結、整理一下RMAN異機恢復這方面的知識點,這篇筆記在個人筆記裡面躺了幾年了,直到最近偶然被翻看到,遂整理、總結一下。如下所示,個人將整個RMAN異機恢復分為準備工作和操作步驟兩大部分。當然,準備工作裡面,有些步驟不是必須的,可以跳過或忽略的。這個取決於你的實際環境和你對RMAN異機恢復的熟悉... ...
  • haproxy的記憶體管理中,通過pool_head free_list,存儲空閑記憶體塊,free_list是個二級指針,卻把空閑記憶體塊都串了起來,沒有用next,pre之類的指針。怎麼實現的?著實思考了半個小時才明白。 pool_head結構: 可知,free_list是個二級指針,二級指針是指向指 ...
  • vim: 移動游標至段首:^或者home鍵 移動游標至段尾:$或者end鍵 刪除游標位置到本行開頭:d0或者d^ 刪除游標位置到本行末尾:D或者d$ 撤銷操作:u 取消撤銷操作:ctrl+r ...
  • 1.使用xinput list查看與觸摸板相關的id,以下是本機的輸出,沒搞清楚為什麼是Mouse!!! jello@jello:~$ xinput list⎡ Virtual core pointer id=2 [master pointer (3)]⎜ ↳ Virtual core XTEST ...
  • SPI (Serial Peripheral interface),顧名思義就是串列外圍設備介面。SPI是一種高速的,全雙工,同步的通信匯流排,並且在晶元的管腳上只占用四根線,節約了晶元的管腳,同時為PCB的佈局上節省空間,提供方便,主要應用在 EEPROM,FLASH,實時時鐘,AD轉換器,還有數字 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...