## 190905514 MOHAMMAD TOFIK

## **WEEK 7 LAB 7:**

1. Design and simulate the following counters (a) 4 bit synchronous up counter

```
module fourbitup(clk,rstn,out);
input clk;
input rstn;
output [3:0] out;
reg [3:0] out;
always @ (posedge clk) begin
  if (! rstn)
out <= 0;
    else
       out <= out + 1;
  end
endmodule</pre>
```

## **OUTPUT:**



**1.(b)** 3 bit synchronous up/down counter with a control input up/down. If up/down = 1, then the circuit should behave as an up counter. If up/down = 0, then the circuit should behave as a down counter.

```
module threebit(Clock, updown, resetn, c);
input Clock, resetn, updown;
output [2:0]c;
reg [2:0]c;
always @(posedge Clock)
begin
if(!resetn)
c \le 0;
else
begin
if(updown)
c <= c+1;
else
c \le c-1;
end
end
endmodule
```

## **OUTPUT:**

