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

event:指的就是信号值的变化,发生一次变化叫一个event。(比如G3没有变化,所以不用评估G3)。
下图描述了zero-delay event-driven simulation 的flow(zero-delay指的是门和互连线都没有延迟):

event-driven simulation的两个主要优点:
- 效率高
- 能仿真任何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:
- 是cycle-based simulation,只关注时钟周期末尾的电路行为,可以用来做zero-delay
simulation - 可以隐藏simulation model的细节
- 当circuit activity较高时可以使用并行仿真
Event-driven simulation:
- 考虑delay models时是最好的方法,而且能检测hazards
- low circuits activity时是最好的方法,比如低功率电路
- 是debug时候最好的方法,周期可变