女人荫蒂被添全过程13种图片,亚洲+欧美+在线,欧洲精品无码一区二区三区 ,在厨房拨开内裤进入毛片

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何在FPGA中實(shí)現(xiàn)狀態(tài)機(jī)

FPGA設(shè)計論壇 ? 來源:未知 ? 2023-07-18 16:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

狀態(tài)機(jī)往往是FPGA 開發(fā)的主力。選擇合適的架構(gòu)和實(shí)現(xiàn)方法將確保您獲得一款最佳解決方案。

FPGA 常常用于執(zhí)行基于序列和控制的行動, 比如實(shí)現(xiàn)一個簡單的通信協(xié)議。對于設(shè)計人員來說,滿足這些行動和序列要求的最佳方法則是使用狀態(tài)機(jī)。狀態(tài)機(jī)是在數(shù)量有限的狀態(tài)之間進(jìn)行轉(zhuǎn)換的邏輯結(jié)構(gòu)。一個狀態(tài)機(jī)在某個特定的時間點(diǎn)只處于一種狀態(tài)。但在一系列觸發(fā)器的觸發(fā)下,將在不同狀態(tài)間進(jìn)行轉(zhuǎn)換。理論上講,狀態(tài)機(jī)可以分為Moore 狀態(tài)機(jī)和Mealy 狀態(tài)機(jī)兩大類。它們之間的差異僅在于如何生成狀態(tài)機(jī)的輸出。Moore 狀態(tài)機(jī)的輸出僅為當(dāng)前狀態(tài)的函數(shù)。典型的例子就是計數(shù)器。而Mealy 狀態(tài)機(jī)的輸出是當(dāng)前狀態(tài)和輸入的函數(shù)。典型的例子就是Richards 控制器.

定義狀態(tài)機(jī)
當(dāng)需要定義一個狀態(tài)機(jī)時,首先要繪制一張狀態(tài)圖。狀態(tài)圖可用來顯示狀態(tài)、狀態(tài)間的轉(zhuǎn)換和狀態(tài)機(jī)的輸出。圖1 顯示了Moore 狀態(tài)機(jī)的狀態(tài)圖(左)和Mealy 狀態(tài)機(jī)的狀態(tài)圖(右)。

wKgZomToDwqAPwQ0AABPk6bb5_g765.jpg

如果您要在物理組件中實(shí)現(xiàn)這些狀態(tài)圖(工程師在FPGA問世之前就是這么做的),首先就得生成當(dāng)前狀態(tài)和后續(xù)狀態(tài)表,然后生成實(shí)現(xiàn)狀態(tài)機(jī)所需的邏輯。不過由于我們將使用FPGA來實(shí)現(xiàn)設(shè)計,因此我們可以直接從狀態(tài)轉(zhuǎn)換圖開始工作。

算法狀態(tài)圖
雖然有許多狀態(tài)機(jī)是使用圖1 所示的狀態(tài)圖方法進(jìn)行設(shè)計的,但另外還有一種描述狀態(tài)機(jī)行為的方法,這就是算法狀態(tài)圖法。ASM 圖(圖2)在外觀上更加接近軟件工程流程圖。它由三個基本部分構(gòu)成:
1. 狀態(tài)框。它與狀態(tài)名稱有關(guān),并包含Moore 狀態(tài)輸出列表。
2. 決策框。如果檢驗?zāi)硹l件為真,則進(jìn)行下一狀態(tài)的判斷。
3. 條件輸出框。讓狀態(tài)機(jī)根據(jù)當(dāng)前狀態(tài)和輸入描述Mealy輸出。

一些工程師認(rèn)為,如果使用VHDL 等硬件描述語言,則采用ASM 格式進(jìn)行描述的狀態(tài)機(jī)更易于映射到實(shí)現(xiàn)方案中。

wKgZomToDwqALcL6AACv6iaOBNg611.jpg

