Tiedätkö ESP32 ADC -säädöstä?: 29 vaihetta
Tiedätkö ESP32 ADC -säädöstä?: 29 vaihetta
Anonim
Image
Image
Käytetyt resurssit
Käytetyt resurssit

Tänään aion puhua teknisemmästä ongelmasta, mutta mielestäni kaikkien, jotka työskentelevät ESP32: n kanssa, pitäisi tietää: ADC (analoginen-digitaalinen muunnin) -lukujen säätö. Pidän tätä tärkeänä, koska kun teet "mittausta", etenkin jos laitteella on analoginen lähtö, sinun on oltava täysin varma, että lukema suoritetaan oikein.

Tämän päivän videossa teemme siis mittauksia ESP32: n "analoginen-digitaalinen muunnin" -laitteella, tarkkailemme muunnoseroja ja käytämme ADC-säätö- / kalibrointimenetelmää.

Vaihe 1: Mikä on AD -muunnin?

AD -muunnin on piiri, joka pystyy muuntamaan analogisen (jatkuvan) määrän digitaaliseksi (diskreetiksi). Mitä tuo tarkoittaa? Se tarkoittaa, että vaikka digitaaliset arvot voivat olettaa vain erillisiä arvoja, jotka muodostuvat nollien ja ykkösten yhdistelmästä, analoginen määrä voi olettaa mitä tahansa arvoa alueella. Jos esimerkiksi mittaamme ihanteellisen AA -kennon jännitteen, voimme löytää minkä tahansa arvon välillä 0V - 1,5V, koska tämä on analoginen määrä. Ihanteellisen lampun lähtötilan on oletettava vain kaksi tilaa (pois päältä tai päällä), mikä on diskreetti suuruus. Koska mikro -ohjaimet toimivat tätä erillistä logiikkaa käyttäen, tarvitsemme piirin, joka pystyy kääntämään analogisen määrän digitaaliseksi (tai diskreetiksi).

Vaihe 2: Käytetyt resurssit

• Yksi Lolin32 Lite -kortti v1.0.0

• Tektronix TDS1001C -oskilloskooppi kuvaamiseen

• Yksi USB -kaapeli ESP32: lle

• Hantek DSO4102C -oskilloskooppi signaaligeneraattorina

Vaihe 3: ESP32 ADC

ESP32 ADC
ESP32 ADC

Espressifin tietojen mukaan ESP32-siruissa voi olla +/- 6% ero sirusta toiseen mitatuissa tuloksissa.

Lisäksi muunnoksella EI ole lineaarista vastausta jokaiselle käytettävissä olevalle lukualueelle. Espressif tarjoaa kalibrointimenetelmän ja ehdottaa, että käyttäjät ottavat käyttöön muita menetelmiä, jos he pitävät sitä tarpeellisena halutun tarkkuuden saavuttamiseksi.

Suoritamme tietojen keräämisen ja näytämme tästä ADC -vastaukset ja esimerkin matemaattisen prosessin soveltamisesta säädön lukemiseen.

On olemassa useita (yksinkertaisempia tai monimutkaisempia) tapoja tehdä nämä korjaukset. Sinun tehtäväsi on arvioida projektillesi sopivin.

Tässä esitetyllä on havainnollistava tarkoitus ja se pyrkii käsittelemään mielenkiintoisia kohtia, jotka voidaan havaita säätöjen aikana.

Vaihe 4: Käytetty piiri

Käytetty piiri
Käytetty piiri

Käytin oskilloskooppia ja signaaligeneraattoria, joka kulkee jopa 25 MHz, Hantek DSO4102C. Loimme aallon, jonka ESP A / D ja oskilloskooppi lukivat. Kerätyt tiedot tallennettiin csv -muodossa ja laskentataulukkoon, jonka jätän artikkelin loppuun ladattavaksi.

Vaihe 5: Merkki käytetty

Merkki Käytetty
Merkki Käytetty

Valitsimme matalataajuisen puolisuunnikkaan signaalin, joka mahdollistaa pääsyn koko muunnosalueen läpi kulkeville rampeille. Tämä mahdollistaa suuren määrän näytteitä näillä rampeilla.

