为什么FPGA中推荐使用独热码?
独热码只有一个比特位不同,所以在进行比较的时候:
假如我们要判断状态机是否处于某状态S1,代码如下
格雷码:assign S1 = (STATUS == 2'b01)
二进制码:assign S1 = (STATUS == 2'b01)
而独热码:assign S1 = STATUS[1]
只需要进行一位的比较就好了,在FPGA代码综合的时候,会将代码综合成比较器,1位的比较器肯定是比多位的比较器节省逻辑资源,而FPGA中寄存器资源丰富,所以虽然独热码占位多,但是无所谓,高速系统中就可能因为比较导致输出不稳定,因此独热码很适合在FPGA尤其是告诉系统中使用。
如果状态数非常多就是用格雷码,可以节省寄存器资源,并且各个状态之间转移只需要一位的翻转,就是独热码和二进制码的折衷。
野火的课程中说:在低速系统中,状态个数低于4个使用二进制码,4~24个使用独热码,大于24使用格雷码,高速系统中尽量使用独热码就好了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端