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时候最好的方法,周期可变
相关推荐
_李小白1 小时前
【OSG学习笔记】Day 37: NodeVisitor(顶点访问器)
笔记·学习
SccTsAxR2 小时前
算法基石:手撕离散化、递归与分治
c++·经验分享·笔记·算法
西梅汁2 小时前
C++ 观察者模式
笔记
لا معنى له3 小时前
Var-JEPA:联合嵌入预测架构的变分形式 —— 连接预测式与生成式自监督学习 ----论文翻译
人工智能·笔记·学习·语言模型
chase。3 小时前
【学习笔记】让机器人“边想边动”——实时动作分块流策略的执行方法
笔记·学习·机器人
[ ]8983 小时前
Stack_MLAG_知识点梳理
网络·笔记·网络协议
唐樽4 小时前
C++ 竞赛学习路线笔记
c++·笔记·学习
bobasyu4 小时前
Claude Code 源码笔记 -- queryLoop
java·笔记·spring
水云桐程序员4 小时前
Quartus II集成开发环境 |FPGA
笔记·fpga开发·硬件工程·创业创新
禹中一只鱼5 小时前
【Charles 抓包工具笔记】(自用复盘版)
笔记·charles·抓包工具·配置代理