Vaihe 6: Oskilloskoopin hankkimat tiedot

Oskilloskoopin hankkimat tiedot
Oskilloskoopin hankkimat tiedot

Kuva kaappauksesta suoritettiin oskilloskoopilla. Tiedot tallennettiin csv -tiedostoon. Huomaa pieni kaarevuus signaalin nousu- ja laskurampeissa.

Vaihe 7: Oskilloskoopin hankkimat tiedot (csv -tiedosto Excelissä)

Oskilloskoopin hankkimat tiedot (csv -tiedosto Excelissä)
Oskilloskoopin hankkimat tiedot (csv -tiedosto Excelissä)

Meillä on näytteitä täällä.

Vaihe 8: ADC: n hankkimat tiedot

ADC: n hankkimat tiedot
ADC: n hankkimat tiedot

Muuttamalla sarjan siirtonopeutta voimme tarkastella ADC: n sieppaamia tietoja. Tarkkaile puolisuunnikkaan signaalin muodonmuutosta.

Tiedot havaittiin Arduino IDE -sarjaplotterissa

Vaihe 9: ADC: n hankkimat tiedot - Excel

ADC: n hankkimat tiedot - Excel
ADC: n hankkimat tiedot - Excel

Korkeamman nopeuden ja sarjapäätteen avulla voimme kaapata arvot ja soveltaa niitä Excelissä vertailuja varten.

Vaihe 10: Kiipeilyramppien vertailu

Kiipeilyramppien vertailu
Kiipeilyramppien vertailu

Vertaamme kahden saaliin kahta kiipeilyramppia.

Huomaa kummankin luiskan kaarevuus.

Huomaa myös, että samaa ramppia varten meillä on paljon enemmän ESP32 -näytteitä kuin oskilloskoopista.

Vaihe 11: Näytteiden lukumäärän vastaaminen

Näytteiden lukumäärän vastaaminen
Näytteiden lukumäärän vastaaminen
Näytteiden lukumäärän vastaaminen
Näytteiden lukumäärän vastaaminen

Koska ESP32 tarjosi suuremman määrän näytteitä kuin oskilloskooppi, meidän on rinnastettava nämä arvot, koska ne toimivat indeksinä kahden käyrän vertaamiseksi.

Tätä varten teemme suoran vertailun.

Meillä on 305 näytettä oskilloskoopin ramppia ja 2365 näytettä ADC -ramppia varten.

Koska luiskat ovat samaa aluetta, voimme sanoa, että meillä on noin 7,75 näytettä ADC: tä kutakin oskilloskooppia kohti.

Kunkin oskilloskooppinäytteen indeksin kertomalla on sama käyrä, mutta indeksit vastaavat ADC: tä ja uudelleenjaettuja tietoja.

Täyttääksemme puuttuvat tiedot uusista tehtävistä käytämme käyrää, joka sopii tilastollisesti tunnettuihin tietoihin.

Vaihe 12: Aukkojen täyttäminen - trendirivi

Aukkojen täyttäminen - Trend Line
Aukkojen täyttäminen - Trend Line
Aukkojen täyttäminen - Trend Line
Aukkojen täyttäminen - Trend Line

Valitsemalla tiedossa olevat tiedot (siniset pisteet) napsauttamalla ja napsauttamalla sitten oikeaa painiketta valitsemme: "Lisää trendirivi …"

Valitsemme avautuvassa ikkunassa Polynomi -tyypin (tilaus 2 riittää).

Tarkistimme myös vaihtoehdot "Näytä yhtälö kaaviossa" ja "Näytä R-neliöarvo kaaviossa".

Napsauta "Sulje".

Vaihe 13: Aukkojen täyttäminen - Grade 2 -polynomikäyrä

Aukkojen täyttäminen - Grade 2 Polynomial Curve
Aukkojen täyttäminen - Grade 2 Polynomial Curve

Excel antaa meille kaksi uutta tietoa; toisen kertaluvun yhtälö, joka sopii parhaiten dataan, ja R-neliöyhtälö, joka ilmaisee tämän riittävyyden.

