第八章時序邏輯電路設(shè)計_第1頁
第八章時序邏輯電路設(shè)計_第2頁
第八章時序邏輯電路設(shè)計_第3頁
第八章時序邏輯電路設(shè)計_第4頁
第八章時序邏輯電路設(shè)計_第5頁
已閱讀5頁,還剩40頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第八章時序邏輯電路設(shè)計第1頁,共45頁,2023年,2月20日,星期三時序邏輯電路定義:任意時刻的輸出不僅取決于當時的輸入信號,而且還取決于電路原來的狀態(tài),或者說,還與以前的輸入有關(guān)。

按照電路的工作方式,時序邏輯電路可分為同步時序邏輯電路(簡稱同步時序電路)和異步時序邏輯電路(簡稱異步時序電路)兩種類型。

常見的時序邏輯電路有觸發(fā)器、計數(shù)器、寄存器等。概述第2頁,共45頁,2023年,2月20日,星期三畫出狀態(tài)轉(zhuǎn)換圖填寫狀態(tài)轉(zhuǎn)換真值表次態(tài)卡諾圖選定觸發(fā)器類型求出輸出方程、狀態(tài)方程和驅(qū)動方程畫電路圖

時序邏輯電路設(shè)計步驟(補充)第3頁,共45頁,2023年,2月20日,星期三8.1時鐘信號和復(fù)位信號8.1.1時鐘信號描述時序電路總是以時鐘進程形式來描述,方式有兩種:1)進程的敏感信號是時鐘信號2)用進程中的WAITON語句等待時鐘任何時序電路都是用時鐘信號作為驅(qū)動信號的。時序電路只是在時鐘信號的有效沿或電平到來時,其狀態(tài)才發(fā)生變化。因此,時鐘信號通常是描述時序電路的程序的執(zhí)行條件。第4頁,共45頁,2023年,2月20日,星期三1)進程的敏感信號是時鐘信號在這種情況下,時鐘信號應(yīng)作為敏感信號,顯式地出現(xiàn)在PROCESS語句后跟的括號中,例如PROCESS(clock_signal)。時鐘信號邊沿的到來,將作為時序電路語句執(zhí)行的條件。例:PROCESS(clock_signal)BEGINIF(clock_edge_condition)THENsignal_out<=signal_in;---其它時序語句;---ENDIF;ENDPROCESS;該進程在時鐘信號發(fā)生變化時被啟動,而在時鐘邊沿的條件得到滿足時才真正執(zhí)行時序電路所對應(yīng)的語句。使用了IF語句對時鐘沿進行說明。第5頁,共45頁,2023年,2月20日,星期三在這種情況下,描述時序電路的進程將沒有敏感信號,而是用WAITON語句來控制進程的執(zhí)行。也就是說,進程通常停留在WAITON語句上,只有在時鐘信號到來,且滿足邊沿條件時,其余的語句才能執(zhí)行,如下例如示:PROCESSBEGINWAITON(clock_signal)UNTIL(clock_edge_conditon);signal_out<=signal_in;---其它時序語句;---ENDPROCESS2)用進程中的WAITON語句等待時鐘在使用WAITON語句的進程中,敏感信號量應(yīng)寫在進程中的WAITON語句后面。第6頁,共45頁,2023年,2月20日,星期三在編寫上述兩個程序時應(yīng)注意:?無論IF語句還是WAITON語句,在對時鐘邊沿說明時,一定要注明是上升沿還是下降沿,光說明是邊沿是不行的。?當時鐘信號作為進程的敏感信號時,在敏感信號的表中不能出現(xiàn)一個以上的時鐘信號,除時鐘信號以外,像復(fù)位信號等是可以和時鐘信號一起出現(xiàn)在敏感表中的。?WAITON語句只能放在進程的最前面或者是最后面。第7頁,共45頁,2023年,2月20日,星期三3)時鐘邊沿的描述可以用時鐘信號的屬性來描述時鐘的邊沿。其上升沿的描述為:IFclk=‘1’ANDclk’LAST_VALUE=‘0’ANDclk’EVENT時鐘的下降沿的描述為:IFclk=‘0’ANDclk’LAST_VALUE=‘1’ANDclk’EVENT在一些程序中經(jīng)常所見時鐘沿表達如下時鐘上升沿:

(clock’eventandclock=‘1’)時鐘下降沿:

