女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

【教程分享】在FPGA中何時用組合邏輯或時序邏輯?

電子發(fā)燒友論壇 ? 來源:未知 ? 2023-03-21 09:50 ? 次閱讀

本系列將帶來FPGA的系統(tǒng)性學習,從最基本的數(shù)字電路基礎開始,最詳細操作步驟,最直白的言語描述,手把手的“傻瓜式”講解,讓電子、信息、通信類專業(yè)學生、初入職場小白及打算進階提升的職業(yè)開發(fā)者都可以有系統(tǒng)性學習的機會。

系統(tǒng)性的掌握技術開發(fā)以及相關要求,對個人就業(yè)以及職業(yè)發(fā)展都有著潛在的幫助,希望對大家有所幫助。后續(xù)會陸續(xù)更新 Xilinx 的 Vivado、ISE 及相關操作軟件的開發(fā)的相關內容,學習FPGA設計方法及設計思想的同時,實操結合各類操作軟件,會讓你在技術學習道路上無比的順暢,告別技術學習小BUG卡破腦殼,告別目前忽悠性的培訓誘導,真正的去學習去實戰(zhàn)應用,這種快樂試試你就會懂的。話不多說,上貨。

在FPGA中何時用組合邏輯或時序邏輯

在設計FPGA時,大多數(shù)采用Verilog HDL或者VHDL語言進行設計(本文重點以verilog來做介紹)。設計的電路都是利用FPGA內部的LUT和觸發(fā)器等效出來的電路。

數(shù)字邏輯電路分為組合邏輯電路和時序邏輯電路。時序邏輯電路是由組合邏輯電路和時序邏輯器件構成(觸發(fā)器),即數(shù)字邏輯電路是由組合邏輯和時序邏輯器件構成。所以FPGA的最小單元往往是由LUT(等效為組合邏輯)和觸發(fā)器構成。

在進行FPGA設計時,應該采用組合邏輯設計還是時序邏輯?這個問題是很多初學者不可避免的一個問題。

設計兩個無符號的8bit數(shù)據(jù)相加的電路。

組合邏輯設計代碼:

01fa80d8-c78a-11ed-bfe3-dac502259ad0.png

對應的電路為:

0214c538-c78a-11ed-bfe3-dac502259ad0.png

時序邏輯對應代碼為:

021d9032-c78a-11ed-bfe3-dac502259ad0.png

對應的電路為:

022e12ae-c78a-11ed-bfe3-dac502259ad0.png

可以思考一下,這個兩種設計方法都沒有任何錯誤。那么在設計時應該用哪一種呢?

在設計時,有沒有什么規(guī)定必須要用組合邏輯或者時序邏輯?例如:在verilog中,在always中被賦值了就必須是reg類型,assign賦值了就必須是wire類型。很遺憾的是,目前沒有任何的規(guī)定。

下面幾點筆者平時自己做設計的經驗,在這里分享一下:

帶有反饋的必須用時序邏輯

何為帶有有反饋?即輸出結果拉回到輸入。

自加一計數(shù)器。

代碼為:

02356842-c78a-11ed-bfe3-dac502259ad0.png

對應的電路為:

0245679c-c78a-11ed-bfe3-dac502259ad0.png

這種電路在工作時,就會出現(xiàn)無限反饋,不受任何控制,一般情況下,我們認為結果沒有任何意義。

和上面的情況類似的還有取反。

0250b782-c78a-11ed-bfe3-dac502259ad0.png

類似情況還有很多就不在一一列舉。

上述說的情況都是直接帶有反饋,下面說明間接反饋。

代碼為:

02619070-c78a-11ed-bfe3-dac502259ad0.png

從代碼上來看,沒有什么明確反饋,下面看實際對應的電路。

026928d0-c78a-11ed-bfe3-dac502259ad0.png

從實際的電路上來看,一旦運行起來,還是會出現(xiàn)無限反饋,不受任何控制。

還有一種情況是帶有控制的反饋。

設計代碼為:

0277f4fa-c78a-11ed-bfe3-dac502259ad0.png

這個電路可以等效為:

02802328-c78a-11ed-bfe3-dac502259ad0.png

在flag等于1期間,此電路依然會無限制的反饋,無法確定在此期間進行了多少次反饋。

從代碼的角度理解是flag變化一次,加一次。可是對應于電路后,和預想的是不相同的。

說了這么多的這么多不對的情況,下面考慮正確的情況。

028f1d74-c78a-11ed-bfe3-dac502259ad0.png

設計代碼為:

029a348e-c78a-11ed-bfe3-dac502259ad0.png

在上述的電路中,clk每來一個上升沿,cnt的數(shù)值增加一。可以用作計時使用。