Muista vain, että mitä lähempänä 1, sitä sopivampi yhtälö.

Älkäämme syventykö matematiikkaan, vaan käytämme sitä työkaluna.

Vaihe 14: Aukkojen täyttäminen - toiminnon arviointi

Täytetään näytteenottoaukot yhtälön tuottamilla tiedoilla. Ja sitten vertaa niitä kohta kohdalta.

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

R² = 0, 9999

Oskilloskoopin jännite = -9E -08 * indeksi2 + 0, 0014 * indeksi + 0, 1505

Vaihe 15: Oskilloskoopin jännitteen muuntaminen vastaavaan arvoon verrattuna ADC: hen

Oskilloskoopin jännitteen muuntaminen vastaavaan arvoon verrattuna ADC: hen
Oskilloskoopin jännitteen muuntaminen vastaavaan arvoon verrattuna ADC: hen

Hyödynnä tätä hyötyä muuntaaksemme myös oskilloskoopin jännitteen arvon vastaavaksi ADC -arvoksi.

Koska korkein ESP32: n ADP: ssä saatu arvo oli 4095, mikä vastaa 2,958 V: n lukemaa samalla indeksillä, voimme sanoa, että:

Kukin voltti oskilloskoopin mittauksissa vastaa noin 1384,4 AD -yksikköä. Siksi voimme kertoa kaikki oskilloskoopin mittaukset tällä arvolla.

Vaihe 16: Kahden saavutetun rampin vertailu

Vertaamalla saatuja kahta ramppia
Vertaamalla saatuja kahta ramppia

Visualisoi kahden lukeman erot.

Vaihe 17: ADC Reading Difference (ERROR) -käyttäytyminen

ADC Reading Difference (ERROR) -käyttäytyminen
ADC Reading Difference (ERROR) -käyttäytyminen

Alla oleva käyrä osoittaa, miten ADC -lukeman ero toimii mittauksen funktiona. Tämän tiedonkeruun avulla voimme löytää korjaustoiminnon.

Tämän käyrän löytämiseksi piirrämme yksinkertaisesti kussakin mittauksessa havaitun eron kunkin mahdollisen AD -sijainnin funktiona (0-4095).

Vaihe 18: ADC -lukujen erokäyttäytyminen - korjaustoiminnon löytäminen

ADC Reading Difference Behavior - Korjaustoiminnon löytäminen
ADC Reading Difference Behavior - Korjaustoiminnon löytäminen

Voimme määrittää Excelissä korjaustoiminnon lisäämällä nyt korkeamman suuntauslinjan, kunnes se sopii riittävästi tietoihimme.

Vaihe 19: Muiden ohjelmistojen käyttäminen

Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen
Muiden ohjelmistojen käyttäminen

Muita mielenkiintoisia ohjelmistoja käyrien määrittämiseen on PolySolve, jota voidaan käyttää suoraan linkistä: https://arachnoid.com/polysolve/ tai ladata Java -sovelluksena.

Se mahdollistaa korkeamman asteen polynomi-regressioiden soveltamisen ja muotoillun funktion sekä muiden toimintojen toimittamisen.

Voit käyttää sitä kirjoittamalla tiedot ensimmäiseen tekstikenttään. Tietojen on noudatettava järjestystä X, Y pilkulla tai sarkaimella erotettuna. Ole varovainen käyttäessäsi pistettä oikein desimaalipisteenä.

Kaavio näkyy seuraavassa ruudussa, jos syötetyt tiedot on muotoiltu oikein.

Näin ADC -virhekäyrämme meni.

Tässä ikkunassa esitetään regression tulos, mukaan lukien toimintojen riittävyystiedot, joiden lähtö voidaan muotoilla useilla tavoilla: C / C ++ -funktiona, kertoimien luettelo, Java -funktio jne.

Huomautus: Kiinnitä huomiota desimaalierottimiin

Vaihe 20: Vakiot ja asetukset ()

Mainitsen tässä GPIO: n, jota käytettiin analogiseen sieppaukseen. Alustan sarjaportin sekä analogista sieppausta varten määritetyn nastan.