MOORE 和MEALY:應(yīng)該選擇哪個?
實(shí)現(xiàn)Moore 狀態(tài)機(jī)還是Mealy 狀態(tài)機(jī),取決于狀態(tài)機(jī)需要實(shí)現(xiàn)的功能,以及特定的反應(yīng)次數(shù)要求。兩種狀態(tài)機(jī)之間的最大差別在于狀態(tài)機(jī)如何對輸入做出反應(yīng)。在輸入和設(shè)置的適當(dāng)輸出之間,Moore 狀態(tài)機(jī)一般有一個時鐘周期的延遲。這就意味著Moore 狀態(tài)機(jī)無法對輸入變化立即做出反應(yīng),這點(diǎn)在圖3中可以清楚地看到。而Mealy 狀態(tài)機(jī)則能夠立即對輸入做出反應(yīng),這通常意味著:實(shí)現(xiàn)相同的函數(shù),Mealy 狀態(tài)機(jī)比Moore狀態(tài)機(jī)需要更少的狀態(tài)。Mealy 狀態(tài)機(jī)的不足之處就是在與另一個狀態(tài)機(jī)進(jìn)行通信時,如果輸出出乎意料地嚴(yán)重依賴于其它事件的序列或時序,就可能會發(fā)生紊亂情況。

wKgZomToDwqADNpDAACW_hidFhM360.jpg

當(dāng)然,并非只能使用單純的Moore狀態(tài)機(jī)或Mealy 狀態(tài)機(jī),也可以將這兩種狀態(tài)機(jī)混合使用,從而更有效地實(shí)現(xiàn)所需的函數(shù)。比如說,用于接收RS232 串行數(shù)據(jù)的狀態(tài)機(jī)就可以是混合機(jī)。

實(shí)現(xiàn)狀態(tài)機(jī)
使用VHDL 這樣的高級語言,可以輕松地直接從狀態(tài)圖實(shí)現(xiàn)狀態(tài)機(jī)。VHDL 支持多種枚舉類型,方便您定義實(shí)際的狀態(tài)名稱。舉例如下:

wKgZomToDwqAAog_AAAK-wQ9T_k852.jpg

上面的類型定義對應(yīng)的是圖1 中所示的狀態(tài)圖,即用于在按下按鈕時切換發(fā)光二極管開/ 關(guān)的狀態(tài)機(jī)。

實(shí)現(xiàn)狀態(tài)機(jī)有許多種方法,可分為兩類基本方法。第一類基本方法就是一次性將所有內(nèi)容集成到單個進(jìn)程中。第二類基本方法是雙進(jìn)程法,將組合邏輯和順序邏輯分開。

一般來說,大多數(shù)工程師都傾向于實(shí)現(xiàn)單進(jìn)程狀態(tài)機(jī)。與傳統(tǒng)上講授的雙進(jìn)程法相比,這種方法具有以下優(yōu)勢:
? 可以避免組合過程中信號覆蓋不完全造成的閉鎖風(fēng)險。
? 狀態(tài)機(jī)的輸出與時鐘保持同步。
? 通常比雙進(jìn)程實(shí)現(xiàn)方案更容易調(diào)試。

無論您決定采用哪一種方法來實(shí)現(xiàn)狀態(tài)機(jī),都需要使用CASE 語句來評估下一狀態(tài)的判定和任何輸出,如圖4 所示。該圖并行比較了使用單進(jìn)程法的Moore 狀態(tài)機(jī)( 左) 和Mealy 狀態(tài)機(jī)(右)。

wKgZomToDwqAdOcAAACCLiB89Yc881.jpg

狀態(tài)機(jī)編碼
狀態(tài)變量存儲在觸發(fā)器中,使用下一時鐘邊緣上的下一狀態(tài)進(jìn)行更新(即使沒有狀態(tài)變化也是如此)。如何使用觸發(fā)器來表示狀態(tài)值具體取決于狀態(tài)的數(shù)量和是否選擇用某種特定的方法來管理綜合工具。狀態(tài)編碼最常見的三種類型是:
? 順序碼——狀態(tài)編碼遵循傳統(tǒng)的狀態(tài)二進(jìn)制序列。
? 格雷碼——除了狀態(tài)編碼使用格雷碼,且狀態(tài)編碼串
之間只有一個位變化外,其它基本與順序編碼方法類似。
? 獨(dú)熱碼——這種方法在狀態(tài)機(jī)中為每一種狀態(tài)分配一個觸發(fā)器。只有一個觸發(fā)器當(dāng)前設(shè)置為高位,其余均設(shè)置為低位。故稱為“獨(dú)熱”。

順序編碼和格雷編碼都需要一定數(shù)量的觸發(fā)器,可以通過下列等式來確定:

wKgZomToDwuABxOnAAARFGQ_GUw364.jpg

相比之下,獨(dú)熱編碼法所需的觸發(fā)器數(shù)量和狀態(tài)數(shù)量一樣多。

