VHDL和verilog應該先學哪個?

来源:https://www.cnblogs.com/Colin-Cai/archive/2018/03/15/8547099.html
-Advertisement-
Play Games

網上有太多的VHDL和verilog比較的文章,基本上說的都是VHDL和verilog之間可以實現同一級別的描述,包括模擬級、寄存器傳輸級、電路級,所以可以認為兩者是等同級別的語言。很多時候會了其中一個,當然前提是真的學會,知道rtl(寄存器傳輸級)的意義,知道rtl與電路如何對應,在此基礎上,則很 ...


  網上有太多的VHDL和verilog比較的文章,基本上說的都是VHDL和verilog之間可以實現同一級別的描述,包括模擬級、寄存器傳輸級、電路級,所以可以認為兩者是等同級別的語言。很多時候會了其中一個,當然前提是真的學會,知道rtl(寄存器傳輸級)的意義,知道rtl與電路如何對應,在此基礎上,則很容易就可以學另外一個。從這個意義上,或許先學什麼都無所謂。

  學HDL無非要這麼幾類人:

  1.學生

  2.電子工程師

  3.軟體工程師

  4.純粹的愛好者

  學生,兩眼一摸黑,老師教什麼學什麼,只為了應付而已,從而很多學生學的非常垃圾,畢業了連個跑馬燈都不會做;電子工程師有電路的基礎,甚至可以用原理圖設計一定的數字邏輯,一般也是因為FPGA而學習;軟體工程師有軟體語言的基礎,一般是嵌入式軟體工程師為了FPGA而學習;愛好者只為興趣,甚至未必是IT業的工作者。

  VHDL是強類型語言,比verilog嚴格。有很多人覺得verilog長的像C語言,所以覺得verilog可能更容易學,我覺得說這話的一般都是軟體工程師。然而verilog只不過借用了C語言的符號而已,我甚至覺得還不夠徹底,如果verilog當初由我來設計,我肯定就會趕begin/end滾蛋了,而且我實在不理解為什麼不這麼做。使用&還是and有本質區別嗎?使用always@還是process有本質區別嗎?這些都不是重點,這些都只是語法的區別而已。你有C語言的基礎對於你學慣用verilog設計電路作用不是很大,但HDL不僅用來設計真實電路,也是可以拿來設計模擬的,如果你是玩模擬的話,那麼C的基礎作用還是很大的。

  VHDL當初是用來做美國軍方定製硬體的行為描述的語言,HDL的D不是design,而是description。VHDL有著相對verilog更大的抽象能力,理論上verilog只能在0/1的數字信號系統上玩,而VHDL完全可以為多進位數字建模。當然,同時,VHDL被定義成一種強類型語言,從而不像verilog用起來那麼爽,很容易就寫出語法錯誤,這對於有些人是一段痛苦的經歷。從VHDL強大的抽象能力和強類型來看,這玩意比verilog更像軟體,而verilog更像電路。VHDL的rtl更像是一種人為的定義,而verilog的rtl才更像是與電路的對應。

  在用VHDL的時候,遇到狀態機,就定義一下類型type state is (stat1, stat2 ...),這個stat1、stat2只是不同的符號,這個很不電路啊。我們經常使用的std_logic、std_logic_vector,遇到與數字比較要conv_integer一通,這個真的很不電路。VHDL寫代碼的確很啰嗦,代碼長度遠勝於verilog。看來看去,明顯還是verilog直接,那就是電路,不繞彎子。

  verilog強大的模擬功能,相比之下VHDL的模擬功能弱爆了。verilog這麼多年的市場占有率遠勝於VHDL,基本可以認為VHDL快被淘汰了,除了一些以前的設計需要支持以及很多學校還是以VHDL教學,基本用的很少了。

  學習HDL的設計,很多時候是要搞清楚RTL里實際電路和代碼的對應。其實,對於verilog,也只要知道assign在rtl里肯定是組合邏輯(當然你帶反饋除外,不過絕對不建議帶反饋這麼去寫),而always里綜合為組合邏輯和時序邏輯的條件,這些其實並不難。VHDL這一點倒也類似,區別不大。順便說一句,三段式和一段式的本質差別在於三段式下狀態和動作完全同時,而一段式下狀態比動作快一拍。至於其他的網路上說法的各種扯淡,不用理會,都什麼時代了,編譯器(還沒到綜合階段)如果連組合電路和時序電路都不能很好的整理出來並優化的,還好意思在世面上丟人現眼?

  綜上所述,我現在還是覺得verilog比較適合初學了,甚至於學了verilog再去學VHDL作用不大。但是verilog很是靈活,這本是我之前覺得在學習verilog之前應該先學習VHDL的原因。但現在,我覺得,在學習verilog之前,還是先學習原理圖設計吧,只是原理圖設計之後的VHDL階段沒太多必要。


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

-Advertisement-
Play Games
更多相關文章
  • 本文較為詳細地介紹了Scala的理論,並結合相應的代碼進行解讀與實踐。文章內容主要包含Scala的簡介,數據類型,函數(函數定義、匿名函數、嵌套函數、迴圈語句等),集合(List、Tuple、Map),伴生對象,trait,Actor,隱式轉換,JDBC等。 ...
  • 看一次哭一次網址: https://www.bilibili.com/bangumi/play/ss836/?from=search&seid=4709676986893938334 4月出第二部! 聲臨其境,有一個人能配石頭門第22集嗎? 發Python上了,不喜歡求舉報 ...
  • 1. 啟動報錯,查看debug $ java -jar myproject-0.0.1-SNAPSHOT.jar –debug 2.自定義banner The banner that is printed on start up can be changed by adding a banner.t ...
  • While 迴圈語句 用於迴圈執行程式,即在某條件下,迴圈執行某段程式,以處理需要重覆處理的相同任務。 語法: 執行語句可以是單個語句或語句塊。判斷條件可以是任何表達式,任何非零、或非空(null)的值均為true。 當判斷條件假false時,迴圈結束。 示例:for迴圈實現猜字游戲 while 實 ...
  • 1. 字元串中必須僅有P, A, T這三種字元,不可以包含其它字元; 2. 任意形如 xPATx 的字元串都可以獲得“答案正確”,其中 x 或者是空字元串,或者是僅由字母 A 組成的字元串; 3. 如果 aPbTc 是正確的,那麼 aPbATca 也是正確的,其中 a, b, c 均或者是空字元串, ...
  • java.lang.IllegalArgumentExceptionat org.springframework.asm.ClassReader.<init>(Unknown Source)at org.springframework.asm.ClassReader.<init>(Unknown S ...
  • 練習 ...
  • 1.使用字元串來存儲文本; 2.在程式中顯示字元串; 3.在字元串中包含特殊的字元; 4.拼接字元串; 5.在字元串中包含變數; 6.比較字元串; 7.判斷字元串的長度; 程式Credits:顯示一部電影的導演和演員名單 1 package com.jsample; 2 3 public class ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...