## **Outline**

1. DSP project info

2. Analog-to-digital converters

3. Digital-to-analog converters

4. 2-dimensional register memory

# **DSP Project**

**Reminder:** Project proposal is due Friday, October 9, 2009 by *5pm*.

→ Lab book extensions possible.

Budget: \$250 for project.

Basic guideline for project proposal (also see Project Guidelines document):

You must convince your reader that your design concept will work well enough that it deserves to be funded. This means that your design has reached the point that you can draw up a budget, and the basic design algorithm has been worked out. Your proposal must include a budget which is as specific as possible and an expected timeline ... circuit schematics are helpful.

**Free parts:** Surplus parts from last year's project will be available on a first-come-first-serve basis during the Wednesday, October 14, 2009 lab period.

# **Analog** ←→ **Digital**

## As physicists, we know that:

- We live in an analog world of continuously varying signals.
- Almost all physical quantities (observables) are continuous in nature.

## As electronics designers, we know that:

- ➤ Digital electronics is very **powerful**, **cheap**, and relatively **easy** to design (at least compared to analog circuits).
- Digital electronics only works with digital signals.

## THEREFORE ...

If we're ever going to make anything useful, we need to find a way to convert (or approximate) an ANALOG signal to (by) a sequence of digital-binary numbers, and vice versa.

# Analog -> Digital



- **Algorithm:** → At each clock cycle, round your analog voltage to the nearest digital value.
  - → The size of a digital step is defined by V<sub>ref</sub>/2<sup>n</sup> for an n-bit converter.

# **Shannon-Nyquist Sampling Theorem**

#### **THEOREM:**

A continuous-time finite bandwidth signal can be exactly reconstructed from its samples if the sampling frequency is greater than 2 times the signal bandwidth B, where B is largest (non-zero) frequency component of the signal.

F=2B is referred to as the Nyquist frequency (the lowest possible sampling frequency).

### **Practical Considerations:**

- ightharpoonup Any finite duration signal has B ightharpoonup +  $\infty$ , so exact mathematical application of the theorem is impossible.
- ➤ The theorem indicates the frequency scale that one should use in order to usefully sample a signal → always use a sampling rate which is greater than twice the highest frequency component of "reasonable amplitude".

## Flash ADCs

The fastest (and most expensive) n-bit ADCs use 2<sup>n</sup>-1 comparators to determine which of the 2<sup>n</sup> numbers the analog input is closest to.

8-bit ADC: 255 comparators.

12-bit ADC: 4096 comparators

In general, higher bit resolution results in a slower ADC (and more expensive).

Most digital oscilloscopes use an 8-bit ADC.



# ADC0820 & TLC5510A: Half-Flash ADC (I)

- ➤ In order to keep the number of comparators small, it holds the input voltage, and converts it in steps:
  - → Converts the upper four bits with a 4-bit ADC.
  - → Converts the digitized value back into an analog value with a Digital-to-Analog Converter (DAC).
  - → Subtracts this from the input to generate the smaller, difference voltage.
  - → Finally, it uses a 2<sup>nd</sup> 4-bit ADC to convert the lower 4-bits.
  - ➤ The entire process takes less than 800 ns when operating off the internal timing of the ADC0820 (RD mode) and about 150 ns for a TLC5510A (20 MHz clock).

# ADC0820: Half-Flash ADC (II)



[figure from the National Semiconductor ADC0820 datasheet]

# ADC0820: Half-Flash ADC (III)

## Functional Table

