Innholdsfortegnelse:
2025 Forfatter: John Day | [email protected]. Sist endret: 2025-01-23 15:02
Hei der, Har du noen gang ønsket å bygge en rover som du kan styre med enkle håndbevegelser, men aldri kunne ta mot til å våge deg inn i vanskelighetene med bildebehandling og grensesnitt mellom et webkamera og mikrokontrolleren din, for ikke å snakke om oppoverbakke for å overvinne dårlig rekkevidde og rekkefølge synsproblemer? Vel, frykt ikke … for det er en enkel vei ut! Se, som jeg presenterer for deg den mektige ACCELEROMETER! *ba dum tsss*
Et akselerometer er en veldig kul enhet som måler gravitasjonsakselerasjon langs en lineær akse. Det representerer dette som et spenningsnivå som svinger mellom jord og forsyningsspenning, som vår mikrokontroller leser inn som en analog verdi. Hvis vi bruker hjernen vår litt (bare litt matte og litt newtonsk fysikk), kan vi ikke bare bruke den til å måle lineær bevegelse langs en akse, men vi kan også bruke den til å bestemme tiltvinkelen og føle vibrasjoner. Ikke bekymre deg! Vi trenger ikke matematikk eller fysikk; vi skal bare håndtere råverdier som akselerometeret spytter ut. Faktisk trenger du ikke bekymre deg særlig mye om det tekniske ved et akselerometer for dette prosjektet. Jeg vil bare berøre noen få detaljer og utdype bare så mye du trenger for å forstå det store bildet. Selv om du er interessert i å studere dens indre mekanikk, ta en titt her.
Du trenger bare å huske på dette for øyeblikket: et akselerometer er gizmo (ofte kombinert med et gyroskop) som åpner dører til alle de bevegelsessensorspillene vi spiller på smarttelefonene våre; et bilspill for eksempel, hvor vi styrer kjøretøyet ved å vippe enhetene våre i begge retninger. Og vi kan etterligne denne effekten ved å stikke et akselerometer (med noen få hjelpemidler, selvfølgelig) på en hanske. Vi tar bare på oss våre magiske hansker og vipper hendene til venstre eller høyre, fremover eller bakover og ser roverne våre danse til melodiene våre. Alt vi trenger å gjøre her er å oversette akselerometerets avlesninger til digitale signaler som motorene på roveren kan tolke og utvikle en mekanisme for å overføre disse signalene til roveren. For å oppnå dette, ber vi den gode ol 'Arduino og dens hjelpere for dagens eksperiment, et RF-sender-mottakerpar som opererer på 434MHz og derved gi et område på omtrent 100-150m i åpent rom, noe som også redder oss fra linje-av- synsproblemer.
Ganske greit hack, ikke sant? La oss dykke inn…
Trinn 1: Samle rekvisita
• Arduino Nano | x1 |
• Akselerometer (ADXL335) | x1 |
• 5V DC motor + hjul | x2 hver |
• Storfehjul* | x1 |
• L293D -motordriver + 16 -pinners IC -kontakt | x1 hver |
• 434 MHz RF -sender | x1 |
• 434 MHz RF -mottaker | x1 |
• HT-12E Encoder IC + 18-pins IC-kontakt | x1 hver |
• HT-12D dekoder IC + 18-pinners IC-kontakt | x1 hver |
• LM7805 spenningsregulator | x1 |
• Trykknappbryter | x2 |
• Rød LED + 330O motstand | x2 hver |
• Gul LED + 330O motstand | x1 hver |
• Grønn LED + 330O motstand (valgfritt) | x4 hver |
• 51kO og 1MO motstander | x1 hver |
• 10µF radialkondensatorer | x2 |
Batterier, batterikontakter, USB-kabel, jumperledninger, hunnhoder, 2-pinners skrueterminaler, kretskort, Chasis og ditt vanlige loddetilbehør |
Hvis du lurer på hvorfor vi bruker et storfehjul, er saken at RF -senderen og mottakermodulene bare har 4 datapinner, noe som betyr at vi bare kan kjøre 2 motorer og dermed bruk av et storfehjul for å støtte strukturen. Men hvis du føler at roveren din vil se litt mer kul ut med fire hjul, ikke bekymre deg, det er en jobb! I dette tilfellet kan du bare skrape storfehjulet fra listen og legge til et par 5V likestrømsmotorer, ledsaget av et hjul hver, og se etter den enkle hacken som ble diskutert mot slutten av trinn 3.
Til slutt, for de modige, er det rom for en annen liten modifikasjon i design, noe som innebærer å konstruere din egen Arduino. Gå til bonusseksjonen i neste trinn og se selv. Du trenger også noen ekstra forsyninger: en ATmega328P, en 28pin IC -kontakt, en 16Mhz krystalloscillator, to 22pF keramiske hetter, en annen 7805 spenningsregulator, ytterligere 10μF radialkapsler og 10kΩ, 680Ω, 330Ω motstander og ja, minus Arduino!
Trinn 2: Koble opp senderen
Vi vil dele prosjektet ned til to bestanddeler: senderen og mottakerkretsene. Senderen består av et akselerometer, en Arduino og en RF-sendermodul kombinert med en HT-12E-encoder IC, alle sammenkoblet i henhold til den vedlagte skjematikken.
Akselerometeret, som introdusert tidligere, tjener til å gjenkjenne håndbevegelsene våre. Vi kommer til å bruke et tre-akset akselerometer (i utgangspunktet tre enakse akselerometre i ett) for å dekke våre behov. Den kan brukes til å måle akselerasjon i alle tre dimensjonene, og som du kanskje har gjettet, gir den ikke én, men et sett med tre analoge verdier i forhold til de tre aksene (x, y og z). Egentlig trenger vi bare akselerasjonen langs x- og y -aksene siden vi bare kan kjøre roveren i fire retninger: fremover eller bakover (dvs. langs y -aksen) og venstre eller høyre (dvs. langs x -aksen). Vi ville trengt z -aksen hvis vi bygde en drone, slik at vi også kunne kontrollere dens stigning eller nedstigning ved hjelp av bevegelser. Uansett må disse analoge verdiene som akselerometeret gir, konverteres til digitale signaler for å kunne drive motorene. Dette blir tatt hånd om av Arduino som også overfører disse signalene, ved konvertering, til roveren via RF -sendermodulen.
RF-senderen har bare en jobb: å overføre de "serielle" dataene som er tilgjengelige på pin 3 ut av antennen på pin 1. Dette taler for bruk av HT-12E, en 12 biters parallell til seriell datakoder, som samler opptil 4 biter parallelle data fra Arduino på linjene AD8 til AD11, og dermed kan vi gjøre plass til opptil 24 = 16 forskjellige I/O -kombinasjoner i motsetning til den ene datapinnen på RF -senderen. De resterende 8 bitene, trukket fra linjene A0 til A7 på koderen, utgjør adressebyten, noe som letter paring av RF -senderen med en tilsvarende RF -mottaker. De 12 bitene blir deretter satt sammen og seriellisert og sendt videre til datapinnen til RF-senderen, som igjen ASK-modulerer dataene på en 434MHz bærerbølge og skyter den ut via antennen ved pinne 1.
Konseptuelt bør enhver RF -mottaker som lytter på 434Mhz kunne fange opp, demodulere og dekode disse dataene. Adresselinjene på HT-12E, og de på HT-12D-motstykket (en 12-biters seriell-til-parallell datadekoder), tillater oss imidlertid å gjengi et RF-sender-mottakerpar unikt ved å rute dataene bare til tiltenkt mottaker og dermed begrense kommunikasjonen med alle andre. Alt som kreves av oss er å konfigurere adresselinjene identisk på begge fronter. Siden vi for eksempel har jordet alle adresselinjene for HT-12E, må vi gjøre det samme for HT-12D i mottakerenden, ellers vil ikke roveren kunne motta signalene. På denne måten kan vi også kontrollere flere rovere med en enkelt senderkrets ved identisk å konfigurere adresselinjene på HT-12Dene på hver av mottakerne. Eller vi kan ta på oss to hansker, hver festet med en senderkrets som inneholder en distinkt adresselinjekonfigurasjon (si en med alle adresselinjer jordet og den andre med alle holdt høyt, eller en med en linje jordet mens de resterende syv holdes høy og den andre med to linjer jordet mens de resterende seks holdes høyt, eller en hvilken som helst annen kombinasjon derav) og hver styring av flere identisk konfigurerte rovere. Spill maestroen på en android symfoni!
En viktig ting å merke seg når du setter sammen kretsen, er verdien av Rosc. HT-12E har en intern oscillatorkrets mellom pinnene 15 og 16, som aktiveres ved å koble en motstand, kalt Rosc, mellom disse pinnene. Verdien som er valgt for Rosc bestemmer faktisk oscillatorfrekvensen, som kan variere avhengig av forsyningsspenningen. Å velge en passende verdi for Rosc er avgjørende for funksjonen til HT-12E! Ideelt sett bør HT-12Es oscillatorfrekvens være 1/50 ganger den for HT-12D-motstykket. Derfor, siden vi opererer på 5V, valgte vi 1MΩ og 51kΩ motstander som Rosc for henholdsvis HT-12E og HT-12D kretsene. Hvis du planlegger å bruke kretsene på en annen forsyningsspenning, kan du se grafen “Oscillatorfrekvens vs forsyningsspenning” på side 11 i det vedlagte HT-12E-databladet for å bestemme den eksakte oscillatorfrekvensen og motstanden som skal brukes.
Som en sidebemerkning vil vi også bruke kvinnelige overskrifter her (som tjener et lignende formål som IC -kontakter) for å plugge akselerometeret, RF -senderen og Arduino i kretsen i stedet for å lodde dem direkte på kretskortet. Intensjonen er å innkvartere litt gjenbrukbarhet. Si, det er en stund siden du konstruerte din gestkontrollerte rover og den bare satt der, halvt dekket av støv, på toppen av pokalhyllen din, og du snublet over en annen flott instruktør som utnytter effekten av et akselerometer. Så hva gjør du? Du tar den bare ut av roveren og skyver den inn i den nye kretsen. Du trenger ikke å tilkalle “Amazons” for å skaffe deg en ny:-p
Bonus: Gjør unna med Arduino, og likevel ikke
Bare i tilfelle du føler deg litt mer eventyrlystne, og spesielt hvis du tror at å bruke dette vakkert designet vidunderet (Arduino, selvfølgelig) for en så triviell oppgave som vår er litt av en overkill, må du bære med meg litt lenger; og hvis ikke, kan du hoppe til neste trinn.
Målet vårt her er å gjøre Arduino (hjernen til Arduino, faktisk; ja, jeg snakker om ATmega IC!) Til et permanent medlem av teamet. ATmega ville bli programmert til å kjøre bare en enkelt skisse igjen og igjen, slik at den kunne tjene som en evig del av kretsen, akkurat som HT-12E-bare IC, bare sitte der og gjøre det den skal. Er det ikke slik et ekte innebygd system skal være?
Uansett, for å fortsette med denne oppgraderingen, må du bare endre kretsen i henhold til den andre skjemaet som er vedlagt. Her erstatter vi ganske enkelt hunnhodene til Arduino med en IC-kontakt for ATmega, legger til en 10K opptrekkmotstand ved tilbakestillingspinnen (pin 1) på IC og pumper den opp med en ekstern klokke mellom pinne 9 og 10. Dessverre, hvis vi gjør opp med Arduino, slipper vi også de innebygde spenningsregulatorene; ergo, må vi replikere LM7805-kretsen som vi hadde brukt for mottakeren også her. I tillegg bruker vi også en spenningsdeler for å tegne 3.3V som kreves for å drive akselerometeret.
Nå er den eneste andre fangsten her å programmere ATmega for å gjøre jobben sin. Du må imidlertid vente på det til trinn 4. Så, følg med …
Trinn 3: Og mottakeren
Mottakeren består av en RF-mottakermodul kombinert med en HT-12D-dekoder IC og et par likestrømsmotorer som drives ved hjelp av en L293D-motordriver, alle sammenkoblet i henhold til vedlagt skjema.
RF-mottakerens eneste jobb er å demodulere bærebølgen (mottatt via antennen ved pinne 1) og gjengi de hentede "serielle" dataene på pinne 7 fra hvor den blir hentet av HT-12D for deserialisering. Forutsatt at adresselinjene (A0 til A7) på HT-12D er konfigurert identisk med HT-12E-motstykket, trekkes de 4 parallelle databitsene ut og sendes videre via datalinjene (D8 til D11) på HT-12D, til motorføreren, som igjen tolker disse signalene for å drive motorene.
Igjen, vær oppmerksom på verdien av Rosc. HT-12D har også en intern oscillatorkrets mellom pinnene 15 og 16, som aktiveres ved å koble en motstand, kalt Rosc, mellom disse pinnene. Verdien som er valgt for Rosc bestemmer faktisk oscillatorfrekvensen, som kan variere avhengig av forsyningsspenningen. Å velge en passende verdi for Rosc er avgjørende for funksjonen til HT-12D! Ideelt sett bør HT-12Ds oscillatorfrekvens være 50 ganger den for HT-12E-motstykket. Derfor, siden vi opererer på 5V, valgte vi 1MΩ og 51kΩ motstander som Rosc for henholdsvis HT-12E og HT-12D kretsene. Hvis du planlegger å bruke kretsene på en annen forsyningsspenning, kan du se grafen "Oscillatorfrekvens vs forsyningsspenning" på side 5 i det vedlagte HT-12D-databladet for å bestemme den eksakte oscillatorfrekvensen og motstanden som skal brukes.
Ikke glem de kvinnelige overskriftene til RF -mottakeren.
Eventuelt kan en LED kobles via en 330Ω strømbegrensende motstand til hver av de 4 datapinnene på HT-12D for å bestemme biten som mottas ved den pinnen. Lysdioden vil lyse hvis den mottatte biten er HØY (1) og dempe hvis den mottatte biten er LAV (0). Alternativt kan en enkelt LED knyttes til VT-pinnen på HT-12D (igjen, via en 330Ω strømbegrensende motstand), som ville lyse opp i tilfelle en gyldig overføring.
Nå, hvis du leter etter hacken med motorene som jeg snakket om i trinn ett, er det forbanna enkelt! Bare koble de to motorene i hvert sett parallelt som vist i det andre skjemaet. Dette fungerer slik det skal fordi motorene i hvert sett (motorene foran og bak på venstre og motorene foran og bak til høyre) aldri drives i motsatte retninger. Det vil si at for å dreie roveren til høyre må både fremre og bakre motorer på venstre kjøres fremover og motorene foran og bak til høyre må begge kjøres bakover. For å få roveren til å svinge til venstre må motorene foran og bak på venstre side begge kjøres bakover, og motorene foran og bak til høyre må kjøres fremover. Derfor er det trygt å mate inn det samme spenningsparet til begge motorene i et sett. Og måten å gjøre det på er ved å koble dem til motorer parallelt.
Trinn 4: Videre til koden
Det er bare en ting igjen å gjøre for å få roveren i gang. Ja, du gjettet riktig! (Jeg håper du gjorde) Vi må fortsatt oversette akselerometeravlesningene til et skjema som motordriveren kan tolke for å kunne kjøre motorene. Hvis du tenker at siden akselerometeravlesningene er analoge og motorføreren forventer digitale signaler, må vi implementere en slags ADC, vel, ikke teknisk, men det er det vi må gjøre. Og det er ganske greit.
Vi vet at et akselerometer måler gravitasjonsakselerasjon langs en lineær akse og at denne akselerasjonen er representert som et spenningsnivå som svinger mellom bakken og forsyningsspenningen, som mikrokontrolleren vår leser inn som en analog verdi som varierer mellom 0 og 1023. Men siden vi Hvis jeg bruker akselerometeret på 3,3V, anbefales det at vi setter den analoge referansen for 10-biters ADC (som kommer integrert i ATmeaga ombord på en Arduino) til 3,3V. Det vil bare gjøre ting enklere å forstå; selv om det ikke vil ha mye å si for vårt lille eksperiment, selv om vi ikke gjorde det (vi må bare justere koden litt). For å gjøre det, kobler vi ganske enkelt AREF -pinnen på Arduino (pin 21 på ATmega) til 3,3V og angir denne endringen i kode ved å ringe analogReference (EXTERNAL).
Når vi legger akselerometeret flatt og analogt Les akselerasjonen langs x- og y -aksene (husk? Vi trenger bare disse to aksene), får vi en verdi på omtrent 511 (dvs. halvveis mellom 0 og 1023), som bare er en måte å si at det er 0 akselerasjon langs disse aksene. I stedet for å grave i detaljene i det faktum, bare tenk deg dette som x- og y -aksene på en graf, med verdien 511 som angir opprinnelsen og 0 og 1023 endepunktene som vist på figuren; orienter akselerometeret på en slik måte at pinnene peker ned og holdes nærmere deg, ellers kan du snu/bytte aksene. Dette betyr at hvis vi vipper akselerometeret til høyre, bør vi lese en verdi større enn 511 langs x-aksen, og hvis vi vipper akselerometeret til venstre, bør vi få en verdi lavere enn 511 langs x-aksen. På samme måte, hvis vi vipper akselerometeret fremover, bør vi lese en verdi større enn 511 langs y-aksen, og hvis vi vipper akselerometeret bakover, bør vi lese en verdi lavere enn 511 langs y-aksen. Og dette er hvordan vi i kode utleder retningen som roveren skal kjøres i. Men dette betyr også at vi må holde akselerometeret virkelig stabilt og justert parallelt med en flat overflate for å kunne lese en 511 langs begge aksene for å få roveren parkert stille. For å lette denne oppgaven litt, definerer vi visse terskler som danner en grense, slik figuren viser, slik at roveren forblir stasjonær så lenge x- og y -avlesningene ligger innenfor grensene, og vi vet sikkert at roveren må settes i bevegelse når terskelen er overskredet.
For eksempel, hvis y-aksen leser 543, vet vi at akselerometeret er vippet fremover, så må vi styre roveren fremover. Vi gjør dette ved å sette pins D2 og D4 HIGH og pins D3 og D5 LOW. Siden disse pinnene er koblet direkte til HT-12E, blir signalene seriell og avfyrt RF-senderen bare for å bli fanget opp av RF-mottakeren som sitter på roveren, som ved hjelp av HT-12D deserialiserer signalene og sender dem videre til L293D, som igjen tolker disse signalene og driver motorene fremover
Du vil kanskje endre disse tersklene for å kalibrere følsomheten. En enkel måte å gjøre det på er å bare koble akselerometeret til Arduino og kjøre en skisse som spytter ut x- og y -avlesningene til den serielle skjermen. Nå er det bare å flytte akselerometeret litt rundt, se gjennom målingene og bestemme terskelverdiene.
Og det er det! Last opp koden til Arduino og nyt! Eller, kanskje ikke så snart:-(Hvis du ikke hoppet over bonusdelen, ville det å laste opp koden til ATmega bety litt mer arbeid. Du har to alternativer:
Alternativ A: Bruk en USB til seriell enhet, for eksempel FTDI FT232 basic breakout board. Bare kjør ledninger fra TTL -toppteksten til de tilsvarende pinnene på ATmega i henhold til kartleggingen nedenfor:
Pins på Breakout Board | Pins på mikrokontrolleren |
---|---|
DTR/GRN | RST/Tilbakestill (Pin 1) via 0,1 µF lokk |
Rx | Tx (Pin 3) |
Tx | Rx (Pin 2) |
Vcc | +5v utgang |
CTS | (ubrukt) |
Gnd | Bakke |
Koble nå den ene enden av en USB -kabel til utbruddskortet og den andre til PC -en og last opp koden som du vanligvis ville: start Arduino IDE, velg en passende seriell port, angi brettypen, kompiler skissen og trykk på last opp.
Alternativ B: Bruk en UNO hvis du har en liggende et sted. Bare koble din ATmega til UNO, last opp koden som du vanligvis ville, trekk ICen ut og skyv den tilbake til senderkretsen. Så enkelt som en pai!
Begge disse alternativene burde fungere, forutsatt at du var smart nok til å brenne opplasteret på forhånd på din ATmega, eller hvis du var enda smartere å kjøpe en ATmega med bootloaderen allerede installert i utgangspunktet. Hvis ikke, fortsett og gjør det ved å følge trinnene som er skissert her.
Andddd, vi er offisielt ferdige! Jeg håper du likte denne bisarre lange instruksen. Nå, fortsett å bygge roveren din hvis du ikke allerede er ferdig, lek med den en stund og kom tilbake for å oversvømme kommentarfeltet nedenfor med spørsmål og/eller konstruktiv kritikk.
Takk
P. S. Grunnen til at jeg ikke lastet opp noen bilder av det ferdige prosjektet, er vel, fordi jeg ikke fullførte det selv. Halvveis i byggingen tenkte jeg på noen forstørrelser, for eksempel hastighetskontroll, hindring av hindringer og kanskje en LCD -skjerm på roveren, noe som faktisk ikke er så vanskelig hvis vi bruker en mikrokontroller på både sende- og mottaksenden. Men hvorfor ikke gjøre det på den harde måten ?! Så, jeg jobber for tiden i den retningen, og jeg legger ut en oppdatering så snart den bærer noen frukt. Imidlertid testet jeg ut koden og designet ved hjelp av en rask prototype som jeg bygde ved hjelp av moduler fra et av mine tidligere prosjekter; du kan se på videoen her.
Anbefalt:
DIY -- Hvordan lage en edderkopprobot som kan kontrolleres ved hjelp av smarttelefon ved hjelp av Arduino Uno: 6 trinn
DIY || Hvordan lage en edderkopprobot som kan kontrolleres ved hjelp av smarttelefon ved hjelp av Arduino Uno: Mens du lager en edderkopprobot, kan du lære så mange ting om robotikk. Som å lage roboter er både underholdende og utfordrende. I denne videoen skal vi vise deg hvordan du lager en Spider -robot, som vi kan bruke ved hjelp av smarttelefonen vår (Androi
Gestkontrollert robot ved bruk av Arduino: 7 trinn
Bevegelseskontrollert robot ved bruk av Arduino: Roboter brukes i mange sektorer som konstruksjon, militær, produksjon, montering, etc. Roboter kan være autonome eller semi-autonome. Autonome roboter krever ingen menneskelig inngrep og kan handle på egen hånd i henhold til situasjonen. Se
Hvordan lage en drone ved hjelp av Arduino UNO - Lag en quadcopter ved hjelp av mikrokontroller: 8 trinn (med bilder)
Hvordan lage en drone ved hjelp av Arduino UNO | Lag en Quadcopter ved hjelp av mikrokontroller: Introduksjon Besøk min Youtube -kanal En Drone er en veldig dyr gadget (produkt) å kjøpe. I dette innlegget skal jeg diskutere hvordan jeg får det billig? Og hvordan kan du lage din egen slik til en billig pris … Vel, i India er alle materialer (motorer, ESCer
Foreløpig* SPI på Pi: Kommunikasjon med et SPI 3-akset akselerometer ved hjelp av en bringebær Pi: 10 trinn
Foreløpig* SPI på Pi: Kommunikasjon med et SPI 3-akset akselerometer Bruke en Raspberry Pi: Trinnvis veiledning om hvordan du konfigurerer Raspbian og kommuniserer med en SPI-enhet ved hjelp av bcm2835 SPI-bibliotek (IKKE litt banket!) Dette er fortsatt veldig foreløpig … Jeg må legge til bedre bilder av fysisk oppkobling, og jobbe med noen av de vanskelige kodene
Vinkelmåling ved hjelp av gyro, akselerometer og Arduino: 5 trinn
Vinkelmåling ved hjelp av Gyro, Accelerometer og Arduino: Enheten er en grov prototype av det som til slutt vil bli en selvbalanseringsrobot, dette er den andre delen av hullet (les akselerometer og kontroller en motor til selvbalanse). Den første delen med bare gyroen finner du her. På denne inst