const int pin_leitura = 36; // GPIO usado para captura analógica void setup () {Serial.begin (1000000); // Iniciciando a porta serial somente para debug pinMode (pin_leitura, INPUT); // Pino utilizado para captura analógica}

Vaihe 21: Silmukka () ja korjaustoiminto

Tallennamme säädetyn jännitteen ja tulostamme arvot oikeilla korjauksilla tai ilman niitä.

void loop () {int valor_analogico = analoginenLue (pin_leitura); // realiza a 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 (","); Sarja.println (0); // cria uma linha para marcar o valor mínimo de 0}

Huomaa rivillä 12, että meillä on mahdollisuus tulostaa tiedot lisäämällä erotustoiminto f (analoginen_arvo).

Vaihe 22: PolySolve Correction -toiminnon käyttäminen

Tässä käytämme PolySolve -toimintoa Arduino IDE: n sisällä.

/* Tila: normaali Polynomi-aste 6, 2365 x, y-dataparit Korrelaatiokerroin (r^2) = 9, 907187626418e-01 Vakavirhe = 1, 353761109831e+01 Tulostusmuoto: C/C ++ -toiminto: Copyright © 2012, P. Lutus - https://www.arachnoid.com. Kaikki oikeudet pidätetään. */ 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); }

Huomaa pilkku-piste-muutos desimaalierottimena.

Vaihe 23: Tallenna korjauksella - Plotter -sarja

Tallenna korjauksella - Plotter -sarja
Tallenna korjauksella - Plotter -sarja

Vaihe 24: Laskennalliset kustannukset

Laskennallinen hinta
Laskennallinen hinta
Laskennallinen hinta
Laskennallinen hinta

Suorittaakseen polynomilaskelmat prosessorin on suoritettava tämä tehtävä. Tämä voi johtaa suorituksen viivästymiseen lähdekoodista ja käytettävissä olevasta laskentatehosta riippuen.

Tässä näemme tuloksen taulukon testistä, jossa käytetään moniasteisia polynomeja. Huomaa ero aikojen välillä, jolloin pow () -toimintoa käytettiin ja milloin sitä ei käytetty.

Vaihe 25: Testikoodi - Asennus () ja silmukan käynnistys ()

Tässä meillä on testissä käytetty koodi.

void setup () {Serial.begin (1000000); // Iniciando a porta serial somente para 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

Vaihe 26: Testikoodi - silmukka () ja käsittely

Käytin micros () -funktiota arvon saamiseksi mikrosekunneissa.

// ============= inicia o prosesso 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 a função POW // f13_comPow (valor_analogico); // grau 13º COM a função POW contador ++; } agora = (micros () - agora) / quantidade; // determina o intervalo que se passou para cada iteração // ============= finaliza o processo

Vaihe 27: Testikoodi - silmukka () - Tulokset

Tulostamme luokan 13 toiminnosta palautetun arvon POW: lla ja ilman vertailua sekä käsittelyvälin.

// imprime o valor retornado da função de grau 13 com e sem POW para comparação Serial.print (f13_semPow (valor_analogico)); // grau 13º SEM a função POW Serial.print (" -"); Serial.print (f13_comPow (valor_analogico)); // grau 13º COM a função POW Serial.print (" -"); // imprime o intervalo do processamento Serial.println (agora, 6); }

Vaihe 28: Testikoodi - käytetyt toiminnot

Tyhjät toiminnot (vain palauttamisen yhteydessä) asteet 0 ja 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 double f1 (double x) {return 2.202196968876e + 02 + 3.561383996027e-01 * x; }

Luokkien 2, 3 ja 4 toiminnot.

// 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); }

Luokan 5 ja 6 toiminnot.

// FUNÇÃO DE GRAU 5double f5 (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); } // FUNÇÃO DE GRAU 6 double f6 (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); }

Luokan 13 toiminto POW: n avulla.

// 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); }

Luokan 13 toiminto ilman POW: ta.

// 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 * 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; }

Vaihe 29: Tiedostot

Lataa tiedostot:

PDF

INO

Laskentataulukko