

# 第三章

資料流描述與組合電路

# 3-1 共時性與順序性

## 1. 組合邏輯電路：共時性 ( concurrent )

- 訊號從輸入端開始就會以平行方式傳送至輸出端，沒有順序產生。
- 於Verilog中的程式敘述大都具備這種特性，這些敘述稱為資料流(data flow)敘述。

## 2. 序向邏輯電路：順序性 ( sequential )

- 各種元件(正反器及時脈等)訊號存在著優先順序。
- 這些敘述稱之為行為(behavior)模式。

# 共時性 concurrent

敘述 A :

```
assign X = ~A ;  
assign Y = B & C ;  
assign Z = C ^ D ;
```

敘述 B :

```
assign Y = B & C ;  
assign Z = C ^ D ;  
assign X = ~A ;
```



# 3-2 持續指定與真值表描述

範例一

檔名：DECODER\_2\_4\_HIGH\_BOOLEAN

以布林代數持續指定方式，設計一個高態動作的 2 對 4 解碼器電路。

1. 方塊圖：



2. 真值表：

| A | B | Y[0] | Y[1] | Y[2] | Y[3] |
|---|---|------|------|------|------|
| 0 | 0 | 1    | 0    | 0    | 0    |
| 0 | 1 | 0    | 1    | 0    | 0    |
| 1 | 0 | 0    | 0    | 1    | 0    |
| 1 | 1 | 0    | 0    | 0    | 1    |

3. 布林代數：

$$Y[0] = \bar{A}\bar{B}$$

$$Y[1] = \bar{A}B$$

$$Y[2] = A\bar{B}$$

$$Y[3] = AB$$

## 原始程式 ( source program ) :

```
1  ****
2  * 2 to 4 decoder active high *
3  *          using boolean        *
4  *      Filename : DECODER2_4.v  *
5  ****
6
7 module DECODER2_4(A, B, Y);
8
9   input A, B;
10  output [3:0] Y;
11
12  assign Y[0] = ~A & ~B;
13  assign Y[1] = ~A & B;
14  assign Y[2] = A & ~B;
15  assign Y[3] = A & B;
16
17 endmodule
```



# 功能模擬：



## 範例二

檔名：MUL4\_1\_BOOLEAN

以布林代數持續指定方式，設計一個 1 位元 4 對 1 的多工器電路。

1. 方塊圖：



2. 真值表：

| S[1] | S[0] | F    |
|------|------|------|
| 0    | 0    | I[0] |
| 0    | 1    | I[1] |
| 1    | 0    | I[2] |
| 1    | 1    | I[3] |

3. 布林代數：

$$F = \overline{S[1]} \overline{S[0]} I[0] + \\ \overline{S[1]} S[0] I[1] + \\ S[1] \overline{S[0]} I[2] + \\ S[1] S[0] I[3]$$

原始程式 (source program) :

```

1  ****
2  *      4 to 1 multiplexer      *
3  *          using boolean        *
4  *  Filename : MUL4_1.v       *
5  ****
6
7 module MUL4_1(I, S, F);
8
9   input  [3:0] I;
10  input  [1:0] S;
11  output F;
12
13 assign F = ~S[1] & ~S[0] & I[0] |
14           ~S[1] & S[0] & I[1] |
15           S[1] & ~S[0] & I[2] |
16           S[1] & S[0] & I[3];
17
18 endmodule

```



# 功能模擬：



# 3-3 以條件指定實現組合邏輯

範例一

檔名：DEMUL1\_2\_CONDITION

以單行的條件敘述，設計一個 1 對 2 解多工器電路。

1. 方塊圖：



2. 真值表：

| S | DIN | Y[0] | Y[1] |
|---|-----|------|------|
| 0 | 0   | 0    | 0    |
| 0 | 1   | 1    | 0    |
| 1 | 0   | 0    | 0    |
| 1 | 1   | 0    | 1    |

原始程式 ( source program ) :

```
1  ****
2  *  1 to 2 DEMULTIPLEXER      *
3  *      using condition ?:    *
4  *  Filename : DEMUL1_2.v   *
5  ****
6
7 module DEMUL1_2(DIN, S, Y);
8
9     input DIN, S;
10    output [1:0] Y;
11
12    assign Y[0] = (~S) ? DIN : 1'b0;
13    assign Y[1] = ( S) ? DIN : 1'b0;
14
15 endmodule
```



