# ECE 271 Microcomputer Architecture and Applications Lab 9: Analog to Digital Converter (ADC) Instructor: Prof. Yifeng Zhu Spring 2015

# Goals

- 1. Learn to use analog to digital converter to perform single or continuous conversion
- 2. Learn to use interrupts to read data between consecutive sampling

# **Pre-lab Assignment**

- 1. Read Chapter 20 Analog to Digital Conversion (ADC)
- 2. Complete the pre-lab assignment

# Lab Demo

- 1. Part 1. When the voltage input is higher than 2.0V, the LED is light up. When the voltage is lower than 1.0V, the LED is off. The input voltage can be controlled manually by using a potentiometer. Use a voltage meter to verify it.
- 2. Part 2. Infrared (IR) proximity sensor. When an object gets close to the IR sensor, light up the LED.
- 3. Something cool. The following gives a few examples.
  - a. Use a timer to periodically trigger the ADC
  - b. Use the potentiometer to control the brightness of a LED
  - c. Show the measurement on the LCD
  - d. Using the potentiometer to control the rotation speed of a stepper motor
  - e. Count how many times your hands wave over the IR sensor
  - f. Measure the distance of an object from the IR sensor
  - g. Use the analog watchdog in the processor to trigger ADC when an object gets too close to the sensor
  - h. Build a heartbeat rate sensor

# **Post-lab Assignment**

1. Write your answer in Readme.md and submit it to the gitlab server.

#### Part 1. Measuring the Input Voltage Adjusted by a Potentiometer

A potentiometer (pot) is a three-terminal variable resistor. It uses a sliding contact and works as an adjustable voltage divider. When two outer terminals connected to Vcc and the ground respectively, the center terminal will generate a voltage that varies from 0 to Vcc depending on the position of the sliding contact.



Figure 1. Measure the voltage from a potentiometer-based divider (Vcc = 3V)

#### Part 2. Infrared (IR) Proximity Sensor

PD 2 is to turn on or off the infrared emitter. When the output of PD 2 is high, the infrared emitter is turned on. The processor is to monitor via PB 15 the voltage across the phototransistor. When the phototransistor receives more infrared light reflected from an object, the phototransistor allows more current to flow through and thus the voltage of PB 15 gets smaller.



Figure 2. Schematic Diagram of IR emitter and phototransistor. (Vcc = 3V)

# ECE 271 pre-Lab Assignment Lab 9: Analog to Digital Converter (ADC)

Student Name: \_\_\_\_\_ TA: \_\_\_\_\_ Time & Date: \_\_\_\_\_

# 1. Setting of ADC Control Registers

| Register  | 31                                | 30 | 29    | 28  | 27 | 26           | 25 | 24       | 23                   | 22     | 21       | 20             | 19 | 18 | 17    | 16               | 15     | 14                | 13       | 12    | 11       | 10             | 6       | 8     | 7        | 9     | 5        | 4    | e        | 7       | -        | 0    |  |
|-----------|-----------------------------------|----|-------|-----|----|--------------|----|----------|----------------------|--------|----------|----------------|----|----|-------|------------------|--------|-------------------|----------|-------|----------|----------------|---------|-------|----------|-------|----------|------|----------|---------|----------|------|--|
| ADC_SR    | Reserved                          |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        | JCNR              | RCNR     | ved   | ADONS    | OVR            | STRT    | JSTRT | JEOC     | EOC   | AWD      |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          | Reser |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_CR1   |                                   | R  | eserv | /ed |    | OVRIE        |    | Real : U | AWDEN                | JAWDEN | Reserved |                |    |    | PDI   | PDD              | DI     | DISC NUM<br>[2:0] |          |       | DISCEN   | JAUTO          | AWD SGL | SCAN  | JEOCIE   | AWDIE | MA EOCIE |      |          | NDC     | DCH[4:0] |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_CR2   | Reserved<br>SWSTART<br>EXTEN[1:0] |    |       |     |    | EXTSEL [3:0] |    |          | Reserved<br>JSWSTART |        |          | JEXTR<br>JEXTS |    |    |       | EL [3:0]<br>Rese |        |                   | Reserved |       |          | EOCS           | SOO     | DMA   | Reserved | D     | ELS[     | 2:0] | Reserved | ADC_CFG | CONT     | ADON |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_SMPR1 | Sample time bits SMPx_x           |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        | -                 |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_SMPR2 |                                   | 1  |       | 1   | 1  |              | 1  | 1        | 1                    |        |          | 1              | 1  | Sa | ample | e time           | e bits | SMP               | x_x      |       |          |                |         |       | 1        |       | 1        |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_SMPR3 |                                   |    |       |     |    |              |    |          |                      |        |          |                |    | Sa | ample | e time           | e bits | SMP               | x_x      |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC JOFR1 |                                   | 1  |       |     | 1  |              |    | 1        | 1                    | _      |          |                | 1  | 1  |       | 1                |        |                   |          |       |          |                |         |       | JO       | ET1[1 | 1:0]     |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      | Res    | erved    |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_JOFR2 |                                   |    |       |     |    |              |    |          |                      | Res    | erved    |                |    |    |       |                  |        |                   |          |       |          |                |         |       | JO       | FFSE  | ET2[1    | 1:0] |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_JOFR3 |                                   |    |       |     |    |              |    |          |                      | Res    | erved    |                |    |    |       |                  |        |                   |          |       |          | JOFFSET3[11:0] |         |       |          |       |          |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      | 1100   | 01100    |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_JOFR4 |                                   |    |       |     |    |              |    |          |                      | Res    | erved    |                |    |    |       |                  |        |                   |          |       |          |                |         |       | JO       | FFSE  | ET4[1    | 1:0] |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_HTR   |                                   |    |       |     |    |              |    |          |                      | Res    | erved    |                |    |    |       |                  |        |                   |          |       | HT[11:0] |                |         |       |          |       |          |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      |        |          |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |
| ADC_LTR   |                                   |    |       |     |    |              |    |          |                      | Rec    | arvad    |                |    |    |       |                  |        |                   |          |       |          | LT[11:0]       |         |       |          |       |          |      |          |         |          |      |  |
| Value     |                                   |    |       |     |    |              |    |          |                      | Res    | erveu    |                |    |    |       |                  |        |                   |          |       |          |                |         |       |          |       |          |      |          |         |          |      |  |