| Pin   | Name                | Function                                                                                                                                                                                                                                                                                                                                 |  |
|-------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1     | VIN                 | Analog input; range $GND \le VIN \le VCC$                                                                                                                                                                                                                                                                                                |  |
| 2-5   | DB0-DB3             | TRI-STATE data outputs; bit 0 (LSB) to bit 3                                                                                                                                                                                                                                                                                             |  |
| 6     | WR / RDY            | WR-RD Mode - WR: With CS low, the conversion is started on the falling edge of WR. RD Mode - RDY: RDY will go low after the falling edge of CS; RDY will go TRI-STATE when the result of the conversion is strobed into the output latch.                                                                                                |  |
| 7     | MODE                | Select mode: $LOW = RD$ Mode $HIGH = WR-RD$ Mode                                                                                                                                                                                                                                                                                         |  |
| 8     | RD                  | WR-RD Mode With CS low, the TRI-STATE data outputs (DB0-DB7) will be activated when RD goes low. RD Mode With CS low, the conversion will start with RD going LOW; also RD will enable the TRI-STATE data outputs at the completion of the conversion. RDY going TRI-STATE and INT going low indicates the completion of the conversion. |  |
| 9     | INT                 | INT going LOW indicates that the conversion is completed and the data result is in the output latch. INT is reset by rising edge on RD or CS.                                                                                                                                                                                            |  |
| 11    | V <sub>REF(-)</sub> | Bottom of resistor ladder; range: GND $\leq$ V <sub>REF(-)</sub> $\leq$ V <sub>REF(+)</sub>                                                                                                                                                                                                                                              |  |
| 12    | V <sub>REF(+)</sub> | Top of resistor ladder; range: $V_{REF(-)} \le V_{REF(+)} \le V_{CC}$                                                                                                                                                                                                                                                                    |  |
| 13    | CS                  | CS must be low for the RD or WR to be recognized.                                                                                                                                                                                                                                                                                        |  |
| 14-17 | DB4-7               | TRI-STATE data output—bits 4-7                                                                                                                                                                                                                                                                                                           |  |
| 18    | OFL                 | Overflow—If the analog input is higher than the $V_{REF(+)}$ , OFL will be LOW at the end of conversion. Can be used to cascade.                                                                                                                                                                                                         |  |

# ADC0820: Half-Flash ADC (IV)

- ➤ In RD mode, the RD# line going LOW initiates the conversion.
- ➤ When the conversion is complete, the INT# line goes LOW & the data is latched into output buffers.
- The output buffers will be put in a Z state when WR# goes LOW until the INT# line goes LOW.



# ADC0820: Half-Flash ADC (IV)

- ➤ In RD mode, the RD# line going LOW initiates the conversion.
- ➤ When the conversion is complete, the INT# line goes LOW & the data is latched into output buffers.



# **TLC5510A: Basic Operation**



#### **Terminal Functions**

| TERMINAL  |            |     |                                                                                                                                                                                                                                |
|-----------|------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME      | NO.        | 1/0 | DESCRIPTION                                                                                                                                                                                                                    |
| AGND      | 20, 21     |     | Analog ground                                                                                                                                                                                                                  |
| ANALOG IN | 19         | - 1 | Analog input                                                                                                                                                                                                                   |
| CLK       | 12         | - 1 | Clock input                                                                                                                                                                                                                    |
| DGND      | 2, 24      |     | Digital ground                                                                                                                                                                                                                 |
| D1-D8     | 3-10       | 0   | Digital data out. D1 = LSB, D8 = MSB                                                                                                                                                                                           |
| ŌĒ        | 1          | Ι   | Output enable. When OE = low, data is enabled. When OE = high, D1-D8 is in high-impedance state.                                                                                                                               |
| $V_{DDA}$ | 14, 15, 18 |     | Analog supply voltage                                                                                                                                                                                                          |
| VDDD      | 11, 13     |     | Digital supply voltage                                                                                                                                                                                                         |
| REFB      | 23         | - 1 | Reference voltage in bottom                                                                                                                                                                                                    |
| REFBS     | 22         |     | Reference voltage in bottom. When using the TLC5510 internal voltage divider to generate a nominal 2-V reference, REFBS is shorted to REFB (see Figure 3). When using the TLC5510A, REFBS is connected to ground.              |
| REFT      | 17         | I   | Reference voltage in top                                                                                                                                                                                                       |
| REFTS     | 16         |     | Reference voltage in top. When using the TLC5510 internal voltage divider to generate a nominal 2-V reference, REFTS is shorted to REFT (see Figure 3). When using the TLC5510A, REFTS is connected to $^{ m V}$ DDA $^{ m c}$ |