狀態(tài)編碼的自動分配取決于狀態(tài)機(jī)所包含的狀態(tài)數(shù)量。同時還需要考慮您選擇使用的綜合工具。您可以根據(jù)下列經(jīng)驗法則來選取編碼方法:
? 順序:少于5 種狀態(tài)。
? 獨(dú)熱:5-50 種狀態(tài)。
? 格雷:多于50 種狀態(tài)。

一般情況下您不必去考慮使用哪一種狀態(tài)編碼方法,而是讓綜合引擎工具確定合適的實(shí)現(xiàn)方案,只在選擇的方法出現(xiàn)問題時進(jìn)行考慮。但是,如果您要全盤自行掌控,并定義狀態(tài)編碼方法,也沒必要手動操作,只需使用狀態(tài)編碼為每一種狀態(tài)設(shè)定常數(shù)即可。相反地,可以使用代碼中的一個屬性來驅(qū)動綜合工具,從而選擇特定的編碼方法。具體如下所示:

wKgZomToDwuAW8oiAAA64RouyEA374.jpg

其中“sequential”也可以是“gray”和“onehot”。您還可以通過結(jié)合使用“safe”屬性來確保在狀態(tài)機(jī)進(jìn)入非法狀態(tài)時能夠恢復(fù)到有效狀態(tài)。

另外,您也可以使用syn_encoding 屬性直接定義狀態(tài)編碼的值。例如,假設(shè)您想要使用下列狀態(tài)編碼法來對三態(tài)狀態(tài)機(jī)進(jìn)行編碼:Idle = “11,” led_on = “10,” led_off = “01(與較傳統(tǒng)的順序“00”、“01”和“10”不同):

wKgZomToDwuASNbwAAA4TkPhX84039.jpg

前面給出的等式可確定狀態(tài)機(jī)實(shí)現(xiàn)方案所需的觸發(fā)器數(shù)量。由于不是所有的狀態(tài)機(jī)都是2 的冪次方,因此某些狀態(tài)在設(shè)計中將不會用到。實(shí)現(xiàn)狀態(tài)機(jī)的工程師必須負(fù)責(zé)確保未使用的狀態(tài)在設(shè)計中得到妥善處理??梢圆捎脦追N適用于多種設(shè)計的基本技巧來實(shí)現(xiàn)這一目標(biāo)。對于高度可靠的安全關(guān)鍵型設(shè)計,則需要采用其它更高級的技巧。(參見Xcell 雜志第73 期刊登的深度文章《在關(guān)鍵任務(wù)系統(tǒng)中使用FPGA》。該文章著重闡述狀態(tài)機(jī)保護(hù)問題。)

不過對于大多數(shù)應(yīng)用來說,只需要確保狀態(tài)機(jī)能夠妥善地處理未使用的狀態(tài)并在進(jìn)入非法狀態(tài)時能夠正確地恢復(fù)。要做到這一點(diǎn)有兩種主要的方法。第一種方法是使用綜合工具實(shí)現(xiàn)一個安全的狀態(tài)機(jī)。綜合工具通常會插入額外的邏輯,用于檢測非法狀態(tài)并將狀態(tài)機(jī)返回到有效狀態(tài)。第二種方法是加強(qiáng)對實(shí)現(xiàn)邏輯的控制,聲明所有2 的冪次方狀態(tài)機(jī)的狀態(tài),并使用另一屬性來確保即便是在沒有入口條件下,2 的冪次方狀態(tài)機(jī)的狀態(tài)也不會被優(yōu)化掉。這意味著除非出錯(單粒子翻轉(zhuǎn)等),狀態(tài)機(jī)內(nèi)部的任何條件都不會進(jìn)入狀態(tài)。下面的代碼顯示了通過使用屬性以防止清除未使用的狀態(tài)。

wKgZomToDwuAIR0QAAArEANyBi0199.jpg

簡而言之,安全高效的狀態(tài)機(jī)設(shè)計對于任何使用FPGA的工程師而言都是一項重要技能。選擇Moore 狀態(tài)機(jī)、Mealy
狀態(tài)機(jī)還是混合機(jī)取決于整個系統(tǒng)的需求。無論選擇哪種類型的狀態(tài)機(jī),充分掌握實(shí)現(xiàn)方案所需的工具和技巧,將確保您實(shí)現(xiàn)最佳解決方案。

wKgZomToDwuAfSyyAAAJM7aZU1A696.png