(clock’eventandclock=‘0’)第8頁,共45頁,2023年,2月20日,星期三8.1.2觸發(fā)器的同步和非同步復(fù)位同步復(fù)位:當復(fù)位信號有效且在給定的時鐘邊沿到來時,觸發(fā)器才被復(fù)位。異步復(fù)位:一旦復(fù)位信號有效,觸發(fā)器就被復(fù)位。第9頁,共45頁,2023年,2月20日,星期三1)同步復(fù)位在用VHDL語言描述時,同步復(fù)位一定在以時鐘為敏感信號的進程中定義,且用IF語句來描述必要的復(fù)位條件。例如:process(clock_signal)beginif(clock_edge_condition)then

if(reset_condition)thensignal_out<=reset_value;elsesignal_out<=signal_in;┇endif;endif;endprocess;第10頁,共45頁,2023年,2月20日,星期三2)非同步復(fù)位異步復(fù)位在描述時與同步方式不同:首先在進程的敏感信號中除時鐘信號以外,還應(yīng)加上復(fù)位信號;其次是用IF語句描述復(fù)位條件;最后在ELSE段描述時鐘信號邊沿的條件,并加上EVENT屬性。其描述方式如:PROCESS(reset_signal,clk_signal)BEGINIF(reset_condition)THENsignal_out<=reset_value;ELSIF(clk_eventANDclk_edge_condition)THENsignal_out<=signal_in;---其它時序語句;---屬性’EVENT對在當前的一個極小的時間段Δ內(nèi)發(fā)生的事件的情況進行檢測。如發(fā)生事件,則返回true,否則返回false。發(fā)生事件:信號電平發(fā)生變化。左例中進程后跟括號內(nèi)有兩個敏感信號:復(fù)位信號和時鐘信號。進程中的IF語句一開始就判斷復(fù)位條件,可見復(fù)位優(yōu)先級高于時鐘。第11頁,共45頁,2023年,2月20日,星期三8.2觸發(fā)器觸發(fā)器(FlipFlop)是一種可以存儲電路狀態(tài)的電子元件。按邏輯功能不同分為:RS觸發(fā)器、D觸發(fā)器、JK觸發(fā)器、T觸發(fā)器。第12頁,共45頁,2023年,2月20日,星期三8.2.1鎖存器

鎖存器(Latch)是一種對脈沖電平敏感的存儲單元電路,它們可以在特定輸入脈沖電平作用下改變狀態(tài)。鎖存,就是把信號暫存以維持某種電平狀態(tài)。鎖存器的最主要作用是緩存。鎖存器根據(jù)觸發(fā)邊沿、復(fù)位和預(yù)置方式以及輸出端多少的不同可以有多種形式的鎖存器。第13頁,共45頁,2023年,2月20日,星期三1)D鎖存器上升沿觸發(fā)的D鎖存器:上升沿觸發(fā)的D鎖存器,有一個數(shù)據(jù)輸入端d,一個時鐘輸入端Clk和一個數(shù)據(jù)輸出端q。D鎖存器的輸出端只有在上升沿脈沖過后輸入端d的數(shù)據(jù)才傳送到輸出端q。第14頁,共45頁,2023年,2月20日,星期三時鐘信號應(yīng)作為敏感信號,顯式地出現(xiàn)在PROCESS語句后跟的括號中。使用了IF語句對時鐘沿進行說明。時鐘邊沿的到來時,將作為時序電路語句執(zhí)行的條件。D鎖存器程序?qū)嵗?第15頁,共45頁,2023年,2月20日,星期三D鎖存器程序?qū)嵗?WAITUNTIL

表達式;當表達式的值為“真”時,進程被啟動,否則進程被掛起。