# **Mixed Signal Design**

#### APPLICATION INFORMATION

The following notes are design recommendations that should be used with the device.

- External analog and digital circuitry should be physically separated and shielded as much as possible to reduce system noise.
- RF breadboarding or printed-circuit-board (PCB) techniques should be used throughout the evaluation and production process. Breadboards should be copper clad for bench evaluation.
- Since AGND and DGND are connected internally, the ground lead in must be kept as noise free as possible.
  A good method to use is twisted-pair cables for the supply lines to minimize noise pickup. An analog and
  digital ground plane should be used on PCB layouts when additional logic devices are used. The AGND
  and DGND terminals of the device should be tied to the analog ground plane.
- V<sub>DDA</sub> to AGND and V<sub>DDD</sub> to DGND should be decoupled with 1-μF and 0.01-μF capacitors, respectively, and placed as close as possible to the affected device terminals. A ceramic-chip capacitor is recommended for the 0.01-μF capacitor. Care should be exercised to ensure a solid noise-free ground connection for the analog and digital ground terminals.
- V<sub>DDA</sub>, AGND, and ANALOG IN should be shielded from the higher frequency terminals, CLK and D0–D7.
   When possible, AGND traces should be placed on both sides of the ANALOG IN traces on the PCB for shielding.
- In testing or application of the device, the resistance of the driving source connected to the analog input should be 10 Ω or less within the analog frequency range of interest.

# Digital → Analog

A Digital-to-Analog Converter (DAC) is used to convert a digital signal into an analog voltage.

#### A DAC is useful for:

- ➤ Generating a voltage from a computer, microprocessor, or FPGA that will then control part of an experiment.
- > Producing a digitally synthesized waveform (triangle, sine, or more complex).
- Converting digital music to sound, etc ...

(the CD standard is 16-bits at 44.1 KHz)

DACs are generally much faster than ADCs for a same bit resolution.

# R-2R resistor ladder (I)

> It's easy to make the DAC output voltages.

- Look from the right-hand side
  - → 2 parallel resistors
  - $\rightarrow$  Each with a value of 2R



# R-2R resistor ladder (I)

> It's easy to make the DAC output voltages.

- Look from the right-hand side
  - → 2 parallel resistors
  - $\rightarrow$  Each with a value of 2R



# R-2R resistor ladder (II)

➤ Continuing farther to the left, we find that the effective resistance to ground is *R* at every dot on the top line



# R-2R resistor ladder (III)

- ➤ The ladder acts like a series of voltage dividers that reduces the voltage by an additional factor of 2 at each *R*-2*R* junction.
- V decreases by half at each connection point along the top rail.
- Thus each output voltage is related to the input voltage by a power of two.



# Simple DAC

- We can generate an analog voltage by adding together the voltages represented by the various stages in the ladder.
- ➤ If we sum the ladder outputs based on a simple a binary representation in switches then we have a DAC.



[figure from the Art of Electronics (2<sup>nd</sup> edition, 1999) by P. Horowitz and W. Hill, p. 616]

# Simple DAC

- We can generate an analog voltage by adding together the voltages represented by the various stages in the ladder.
- ➤ If we sum the ladder outputs based on a simple a binary representation in switches then we have a DAC.



[figure from the Art of Electronics (2<sup>nd</sup> edition, 1999) by P. Horowitz and W. Hill, p. 616]

# Simple DAC

- We can generate an analog voltage by adding together the voltages represented by the various stages in the ladder.
- ➤ If we sum the ladder outputs based on a simple a binary representation in switches then we have a DAC.



[figure from the Art of Electronics (2<sup>nd</sup> edition, 1999) by P. Horowitz and W. Hill, p. 616]

## A real DAC: the TLC7524