有你想看的精彩 至芯科技-FPGA就業(yè)培訓(xùn)來襲!你的選擇開啟你的高薪之路!7月12號北京中心開課、歡迎咨詢! 至芯科技奮斗的小孩之verilog 基礎(chǔ)語法 基于matlab FPGA verilog的FIR濾波器設(shè)計

wKgZomToDwuAFZTPAABUdafP6GM512.jpg

掃碼加微信邀請您加入FPGA學(xué)習(xí)交流群

wKgZomToDwuAaCsXAAACXWrmhKE084.png

歡迎加入至芯科技FPGA微信學(xué)習(xí)交流群,這里有一群優(yōu)秀的FPGA工程師、學(xué)生、老師、這里FPGA技術(shù)交流學(xué)習(xí)氛圍濃厚、互分享、相互幫助、叫上小伙伴一起加入吧

點(diǎn)個在看你最好看


原文標(biāo)題:如何在FPGA中實(shí)現(xiàn)狀態(tài)機(jī)

文章出處:【微信公眾號:FPGA設(shè)計論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


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

    關(guān)注

    1644

    文章

    22009

    瀏覽量

    616580

原文標(biāo)題:如何在FPGA中實(shí)現(xiàn)狀態(tài)機(jī)

文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設(shè)計論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    有可能在 FX3 GPIF2 創(chuàng)建兩個獨(dú)立的狀態(tài)機(jī)嗎?

    我想,如果我想通過 FX3 GPIF2 創(chuàng)建兩個獨(dú)立的傳輸流接口,我需要在 GPIF2 設(shè)計器創(chuàng)建兩個獨(dú)立的狀態(tài)機(jī),我是否有可能在 GPIF2 設(shè)計器創(chuàng)建兩個獨(dú)立的狀態(tài)機(jī)
    發(fā)表于 05-20 06:14

    cypress3014視頻格式改變的話,GPIF狀態(tài)機(jī)需不需要重新配置?

    你好,請問視頻格式改變的話,GPIF狀態(tài)機(jī)需不需要重新配置
    發(fā)表于 05-14 07:28

    求助,關(guān)于srammaster.cydsn狀態(tài)機(jī)的問題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn狀態(tài)機(jī),有狀態(tài)START和START
    發(fā)表于 05-12 06:20

    高速ssd存儲系統(tǒng)數(shù)據(jù)緩存控制器流程控制設(shè)計

    高速SSD系統(tǒng)中流程控制模塊設(shè)計。該模塊主要由寄存器、讀狀態(tài)機(jī)、寫狀態(tài)機(jī)和命令生成模塊組成,系統(tǒng)介紹各模塊功能。
    的頭像 發(fā)表于 04-14 10:43 ?233次閱讀
    高速ssd存儲系統(tǒng)<b class='flag-5'>中</b>數(shù)據(jù)緩存控制器流程控制設(shè)計

    Simulink狀態(tài)機(jī)建模方法 Simulink數(shù)據(jù)可視化與分析功能

    1. Simulink狀態(tài)機(jī)建模方法 1.1 理解狀態(tài)機(jī)的基本概念 在開始建模之前,了解狀態(tài)機(jī)的基本概念是必要的。狀態(tài)機(jī)由以下幾個部分組
    的頭像 發(fā)表于 12-12 09:27 ?2898次閱讀

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

    ,優(yōu)勢在哪里? A:在 Verilog ,狀態(tài)機(jī)可以全部使用時序邏輯來實(shí)現(xiàn),但通常會采用組合邏輯來實(shí)現(xiàn)狀態(tài)轉(zhuǎn)移和輸出,主要是基于以下原因: 資源利用效率:全部使用時序邏輯會導(dǎo)致大量的
    發(fā)表于 09-23 18:26

    如何用FPGA實(shí)現(xiàn)一個通信系統(tǒng)的發(fā)射端接收機(jī)?

    FPGA 的開發(fā)流程,包括設(shè)計輸入、綜合、實(shí)現(xiàn)、仿真等。 ? 掌握常用的 FPGA 開發(fā)工具,如 Vivado、Quartus 等。 ? 練習(xí)使用狀態(tài)機(jī)、流水線等設(shè)計技巧來優(yōu)化
    發(fā)表于 09-10 19:15

    何在反激式拓?fù)?b class='flag-5'>中實(shí)現(xiàn)軟啟動

    電子發(fā)燒友網(wǎng)站提供《如何在反激式拓?fù)?b class='flag-5'>中實(shí)現(xiàn)軟啟動.pdf》資料免費(fèi)下載
    發(fā)表于 09-04 11:09 ?0次下載
    如<b class='flag-5'>何在</b>反激式拓?fù)?b class='flag-5'>中</b><b class='flag-5'>實(shí)現(xiàn)</b>軟啟動

    何在FPGA實(shí)現(xiàn)按鍵消抖

    FPGA(現(xiàn)場可編程門陣列)實(shí)現(xiàn)按鍵消抖是一個重要的設(shè)計環(huán)節(jié),特別是在處理用戶輸入時,由于物理按鍵的機(jī)械特性和電氣特性,按鍵在按下和釋放的瞬間會產(chǎn)生抖動現(xiàn)象,這種抖動可能導(dǎo)致系統(tǒng)錯誤地識別為多次
    的頭像 發(fā)表于 08-19 18:15 ?3423次閱讀

    觸發(fā)器和狀態(tài)機(jī)的關(guān)系是什么

    觸發(fā)器和狀態(tài)機(jī)在數(shù)字電路設(shè)計中有著緊密的關(guān)系,它們共同構(gòu)成了時序邏輯電路的基礎(chǔ),用于實(shí)現(xiàn)數(shù)據(jù)的存儲、處理和傳輸。
    的頭像 發(fā)表于 08-12 11:24 ?899次閱讀

    何在FPGA實(shí)現(xiàn)隨機(jī)數(shù)發(fā)生器

    分享如何在Xilinx Breadboardable Spartan-7 FPGA, CMOD S7實(shí)現(xiàn)4位偽隨機(jī)數(shù)發(fā)生器(PRNGs)。
    的頭像 發(fā)表于 08-06 11:20 ?1152次閱讀
    如<b class='flag-5'>何在</b><b class='flag-5'>FPGA</b><b class='flag-5'>中</b><b class='flag-5'>實(shí)現(xiàn)</b>隨機(jī)數(shù)發(fā)生器

    何在FPGA實(shí)現(xiàn)狀態(tài)機(jī)

    FPGA(現(xiàn)場可編程門陣列)實(shí)現(xiàn)狀態(tài)機(jī)是一種常見的做法,用于控制復(fù)雜的數(shù)字系統(tǒng)行為。狀態(tài)機(jī)能夠根據(jù)當(dāng)前的輸入和系統(tǒng)狀態(tài),決定下一步的動作
    的頭像 發(fā)表于 07-18 15:57 ?1177次閱讀

    如何使用FX3同步從屬fifo模式通過FPGA傳輸傳感器數(shù)據(jù)?

    作為多路復(fù)用器選擇引腳。 不過,在切換到從屬 FIFO 之前,我們在固件調(diào)用了[i]CyU3PGpioDeInit(),以啟用 GPIF II 定義的配置和狀態(tài)機(jī)。 此過程將擦除 C 型多路復(fù)用器選擇 GPIO 的
    發(fā)表于 07-17 08:04

    何在Tensorflow實(shí)現(xiàn)反卷積

    ,扮演著重要角色。以下將詳細(xì)闡述如何在TensorFlow實(shí)現(xiàn)反卷積,包括其理論基礎(chǔ)、TensorFlow實(shí)現(xiàn)方式、以及實(shí)際應(yīng)用
    的頭像 發(fā)表于 07-14 10:46 ?1105次閱讀

    何在FPGA實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)

    可編程門陣列(FPGA)作為一種靈活、高效的硬件實(shí)現(xiàn)方式,為神經(jīng)網(wǎng)絡(luò)的加速提供了新的思路。本文將從FPGA實(shí)現(xiàn)神經(jīng)網(wǎng)絡(luò)的基本原理、關(guān)鍵技術(shù)、實(shí)現(xiàn)
    的頭像 發(fā)表于 07-10 17:01 ?3577次閱讀
    主站蜘蛛池模板: 永清县| 抚顺市| 青冈县| 商丘市| 沂源县| 乐安县| 天水市| 怀化市| 英超| 滨海县| 东兴市| 策勒县| 富阳市| 峨眉山市| 奈曼旗| 安吉县| 淮安市| 建阳市| 高要市| 屏山县| 浪卡子县| 历史| 天气| 雅江县| 会泽县| 台南市| 宁波市| 佛教| 日喀则市| 错那县| 浦县| 芜湖市| 收藏| 泸州市| 淮滨县| 公主岭市| 鄂伦春自治旗| 延长县| 广宁县| 岢岚县| 湟源县|