数字电子系统设计中状态机“毛刺”的产生与消除方法
22 浏览量
更新于2024-08-30
收藏 179KB PDF 举报
状态机“毛刺”的产生及消除方法
状态机作为数字系统控制单元的重要设计方案之一,在运行速度的高效、执行时间的确定性和高可靠性方面都显现出强大的优势。因此状态机在数字电子系统设计中的地位日益凸显。
状态机“毛刺”的产生是由于状态机输出信号会出现竞争冒险现象和传输延迟引起的。状态机通常包含主控时序进程、主控组合进程和辅助进程三个部分。其中,主控组合进程的任务是根据外部输入的控制信号和当前状态的状态值确定下一状态的取向,并确定对外输出内容和对内部其他组合或时序进程输出控制信号的内容。
状态机“毛刺”的产生有两个主要原因:
1. 竞争冒险现象:由于组合逻辑进程的存在,状态机输出信号会出现毛刺——竞争冒险现象。
2. 传输延迟:如果状态信号是多位值的,则在电路中对应了多条信号线。由于存在传输延迟,各信号线上的值发生改变的时间则存在先后,从而使得状态迁移时在初始状态和目的状态之间出现临时状态——毛刺。
例如,采用Moore型有限状态机方案对ADC0809采样过程实现控制,其主要程序如下:
begin
lock<=lock1;
process(current_state,eoc)
begin
case current_state IS
when st0=> ale<=‘0’; start<=‘0’; oe<=‘0’; lock1<=‘0’;
next_state<=st1;
when st1=> ale<=‘1’; start<=‘0’; oe<=‘0’; lock1<=‘0’;
next_state<=st2;
...
状态机“毛刺”的消除方法有多种,以下是一些常见的方法:
1. 使用同步reset信号:在状态机中添加一个同步reset信号,可以消除状态机“毛刺”的影响。
2. 使用 pipeline结构:使用pipeline结构可以减少状态机“毛刺”的影响。
3. 使用锁存器:使用锁存器可以减少状态机“毛刺”的影响。
4. 优化状态机设计:优化状态机设计可以减少状态机“毛刺”的影响。
状态机“毛刺”的产生是由于状态机输出信号会出现竞争冒险现象和传输延迟引起的。状态机“毛刺”的消除方法有多种,包括使用同步reset信号、使用pipeline结构、使用锁存器和优化状态机设计等。
点击了解资源详情
点击了解资源详情
点击了解资源详情
2020-11-05 上传
2020-07-27 上传
2021-10-11 上传
2020-08-03 上传
2021-01-20 上传
2022-09-14 上传
weixin_38658568
- 粉丝: 3
- 资源: 903
最新资源
- Angular实现MarcHayek简历展示应用教程
- Crossbow Spot最新更新 - 获取Chrome扩展新闻
- 量子管道网络优化与Python实现
- Debian系统中APT缓存维护工具的使用方法与实践
- Python模块AccessControl的Windows64位安装文件介绍
- 掌握最新*** Fisher资讯,使用Google Chrome扩展
- Ember应用程序开发流程与环境配置指南
- EZPCOpenSDK_v5.1.2_build***版本更新详情
- Postcode-Finder:利用JavaScript和Google Geocode API实现
- AWS商业交易监控器:航线行为分析与营销策略制定
- AccessControl-4.0b6压缩包详细使用教程
- Python编程实践与技巧汇总
- 使用Sikuli和Python打造颜色求解器项目
- .Net基础视频教程:掌握GDI绘图技术
- 深入理解数据结构与JavaScript实践项目
- 双子座在线裁判系统:提高编程竞赛效率