| Register  | 31 | 30                  | 29       | 28                                  | 27  | 26    | 25 | 24  | 23      | 22 | 21 | 20 | 19 | 18  | 17                                    | 16       | 15                 | 14   | 13       | 12       | 11       | 10       | 6      | 8        | 7     | 9   | 5    | 4     | S    | 2   | ÷   | 0 |
|-----------|----|---------------------|----------|-------------------------------------|-----|-------|----|-----|---------|----|----|----|----|-----|---------------------------------------|----------|--------------------|------|----------|----------|----------|----------|--------|----------|-------|-----|------|-------|------|-----|-----|---|
| ADC_SQR1  | Ι  | -                   | L[4:C    |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      | Re       | gular    | chan     | nel s    | x bits |          |       |     |      |       |      |     |     |   |
| Value     | 1  |                     | Reserved |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_SQR2  |    | Irved               |          | Regular channel sequence SQx_x bits |     |       |    |     |         |    |    |    |    |     |                                       |          | <b></b>            |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    | Rese                |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_SQR3  |    | rved                |          | 1                                   |     | 1     | 1  |     |         | 1  |    | 1  | 1  | Reg | gular                                 | chan     | nel s              | eque | nce S    | SQx_x    | < bits   |          | 1      | 1        | 1     |     | 1    |       |      |     |     |   |
| Value     |    | Rese                |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_SQR4  |    | rved                |          | Regular channel sequence SQx_x bits |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      | <b></b>  |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     | 1, | Rese                |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_SQR5  |    | rved                |          |                                     |     |       |    |     |         |    |    |    |    | Reg | gular                                 | chan     | nel s              | eque | nce S    | SQx_>    | c bits   |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    | Rese                |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_JSQR  |    |                     | JL[1:0]  |                                     |     |       |    |     |         |    |    |    |    |     | Injected channel sequence JSQx_x bits |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     | ]  |                     |          |                                     | Res | erveo |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_JDR1  |    |                     |          |                                     |     |       |    | _   |         |    |    |    |    |     | 1                                     | I        |                    |      |          | 1        |          | L        |        | JDAT     | A[15: | 0]  | I    |       |      |     | LI  |   |
| Value     | ]  |                     |          |                                     |     |       |    | Res | erved   |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_JDR2  |    |                     |          |                                     |     |       |    | _   |         |    |    |    |    |     |                                       |          | JDATA[15:0]        |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     | ]  |                     |          | Reserved                            |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_JDR3  |    |                     |          |                                     |     |       |    | _   |         |    |    |    |    |     |                                       |          |                    |      |          |          |          | 1        |        | JDAT     | A[15: | 0]  | 1    |       |      |     |     |   |
| Value     |    |                     |          |                                     |     |       |    | Res | erved   |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_JDR4  |    |                     |          |                                     |     |       |    | _   |         |    |    |    |    |     |                                       |          | JDATA[15:0]        |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    |                     |          |                                     |     |       |    | Res | erved   |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_DR    |    |                     |          |                                     |     |       |    | _   |         |    |    |    |    |     |                                       |          | Regular DATA[15:0] |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    |                     |          |                                     |     |       |    | Res | erved   |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_SMPR0 |    |                     |          |                                     |     |       |    |     |         |    |    |    |    | Sa  | ample                                 | e time   | e bits             | SMP  | y_x      |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    |                     |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_CSR   |    |                     |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       | <u> </u> | <u> </u>           |      | <b>_</b> | <u> </u> | <b>_</b> | <b>_</b> |        | <b>_</b> | ADONS | OVR | STRT | JSTRT | JEOC | EOC | AWD |   |
| Value     | -  |                     |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          | ADC1               |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| ADC_CCR   |    |                     |          |                                     |     |       |    |     | TSVREFE |    | Di |    |    |     |                                       | AUCPRE   | Reserved           |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |
| Value     |    | Reserved F Reserved |          |                                     |     |       |    |     |         |    |    |    |    |     |                                       |          |                    |      |          |          |          |          |        |          |       |     |      |       |      |     |     |   |

# ECE 271 Lab Demo Lab 9: Analog to Digital Converter (ADC)

Demo Part 1, Part 2, and something cool to TA.

# ECE 271 post-Lab Assignment Lab 9: Analog to Digital Converter (ADC)

# Write your answer to the following questions in Readme.md and submit it to the gitlab server.

1. For 12-bit ADC, we know that

$$ADC \ Result = \ floor\left(2^{12} \times \frac{V}{V_{REF}} + \frac{1}{2}\right)$$

Design an experiment to find out  $V_{REF}$ 

- 2. When the voltage output from the potentiometer-based voltage divider is lower than 1.0V, the LED is turned off. What constant value should the ADC DR register be compared with?
- 3. When the voltage output from the potentiometer-based voltage divider is higher than 2.0V, the LED is light up. What constant value should the ADC DR register be compared with?
- 4. What is the maximum distance at which your sensor can reliably detect your hand?