[figure from Texas Instruments TLC7524 datasheet]

# **TLC7524 timing**

- ➤ The data on the digital inputs is sent to the analog output when WR goes LOW.
- ➤ When WR is HIGH, the digital inputs and analog output remain latched to their present values.



[figure from Texas Instruments TLC7524 datasheet]

# ADC → DAC Analog-to-Analog



# 2-dimensional registers with Quartus II

```
V/ This module produces a sequence of 8-bit binary numbers
     // with a period of 1 second (based on a 50.0 MHz clock).
2
    module TwoD Register(clock,output signal);
         input clock;
                                                  // input clock at 50 MHz
         output reg [7:0] output signal;
                                                  // output 8-bit binary number sequence
5
         reg [25:0] frequency counter; // frequency counter used to convert 50 MHz clock to 1 Hz clock
                           // 5-bit (integers: 0-63) counter/register for addressing memory
8
         req [5:0] i;
9
     // Simultaneously Declare and Load the data file "data" into 2-d register memory on FPGA
10
11
     // This "(* ... *)" code is compiler specific to Quartus II (it is not universal Verilog).
     // The 2-d register memory consists of 30 words which are 8-bits long each.
12
         (* ram init file = "File with Data.mif" *) reg [7:0] Register 2D [0:29];
13
14
15
     // initialize 1-d registers
16
         initial
17
           begin
            i = 5'b000000;
18
19
            20
            end
21
```

# 2-dimensional registers with Quartus II

```
V/ This module produces a sequence of 8-bit binary numbers
     // with a period of 1 second (based on a 50.0 MHz clock).
    module TwoD Register(clock,output signal);
         input clock;
                                                   // input clock at 50 MHz
         output reg [7:0] output signal;
 5
                                                   // output 8-bit binary number sequence
         reg [25:0] frequency counter; // frequency counter used to convert 50 MHz clock to 1 Hz clock
                                     (integers: 9 63) counter/register for addressing memory
8
         red [5:0] i;
9
     // Simultaneously Declare and Load the data file "data" into 2-d register memory on FPGA
11
     // This "(* ... *)" code is compiler specific to Quartus II (it is not universal Verilog).
     // The 2-d register memory consists of 30 words which are 8-bits long each.
12
         (* ram init file = "File with Data.mif" *) reg [7:0] Register 2D [0:29];
14
     // initialize 1-d registers
15
16
         initial
17
             begin
             i = 5'b000000;
18
19
             20
             end
21
```

Declare 2-d register &
Initialize with data in file.

# Using a 2-d Register in Verilog

```
21
22
     // This 50 MHz clock counter counts up to 50e6 in 1 seconds and then resets
23
     // and increases in the "i" counter by 1 ("i" clock is effectively 1 Hz).
24
         always@(posedge clock)
25
             begin
26
27
             // increase 50 MHz frequency counter by 1.
28
             frequency counter <= frequency counter + 1;
29
30
             // if "frequency counter" is equal to 50 million,
31
             // then reset frequency counter to ZERO
             // and send the 8-bit word corresponding to Register 2D[i] to the ouptut
32
33
             // and increase the "i" counter by ONE.
34
             if (frequency counter == 26'b10111110101111000010000000)
35
                begin
                36
                 output signal <= Register 2D[i];
37
                 i \le i + 5'b00001;
38
                 if (i == 5'b10000) i <= 5'b00000: // reset "i" counter to ZERO if it becomes 32.
39
40
                 end
41
             end
42
43
     endmodule
```

# Using a 2-d Register in Verilog

