# **HW5** Report

Q1.

## **Verilog Code:**

#### **Stimulation Result:**



**Q2.** 

## **Verilog Code:**

```
module Q2(Data_in, clk, R ,Data_out);
  input [3:0] Data_in;
  input clk,R;
  output [3:0] Data_out;
  reg [3:0] Data_out;
  always @(posedge clk or negedge clk)
  if(R==1'b0) Data_out <= 4'b0;
  else Data_out <= Data_in;
endmodule</pre>
```

#### **Stimulation Result:**



# **Verilog Code:**

```
module Q3(clk,x);
input clk;
output [3:0]x;
reg [3:0]x=4'b0001;
always @(posedge clk)
    begin
    x[0]<=x[1];
    x[1]<=x[2];
    x[2]<=x[3];
    x[3]<=x[0]+x[3];
    end
endmodule</pre>
```

#### **Stimulation Result:**



## **Q4.**

# **Verilog Code:**

## **Stimulation Result:**



## Q5.

# **Verilog Code:**

```
module Q5(clk,x,upper,reset);
input clk,reset;
output upper;
output [3:0]x;

reg [3:0]x=4'b0000;
reg upper=1'b0;
always @(posedge clk or posedge reset)begin
    if(reset==1'b0001)x=4'b0000;
    else x=x+4'b0001;
    if(x>=8)upper=1'b1;
    else upper=1'b0;
end
endmodule
```

## **Stimulation Result:**

