Znate li o podešavanju ESP32 ADC -a?: 29 koraka
Znate li o podešavanju ESP32 ADC -a?: 29 koraka
Anonim
Image
Image
Korišćeni resursi
Korišćeni resursi

Danas ću govoriti o jednom tehničkom pitanju, ali mislim da bi svi koji rade s ESP32 trebali znati: pitanje prilagođavanja čitanja ADC-a (analogno-digitalni pretvarač). Smatram da je ovo važno jer kada radite "mjerenje", posebno s instrumentom koji ima analogni izlaz, morate biti potpuno sigurni da se očitavanje izvodi pravilno.

Stoga ćemo u današnjem videu izvesti mjerenja pomoću "analogno-digitalnog pretvarača" ESP32, promatrati odstupanja konverzije i primijeniti metodu podešavanja / kalibracije ADC-a.

Korak 1: Šta je AD konverter?

AD pretvarač je kolo koje može prevesti analognu (kontinuiranu) veličinu u digitalne (diskretne) vrijednosti. Sta to znaci? To znači da iako digitalne vrijednosti mogu pretpostaviti samo diskretne vrijednosti nastale kombinacijom nula i jedinica, analogna veličina može poprimiti bilo koju vrijednost unutar raspona. Na primjer, ako bismo izmjerili napon idealne AA ćelije, mogli bismo pronaći bilo koju vrijednost između 0V i 1.5V, jer je to analogna veličina. Izlazno stanje idealne lampe mora poprimiti samo dva stanja (isključeno ili uključeno), što je diskretna veličina. Budući da mikrokontroleri rade pomoću ove diskretne logike, potrebno nam je kolo sposobno za prevođenje analogne veličine u digitalnu (ili diskretnu).

Korak 2: Korišteni resursi

• Jedna Lolin32 Lite kartica v1.0.0

• Tektronix TDS1001C osciloskop za snimanje

• Jedan USB kabl za ESP32

• Hantek DSO4102C osciloskop kao generator signala

Korak 3: ESP32 ADC

ESP32 ADC
ESP32 ADC

Prema podacima Espressifa, ESP32 čipovi mogu pokazati +/- 6% razlike u odnosu na jedan čip u izmjerenim rezultatima.

Osim toga, konverzija NEMA linearni odgovor za svaki raspon čitanja. Espressif nudi metodu kalibracije i predlaže korisnicima da primijene druge metode ako smatraju da je potrebno postići željenu točnost.

Izvršit ćemo prikupljanje podataka, a zatim ćemo pokazati odgovore ADC -a i primjer primjene matematičkog procesa za čitanje prilagodbe.

Postoji nekoliko (jednostavnijih ili složenijih) načina za postizanje ovih popravaka. Na vama je da ocijenite najprikladnije za vaš projekt.

Ova prikazana ovdje će imati ilustrativnu svrhu i pokušat će se pozabaviti zanimljivim stvarima koje se mogu uočiti tokom prilagođavanja.

Korak 4: Upotrijebljeno kolo

Korišteno kolo
Korišteno kolo

Koristio sam osciloskop sa generatorom signala koji ide do 25 MHz, Hantek DSO4102C. Generirali smo val koji su očitali ESP A / D i osciloskop. Prikupljeni podaci zabilježeni su u csv -u i u proračunskoj tablici koju ću ostaviti na kraju članka za preuzimanje.

Korak 5: Znak se koristi

Sign Used
Sign Used

Odabrali smo niskofrekventni trapezni signal koji omogućava pristup rampama koje prolaze kroz cijeli raspon konverzije. To omogućava veliki broj uzoraka na ovim rampama.

Korak 6: Podaci dobijeni osciloskopom

Podaci dobijeni osciloskopom
Podaci dobijeni osciloskopom

Slika snimanja izvedena je osciloskopom. Podaci su pohranjeni u csv datoteci. Obratite pažnju na blagu zakrivljenost na rastućim i padajućim rampama signala.

Korak 7: Podaci dobiveni osciloskopom (csv datoteka u Excelu)

Podaci dobiveni osciloskopom (csv datoteka u Excelu)
Podaci dobiveni osciloskopom (csv datoteka u Excelu)

Ovdje imamo uzorke.

Korak 8: Podaci dobijeni od ADC -a

Podaci pribavljeni od ADC -a
Podaci pribavljeni od ADC -a

Promjenom brzine prijenosa serije, možemo vidjeti podatke koje je ADC uhvatio. Promatrajte deformaciju trapeznog signala.

Podaci uočeni na Arduino IDE serijskom ploteru

Korak 9: Podaci dobijeni od ADC -a - Excel

Podaci pribavljeni od ADC - Excel
Podaci pribavljeni od ADC - Excel

Koristeći višu brzinu i serijski terminal, možemo zabilježiti vrijednosti i primijeniti ih u Excelu za usporedbe.

Korak 10: Usporedba rampi za uspon

Poređenje rampi za uspon
Poređenje rampi za uspon

Upoređujemo dvije penjalice za dva hvata.

Obratite pažnju na zakrivljenost koja se javlja na obje rampe.

Također imajte na umu da za istu rampu imamo mnogo više uzoraka ESP32 nego s osciloskopa.

Korak 11: Izjednačavanje broja uzoraka

Izjednačavanje broja uzoraka
Izjednačavanje broja uzoraka
Izjednačavanje broja uzoraka
Izjednačavanje broja uzoraka

Budući da je ESP32 dao veći broj uzoraka od osciloskopa, moramo izjednačiti ove vrijednosti jer će one poslužiti kao indeks za usporedbu dviju krivulja.

Za to ćemo napraviti direktno poređenje.

Imamo 305 uzoraka za osciloskopsku rampu i 2365 uzoraka za ADC rampu.

Budući da su rampe istog raspona, možemo reći da imamo približno 7,75 uzoraka ADC -a za svaki osciloskop.

Množenje indeksa svakog uzorka osciloskopa ima istu krivulju, ali s indeksima ekvivalentnim ADC -u i preraspodijeljenim podacima.

Da bismo popunili podatke koji nedostaju za nove pozicije, primijenit ćemo krivulju koja statistički odgovara poznatim podacima.

Korak 12: Popunjavanje praznina - linija trenda

Popunjavanje praznina - linija trenda
Popunjavanje praznina - linija trenda
Popunjavanje praznina - linija trenda
Popunjavanje praznina - linija trenda

Odabirom poznatih podataka (plave točkice) klikom i desnim gumbom miša odabiremo: "Dodaj liniju trenda …"

U prozoru koji se pojavi odabiremo polinomski tip (redoslijed 2 bit će dovoljan).

Provjerili smo i opcije "Prikaži jednadžbu na grafikonu" i "Prikaži vrijednost R-kvadrata na grafikonu".

Kliknemo "Zatvori".

Korak 13: Popunjavanje praznina - polinomska kriva 2. stepena

Popunjavanje praznina - polinomska kriva 2. stepena
Popunjavanje praznina - polinomska kriva 2. stepena

Excel nam daje dvije nove informacije; jednadžba drugog reda koja najbolje odgovara podacima i jednadžba na kvadrat R koja kvantificira ovu adekvatnost.

Samo zapamtite da što je bliže 1, jednadžba je prikladnija.

Nemojmo se upuštati u matematiku koja je u pitanju, samo je upotrijebimo kao alat.

Korak 14: Popunjavanje praznina - Procjena funkcije

Popunimo praznine u uzorku podacima generiranima jednadžbom. Zatim ih usporedite po tačku.

y = -9E -08x2 + 0, 0014x + 0, 1505

R² = 0, 9999

Napon osciloskopa = -9E -08 * indeks2 + 0, 0014 * indeks + 0, 1505

Korak 15: Pretvaranje napona osciloskopa u ekvivalentnu vrijednost za usporedbu s ADC -om

Pretvaranje napona osciloskopa u ekvivalentnu vrijednost za usporedbu s ADC -om
Pretvaranje napona osciloskopa u ekvivalentnu vrijednost za usporedbu s ADC -om

Iskoristimo ovo za transformaciju vrijednosti napona osciloskopa u ekvivalentnu vrijednost ADC -a.

Kako je najveća vrijednost dobivena u ADP -u ESP32 bila 4095, što je ekvivalentno očitanju od 2,958 V za isti indeks, možemo reći da:

Svaki volt u mjerenjima osciloskopa jednak je približno 1384,4 jedinica AD. Stoga možemo pomnožiti sva mjerenja osciloskopa s ovom vrijednošću.

Korak 16: Poređenje dvije dobijene rampe

Poređenje dvije dobijene rampe
Poređenje dvije dobijene rampe

Vizualizacija razlika dobijenih u dva čitanja.

Korak 17: Ponašanje razlike čitanja ADC -a (ERROR)

Ponašanje razlike čitanja ADC -a (ERROR)
Ponašanje razlike čitanja ADC -a (ERROR)

Donja krivulja prikazuje kako se razlika u očitanju ADC -a ponaša kao funkcija mjerenja. Ova zbirka podataka omogućit će nam da pronađemo funkciju korekcije.

Da bismo pronašli ovu krivulju, jednostavno iscrtamo razliku koja se nalazi u svakoj mjeri kao funkciju svakog mogućeg položaja AD (0 do 4095).

Korak 18: Različito ponašanje čitanja ADC -a - pronalaženje funkcije korekcije

Ponašanje razlike u čitanju ADC -a - pronalaženje korekcijske funkcije
Ponašanje razlike u čitanju ADC -a - pronalaženje korekcijske funkcije

U Excelu možemo odrediti funkciju korekcije dodavanjem linije trenda, sada višeg stupnja, sve dok se dovoljno ne uklapa u naše podatke.

Korak 19: Korištenje drugog softvera

Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera
Korištenje drugog softvera

Drugi zanimljiv softver za određivanje krivulja je PolySolve, koji se može koristiti direktno na linku: https://arachnoid.com/polysolve/ ili preuzeti kao Java aplikaciju.

Omogućuje primjenu polinomskih regresija višeg stupnja i isporuku formatirane funkcije, kao i drugih funkcionalnosti.

Da biste ga koristili, jednostavno unesite podatke u prvo polje za tekst. Podaci moraju slijediti redoslijed X, Y odvojen zarezom ili tabulatorom. Budite oprezni pri ispravnoj upotrebi tačke kao decimalne tačke.

Grafikon će se pojaviti u sljedećem okviru ako su uneseni podaci ispravno formatirani.

Evo kako je prošla naša kriva greške ADC -a.

Ovaj prozor će prikazati rezultat regresije, uključujući podatke o adekvatnosti funkcije, koji zauzvrat mogu imati formatiran izlaz na nekoliko načina: kao C / C ++ funkcija, popis koeficijenata, funkcija napisana na Javi itd.

Napomena: Obratite pažnju na decimalne separatore

Korak 20: Konstante i postavljanje ()

Ovdje ističem GPIO koji se koristi za analogno snimanje. Pokrećem serijski port, kao i pin određen za analogno snimanje.

const int pin_leitura = 36; // GPIO koristi parametarsku analizu void setup () {Serial.begin (1000000); // Pokretanje serijskog porta za debug pinMode (pin_leitura, INPUT); // Pino utilizado para captura analógica}

Korak 21: Loop () i funkcija korekcije

Snimamo prilagođeni napon i ispisujemo vrijednosti sa ili bez ispravnih ispravki.