```
21
22
      // This 50 MHz clock counter counts up to 50e6 in 1 seconds and then resets
23
         and increases in the "i" counter by 1 ("i" clock is effectively 1 Hz).
24
          always@(posedge clock)
25
              begin
26
              // increase 50 MHz frequency counter by 1.
27
              frequency counter <= frequency counter + 1;
28
29
30
              // if "frequency counter" is equal to 50 million,
31
              // then reset frequency counter to ZERO
              // and send the 8-bit word corresponding to Register 2D[i] to the ouptut
32
              // and increase the "i" counter by ONE.
33
              if (frequency counter == 26'b10111110101111000010000000)
34
35
                  begin
36
                  frequency counter <= 26'h000000000000000000000000000000000;
                output signal <= Register 2D[i];
37
38
                  i \le 1 + 5'b00001;
                                                           reset "i" counter to ZERO if it becomes 32.
                  if (i == 5'b10000) i <= 5'b000000;</pre>
39
40
                  end
41
              end
42
43
      endmodule
```

Reads the 8-bit word at address "i" of "Register\_2D" & sends it to the 8-bit 1-d register "output\_signal".

# Generating the Memory Initialization File (I)

You can write the file yourself or ...



# Generating the Memory Initialization File (II)

You can use Quartus II to generate the file using the Memory Editor:

Select: New File

- → Other Files
- → Memory Initialization File

```
■module Iwov kegister(Clock, output signal);
             input clock:
 4
                                                                       // input clock at 5
             output reg [7:0] output signal;
 5
                                                                       // output 8-bit bin
 6
                                                                              ter used to co
             reg
 8
                                                                              nter/register
             rea
 9
                      Device Design Files Other Files
10
           Simul
                                                                              h" into 2-d re
11
           This
                                                                              tus II (it is
                       AHDL Include File
12
        // The 2-
                                                                               are 8-bits lo
                       Block Symbol File
                       Chain Description File
13
             (* r:
                                                                              :0] Register 2
                       Hexadecimal (Intel-Format) File
14
                       In-System Sources and Probes Editor File
1.5
       // initi:
                       Logic Analyzer Interface File
16
             init
                       Memory Initialization File
17
                       SignalTap II Logic Analyzer File
                       Synopsys Design Constraints File
18
                       Tol Script File
19
                                                                              boooos
                       Text File
20
                       Vector Waveform File
21
22
           This
                                                                              econds and the
23
           and i
                                                                              b effectively
24
             alwa
25
26
                                                         OΚ
                                                                    Cancel
```

egister" for the top level hierarchy

# **Memory Initialization File Editor**



Right-click to enter type memory information: integer, hexadecimal, binary, etc ...

# **Logic Element or RAM memory?**

If your memory space is not very large, the compiler will automatically choose to implement your Verilog circuit with D-type flip-flops of the Logic Elements.

You can force the compiler to use the dedicated FPGA memory:

Assignments > Settings > Settings - TwoD Register Category: General Analysis & Synthesis Settings Files Specify options for analysis & synthesis. These options control Quartus II Integrated Synthesis and Libraries do not affect VQM or EDIF netlists unless WYSIWYG primitive resunthesis is enabled. Device - Operating Settings and Conditions Voltage Optimization Technique Auto Global Options (MAX Devices Only): - Temperature ∇ Clock C Speed ⊟ Compilation Process Settings Ralanced. □ Output Enable Early Timing Estimate O Area ▼ Register Control Signals Incremental Compilation Create debugging nodes for IP cores 📥 Analysis & Synthesis Settings Auto DSP Block Replacement ✓ Auto Open-Drain Pins ✓ Auto Parallel Expanders Assembler ▼ Auto RAM Replacement Power-Up Don't Care Design Assistant Click here ✓ Auto BAM Block Balancing. SignalTap II Logic Analyzer Logic Analyzer Interface Auto Restructure Multiplexers: PowerPlay Power Analyzer Settings • PowerPlay power optimization: Normal compilation HDL Message Level: Level2 Advanced.. More Settings... Description: OK Cancel

# **Logic Element or RAM memory?**

If your memory space is not very large, the compiler will automatically choose to implement your Verilog circuit with D-type flip-flops of the Logic Elements.

You can force the compiler to use the dedicated FPGA memory:

Assignments > Settings >



# **Dedicated Memory Usage**

Check compiler report for memory usage:

