“通过检查得出方程”是什么意思?
One-hot 状态机编码保证恰好有一个状态位为 1。这意味着可以通过仅检查一个状态位而不是所有状态位来确定状态机是否处于特定状态。通过检查状态转换图中每个状态的输入边,这导致了状态转换的简单逻辑方程。

比如上面的状态机中,状态机如何才能达到状态A?它必须使用两个传入边之一:“当前处于状态 A 且 in=0”或“当前处于状态 C 且 in = 0”。由于 one-hot 编码,用于测试“当前处于状态 A”的逻辑方程只是状态 A 的状态位。这导致状态位 A 的下一个状态的最终逻辑方程:next_state[0] =状态[0]&(~in) |状态[2]&(~in)。 one-hot 编码保证一次最多有一个子句(乘积项)是“活动的”,因此这些子句可以被 ORed 在一起。

当练习要求“通过检查”获得状态转移方程时,请使用此特定方法。法官将使用非单热输入进行测试,以确保您的逻辑方程遵循此方法,而不是对状态位的非法(非单热)组合执行其他操作(例如重置 FSM)。

虽然知道这个算法对于 RTL 级设计(逻辑合成器处理这个)不是必需的,但它说明了为什么 one-hot FSM 通常具有更简单的逻辑(以更多的状态位存储为代价),并且这个主题经常显示参加数字逻辑课程的考试。

module top_module(input in,input [3:0] state,output [3:0] next_state,output out); //parameter A=0, B=1, C=2, D=3;// State transition logic: Derive an equation for each state flip-flop.assign next_state[A] = state[A]&~in | state[C]&~in ;assign next_state[B] = state[B]&in | state[D]&in | state[A]∈assign next_state[C] = state[B]&~in | state[D]&~in;assign next_state[D] = state[C]∈// Output logic: assign out = (state[D] == 1'b1);endmodule

Fsm3onehot相关推荐

  1. 【verilog学习23】HDLBits:Circuits_Sequential Logic_Finite State Machines

    [HDLBits]Circuits_Sequential Logic_Finite State Machines I FSM 1 (asynchronous reset) (Fsm1) 1.代码编写 ...

  2. verilog练习:hdlbits网站上的做题笔记(6)

    前言 之前的文章<如何学习verilog,如何快速入门?>中提到了verilog学习,推荐了一个可以练习的网站:hdlbits网站,那自己也玩玩这个网站. 这篇文章,是接着<veri ...

  3. HDLBits练习汇总-13-时序逻辑设计测试--状态机(一)

    简单摩尔状态机1(Fsm1) 是一个摩尔状态机,具有两种状态,一种输入,一种输出.实现此状态机.请注意,重置状态为 B.使用异步复位. 模块声明 module top_module(input clk ...

  4. 【HDLBits 刷题 9】Circuits(5)Finite State Manchines 1-9

    目录 写在前面 Finite State Manchines Fsm1 Fsm1s Fsm2 Fsm2s Fsm3comb Fsm3onehot Fsm3 Fsm3s Design a Moore F ...

最新文章

  1. 码流 / 码率 / 比特率 / 帧速率 / 分辨率 / 高清
  2. linux 内核编译错误 .size expression for copy_user_generic_c does not evaluate to a constant
  3. 设计模式:桥接模式(Bridge Pattern)
  4. Java并发编程的基础-线程的终止
  5. 红橙Darren视频笔记 自定义TextView 基线的理解 问题引申(viewgroup 不触发onDraw方法)
  6. mysql 一列数据变为一条_SQL 一列数据整合为一条数据
  7. lampp mysql 等待响应时间很长_Apache 打开网页的时候等待时间过长的解决方案
  8. python打包exe
  9. android下实现4分屏播放4路高清h264格式的rtsp流
  10. html 链接 vf,VFP中超链接实现方法
  11. win10桌面null图标删除
  12. 计算机创建快捷方式w10,win10中解决无法在桌面添加快捷方式的修复方法
  13. windows10打开natapp.exe 报Error: oppen NUL: The system cannot find the file specified.
  14. 《我的博客》之选择公共博客平台还是自建博客站点
  15. 证明最小码距与纠检错图像_详解差错控制之码距、检错与纠错
  16. Auto.js Pro安卓免ROOT引流脚本开发系列教程23网易公开课(1)-前言
  17. pyscripter与python的关系_我用过的最好的python编辑器PyScripter
  18. CTF密码学总结(一)
  19. python下载西瓜视频2020最新思路
  20. 冒泡排序-java版

热门文章

  1. 2020-2021学年第二学期期末考试《薪酬管理》大作业
  2. 2022seo网站推广从0开始方案
  3. 百度地图与腾讯地图坐标转换
  4. 市场营销有哪些常识?
  5. 【工具】失传的2个全自动客流爆破工具?(上)
  6. 点桌面计算机一直在加载,Win10系统打开此电脑很慢总显示在加载的2个解决方法...
  7. linux 重启rsync服务,linux-rsync服务的常见问题
  8. 第1期|产业区块链一周快讯速览
  9. KNX智能家居工程设计
  10. 损失函数------CTCLoss