Laborator 4: Analog Digital Convertor (ADC)

Acest laborator are ca scop familiarizarea voastră cu lucrul cu convertorul analog-digital prezent în microcontroller-ul Atmega324p.

1. Măsurarea semnalelor analogice

Pentru a putea măsura semnalele analogice într-un sistem de calcul digital, acestea trebuie convertite în valori numerice discrete. Un convertor analog – digital (en. Analog to Digital Converter - ADC) este un circuit electronic care convertește o tensiune analogică de la intrare într-o valoare digitală la ieșire.

 Semnal Analogic

O caracteristică importantă a unui ADC o constituie rezoluția acestuia. Rezoluția indică numărul de valori discrete pe care convertorul poate să le furnizeze la ieșirea sa în intervalul de măsurare. Deoarece rezultatele conversiei sunt stocate intern sub formă binară, rezoluția unui convertor analog-digital este exprimată în biți. Cuanta de măsurare - cea mai mică valoare care poate fi distinsă de ADC reprezintă raportul între domeniul tensiunii de intrare (diferența între tensiunea maximă și tensiunea minimă ce pot fi aplicate la intrarea în convertor) și numărul maxim de valori binare reprezentabile (2^N).

| Rezolutie ADC

De exemplu, dacă rezoluția unui convertor este de 10 biți atunci el poate furniza 2^10 = 1024 valori diferite la ieșire. Dacă gama de măsurare este de la 0 la 5V, cuanta de măsurare va fi: (5V-0V)/1024 = 0.0048V adică 4.8mV.

O altă caracteristică importantă a unui convertor analog-digital o constituie rata de eșantionare (e.n. sampling rate). Aceasta depinde de timpul dintre două conversii succesive și afectează modul în care forma de undă originală va fi redată după procesarea digitală. Mai jos observăm cum arată modul în care semnalul eșantionat va fi reconstituit în urma trecerii printr-un convertor digital – analog (DAC). După cum se poate observa, semnalul reprodus nu este identic cu cel original. Dacă rata de eșantionare ar crește semnalul reprodus prin unirea punctelor/eșantioanelor digitale aproximează din ce în ce mai bine originalul.

| Nyquist

Care este însa rata minimă de eșantionare pentru a reproduce fără pierderi un semnal de o frecvența data? Teorema lui Nyquist spune că o rată de eșantionare de minimum două ori mai mare decât frecvența semnalului măsurat este necesară pentru acest lucru, teorema aplicându-se și pentru un semnal compus dintr-un intreg spectru de frecvențe, cum ar fi vocea umană sau o melodie. Limitele maxime ale auzului uman sunt 20Hz – 20kHz dar frecvențele obișnuite pentru voce sunt în gama 20-4000Hz, de aceea centralele telefonice folosesc o rată de eșantionare a semnalului de 8000Hz. Rezultatul este o reproducere inteligibilă a vocii umane, suficientă pentru transmiterea de informații într-o convorbire obișnuită. Pentru reproducerea fidelă a spectrului audibil se recurge la rate mai mari de eșantionare. De exemplu, înregistrarea pe un CD are o rată de eșantionare de 44100Hz ceea ce este mai mult decât suficient pentru reproducerea fidelă a tuturor frecvențelor audibile.

In funcție de modul în care se execută conversia, convertoarele analog-digitale pot fi de mai multe tipuri:

  • ADC paralel (Flash)
  • ADC cu aproximare succesivă
  • ADC cu integrare (single-slope, dual-slope);
  • ADC Sigma-delta (delta-sigma, 1-bit ADC sau ADC cu oversampling).

click pentru mai multe informatii

click pentru mai multe informatii

Resolution

The resolution represents the number of discrete values that can be produced over the range of analog values in a measurement period. The discrete values are usually in binary form, so a common way to represent resolution is in audio bit depth (the number of bits of information in each sample). For example, for a resolution of 8 bits, we can encode the analog input signal in 256 different levels, the values ranging from 0 to 255. Resolution can also be expressed in volts, each level representing a fraction of the voltage measurement range. For example, for a range of 0- 5V and an 8-bit resolution, the subdivision would be (5V – 0V) / (2 ^ 8).

Sampling Rate

The sampling rate represents the time at which the values of the analog input signal are read. The time is divided into discrete intervals, each sampling a value from the input signal. The Nyquist frequency tells us that it is mandatory for the sampling rate to be at least twice the frequency of the analog input signal so that the signal can be reconstructed afterwards. There appears a problem where frequencies above half the Nyquist frequency are sampled because they are incorrectly detected as lower frequencies. This process is called aliasing.

ADC Types

Direct Conversion (Flash ADC)

Has a bank of comparators sampling the input signal in parallel, each firing for their decoded voltage range. The comparator bank feeds a logic circuit that generates a code for each voltage range.

Successive Approximation

Uses a comparator to successively narrow a range that contains the input voltage. At each successive step, the converter compares the input voltage to the output of an internal digital to analog converter which might represent the midpoint of a selected voltage range. At each step in this process, the approximation is stored in a successive approximation register (SAR). Successive approximation ADC`s are cheaper than direct conversion ADC`s, and have a smaller footprint on the IC, but they are also slower.

Sigma-Delta

Is a newer design that offers low conversion noise and good resolution. Sigma-delta convertors are appropriate for application that require high resolution, but not the fastest conversion. As stated above, an ADC conversion is not instant, it requires a certain amount of time to complete. This raises a issue: what will happen with the result of the conversion if the input signal will change during this conversion time. The conversion result might not correspond then to the real value of the signal. To solve this, an internal input buffer is used. When the input signal is sampled, switch S1 is closed, S2 open, so that the Csh capacitor will hold a voltage equal to the input signal. S1 will then open, S2 will close and the conversion will begin. The two switches will hold this state until the conversion will end. Capacitor Csh will hold the (analog) value of the signal while the during the A/D conversion.

2. Convertorul ADC al Atmega 324p

Convertorul analog-digital inclus în microcontroller-ul Atmega324p este un ADC cu aproximări succesive. Are o rezoluție de pana la 10 biți și poate măsura orice tensiune din gama 0-5V de pe opt intrări analogice multiplexate (pinii de pe portul A). De asemenea, poate amplifica semnalul de intrare, dacă acesta are o amplitudine mică, în trepte de 0 dB (1x), 20 dB (10x) sau 46 dB (200x)

Acest convertor poate fi controlat prin doua registre de stare și control (ADCSRA si ADCSRB) și un registru cu biți de selecție pentru multiplexoare (ADMUX). În primele, putem stabili când să se efectueze conversia, dacă să se genereze întrerupere la finalul unei conversii etc. Folosind registrul pentru multiplexoare se alege ce canal va genera input pentru convertor si tensiunea de referință. De asemenea, în afară de aceste două registre mai avem registrul ADC în care este scris rezultatul conversiei (registrele procesorului fiind pe 8 biti, iar rezolutia convertorului nostru de pana la 10 biti, inseamna ca registrul ADC este, de fapt, compus dintr-o parte high si una low).

Relația dintre valoarea din registrul ADC și tensiunea măsurată este următoarea:

ADC = V_in * 1024 / V_ref

sau

V_in = ADC * V_ref / 1024

unde V_in este tensiunea măsurată iar V_ref este tensiunea aleasă ca referință.

Tensiune de referinta

In functie de intervalul in care varieaza semnalul pe care il citim putem selecta alta tensiune de referinta. Acest lucru este util pentru a mari rezolutia citirii. ADC-ul de pe Atmega 324p ne ofera ca tensiune de referinta tensiunea de alimentare (AVCC), doua tensiuni interne de 1.1V si 2.56V sau un pin pe care putem conecta o referinta de tensiune externa (AREF).

Prescaler

ADC-ul nostru are nevoie de un semnal de ceas pentru a sti cat timp dureaza o conversie. Pentru ca semnalul de ceas al microcontrollerului este prea rapid avem nevoie de un prescaler. Cea mai mica valoare este 2 si cea mai mare este 128.

F_ADC = F_CPU / PRESCALER

Alegerea prescaler-ului depinde de frecventa de esentionare si de acuratetea dorita. Cu cat prescaler-ul este mai mare frecventa ADC va fi mai mica si acuratetea va fi mai mare. Mai multe informatii se pot gasi in capitolul 25.4 din Datasheet ATmega324P.

Moduri de functionare

Convertorul poate functiona in mai multe moduri. Cel mai comun mod si cel care este disponibil si in biblioteca arduino este Single Conversion Mode. In acest mod se va efectua o singura conversie si se incepe setand ADSC pe 1. Registrul va fi setat pe 0 automat la finalul conversiei.

Un alt mod de functionare este Free Running Mode in care convertorul va functiona in continuu, la finalul unei conversii se va incepe automat urmatoarea conversie. De fiecare data rezultatul precedent va fi suprascris. Pentru a incepe o conversie se va seta registrul ADSC pe 1 si acesta nu va fi pus pe 0 automat.

  • External Interrupt Request. In acest mod o conversie va incepe pe un front pozitiv al unui pin de intrare.
  • Analog Compare mode. In acest mod ADC-ul poate compara doua semnale analogice. Nu vom folosi aceasta functionalitate in cadrul laboratorului. Mai multe detalii in capitolul 22 din datasheet.
  • Timer mode. Pentru un control mai precis al momentului in care se intampla conversia, se poate folosi un eveniment de timer pentru a incepe o noua conversie (compare match, overflow).

 ADC with Timer