# 功能模擬：



## 範例二

檔名 : DECODER3\_8\_LOW\_CONDITION

以單行的條件敘述，設計一個低態動作的 3 對 8 解碼器電路。

## 1. 方塊圖：



## 2. 真值表：

# 原始程式 ( source program ) :

```
1  ****
2  * 3 to 8 decoder active high *
3  *      using condition ?: *
4  *      Filename : DECODER3_8.v *
5  ****
6
7 module DECODER3_8(A, B, C, Y);
8
9   input A, B, C;
10  output [7:0] Y;
11
12 assign Y[0] = ({A, B, C} == 3'o0) ? 1'b0 : 1'b1;
13 assign Y[1] = ({A, B, C} == 3'o1) ? 1'b0 : 1'b1;
14 assign Y[2] = ({A, B, C} == 3'o2) ? 1'b0 : 1'b1;
15 assign Y[3] = ({A, B, C} == 3'o3) ? 1'b0 : 1'b1;
16 assign Y[4] = ({A, B, C} == 3'o4) ? 1'b0 : 1'b1;
17 assign Y[5] = ({A, B, C} == 3'o5) ? 1'b0 : 1'b1;
18 assign Y[6] = ({A, B, C} == 3'o6) ? 1'b0 : 1'b1;
19 assign Y[7] = ({A, B, C} == 3'o7) ? 1'b0 : 1'b1;
20
21 endmodule
```



# 功能模擬 :



### 範例三

檔名：HALF\_ADDER\_CONDITION\_NEST

以多行的條件敘述，設計一個半加器電路。

1. 方塊圖：



2. 真值表：

| X | Y | S | C |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

原始程式 ( source program ) :

```
1  ****
2  *          half adder          *
3  *      using condition ?: nest  *
4  *  Filename : HALF_ADDER.v      *
5  ****
6
7 module HALF_ADDER(X, Y, S, C);
8
9   input X, Y;
10  output S, C;
11
12  assign S = (~X & Y) ? 1'b1 :
13                ( X & ~Y) ? 1'b1 :
14                1'b0;
15  assign C = ( X & Y) ? 1'b1 : 1'b0;
16
17 endmodule
```



# 功能模擬：



#### 範例四

檔名：MULTIPLE\_DECODER3\_5\_LOW\_CONDITION\_NEST

以多行的條件敘述，設計一個低態動作的 3 對 5 多重解碼電路。

1. 方塊圖：



2. 真值表：

| A | B | C | Y[0] | Y[1] | Y[2] | Y[3] | Y[4] |
|---|---|---|------|------|------|------|------|
| 0 | 0 | 0 | 0    | 1    | 1    | 1    | 1    |
| 0 | 0 | 1 | 0    | 1    | 1    | 1    | 1    |
| 0 | 1 | 0 | 1    | 0    | 1    | 1    | 1    |
| 0 | 1 | 1 | 1    | 1    | 0    | 1    | 1    |
| 1 | 0 | 0 | 1    | 1    | 0    | 1    | 1    |
| 1 | 0 | 1 | 1    | 1    | 0    | 1    | 1    |
| 1 | 1 | 0 | 1    | 1    | 1    | 0    | 1    |
| 1 | 1 | 1 | 1    | 1    | 1    | 1    | 0    |

原始程式 ( source program ) :

```

1  ****
2  * 3 to 5 multiple decoder *
3  * using condition ?: nest *
4  * Filename : DECODER3_5.v *
5  ****
6
7 module DECODER3_5(A, B, C, Y);
8
9   input A, B, C;
10  output [4:0] Y;
11
12 assign Y = (({A, B, C} == 3'o0) |
13           ({A, B, C} == 3'o1)) ? 5'b11110 :
14           ({A, B, C} == 3'o2) ? 5'b11101 :
15           (({A, B, C} == 3'o3) |
16           ({A, B, C} == 3'o4) |
17           ({A, B, C} == 3'o5)) ? 5'b11011 :
18           ({A, B, C} == 3'o6) ? 5'b10111 :
19                           5'b01111 ;
20
21 endmodule

```



# 功能模擬 :



## 3-4 結論

依真值表：

1. 直接以布林代數描述。
2. 以二選一的單行條件敘述描述。
3. 以多選一的多行條件敘述描述。