該語句在表達式中將建立一個隱式的敏感信號量表,當表中的任何一個信號量發(fā)生變化時,就立即對表達式進行一次評估。如果評估結(jié)果使表達式返回一個“真”值,則進程脫離等待狀態(tài),繼續(xù)執(zhí)行下一個語句。第16頁,共45頁,2023年,2月20日,星期三2)異步復(fù)位D鎖存器異步復(fù)位D鎖存器和一般的D鎖存器區(qū)別是多了一個復(fù)位輸入端clr。當clr=‘0’時,輸出端q置‘0’。clr稱為清0輸入端。clr低電平有效。第17頁,共45頁,2023年,2月20日,星期三進程后跟括號內(nèi)有兩個敏感信號:清0信號和時鐘信號。進程中的IF語句一開始就判斷清0條件,可見此時清0優(yōu)先級高于時鐘。異步復(fù)位D鎖存器程序?qū)嵗?8頁,共45頁,2023年,2月20日,星期三3)異步復(fù)位/置位D鎖存器除了前述的d,clk,q端外,還有clr和pset的復(fù)位、置位端。當clr=‘0’時復(fù)位,使q=‘0’;當pset=‘0’時置位,使q=‘1’;clr、pset均是低電平有效。第19頁,共45頁,2023年,2月20日,星期三異步復(fù)位/置位D鎖存器程序?qū)嵗M程后跟括號內(nèi)有三個敏感信號:時鐘信號,復(fù)位信號和置位信號。通過進程中的IFTHENELSEIF語句可以看出:優(yōu)先級,置位最高,復(fù)位次之,時鐘最低。第20頁,共45頁,2023年,2月20日,星期三4)同步復(fù)位D鎖存器與異步方式不同的是,當復(fù)位信號有效(clr=‘1’)以后,只是在有效邊沿來時才能進行復(fù)位操作。從圖中可以看出復(fù)位信號的優(yōu)先級比d端的數(shù)據(jù)輸入高,也就是當clr=‘1’時,無論d端輸入什么信號,在clk的上升沿到來時,q輸出總是“0”。第21頁,共45頁,2023年,2月20日,星期三同步復(fù)位D鎖存器程序?qū)嵗M程后跟括號內(nèi)只有一個敏感信號:時鐘信號。通過進程中的IFTHENELSEIF語句可以看出:優(yōu)先級,時鐘最高,復(fù)位次之。第22頁,共45頁,2023年,2月20日,星期三8.2.2JK觸發(fā)器JK觸發(fā)器是數(shù)字電路觸發(fā)器中的一種電路單元。JK觸發(fā)器具有置0、置1、保持和翻轉(zhuǎn)功能,在各類集成觸發(fā)器中,JK觸發(fā)器的功能最為齊全。在實際應(yīng)用中,它不僅有很強的通用性,而且能靈活地轉(zhuǎn)換其他類型的觸發(fā)器。由JK觸發(fā)器可以構(gòu)成D觸發(fā)器和T觸發(fā)器。第23頁,共45頁,2023年,2月20日,星期三JK觸發(fā)器的輸入端有置位輸入pset,復(fù)位輸入clr,控制輸入j和k,時鐘信號輸入clk;輸出端有正向輸出端q和反向輸出端qb。JK觸發(fā)器的真值表如表所示。表中q0表示原狀態(tài)不變,翻轉(zhuǎn)表示改變原來的狀態(tài)。第24頁,共45頁,2023年,2月20日,星期三優(yōu)先級:置位最高于復(fù)位,與真值表不一致,沒有考慮pset=clr=“0”時,輸出時q=“X”(未知態(tài))。四個敏感信號,異步第25頁,共45頁,2023年,2月20日,星期三與真值表一致的程序此例中pset=clr=“0”這種情況沒有考慮,在邏輯綜合時,輸出是未知的。第26頁,共45頁,2023年,2月20日,星期三libraryieee;useieee.std_logic_1164.all;entityrs_ffisport(r,s,clk:instd_logic;q,qn:bufferstd_logic);endrs_ff;architecturertlofrs_ffisbeginprocess(r,s,clk)beginifclk’eventandclk=‘1’thenifs=‘1’andr=‘0’thenq<=‘0’;qn<=‘1’;elsifs=‘0’andr=‘1’thenq<=‘1’;qn<=‘0’;elsifs=‘0’andr=‘0’thenq<=q;qn<=qn;elsenull;endif;endif;endprocess;endrtl;SClkQQRSRQQn00QQn0110100111??8.2.3同步RS觸發(fā)器null為空語句,不作任何操作。格式:

null;第27頁,共45頁,2023年,2月20日,星期三8.3寄存器數(shù)字電路中,用來存放二進制數(shù)據(jù)或代碼的電路稱為寄存器。

寄存器是由具有存儲功能的觸發(fā)器組合起來構(gòu)成的。一個觸發(fā)器可以存儲1位二進制代碼,存放n位二進制代碼的寄存器,需用n個觸發(fā)器來構(gòu)成。

