# **Timing pulses & counters**

# **Timing Pulses**

- Important element of laboratory electronics
- Pulses can control logical sequences with precise timing.

 $\rightarrow$  If your detector "sees" a charged particle or a photon, you might want to signal a clock to store the time at which it occurred.

 $\rightarrow$  You could use the event to generate a standard pulse so that your clock always responds in the same way.

 $\blacktriangleright$  Alternatively, you might need to reset your electronics after the event

 $\rightarrow$  Clearly you want the reset pulse to arrive as soon as possible after the data has been processed

 $\rightarrow$  This requires a precision time *delay generator* 

# **Timing Pulses**

- A simple type of delay generator...
  - 1. A **D-type flip-flop** receives a clock edge and goes from low to high at the output
  - The output charges up an **RC circuit** after going high.
  - The charged capacitor also serves as the clear input to the D flip-flop.
  - 4. So, that after a fixed time (roughly RC) the flip-flop resets back to its initial state.
  - 5. The net result is a single pulse that has a duration (or *pulse width*) determined by the combination of the resistor & capacitor
- This is called a *monostable multivibrator* or *one-shot*.

### **One-shot: D-type flip-flop**



### **One-shot: D-type flip-flop**



### **One-shot: D-type flip-flop**



#### **FUNCTION TABLE**



Texas Instruments 74LS74 flip-flop datasheet]

### **One-shot: 74LS123**

### **Characteristics:**

- $\geq$  2 clock inputs triggered by either a **rising edge** or a **falling edge**.
- > 2 outputs ( $Q \& \overline{Q}$ ).
- A reset or clear input, instantly sets the output to a standard condition regardless of the current state or clock level.
- $\succ$  Can be confused a little by pulses in quick succession.

| INPUTS |              | OUTPUTS  |           |   |
|--------|--------------|----------|-----------|---|
| CLEAR  | Α            | в        | Q         | Q |
| L      | Х            | Х        | L         | Н |
| Х      | н            | Х        | L         | Н |
| Х      | Х            | L        | L         | н |
| н      | L            | <b>↑</b> | <b>Л</b>  | ъ |
| н      | $\downarrow$ | н        | <b>_\</b> | J |
| ↑      | L            | Н        | <b>_T</b> | U |



### One-shot: 74LS123

### **Characteristics:**

- $\geq$  2 clock inputs triggered by either a **rising edge** or a **falling edge**.
- > 2 outputs ( $Q \& \overline{Q}$ ).
- A reset or clear input, instantly sets the output to a standard condition regardless of the current state or clock level.
- $\succ$  Can be confused a little by pulses in quick succession.







| INPUTS |              | OUTPUTS  |           |   |
|--------|--------------|----------|-----------|---|
| CLEAR  | Α            | в        | Q         | Q |
| L      | Х            | Х        | L         | Н |
| Х      | н            | Х        | L         | н |
| Х      | X            | L        | L         | н |
| н      | L            | <b>↑</b> | <b>Л</b>  | J |
| н      | $\downarrow$ | Н        | ת         | J |
| 1      | L            | Н        | <b>_Л</b> | U |



<sup>[</sup>Texas Instruments 74LS123 datasheet]

## **Pulse Delay Generator**

> A single one-shot will produce a variable delay pulse.

2 one-shots can be combined to produce a pulse of variable duration/width produced at variable delay after a trigger.

 $\rightarrow$  Pulse Delay Generator ... very useful in a research lab.

## **Pulse Delay Generator**

> A single one-shot will produce a variable delay pulse.

2 one-shots can be combined to produce a pulse of variable duration/width produced at variable delay after a trigger.

 $\rightarrow$  Pulse Delay Generator ... very useful in a research lab.



[image from www.thinksrs.com]

### **Setting the Pulse Width**

t<sub>W</sub> = K R<sub>ext</sub> C<sub>ext</sub>



## **The Problem with One-Shots**

1. One-shots are very useful in a research laboratory as pulse delay generators.

### 2. One-shots should be avoided in regular circuitry, because

 $\rightarrow$  They are useful in **asynchronous circuits** for avoiding glitches and signal races ...

 $\rightarrow$  It's very easy to put them all over your asynchronous circuit with all the pulse timing set just right. It is very hard to figure out how the circuit works just by looking at it (or even a circuit diagram).

- $\rightarrow$  The pulse width depends on temperature (R, C, and chip).
- $\rightarrow$  The pulse width depends on supply voltage.

### **Pulse Width vs. Temperature**



### **Pulse Width vs. Supply Voltage**



### Counters ... 1234

• Frequency dividers.

2. Counters in Verilog.

3 Ripple counter (next week).

4. Synchronous counter (next week).

# **JK-type flip-flop**



JK-type flip-flops are used in counters.

# **T-type flip-flop**



JK Logic table



T-type flip-flops are used in counters.

### **Counters in Verilog**

Counters in Verilog are easy  $\rightarrow$  just use always (synchronous).  $\rightarrow$  and a self-referential "add 1" assignment.

```
module counter v3(input1,output1); // module for an 8-bit synchronous counter
 1
                          // 1-bit input
         input input1;
 2
         output reg [7:0] output1; // 8-bit output register
 3
 4
 5
         always@ (posedge input1) // synchronous loop, clocked on input1 rising edge
 6
            begin
    7
8
             output1 <= output1 + 1; // self-referential add+1 assignment.
     11
            output1 = output1 + 8'b00000001; could have used this instruction line instead.
9
10
11
             end
12
13
     endmodule
14
```