void loop () {int valor_analogico = analogRead (pin_leitura); // ostvaruje captura da tensão ajustada //Serial.print(valor_analogico + f (valor_analogico)); // imprime os valores para debug (COM CORREÇÃO) Serial.print (valor_analogico); // imprimime os valores para debug (SEM CORREÇÃO) Serial.print (","); Serial.print (4095); // cria uma linha para marcar o valor máximo de 4095 Serial.print (","); Serial.println (0); // cria uma linha para marcar o valor mínimo de 0}

Primijetite u retku 12 da imamo mogućnost ispisa podataka uz dodatak funkcije razlike f (analog_value).

Korak 22: Upotreba funkcije PolySolve Correction

Ovdje koristimo PolySolve funkciju unutar Arduino IDE -a.

/* Režim: normalan Polinomski stepen 6, 2365 x, y parovi podataka Koeficijent korelacije (r^2) = 9, 907187626418e-01 Standardna greška = 1, 353761109831e+01 Izlazni oblik: C/C ++ funkcija: Copyright © 2012, str. Lutus - https://www.arachnoid.com. Sva prava zadržana. */ double f (double x) {return 2.202196968876e + 02 + 3.561383996027e-01 * x + 1.276218788985e-04 * pow (x, 2) + -3.470360275448e-07 * pow (x, 3) + 2.082790802069e- 10 * pow (x, 4) + -5.306931174991e-14 * pow (x, 5) + 4.787659214703e-18 * pow (x, 6); }

Obratite pažnju na promjenu zareza po tačka kao decimalni separator.

Korak 23: Snimanje s ispravkom - Serijski ploter

Snimanje s ispravkom - Serijski ploter
Snimanje s ispravkom - Serijski ploter

Korak 24: Računski troškovi

Računarski trošak
Računarski trošak
Računarski trošak
Računarski trošak

Za izvođenje polinomskih proračuna potrebno je da procesor obavi ovaj zadatak. To može dovesti do kašnjenja u izvođenju, ovisno o izvornom kodu i raspoloživoj računalnoj snazi.

Ovdje vidimo tablicu rezultata testa korištenjem višestepenih polinoma. Uočite razliku između vremena kada je funkcija pow () korištena i kada nije.

Korak 25: Kôd za testiranje - Setup () i Loop Start ()

Ovdje imamo kôd korišten u našem testu.

void setup () {Serial.begin (1000000); // Pokretanje serijskog porta za debug} void loop () {float valor_analogico = 500.0; // um valor arbtrario float quantidade = 10000.0; // quantidade de chamadas float contador = 0.0; // contador de chamadas

Korak 26: Testni kod - Petlja () i obrada

Koristio sam funkciju micros () da dobijem vrijednost u mikrosekundama.

// ============= inicia o proceso float agora = micros (); // marca o instante inicial while (contador <quantidade) {// v (valor_analogico); // função vazia // r (valor_analogico); // função com retorno // f0 (valor_analogico); // grau 0 // f1 (valor_analogico); // grau 1 // f2 (valor_analogico); // grau 2 // f3 (valor_analogico); // grau 3 // f4 (valor_analogico); // grau 4 // f5 (valor_analogico); // grau 5 // f6 (valor_analogico); // grau 6 // f13_semPow (valor_analogico); // grau 13º SEM funkcijski POW // f13_comPow (valor_analogico); // grau 13º COM funkcijski POW contador ++; } agora = (micros () - agora) / kvantidada; // odredba o intervalo que se passou para cada iteração // ============= finalizacija o procesu

Korak 27: Testni kod - Petlja () - Rezultati

Štampamo vrijednost vraćenu iz funkcije ocjene 13 sa i bez POW -a radi usporedbe, kao i interval obrade.

// imprime o valor retornado to função de grau 13 com e sem POW za upoređivanje Serial.print (f13_semPow (valor_analogico)); // grau 13º SEM funkcijski POW Serial.print (" -"); Serial.print (f13_comPow (valor_analogico)); // na 13º COM u funkciji POW Serial.print (" -"); // imprime o intervalo do procesa Serial.println (agora, 6); }

Korak 28: Testni kod - Korištene funkcije

Prazne funkcije (samo s povratkom) stupnjeva 0 i 1.

// FUNÇÃO VAZIAdouble v (double x) {} // FUNÇÃO SOMENTE COM RETORNO double r (double x) {return x; } // FUNÇÃO DE GRAU 0 double f0 (double x) {return 2.202196968876e+02; } // FUNÇÃO DE GRAU 1 dvostruki f1 (dvostruki x) {povratak 2.202196968876e + 02 + 3.561383996027e-01 * x; }

Funkcije razreda 2, 3 i 4.

// FUNÇÃO DE GRAU 2double f2 (double x) {return 2.202196968876e + 02 + 3.561383996027e-01 * x + 1.276218788985e-04 * pow (x, 2); } // FUNÇÃO DE GRAU 3 double f3 (double x) {return 2.202196968876e + 02 + 3.561383996027e-01 * x + 1.276218788985e-04 * pow (x, 2) + -3.470360275448e-07 * pow (x, 3); } // FUNÇÃO DE GRAU 4 double f4 (double x) {return 2.202196968876e + 02 + 3.561383996027e-01 * x + 1.276218788985e-04 * pow (x, 2) + -3.470360275448e-07 * pow (x, 3) + 2,082790802069e-10 * pow (x, 4); }

Funkcije razreda 5 i 6.

// FUNÇÃO DE GRAU 5dvostruki f5 (dvostruki x) {povratak 2,202196968876e + 02 + 3,561383996027e-01 * x + 1,267218788985e-04 * pow (x, 2) + -3,470360275448e-07 * pow (x, 3) + 2.082790802069e-10 * pow (x, 4) + -5.306931174991e-14 * pow (x, 5); } // FUNÇÃO DE GRAU 6 dvostruki f6 (dvostruki x) {povratak 2,202196968876e + 02 + 3,561383996027e-01 * x + 1,267218788985e-04 * pow (x, 2) + -3,470360275448e-07 * pow (x, 3) + 2.082790802069e-10 * pow (x, 4) + -5.306931174991e-14 * pow (x, 5) + 4.787659214703e-18 * pow (x, 6); }

Funkcija razreda 13 pomoću POW -a.

// FUNÇÃO DE GRAU 13 USANDO O POWdouble f13_comPow (double x) {return 2, 161282383460e + 02 + 3, 944594843419e-01 * x + 5, 395439724295e-04 * pow (x, 2) + -3, 968558178426e-06 * pow (x, 3) + 1, 047910519933e-08 * pow (x, 4) + -1, 479271312313e-11 * pow (x, 5) + 1, 220894795714e-14 * pow (x, 6) + -6, 136200785076e-18 * pow (x, 7) + 1, 910015248179e-21 * pow (x, 8) + -3, 566607830903e-25 * pow (x, 9) + 5, 000280815521e-30 * pow (x, 10) + 3, 434515045670e-32 * pow (x, 11) + -1, 407635444704e-35 * pow (x, 12) + 9, 871816383223e-40 * pow (x, 13); }

Funkcija razreda 13 bez upotrebe POW -a.

// FUNÇÃO DE GRAU SEM USAR O POWdouble f13_semPow (double x) {return 2, 161282383460e + 02 + 3, 944594843419e-01 * x + 5, 395439724295e-04 * x * x + -3, 968558178426e-06 * x * x * x + 1, 047910519933e-08 * x * x * x * x + -1, 479271312313e-11 * x * x * x * x * x + 1, 220894795714e-14 * x * x * x * x * x * x + -6, 136200785076e-18 * x * x * x * x * x * x * x + 1, 910015248179e-21 * x * x * x * x * x * x * x * x + -3, 566607830903e- 25 * x * x * x * x * x * x * x * x * x + 5, 000280815521e-30 * x * x * x * x * x * x * x * x * x + 3, 434515045670e- 32 * x * x * x * x * x * x * x * x * x * x * x + -1, 407635444704e -35 * x * x * x * x * x * x * x * x * x * x * x * x + 9, 871816383223e-40 * x * x * x * x * x * x * x * x * x * x * x * x * x; }

Korak 29: Datoteke

Preuzmite datoteke:

PDF

JA NE

Tabela