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时候最好的方法,周期可变
相关推荐
玄同7654 分钟前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
符哥20088 分钟前
C++ 适合初学者的学习笔记整理
c++·笔记·学习
ujainu12 分钟前
让笔记触手可及:为 Flutter + OpenHarmony 鸿蒙记事本添加实时搜索(二)
笔记·flutter·openharmony
曦月逸霜15 分钟前
Python快速入门——学习笔记(持续更新中~)
笔记·python·学习
Gain_chance20 分钟前
37-学习笔记尚硅谷数仓搭建-ADS层分析并以各品牌商品下单统计为例
笔记·学习
pop_xiaoli28 分钟前
effective-Objective-C 第二章阅读笔记
笔记·学习·ios·objective-c·cocoa
代码游侠29 分钟前
复习——Linux设备驱动开发笔记
linux·arm开发·驱动开发·笔记·嵌入式硬件·架构
stars-he29 分钟前
AI工具配置学习笔记
人工智能·笔记·学习
袁气满满~_~34 分钟前
深度学习笔记三
人工智能·笔记·深度学习
wdfk_prog9 小时前
[Linux]学习笔记系列 -- [drivers][input]input
linux·笔记·学习