VHDL如何实现延时

来源:百度知道 编辑:UC知道 时间:2024/06/28 04:25:08
比如使DOUT输出2个CLK之后SIG上面的信号

1。VHDL中的delta延时大于零,但小于任何指定的延时(指定的延时包括after指定的惯性延时和transport指定的传输延时)。因此,在一个确定的仿真时刻t,开启有限多个仿真周期(即一个delta延时)不会使仿真时刻向前推进,就是说不论有多少个delta延时,都认为是在t时刻。为什么能够这样认为呢,请看2。
  2。在具体硬件中,进程是并行发生的,也就是说,数据总是不断的流进各个模块,模块间不会有先来后到。因此在一个时刻t,会同时有多个事件发生。但是仿真软件是在PC机上用C语言之类的串行机制实现的,所以就必须在串行机制下尽可能准确地仿真并行事件的发生。怎么办呢,就出现了delta延时的模型。在一个仿真周期(即一个delta延时)里,仿真器串行的处理各个事件,但我们把这个仿真周期看成一个整体认为这些事件宏观上是并行的。既然是并行的,就理所当然地认为还是在t时刻了。
  3。一个process只要在时刻t它的敏感表中有事件发生,就开启一个仿真周期。一个仿真周期里,可以同时有多个process被激活,就看敏感表中是不是有事件。但是对于一个进程,不管它有多长,只要其中没有after 之类的具体时间延时,就认为需要花费一个delta延时完成,也就是说它的结果是在delta之后才更新的(可以理解成立刻算出来,但是等到delta之后才更新)。如果它的输出在delta后更新完又触发了另外一个process,那么就再开一个仿真周期,再花费delta执行。由1可知,不管开了多少个delta,都认为在时刻t并行发生。但是注意,一旦哪个进程中有after了,就认为新值在after指定时间更新,不考虑delta。
  4。举个例子。
  (i)下面两行在一个architecture中:
  Z <= X+Y;--(1)
  A <= Z+B;--(2)
  这样两句话可以看成两个进程。现在的时刻为t1,此时X变化了,好,激活了(1),开一个仿真周期,立即计算Z=X+Y,但是要等到delta延时后Z的值更新。由于Z的值发生了变化,又激活了(2),好,再开一个仿真周期,算出A=Z+B,再等delta后A的值更新。因此,无论(1)(2)先写谁,都是这样的过程,总共花费2delta(还属于ti时刻)。