利用寄存器將反饋路徑切換即可。此時的反饋是可控制,并且此時的結果就有了意義。

其他的反饋中,加入寄存器即可。而加入寄存器后,就變?yōu)闀r序邏輯。

根據(jù)時序對齊關系進行選擇

在很多的設計時,沒有反饋,那么應該如何選擇呢?

舉例說明:輸入一個八位的數(shù)據(jù)(idata),然后將此八位數(shù)據(jù)進行平方后,擴大2倍,作為輸出。要求輸出結果(result)時,將原數(shù)據(jù)同步輸出(odata),即數(shù)據(jù)和結果在時序上是對齊的。

設計代碼為:

02a58ba4-c78a-11ed-bfe3-dac502259ad0.png

這種設計方法是可以的,因為都采用組合邏輯設計,odata和result都是和idata同步的,只有邏輯上的延遲,沒有任何時鐘的延遲。

另外一種設計代碼為:

02ad891c-c78a-11ed-bfe3-dac502259ad0.png

這種設計方法為錯誤,odata的輸出是和idata同步的,而result的輸出將會比idata晚一拍,最終導致result要比odata晚一拍,此時結果為不同步,設計錯誤。

修改方案為:將result的寄存器去掉,修改為組合邏輯,那就是第一種設計方案。第二種為將odata也進行時序邏輯輸出,那么此時odata也將會比idata延遲一拍,最終結果為result和odata同步輸出。

根據(jù)運行速度進行選擇

在數(shù)字邏輯電路中,中間某一部分為組合邏輯,兩側的輸入或者輸出也會對延遲或者輸入的數(shù)據(jù)速率有一定的要求。

02bac334-c78a-11ed-bfe3-dac502259ad0.png

組合邏輯1越復雜延遲越大,而導致的結果就是clk的時鐘速率只能降低,進而導致設計結果失敗。

當組合邏輯1無法進行優(yōu)化時,還想要達到自己想要的速度時,我們可以進行邏輯拆分,增加數(shù)據(jù)的輸出潛伏期,增加數(shù)據(jù)的運行速度。

02c77804-c78a-11ed-bfe3-dac502259ad0.png

將組合邏輯1的功能拆分為組合邏輯A和組合邏輯B,此時,輸入的數(shù)據(jù)得到結果雖然會多延遲一拍,但是數(shù)據(jù)的流速會變快。

那么這個和選用組合邏輯和時序邏輯有什么關系呢?

舉例說明:目前要設計模塊A,不涉及反饋,不涉及時序對齊等,可以采取組合邏輯設計也可以采用時序邏輯設計。

模塊A的輸出連接到模塊B,經過一些變換(組合邏輯N)連接到某個寄存器K上。如果模塊A采用組合邏輯,那么模塊A的組合邏輯和模塊B到達寄存器K之前的組合邏輯N會合并到一起。那么此時組合邏輯的延遲就會變得很大,導致整體設計的時鐘速率上不去。

當運行速率比較快時,建議對于復雜的組合邏輯進行拆分,有利于時序分析的通過。

在上述的三個規(guī)則中,第一個和第二個用的是最多的,第三個在設計時,有時不一定能夠注意到,當出現(xiàn)時序違例時,知道拆分能夠解決問題就可以。


本文由電子發(fā)燒友社區(qū)發(fā)布,轉載請注明以上來源。如需社區(qū)合作及入群交流,請?zhí)砑?/span>微信EEFans0806,或者發(fā)郵箱liuyong@huaqiu.com

02de6fa0-c78a-11ed-bfe3-dac502259ad0.png

熱門推薦干貨好文

1、RK3568!四核64位ARMv8.2A架構,匯聚編譯源碼及實戰(zhàn)樣例

2、開源作品秀,教你如何DIY一款自己的聲源跟蹤小車

3、ARM架構國產MCU移植!國民技術N32系列開源移植樣例合集

4、低成本ESP32方案,支持OpenHarmony系統(tǒng)開發(fā)(附10+項目樣例Demo)

5、從0到1玩轉瑞薩RA4系列開發(fā)板,教你變著花樣玩板子

6、四核64位,超強CPU ,看RK3568“競”開發(fā)板DEMO!

7、人工智能也能這么玩, 簡單快速入手,還能自定義AI運算

8、全部開源 | 基于全志V85X的運動相機,工業(yè)網關,可穿戴式攝像頭

9、高性能雙核RISC-V,滿足大多數(shù)開發(fā),這款國產MCU工程師都愛


原文標題:【教程分享】在FPGA中何時用組合邏輯或時序邏輯?

