DFT笔记24

3.3.2 Event-Driven Simulation

event-driven simulation:事件驱动的仿真概念如下图所示:

event:指的就是信号值的变化,发生一次变化叫一个event。(比如G3没有变化,所以不用评估G3)。

下图描述了zero-delay event-driven simulation 的flow(zero-delay指的是门和互连线都没有延迟):

event-driven simulation的两个主要优点:

  1. 效率高
  2. 能仿真任何delay model
3.3.2.1 Nominal-Delay Event-Driven Simulation

scheduler:是event-drive simulator的重要组成部分。对于zero-delay simulation,event queue就是一个很好的scheduler,因为不用考虑时间;对于nominal-delay simulation,就需要一个更精确的scheduler,可以确定评估哪个门以及以什么样的时间顺序去评估,这时候scheduler就是一个priority queue。

下图就是一个priority queue,根据时间顺序有time stamps,每一个time stamp对应水平方向上的各个事件:

一个two-pass strategy对于nominal delay event-driven simulation如下图描述(可以避免对多输入电路的门进行重复评估):

下面就用这一章开头的电路N做一个例子,图中是这个flow体现在电路N中的具体波形(之后需要再细看):

对应的仿真过程如下表:

3.3.3 Compiled-Code versus Event-Driven Simulation(两个逻辑仿真方法对比)

Compiled-code simulation:

  1. 是cycle-based simulation,只关注时钟周期末尾的电路行为,可以用来做zero-delay
    simulation
  2. 可以隐藏simulation model的细节
  3. 当circuit activity较高时可以使用并行仿真

Event-driven simulation:

  1. 考虑delay models时是最好的方法,而且能检测hazards
  2. low circuits activity时是最好的方法,比如低功率电路
  3. 是debug时候最好的方法,周期可变
相关推荐
左左右右左右摇晃5 小时前
计算机网络笔记整理
笔记·计算机网络
不吃西红柿的855 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
似水明俊德6 小时前
02-C#.Net-反射-学习笔记
开发语言·笔记·学习·c#·.net
智者知已应修善业7 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
C羊驼7 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
sheeta19987 小时前
苍穹外卖Day04笔记
笔记
今儿敲了吗11 小时前
46| FBI树
数据结构·c++·笔记·学习·算法
苦瓜小生11 小时前
【黑马点评学习笔记 | 实战篇 】| 6-Redis消息队列
redis·笔记·后端
sheeta199812 小时前
LeetCode 每日一题笔记 日期:2025.03.19 题目:3212.统计X和Y频数相等的子矩阵数量
笔记·leetcode·矩阵
巧克力味的桃子13 小时前
国名排序题笔记(字符串函数 + fgets 详解)
笔记