按照功能的不同,可將寄存器分為基本寄存器和移位寄存器兩大類。基本寄存器只能并行送入數(shù)據(jù),需要時也只能并行輸出。移位寄存器中的數(shù)據(jù)可以在移位脈沖作用下依次逐位右移或左移,數(shù)據(jù)既可以并行輸入、并行輸出,也可以串行輸入、串行輸出,還可以并行輸入、串行輸出,串行輸入、并行輸出,十分靈活,用途也很廣。第28頁,共45頁,2023年,2月20日,星期三8位串行輸入、串行輸出移位寄存器它具有兩個輸入端:數(shù)據(jù)輸入端a和時鐘輸入端clk;一個數(shù)據(jù)輸出端b。在時鐘信號作用下,前級數(shù)據(jù)向后級移動。該8位寄存器由8個D觸發(fā)器構(gòu)成。第29頁,共45頁,2023年,2月20日,星期三8位移位寄存器描述(結(jié)構(gòu)描述)在結(jié)構(gòu)體的說明部分利用COMPONENT語句對要引用元件進行聲明。利用生成語句指定生成次數(shù)利用COMPONENT_INSTANT語句,調(diào)用元件,用位置映射方式第30頁,共45頁,2023年,2月20日,星期三8位移位寄存器直接用信號連接描述進程中執(zhí)行信號代入語句時,被代入信號量的值在當時并沒有發(fā)生改變,直到進程結(jié)束,代入過程才同時發(fā)生。此例描述了移位功能。若將程序中信號改成變量,變量賦值語句中,被賦值的變量的值會立即改變,結(jié)果如何?第31頁,共45頁,2023年,2月20日,星期三8.4計數(shù)器在數(shù)字電子技術(shù)中應(yīng)用的最多的時序邏輯電路。計數(shù)器不僅能用于對時鐘脈沖計數(shù),還可以用于分頻、定時、產(chǎn)生節(jié)拍脈沖和脈沖序列以及進行數(shù)字運算等。但是并無法顯示計算結(jié)果,一般都是要通過外接LCD或LED屏才能顯示。1、如果按照計數(shù)器中的觸發(fā)器是否同時翻轉(zhuǎn)分類,可將計數(shù)器分為同步計數(shù)器和異步計數(shù)器兩種。常見的同步計數(shù)器有74160系列,74LS190系列,常見的異步計數(shù)器有74LS290系列。2、如果按照技術(shù)過程中數(shù)字增減分類,又可將計數(shù)器分為加法計數(shù)器和減法計數(shù)器,隨時鐘信號不斷增減的為加法計數(shù)器,不斷減少的為減法計數(shù)器。第32頁,共45頁,2023年,2月20日,星期三

同步計數(shù)器指在時鐘脈沖(計數(shù)脈沖)的控制下,構(gòu)成計數(shù)器的各觸發(fā)器狀態(tài)同時發(fā)生變化的計數(shù)器。8.4.1同步計數(shù)器(1)帶允許端的十二進制計數(shù)器計數(shù)器由4個觸發(fā)器構(gòu)成,clr是清零,en是計數(shù)控制端,qa,qb,qc,qd為計數(shù)器的4位二進制值的輸出端。第33頁,共45頁,2023年,2月20日,星期三帶允許端的十二進制計數(shù)器調(diào)用了標準邏輯無符號包定義了計數(shù)中間信號,由于輸出qa,qb,qc,qd被定義為out類型PROCESS后跟兩個敏感信號判斷清零信號判斷計數(shù)使能信號判斷時鐘信號判斷計數(shù)的終點‘’不同類型數(shù)據(jù)值可以進行相加,這是因為調(diào)用了標準邏輯無符號程序包第34頁,共45頁,2023年,2月20日,星期三(2)可逆計數(shù)器

可逆計數(shù)器根據(jù)計數(shù)控制信號的不同,在時鐘脈沖作用下,可以實現(xiàn)加1和減1的操作??刂贫藆pdn=‘1’計數(shù)器加1,updn=‘0’計數(shù)器減1。第35頁,共45頁,2023年,2月20日,星期三可逆計數(shù)器(加減計數(shù)器)程序設(shè)計調(diào)用了標準邏輯無符號包定義了計數(shù)中間信號第36頁,共45頁,2023年,2月20日,星期三PROCESS后跟兩個敏感信號判斷清零信號判斷時鐘信號加計數(shù)和減計數(shù)判斷不同類型數(shù)據(jù)值可以進行相加減法,這是因為調(diào)用了標準邏輯無符號程序包第37頁,共45頁,2023年,2月20日,星期三(3)六十進制計數(shù)器

4位二進制計數(shù)器構(gòu)成1位BCD十進制計數(shù)器,六十進制計數(shù)器可由兩位十進制計數(shù)器連接。六十

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論