文章出處:【微信公眾號:電子發(fā)燒友論壇】歡迎添加關注!文章轉載請注明出處。


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

    評論

    相關推薦
    熱點推薦

    邏輯電路芯片-組合邏輯電路芯片-時序邏輯電路芯片

    微型電子元件,極小的空間內實現(xiàn)了復雜的邏輯功能。邏輯電路芯片根據(jù)設計不同,可以分為組合邏輯電路和時序
    發(fā)表于 09-30 10:47

    FPGA算法工程師、邏輯工程師、原型驗證工程師有什么區(qū)別?

    組合邏輯的行為,而通過 reg,可以模擬時序邏輯的行為。 綜合行為:綜合時,wire 表示一個組合
    發(fā)表于 09-23 18:26

    時序邏輯電路有記憶功能嗎

    時序邏輯電路確實具有記憶功能 。這一特性是時序邏輯電路與組合邏輯電路的本質區(qū)別之一。
    的頭像 發(fā)表于 08-29 10:31 ?1271次閱讀

    時序邏輯電路的基本概念、組成、分類及設計方法

    Logic Circuit)是一種在數(shù)字電路,其輸出不僅取決于當前輸入,還取決于過去輸入歷史的電路。與組合邏輯電路(Combinational Logic Circuit)不同,組合
    的頭像 發(fā)表于 08-28 11:45 ?3699次閱讀

    時序邏輯電路的功能表示方法有哪些

    時序邏輯電路是數(shù)字電路的一種重要類型,其特點是電路的輸出不僅取決于當前的輸入,還取決于電路的狀態(tài)。時序邏輯電路廣泛應用于計算機、通信、控制
    的頭像 發(fā)表于 08-28 11:41 ?1259次閱讀

    加法器是時序邏輯電路嗎

    加法器不是時序邏輯電路 ,而是組合邏輯電路的一種。時序邏輯電路和
    的頭像 發(fā)表于 08-28 11:05 ?1239次閱讀

    時序邏輯會產生鎖存器嗎

    時序邏輯電路本身并不直接“產生”鎖存器,但鎖存器是時序邏輯電路的重要組成部分。時序
    的頭像 發(fā)表于 08-28 11:03 ?774次閱讀

    組合邏輯電路設計時應遵循什么原則

    一、引言 組合邏輯電路是數(shù)字電路的一種基本類型,它由邏輯門、觸發(fā)器等基本元件組成,通過邏輯門的組合
    的頭像 發(fā)表于 08-11 11:26 ?1992次閱讀

    組合邏輯電路輸出狀態(tài)取決于哪些因素

    組合邏輯電路的輸出狀態(tài)主要取決于以下因素: 核心因素 輸入信號的現(xiàn)態(tài) :組合邏輯電路的輸出狀態(tài)在任何時刻僅由其當前輸入狀態(tài)的
    的頭像 發(fā)表于 08-11 11:24 ?1635次閱讀

    組合邏輯電路的結構特點是什么?

    時序邏輯電路形成對比,后者具有記憶功能,輸出不僅取決于當前輸入,還與過去的狀態(tài)有關。 并行處理能力 :組合邏輯電路可以同時處理多個輸入信號,實現(xiàn)并行運算。這種并行處理能力使得
    的頭像 發(fā)表于 08-11 11:14 ?1537次閱讀

    時序邏輯電路包括什么器件組成

    當前的輸入信號,還取決于電路的歷史狀態(tài)。與組合邏輯電路不同,組合邏輯電路的輸出僅取決于當前的輸入信號,而時序
    的頭像 發(fā)表于 07-30 15:02 ?2074次閱讀

    常用的組合邏輯電路有哪些

    組合邏輯電路是數(shù)字邏輯電路的一種,其特點是輸出只依賴于當前的輸入狀態(tài),而與輸入信號的變化歷史無關。組合邏輯電路廣泛應用于數(shù)字系統(tǒng)
    的頭像 發(fā)表于 07-30 14:41 ?3067次閱讀

    組合邏輯電路邏輯功能的測試方法

    一、引言 組合邏輯電路是數(shù)字電路的重要組成部分,它僅由邏輯門電路(如與門、門、非門等)和輸入/輸出端組成,不包含任何存儲元件。
    的頭像 發(fā)表于 07-30 14:38 ?1876次閱讀

    組合邏輯控制器是什么設備

    組合邏輯控制器(Combinatorial Logic Controller,簡稱CLC)是一種用于控制和管理復雜系統(tǒng)設備的電子設備。它通常由多個邏輯門、觸發(fā)器和其他
    的頭像 發(fā)表于 06-30 10:29 ?1062次閱讀

    組合邏輯控制器是什么實現(xiàn)的

    組合邏輯控制器概述 1.1 定義 組合邏輯控制器是一種基于組合邏輯電路的控制器,它通過
    的頭像 發(fā)表于 06-30 10:11 ?772次閱讀