### **Initializing a register**

```
module counter v3(input1,output1); // module for an 8-bit synchronous counter
1
2
         input input1;
                                       // 1-bit input
         output reg [7:0] output1;
3
                                       // 8-bit output register
4
 5
                                        // this block initializes the output register
         initial
 6
                                        // to zero.
   begin
7
             output1 = 8'b0000000;
8
             end
9
         always@ (posedge input1) // synchronous loop, clocked on input1 rising edge
10
11
             begin
12
13
             output1 <= output1 + 1; // self-referential add+1 assignment.</pre>
             output1 = output1 + 8'b00000001; could have used this instruction line instead.
14
     11
15
16
             end
17
18
     endmodule
19
```

### **Initializing a register**



("initial" is only for simulation !)

### "if" statement

```
module counter v3(input1,output1, output2); // module for an 8-bit synchronous counter
1
         input input1;
                                     // 1-bit input
2
         output reg [7:0] output1; // 8-bit output register
3
4
         output reg [2:0] output2;
                                    // 3-bit output register
5
6
         initial
                                      // this block initializes the output registers
7
            begin
                                      // to zero.
8
             output1 = 8'b0000000;
             output2 = 3'b000;
9
10
             end
11
         always@ (posedge input1) // synchronous loop, clocked on input1 rising edge
12
13
             begin
14
15
             output1 <= output1 + 1; // self-referential add+1 assignment.</pre>
16
    11
           output1 = output1 + 8'b0000001; could have used this instruction line instead.
17
             if (output1 <= 8'b11100111)
18
19
                begin
20
                 output2 = 3'b000; // output2 stays at zero for output1 <= 231.
                end
21
22
             else
23
                begin
24
                 output2 = output2 + 1; // output2 starts counting for output1 > 231.
25
                 end
26
27
             end
28
29
     endmodule
```

## **Variable Registers**

```
module counter v3(input1,output1, output2); // module for an 8-bit synchronous counter
 1
                                      // 1-bit input
 2
         input input1;
         output reg [7:0] output1; // 8-bit output register
 3
         output reg [2:0] output2; // 3-bit output register
 4
 5
         reg [1:0] temp; // "temp" variable 2-bit register.
 6
 7
         initial
                                       // this block initializes the output registers
 8
                                        // to zero.
    begin
 9
             output1 = 8'b0000000;
10
             output2 = 3'b000;
11
             temp = 2'b00;
12
             end
13
14
         always@ (posedge input1) // synchronous loop, clocked on input1 rising edge
15
             begin
16
17
             output1 <= output1 + 1; // self-referential add+1 assignment.</pre>
18
19
             temp <= temp + 1; // temp is used as counter.</pre>
20
21
             if (output1 <= 8'b11100111)
22
                 begin
                 output2 = 3'b000 + temp; // output2 counts continuously to 2 for output1 <= 231.
23
24
                 end
25
             else
26 🔳
                 begin
27
                 output2 = output2 + 1 ; // output2 starts counting for output1 > 231.
28
                 end
29
30
             end
31
32
     endmodule
```

#### Recommendation: check the Technology Map Viewer after compiling.

### The "function" command (I)

```
// Module translates 2-bit inputs to an 8-bit output code
 1
    module Input to Output converter (input register1, input register2, input register3,
 2
                              output register1, output register2, output register3);
 3
 4
          input [1:0] input register1;
 5
          input [1:0] input register2;
 6
          input [1:0] input register3;
 7
          output reg [7:0] output register1;
 8
          output reg [7:0] output register2;
 9
          output reg [7:0] output register3;
10
11
          always
12
              begin
13
14
              // 1st output
15
              output register1 = output 8bit(input register1);
16
              // 2nd output
17
18
              output register2 = output 8bit(input register2);
19
20
              // 3rd output
              output register3 = output 8bit(input register3);
21
22
23
              end
24
```

## The "function" command (II)

| 24 |                                                               |
|----|---------------------------------------------------------------|
| 25 | // This function defines the output codes given a 2-bit input |
| 26 | <pre>function [7:0] output_8bit;</pre>                        |
| 27 | <pre>input [1:0] input_number_2bit;</pre>                     |
| 28 | E begin                                                       |
| 29 | output_8bit = 7'b1111111;                                     |
| 30 |                                                               |
| 31 | <pre>if (input_number_2bit == 4'b00)</pre>                    |
| 32 | output_8bit = 7'b1111111;                                     |
| 33 |                                                               |
| 34 | <pre>if (input_number_2bit == 4'b01)</pre>                    |
| 35 | output_8bit = 7'b1001011;                                     |
| 36 |                                                               |
| 37 | <pre>if (input_number_2bit == 4'b10)</pre>                    |
| 38 | output_8bit = 7'b1000000;                                     |
| 39 |                                                               |
| 40 | <pre>if (input_number_2bit == 4'b11)</pre>                    |
| 41 | output_8bit = 7'b0000000;                                     |
| 42 |                                                               |
| 43 |                                                               |
| 44 | end                                                           |
| 45 |                                                               |
| 46 | endfunction                                                   |
| 47 |                                                               |
| 48 | endmodule                                                     |
| 49 |                                                               |
| 50 |                                                               |

0.4