第5讲-有限状态机课件.ppt(44页)
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《第5讲-有限状态机课件.ppt(44页)》由用户(ziliao2023)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 有限状态机 课件
- 资源描述:
-
1、例:计数器设计例:计数器设计 设计一电路,包含基设计一电路,包含基4计数器,和译码输出模块。计数器,和译码输出模块。计数器的输出计数器的输出(Present_value)从从0到到3循环;循环;当计数值为当计数值为2时,译码输出时,译码输出(DataOut)为为“1”,否则输出否则输出“0”。Regs1ClkPresent_valueQ(n)Next_valueQ(n+1)译码译码DataOutZ(n)00/001/010/111/0Regs1ClkPresent_valueQ(n)Next_valueQ(n+1)译码译码DataOutZ(n)00/001/010/111/0扩展一个输入端扩展
2、一个输入端din,当当din=1时计数器递时计数器递增计数;当增计数;当din=0时时计数器递减计数。计数器递减计数。dinDin=1Din=1Din=1Din=1Din=0Din=0Din=0Din=0Regs/-1ClkPresent_valueQ(n)Next_valueQ(n+1)译码译码DataOutZ(n)再将计数器修改成一再将计数器修改成一个状态转换器,状态个状态转换器,状态为为S0,S1,S2,S3。每个状态的取值根据每个状态的取值根据具体情况而定。比如具体情况而定。比如S0=00,S1=11,S3=01,S4=10。din00/001/010/111/0Din=1Din=1D
3、in=1Din=1Din=0Din=0Din=0Din=0Regs/-1ClkPresent_valueQ(n)Next_valueQ(n+1)译码译码DataOutZ(n)再将计数器修改成一再将计数器修改成一个状态转换器,状态个状态转换器,状态为为S0,S1,S2,S3。每个状态的取值根据每个状态的取值根据具体情况而定。比如具体情况而定。比如S0=00,S1=11,S3=01,S4=10。dinS0/0S1/0S2/1S3/0Din=1Din=1Din=1Din=1Din=0Din=0Din=0Din=0Regs/-1ClkPresent_valueQ(n)Next_valueQ(n+1)译
4、码译码DataOutZ(n)现在我们得到了一个比较通用现在我们得到了一个比较通用的时序电路,这种电路统称为的时序电路,这种电路统称为状态机状态机(State Machine)。dinS0/0S1/0S2/1S3/0Din=1Din=1Din=1Din=1Din=0Din=0Din=0Din=0Regs/-1ClkPresent_valueQ(n)Next_valueQ(n+1)译码译码DataOutZ(n)有限状态机概述有限状态机概述数字系统控制部分的每一个控制态可以看数字系统控制部分的每一个控制态可以看作一种状态,与每一个控制态相关的转换作一种状态,与每一个控制态相关的转换条件指定了当前状态
5、的下一个状态和输出。条件指定了当前状态的下一个状态和输出。根据有限状态机的输出与当前状态与当前根据有限状态机的输出与当前状态与当前输入的关系,可以分成输入的关系,可以分成Moore型和型和Mealy型两种类型的有限状态机。型两种类型的有限状态机。Moore状态机和状态机和Mealy状态机状态机Moore状态机的输出只与当前状态有关状态机的输出只与当前状态有关次态次态逻辑逻辑状状 态态寄存器寄存器输出输出逻辑逻辑输入输入次态次态现态现态输出输出时钟时钟复位复位Moore状态机和状态机和Mealy状态机状态机Mealy状态机的输出与当前状态机及状态机的输出与当前状态机及当前输入信号有关当前输入信号
6、有关次态次态逻辑逻辑状状 态态寄存器寄存器输出输出逻辑逻辑输入输入次态次态现态现态输出输出时钟时钟复位复位状态机的表示方法状态机的表示方法状态转换表状态转换表算法流程图算法流程图状态转换图状态转换图这是最流行的这是最流行的表示方法表示方法状态转换图状态转换图状态状态1状态状态4状态状态2状态状态3入入/出出入入/出出入入/出出入入/出出/出出Mealy条件控条件控制定序制定序直接控直接控制定序制定序用用VHDL描述状态机的组成描述状态机的组成一个用来描述有限状态机功能的一个用来描述有限状态机功能的VHDL语言程序中应该包含以下几个内容:语言程序中应该包含以下几个内容:(1)至少包括一个至少包括
7、一个状态信号状态信号,它们用来指定有,它们用来指定有限状态机的状态;限状态机的状态;(2)状态转移状态转移指定和指定和输出指定输出指定,它们对应于控,它们对应于控制单元中与每个控制步有关的转移条件;制单元中与每个控制步有关的转移条件;(3)时钟信号,它一般是用来进行同步的;时钟信号,它一般是用来进行同步的;(4)同步或异步复位信号。同步或异步复位信号。状态机的状态机的VHDL描述方式描述方式(1)单进程描述方式:单进程描述方式就是指在单进程描述方式:单进程描述方式就是指在VHDL语言程序的结构体中,使用一个进程语句语言程序的结构体中,使用一个进程语句来描述有限状态机中的次态逻辑、状态寄存器和来
8、描述有限状态机中的次态逻辑、状态寄存器和输出逻辑。输出逻辑。(2)双进程描述方式:一个进程语句用来描述有限双进程描述方式:一个进程语句用来描述有限状态机中次态逻辑、状态寄存器和输出逻辑中的状态机中次态逻辑、状态寄存器和输出逻辑中的任何两个;另外一个进程则用来描述有限状态机任何两个;另外一个进程则用来描述有限状态机剩余的功能。剩余的功能。(3)三进程描述方式:一个进程用来描述有限状态三进程描述方式:一个进程用来描述有限状态机中的次态逻辑;一个进程用来描述有限状态机机中的次态逻辑;一个进程用来描述有限状态机中的状态寄存器;另外一个进程用来描述有限状中的状态寄存器;另外一个进程用来描述有限状态机中的
9、输出逻辑。态机中的输出逻辑。状态机的状态机的VHDL描述方式描述方式描述方式描述方式进程描述功能进程描述功能三进程描述方式三进程描述方式进程进程1:描述次态逻辑:描述次态逻辑进程进程2:描述状态寄存器:描述状态寄存器进程进程3:描述输出逻辑:描述输出逻辑双进程描双进程描述方式述方式 形式形式1 进程进程1:描述次态逻辑、状态寄存器:描述次态逻辑、状态寄存器进程进程2:描述输出逻辑:描述输出逻辑形式形式2 进程进程1:描述状态寄存器、输出逻辑:描述状态寄存器、输出逻辑进程进程2:描述次态逻辑:描述次态逻辑形式形式3 进程进程1:描述次态逻辑、输出逻辑:描述次态逻辑、输出逻辑进程进程2:描述状态寄
10、存器:描述状态寄存器单进程描述方式单进程描述方式进程进程1:描述次态逻辑、状态寄存器和:描述次态逻辑、状态寄存器和输出逻辑输出逻辑存储控制器存储控制器idledecisionreadwritereadyread_writereadyreadyreadyreadyreadyread_write 设计一个存储控制器,设计一个存储控制器,它的具体要求为它的具体要求为:(1)存存储控制器能够根据微处储控制器能够根据微处理器的读周期或者写周理器的读周期或者写周期,分别对存储器输出期,分别对存储器输出写使能信号写使能信号we和读使能和读使能信号信号oe;(2)存储控制存储控制器的输入信号有器的输入信号有3
11、个个:微微处理器的准备就绪信号处理器的准备就绪信号ready、微处理器的读、微处理器的读写信号写信号read_write和和时钟信号时钟信号clk。存储控制器存储控制器列出当前状态和输出值的关系列出当前状态和输出值的关系状态状态输出输出OEWEidle00decision00write01read10建立状态转换表,列出次态和转换条件建立状态转换表,列出次态和转换条件当前状态当前状态次态次态转换条件转换条件idledecisionready=1decisionwritew_r=0readw_r=1writeidleready=1writeready=0readidleready=1readre
展开阅读全文