Registre

ADMUX - ADC Multiplexer Selection Register

  • Bit 7:6 - REFS1:0 Reference Selection Bits → Selecteaza tensiunea de referinta

  • Bit 5 - ADLAR ADC Left Adjust Result → Modul de aliniere a celor 10 biti. (left-aligned sau right-aligned)
  • Bit 4:0 - MUX 4:0 Analog Channel Gain Selection Bits → Selecteaza portul de intrare de pe care se face conversia

ADCSRA – ADC Control and Status Register A

| ADCSRA

  • Bit 7 – ADEN: ADC Enable → Porneste convertorul
  • Bit 6 – ADSC: ADC Start Conversion → Folosit pentru a incepe o conversie
  • Bit 5 – ADATE: ADC Auto Trigger Enable → Porneste modul in care se conversiile ADC incep automat in functie de o sursa specificata in ADCSRB
  • Bit 4 – ADIF: ADC Interrupt Flag → Setat pe 1 atunci cand o conversie s-a terminat. Acest flag este sters automat atunci cand se apeleaza o rutina de tratate a intreruperilor.
  • Bit 3 – ADIE: ADC Interrupt Enable → Porneste intreruperile pentru ADC
  • Bits 2:0 – ADPS2:0: ADC Prescaler Select Bits → Setare prescaler

ADCSRB – ADC Control and Status Register B

 ADCSRB

  • Bit 2:0 – ADTS2:0: ADC Auto Trigger Source → Sursa de la care sa se genereze o noua conversie. Depinde de ADATE din ADCSRA

Exemplu

Initializare ADC pentru a citi de pe pinul PA1.

ADMUX = 0;
/* ADC1 - channel 1 */
ADMUX |= (1 << MUX0);
/* AVCC with external capacitor at AREF pin */
ADMUX |= (1 << REFS0);

ADCSRA = 0;
/* set prescaler at 128 */
ADCSRA |= (7 << ADPS0);
/* enable ADC */
ADCSRA |= (1 << ADEN);

Citire valoare convertita.

/* start conversion */
ADCSRA |= (1 << ADSC);
/* wait until conversion is complete */
while ((ADCSRA & (1 << ADSC)));
uint32_t result = ADC;

4. Exercitii

Obiectivul exercitiilor este sa controlam convertorul analog-digital integrat in microprocesorul Atmega324p pentru diferite citiri (butoane multiplexate prin divizoare de tensiune, senzor de temperatura).

Scheletul de cod lab_4_skel.zip

Task 0 Completați scheletul de cod (fișierul “adc.c”) astfel încât sa definiți o funcție cu un comportament similar analogRead(uint8_t pin) → aceasta face o singura conversie a semnalului de pe pinul specificat și este blocanta pana la returnarea rezultatului.

Task 1 Folosind funcția anterior definită, citiți valorile de pe senzorul de temperatura (PA0). Puteti pune degetul peste el (pe proprie răspundere :) ) și observa cum se modifica valorile.

Task 2 Butoanele 1-6 sunt multiplexate pe același pin analogic (PA5) prin intermediul unui sistem de divizoare de tensiune (urmăriți schematicul pentru o explicație vizuala). Aflați ce valoare întoarce fiecare buton la apăsare și completați “define-urile” din cod. Completați codul astfel încât la apăsarea BTN2 sa se aprindă doar LED-ul roșu, la apăsarea BTN3 - LED-ul verde, iar la apăsarea BTN5 - LED-ul albastru.

Task 3 Configurați ADC-ul astfel încât conversia valorilor citite de pe senzorul de temperatura sa se întâmple automat la interval de 1 sec. Folosiți-vă de timer1, este deja configurat sa genereze întreruperi la fiecare secunda! Hint: citiți in datasheet despre ADC Auto Trigger Enable și ADC Auto Trigger Source, care pot începe conversiile automat la apariția unui eveniment; altfel, puteți realiza manual o citire cu funcția completată in Task 0 la fiecare întrerupere de timer, caz in care nu este necesar sa completați și primele 3 funcții din scheletul task-ului 3.

5. Linkuri utile

6. Responsabili laborator

pm/lab/lab4-2023-2024.txt · Last modified: 2024/04/17 18:11 by mihnea.dinica
CC Attribution-Share Alike 3.0 Unported
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0