# IC设计-HW\_2

2021211039 刘沁雨

### hw\_2\_1

源代码

```
module hw_2_1 (
 2
        input CLK, RESET,
 3
        output CLK_1,CLK_2
 4
   );
 5
        reg clk_1,clk_2;
 6
        reg [3:0]counter;
 7
 8
    assign CLK_1 = clk_1;
9
    assign CLK_2 = c1k_2;
10
11
        //5M
12
        always@(posedge CLK)
13
             begin
                 if(RESET)
14
15
                 clk_1 \leftarrow 0;
16
                 else
17
                 clk_1 \leftarrow clk_1;
18
             end
19
20
        //500k
21
        always @(posedge CLK) begin
22
             if(RESET | counter == 9)
23
             counter <= 0;</pre>
24
             else
25
             counter <= counter +1;</pre>
26
        end
27
        always @(posedge CLK) begin
28
29
            if(RESET)
             c1k_2 \ll 0;
30
31
             else if(counter == 9)
32
             c1k_2 \leftarrow c1k_2;
33
             else
34
             c1k_2 \ll c1k_2;
35
        end
    endmodule
36
```

#### 原理图

十进制计数器部分没有展开画,用RTL实现是用4个D触发器串联并通过外接门电路来实现计数功能,并用几个逻辑门把等于9时的进位信号引出,展开略为复杂。



#### 仿真结果



# hw\_2\_2

代码

```
`timescale 1ns/1ns
1
 2
    //series data detector
 3
    module hw_2_2 (
 4
        input DATA_IN,CLK,RST,
 5
        output SIG_OUT
 6
    );
 7
        reg [1:0] state, state_next;
8
        reg sig_out;
9
10
        parameter s0 = 2'b00, s1 = 2'b01, s2 = 2'b10, s3 = 2'b11;
11
        assign SIG_OUT = sig_out;
12
        always @(posedge CLK) begin
13
            if(RST)
14
15
             sig_out <= 0;</pre>
16
             else if(state == s3 && state_next == s3)
17
             sig_out <= 1;</pre>
18
             else
```

```
19
            sig_out <= 0;
20
        end
21
        always@(posedge CLK) begin
22
23
            if(RST)
24
            state <= 0;</pre>
25
            else
26
            state <= state_next;</pre>
27
        end
28
29
        always @(*) begin
30
            if(RST)
31
            state_next = 0;
32
            else begin
33
                case (state)
                s0: if(!DATA_IN) state_next = s0; else state_next = s1;
34
                s1: if(!DATA_IN) state_next = s0; else state_next = s2;
35
36
                s2: if(!DATA_IN) state_next = s0; else state_next = s3;
37
                s3: if(!DATA_IN) state_next = s0; else state_next = s3;
38
                default:
                                 state_next = state_next;
39
            endcase
40
            end
41
        end
42
    endmodule
```

#### 状态转换图





### 仿真结果



## hw\_2\_3

利用循环移位寄存器实现

代码

```
1 //data array generator 0100_1011_001
 2
    module hw_2_3(
 3
        input CLK,RST,
 4
        output SEQ_OUT
 5
        );
        reg [10:0] sequence;
 6
 7
        wire seq_out;
8
9
        assign SEQ_OUT = seq_out;
    always@(posedge CLK)
10
11
    begin
        if(RST)
12
13
            sequence <= 11'b0100_1011_001;</pre>
14
        else
15
            sequence <= {sequence[9:0], sequence[10]};</pre>
16
17
        assign seq_out = sequence[10];
    endmodule
18
19
```



### 仿真结果

