TECHNICKÁ UNIVERZITA V LIBERCI Fakulta mechatroniky, informatiky a mezioborových studií
Autonomní robot na soutěž BEAR RESCUE 2012
Bakalářský projekt
Marek Valšík, Zbyšek Zapadlík
Liberec
2012
Materiál vznikl v rámci projektu ESF (CZ.1.07/2.2.00/07.0247) Reflexe požadavků průmyslu na výuku v oblasti automatického řízení a měření, KTERÝ JE SPOLUFINANCOVÁN EVROPSKÝM SOCIÁLNÍM FONDEM A STÁTNÍM ROZPOČTEM ČESKÉ REPUBLIKY
Zadání projektu TECHNICKÁ UNIVERZITA V LIBERCI Fakulta mechatroniky, informatiky a mezioborových studií Ústav MTI Akademický rok: 2011/2012 ZADÁNÍ BAKALÁŘSKÉHO PROJEKTU Jméno a příjmení: ZAPADLÍK Zbyšek , VALŠÍK Marek studijní program: B 2612 – Elektrotechnika a informatika obor: EIŘS Název tématu:
Autonomní robot na soutěž BEAR RESCUE 2012
Vedoucí učitel projektu:
Doc. Ing. Mgr. Václav Záda, CSc.
Zásady pro vypracování: 1. Navrhněte konstrukci kolového robotu, vhodného pro účast na soutěži BEAR RESCUE 2012. 2. Zkonstruujte robot dle bodu 1, vytvořte software pro řízení robotu a proveďte jeho oživení a otestujte správnost návrhu na hracím poli ekvivalentním s polem užívaným při skutečné soutěži. 3. Zúčastněte se soutěže BEAR RESCUE 2012, konané v Praze. 4. Na základě bodu 3. proveďte případné úpravy a vylepšení robota, zhodnoťte dosažené výsledky a proveďte doporučení pro případné další zájemce o soutěž. Seznam odborné literatury: www.eurobot.org http://opencv.willowgarage.com/wiki/
Rozsah závěrečné zprávy o řešení projektu: 10 až 15 stran V Liberci dne 3. října 2011
vedoucí učitel projektu (podpis) ................................
2
Pravidla soutěže
3
Poděkování Tímto děkujeme doc. Mgr. Ing. Václavu Zádovi, CSc. za cenné připomínky, rady a podporu projektu. Dále děkujeme Ing. Zdeňku Kračmarovi za poskytnutí prostor pro testování robota. Tento text vznikl za podpory projektu ESF CZ.1.07/2.2.00/07.0247 Reflexe požadavků průmyslu na výuku v oblasti automatického řízení a měření.
4
Abstrakt Tento bakalářský projekt popisuje návrh a stavbu autonomního robota na soutěž BEAR RESCUE 2012 pořádané v rámci robotického dne katedrou softwarového inženýrství MFF UK a občanského sdružení Robonika. Stavba a realizace autonomního robota zasahuje do několika oborů – elektronika, automatické řízení, strojírenství a materiály, umělá inteligence a zpracování informací a obrazu. Zpráva je rozčleněna na softwarovou a hardwarovou část.
5
Obsah Zadání projektu ............................................................................................................... 2 Pravidla soutěže .............................................................................................................. 3 Poděkování ..................................................................................................................... 4 Abstrakt .......................................................................................................................... 5 1
Hardware .................................................................................................................. 7 1.1
Úvod ................................................................................................................. 7
1.2
Mechanika ........................................................................................................ 7
1.2.1 Konstrukce .................................................................................................. 7 1.2.2 Motory ........................................................................................................ 7 1.2.3 Netbook ....................................................................................................... 7 1.2.4 Kamera ........................................................................................................ 7 1.2.5 Senzory ....................................................................................................... 7 1.2.6 DPS ............................................................................................................. 7 1.2.7 Uchopovací mechanizmus .......................................................................... 8 1.2.8 Finální podoba robota ................................................................................. 9 1.3 2
Elektronika........................................................................................................ 9
Software ................................................................................................................. 13 2.1
Úvod ............................................................................................................... 13
2.2
Procesory ........................................................................................................ 13
2.2.1 Komunikace .............................................................................................. 13 2.2.2 Zápis: ........................................................................................................ 13 2.2.3 Čtení: ......................................................................................................... 13 2.2.4 Formát I2C DAT pro vlastní desky: ......................................................... 14 2.2.5 PID regulace ............................................................................................. 14 2.2.6 Skenování.................................................................................................. 14 2.3
Řídící program ................................................................................................ 15
2.4
Zpracování obrazu .......................................................................................... 17
3
Shrnutí .................................................................................................................... 18
4
Závěr ...................................................................................................................... 18
5
Literatura ................................................................................................................ 19
6
Reference ............................................................................................................... 19
6
1 Hardware 1.1 Úvod Pohybový systém je řešen jako dvoukolový diferenciálně řízený podvozek, konstrukce je tvořena převážně z hliníkových profilů a spojovacích plechů. Některé části jsou vytištěné z plastu. Senzorický systém tvoří čtveřice infračervených senzorů a pole taktilních senzorů vpředu podvozku. Na vrchní části je umístěna barevná kamera. Řídicí systém obstarává netbook.
1.2 Mechanika 1.2.1 Konstrukce Konstrukce je tvořena převážně hliníkovými profily, plechy, které je drží dohromady a vytištěnými plastovými částmi na 3D tiskárně. Vrchní část robota tvoří plexisklo, ve kterém jsou díry pro nouzový vypínač, zapínací a spouštěcí tlačítka. 1.2.2 Motory Pro pohon robota byly vybrány 2 stejnosměrné motory s převodovkou a enkodéry. Motory jsou na 12 V, jejich točivý moment je 1,5 kg/cm a maximální výkon mají 4,22 W. 1.2.3 Netbook Na soutěž nám byl zapůjčen od školy netbook s následujícími parametry: Intel Atom N570 Dual Core, 10" LED CB 1024x600, RAM 1GB, HDD 320GB 5400 otáček, WiFi, webkamera, 6-článková baterie, Windows 7 1.2.4 Kamera Byla zvolena kamera určená pro Playstation3 (PS3 EYE). Při rozlišení 320x240 pixelů zvládá pořizovat 120 snímků za sekundu. 1.2.5 Senzory Pro pohyb robota se využívaly 4 infračervené senzory vzdálenosti s rozsahem 1080 cm. Dva z nich byly umístěny napevno v zadní části robota, kde směřovaly kolmo ke stěně. Další dva byly umístěny na servech, které je natáčely do různých směrů, podle potřeby. Dále byly na robota umístěny taktilní senzory, na které robot reagoval buď natáčením od místa nárazu, nebo přímo couvnutím. 1.2.6 DPS Desky, na kterých byly elektronické součástky potřebné pro chod robota, jsme si vyrobili vlastnoručně. Některé pomocí metody nažehlování toneru a některé fotocestou. Všechny byly jednostranné, jen nejsložitější z nich měla pár drátových propojek.
7
1.2.7 Uchopovací mechanizmus Uchopovací mechanizmus byl navržen ve SketchUpu a vytištěn na 3D tiskárně.
Obr. 1 Návrh v programu SketchUp
8
1.2.8
Finální podoba robota
Obr. 2 Finální podoba robota před soutěží
1.3 Elektronika Řídicí systém robota tvoří netbook s následujícími parametry:
Mini notebook - Intel Atom N570 Dual Core, 10" LED CB 1024x600, RAM 1GB, HDD 320GB 5400 otáček, WiFi, webkamera, 6-článková baterie Elektronika robota se skládá ze čtyř hlavních desek, každá po jednom mikrokontroléru: I2CBridge ,DriveBoard, SenzorBoard, SenzorBoard2. Netbook komunikuje prostřednictvím redukce USB↔RS232 a převodníkem napěťových úrovní (MAX232) s deskou I2CBridge, která přeposílá pakety požadované desce (podle adresy) přes I2C sběrnici. O řízení motorů se stará deska DriveBoard. Přes čtyři vodiče plus napájení spíná dva H-můstky připojené na motory. Pro regulaci výkonu využívá pulzně šířkovou modulaci (PWM). Tento signál je vytvořen pomocí dvou PWM kanálů mikrokontroléru. Informaci o natočení (resp. rychlosti otáčení) dávají kvadraturní enkodéry na každém z motoru. Ty jsou připojeny na vstupy externího přerušení mikrokontroléru. Každý „tik“ enkodéru tedy vyvolá přerušení. Pro získání dat ze senzorů slouží dvě „senzorové“ desky. Na tyto desky jsou připojena serva jednak pro natáčení předních IR senzorů, jednak pro mechaniku radlice. K jejich řízení je využito PWM kanálů mikrokontrolérů. Na digitální vstupy mají tyto dvě desky připojená taktilní čidla a na vstupy A/D převodníku infračervené senzory. Jeden kanál A/D převodníku je využit pro měření proudu do serva radlice. 9
Měření proudu do serva radlice bylo potřeba kvůli zpětné kontrole nad stiskem. Toto měření je realizováno pomocí bočníku, jehož úbytek napětí je zesílen operačním zesilovačem a přiveden na A/D vstup. Blokové schéma celé elektroniky je uvedeno na Obr. 3.
10
11 Obr. 3 Blokové schéma elektroniky
Blokové schéma napájení je uvedeno na Obr. 4. Spouštěcí deska funguje jako monostabilní klopný obvod s relé. Dva monolitické pětivoltové stabilizátory jsou připevněny k hliníkovému rámu konstrukce, což zajišťuje dostatečné chlazení. Napájení je rozděleno do dvou větví, aby se předešlo rušení řídící elektroniky vlivem odběru serv.
Obr. 4 Blokové schéma napájecí části
12
2 Software 2.1 Úvod Na netbooku běží operační systém Windows 7. Řízení celého robota obstarává program psaný v Javě s grafickým uživatelským rozhraním, ten dostává informace o obrazu od externího programu napsaného v C++, využívající knihovnu OpenCV. Ladění probíhalo tak, že jsme propojovali vlastní notebooky s Krytonem přes Wi-Fi (program TeamViewer), ovládali GUI a nahrávali nové verze programů. Pro zjednodušení spouštěcího procesu, tedy spuštění dvou programů, jejich konzolí a zarovnání oken do požadovaných pozic, jsme napsali několik bat souborů. Procesory na jednotlivých deskách mají programy napsané v C.
2.2 Procesory 2.2.1 Komunikace Netbook komunikuje prostřednictvím redukce USB↔RS232 a převodníkem napěťových úrovní (MAX232) s deskou I2CBridge, která přeposílá pakety (jsou bufferovány) požadované desce - podle adresy- přes I2C sběrnici. Při čtení dat se nejprve odešle příkaz na I2CBridge, který obsahuje ID desky, ze které se má číst. I2CBridge tyto požadavky střádá v bufferu a postupně vyvolává přenosy na I2C sběrnici a čte data z požadované desky. Po načtení a ověření celého paketu se provede odeslání přes USART do netbooku. 2.2.2 Zápis: Formát pro I2C Bridge (přes UART): 1. START byte 2. ADRESA+W 3. POC_DAT 4. DATA I2C Bridge přepošle na ADRESU 1. DATA Na konci dat je checksum - ten se počítá z celých DATA a z POC_DAT 2.2.3 Čtení: Formát pro I2C Bridge (přes UART): 1. START byte 2. ADRESA+R 3. POC_DAT - jen pokud se nepoužije vlastní formát dat, jinak 0 I2C Bridge načte data z ADRESY a pošle je přes UART 1. START 2. POC_DAT 3. DATA DATA mají na začátku ADRESU (od koho jde)
13
2.2.4 Formát I2C DAT pro vlastní desky: Byte| 2xbyte - 2xbyte ….| Byte Na začátku ID Uprostřed wordy Na konci checksum "W+Driverdeska - natočit- (90°,90°/s)" "W+Driverdeska - jet - (400cm,50cm/s)" Před posláním je přičteno k číslu 32768, aby se mohla posílat kladná i záporná čísla. 2xByte -> +/- 32768 65535=32767 .. 32769=1 32768=0 32767=-1 .. 0=-32768 Při čtení ze slave se odešle fronta připravená předchozím příkazem. 2.2.5 PID regulace Motory jsou řízeny pomocí PWM o frekvenci cca 300Hz a zpětnou informaci dávají kvadraturní enkodéry. Na mikrokontroléru desky DriveBoard běží dva nezávislé číslicové PID regulátory. Níže je uvedena rovnice pro výpočet výstupního výkonu jednoho motoru. out = (Kp·err - Kd·(last_err-err) + Ki·integ_err)·Ko; out – výstup pro pwm kanál (po normalizaci) err – rozdíl požadované a skutečné rychlosti last_err – předchozí hodnota err integ_err – integrace proměnné err za čas Kp – proporcionální konstanta Kd – derivační konstanta Ki – integrační konstanta Ko – konstanta pro normalizaci pro výstup
2.2.6 Skenování U senzorových desek je implementována funkce skenování, která funguje tak, že se servo se senzorem cyklicky otáčí o malý úhel a měří se hodnota ze senzoru. Tím je získáno pole dat, které při rozložení po kružnici dává prostorové rozmístění překážek. Tato funkce nebyla při soutěži použita pro svojí nízkou rychlost.
14
2.3 Řídící program V níže uvedené tabulce je seznam a krátký popis tříd v řídícím programu. Tabulka 1 Seznam tříd
KrytonwareApp
Základní třída
KrytonwareView
Třída uživatelských událostí
Main
Hlavní třída, zde probíhá smyčka
cComdriver
Pro posílání zpráv přes COM
cDrive
Řízení podvozku
cPath
Cesta složená z xy bodů, plánování cesty
cSekvence
Posloupnost akcí - natočit, jet rovně
SocketServer
Třída pro komunikaci s OpenCV přes sokety
cMedved
Reprezentace medvěda
cPaket
Jeden paket odesílaný deskám
cSenzor
Uchovává údaje ze senzorů
MapBox
Okno pro zobrazení mapy a cest
SenzorBox
Okno pro vizualizaci dat
FitnessComparator, Pomocné třídy pro hledání cesty ve ArrayListFitness spojitém prostoru
Program obsahuje algoritmus pro nalezení cesty ve spojitém prostoru. Byl použit genetický algoritmus popsaný v [1]. Tento algoritmus se uplatnil v soutěži pouze pro návrat na rozhledovou pozici po sebrání medvěda. Cesta je reprezentována posloupností bodů, takováto forma je předána třídě cSekvence, která ji převede na posloupnost akcí pro podvozek (např.: rovně 20cm, otoč do leva o 45°,rovně 40cm atd..) Diagram na Obr. 5 popisuje použitou strategii. Jedná se tedy o stavový sekvenční automat. Kombinace sledování stěny a pevných pravidel a opravných mechanizmů zaručila velkou robustnost celého systému. Pokud se některý taktilní senzor dotkne překážky v průběhu vykonávání libovolné akce, robot vykoná opravnou sekvenci odpovídající poloze daného taktilního senzoru (např.: Pokud robot narazí levou částí, provede rotaci o pár stupňů doprava).
15
Obr. 5 Diagram popisující použitou strategii na soutěži
16
2.4 Zpracování obrazu Pro zpracování obrazu z kamery se využívá opensourcové knihovny OpenCV. K robustnosti programu byly parametry většiny funkcí konfigurovatelné za běhu programu, pomocí kláves a posuvníků na obrazovce. Základním prvkem pro vyhledání medvěda bylo nalezení největší plochy daného rozmezí barev. Po získání obrazu z kamery se snímek převedl do HSV prostoru barev, kde první hodnota určuje barvu, druhá její sytost a třetí její smíchání s bílou barvou. Pomocí vestavěného filtru v knihovně OpenCV se odfiltrovaly veškeré barvy, které se nevešly do nastaveného rozmezí. Na zbytku obrazu se hledaly takzvané bloby zbylých barev. Odstranily se ty, které byly spojené s postranními okraji obrazu, kvůli případům, kdy robot byl blízko kraje arény a viděl přes ni. Ve zbytku blobů se našel největší z nich, kterým byl medvěd. Okolo vybraného blobu se udělala obdélníková obálka, jejíž počátek a rozměry byly předány řídícímu programu, který podle nich navigoval robota k medvědovi. Další funkce, která byla implementována a připravena k použití, byla detekce hran. V OpenCV nazývaná canny. Celý obraz se převedl do odstínů šedi a hledaly se jednotlivé hrany, které se pak kopírovaly zpět do obrazu z kamery ještě před vyhledáváním blobů. Tato funkce by byla užitečná pro oddělení podobných barev. Na soutěži bylo využito možnosti přípravy, kdy jsme stihli nastavit rozmezí barev, které plyšový medvěd obsahoval. Proto nebylo třeba funkce detekce hran objektů, která by vyhledání medvěda zpomalila, a bylo by nutné snížit rozlišení zpracovávaného obrazu.
17
3 Shrnutí Do naší kategorie se přihlásilo 13 týmů, z toho se 9 skutečně zúčastnilo. Průběh soutěže byl následující: nejprve se konaly 4 kvalifikační jízdy, které Kryton všechny úspěšně absolvoval (jako jediný). Poloha a typ medvěda se s každým kolem měnily. Časy jednotlivých pokusů jsou zde, zleva od prvního: 1:23.75 2:18.82 1:22.72 0:51:91 Z 9 soutěžících robotů se pouze třem, včetně nás, podařilo medvěda sebrat a dovézt zpátky na start. Zbývající dva soupeři měli nejlepší časy 0:59.94 a 1:04.59. Oba soupeřící roboti používali strategii napevno dané dráhy a senzorů na krátkou vzdálenost, nevyhledávali medvěda aktivně. My jsme pro každého medvěda uložili do programu pro rozpoznávání obrazu profil, který definoval rozmezí barev, jež má registrovat. Při každém odstartování jsme pak jen zvolili profil podle toho, jakého medvěda nám rozhodčí dal na hřiště. V třetím pokusu byl malinký medvěd umístěn do rohu hřiště, těsně ke stěně. K našemu velkému překvapení i takto umístěného medvěda dokázal Kryton sebrat. Žádný ze soupeřů medvěda z rohu nedostal. Do finále tedy postoupili 3 roboti. Finále se skládalo ze 3 zápasů, každý s každým. Tyto finálové zápasy probíhaly tak, že dva roboti odstartovali zároveň každý na své dráze a který dovezl medvěda na start dříve, vyhrál. První finálový zápas se nám povedl, medvěd byl na relativně vhodné pozici, Kryton ho zaregistroval rychle a sebrání se povedlo na první pokus. Do cíle dojel o pouhé 2 sekundy před soupeřem, v čase 49,7 s. Druhý finálový zápas jsme dostali na dráhu medvěda s červeným tričkem, takže jsme museli rychle přenastavit barvu, kterou bude Kryton považovat za medvěda. Nastavili jsme, aby Kryton bral právě barvu červeného trička. Po dojetí na místo rozhledu se vydal směrem k medvědovi. Po přiblížení robot vrhl stín na medvěda, tím se změnila detekovaná barva, která byla mimo nastavené rozmezí. Kryton strčil do medvěda a ten se povalil na bok. Kryton pak neviděl na barevné tričko a tím pádem jezdil dokola bez úspěchu, bylo to tedy naší chybou, měli jsme zvolit buď větší toleranci barev, nebo nastavit barvu samotného medvěda. Druhý finálový zápas tedy vyhrál soupeř. Nakonec hráli dva soupeři mezi sebou. Výsledkem bylo, že každý finalista měl po jednom bodu, tedy remíza. Organizátoři se rozhodli, že se nebudou konat další zápasy, ale rozhodne se podle nejrychlejšího času z finálových kol. Náš robot měl nejrychlejší čas – 49,7 s a byli jsme vyhlášeni vítězi. Fakt, že u programu pro rozpoznání obrazu byla možnost rychle měnit nastavení, se ve výsledku velmi osvědčil. Stejně tak i robustnost algoritmu – antikolizní systém a opravné sekvence, při špatném sebrání opakované sebrání medvěda – nám zaručila úspěch.
4 Závěr Navrhli a zkonstruovali jsme autonomního robota pro výše uvedenou mezinárodní soutěž pořádanou v rámci robotického dne, které jsme se následně zúčastnili. Obsadili jsme 1. místo v nejnáročnější kategorii. Postup a vývoj práce na robotu byl námi dvakrát prezentován v Robotickém klubu na naší škole, a také byla uskutečněna krátká ukázka na soutěži Kyberrobot konané též na naší škole. O našem robotu a o nás vyšly články na zpravodajských webech idnes [4] a t-uni[5]. Též jsme vystupovali v pořadu PORT na ČT2[6].
18
5 Literatura [1]DVOŘÁK, J.; KRČEK, P; 2010. AUTONOMOUS LOCOMOTIVE ROBOT PATH PLANNING ON THE BASIS OF MACHINE LEARNING, DISSERTATION THESIS, BRNO UNIVERSITY OF TECHNOLOGY [2]Larry Barello's Home Page: AVR and Robotics. [online]. [cit. 2012-05-16]. Dostupné z: http://www.barello.net/index.htm [3]Bob Blick: Projects / H-Bridge. [online]. [cit. 2012-05-16]. Dostupné z: http://www.bobblick.com/techref/projects/hbridge/hbridge.html [4]Miloš Zajíc. [online]. [cit. 2012-05-16]. Dostupné z: http://www.zajic.cz/menic/menic.htm
6 Reference [4]http://technet.idnes.cz/zavody-robotu-0f5/tec_technika.aspx?c=A120428_225302_tec_technika_top [5]http://tuni.tul.cz/clanek/5938/ [6]http://www.ceskatelevize.cz/porady/10121359557-port/794-roboty-soutezici-ipracujici/
19