时序测试

测试向量功能支持组合时序电路测试。默认情况下,测试是组合的:每个测试前都会重置电路,确保每个测试都是独立的。

对于时序电路,您可以使用特殊的 <set><seq> 标题列来指定测试序列:

以下是时序测试向量的示例:

# 计数器的时序测试
Clock Reset Count <set> <seq>
0     0     0     1     1
1     0     0     1     2
0     0     1     1     3
1     0     1     1     4
0     0     2     1     5
1     0     2     1     6
0     1     0     2     1

在此示例中,前六个测试都具有 <set> 1<seq> 值 1-6,因此它们形成一个按顺序运行的序列(seq 1,然后是 2,然后是 3,等等),步骤之间不重置。最后一个测试具有 <set> 2,因此它开始一个新序列,并在运行前重置电路。

Note also that Clock could be an input pin here. But it could also be a labeled clock component (see below).

序列执行规则

Using the Clock

In a sequential test, the first step begins with a reset. In every step after the first, it begins with a simulation tick. Any Clock components in the simulation will be updated by that tick and their signals will be propagated along with any input pin values for that step. You may add a column to the test to show the ticks. The column will be checked against the clock in the circuit as if it were an output pin to verify it describes the clocks behavior. Here is an example for a simple positive edge-triggered D flip-flop test with a standard clock:

<clk> D Q NotQ  <set> <seq>
  0   0 0   1     1     1
  1   0 0   1     1     2
  0   1 0   1     1     3
  1   1 1   0     1     4
  0   1 1   0     1     5
  1   1 1   0     1     6
  0   0 1   0     1     7

The <clk> header is a special name for an unlabeled clock component. You may also label the clock and use the label as the column header (see earlier example).

We recommend that when using a Clock, you should not change the values of memory inputs during the same step that the clock makes a triggering transition. Doing so may allow an input signal to reach the component at near the same time as the clock signal giving surprising behavior. In the example above, the D input does not change in steps with a rising edge of the clock.

完整示例

以下是结合所有功能的完整示例:

# Mixed combinational and sequential tests
A B C Out     <clk> <set> <seq>
0 0 0 0       0     0     0
0 0 1 1       0     0     0
1 1 0 1       0     1     1
0 1 0 0       1     1     2
1 1 1 1       0     1     3
0 0 0 <DC>    0     2     1
1 0 1 <float> 1     2     2

In this example:

Thus the execution might look like this:

  1. Reset, set A=0, B=0, C=0 and check that Out==0 and clk=0
  2. Reset, set A=0, B=0, C=1 and check that Out==1 and clk=0
  3. Reset, set A=1, B=1, C=0 and check that Out==1 and clk=0
  4. Tick, set A=0, B=1, C=0 and check that Out==0 and clk=1
  5. Tick, set A=1, B=1, C=1 and check that Out==1 and clk=0
  6. Reset, set A=0, B=0, C=0 and not check Out but clk=0
  7. Tick, set A=1, B=0, C=1 and check that Out is floating (in Logisim this is notated as U) and clk=1
  8. Test Vector is complete

上一页: 特殊值 | 下一页: 命令行用法