This is an old revision of the document!
Liikurrobot (mobiilne robot) on üks tüüpilisemaid roboteid, mida soovitakse ehitada. Väga populaarsed on sumorobotid, mängurobotid (jalgpall, võrkpall jms.), päästeoperatsioone simuleerivad (tuletõrje, isiku või objekti leidmine jms.) robotid ja mitmed muud. Sellistele robotitele korraldatakse maailmas ja ka Eestis mitmeid erinevaid võistlusi ja on isegi kujunenud välja standardklassid (näiteks sumorobotid). Kõigi seda tüüpi robotite ühiseks jooneks on tavaliselt liikuv platvorm, mis võib olla küll erineva konstruktsiooni ja võimekusega, kuid oma baasfunktsionaalsuselt jääb samaks. Selleks baasfunktsionaalsuseks on eelkõige mootorite juhtimine ja baasnavigeerimine, mis hõlmab endas objektidest eemalhoidmist ja soovitud sihtkohta sõitmist. Baasfunktsionaalsusele lisandub tavaliselt ülesande spetsiifiline funktsionaalsus, mis projekteeritakse lähtuvalt projektile esitatavatest nõuetest ja võimalustest.
Alljärgnevalt vaatame ühte tüüpilist liikurroboti platvormi projekti ja selle projekteerimise erinevaid etappe.
Projekteerida ja valmistada Kodulabori komponentide baasil multifunktsionaalne liikurroboti platvorm koos baasnavigatsiooni funktsionaalsusega. Robotplatvorm peab võimaldama lihtsalt muuta tema operatiivfunktsionaalsust, varustades teda erinevate seadmetega:
Robot peab olema võimeline liikuma tasasel pinnal sisetingimustes.
Süsteemi üldine mudel on esitatud plokkdiagrammidena. Süsteemi mudel kirjeldab süsteemi struktuuri, käitumist jt. olulisi aspekte. Alljärgnevalt on näiteks toodud süsteemi struktuuri üldine hierarhiline mudel.
Antud ülesande lahenduseks kasutas meeskond ajurünnaku metoodikat ja genereeris 3 põhimõtteliselt erinevat lahendust. Koostati hindamismaatriks, mille abil leiti optimaalseim konstruktsioon. Lahenduste põhiline erinevus seisnes erinevates liikumisskeemides.
Lihtsustatud hindamismaatriks oli järgmine:
Funktsioon/Lahendus | I | II | III | Kaalutegur |
---|---|---|---|---|
Maksumus | 3 | 4 | 6 | 0,8 |
Valmistamise keerukus | 2 | 4 | 7 | 0,7 |
Manööverdamisvõime | 4 | 8 | 8 | 0,5 |
Läbivus | 5 | 8 | 2 | 0,3 |
Kodulabori rakendatavus | 5 | 4 | 5 | 0,9 |
Kaal | 5 | 6 | 7 | 0,8 |
Kokku (koos kaaluteguriga) | 19 | 27 | 28 |
Hindamisskaala oli 1-10 punkti ja kaalutegur 0-1. Kaalutegurid olid valitud lähtuvalt süsteemile esitatud nõuetest ja piirangutest. Kuigi näiteks lahendus 2 oli oluliselt võimekam raskel maastikul liikumisel, ei olnud seda lähteülesandes nõutud ja vastava funktsionaalsuse kaalutegur oli sellest tulenevalt madal.
Hindamise tulemusena osutus antud ülesande optimaalseimaks lahenduseks ratastel liikuv kahe eraldi mootoriga platvorm. Edasine töö jätkus valitud lahenduse edasiarendusega reaalseks süsteemiks.
Mehaanika püüti valmistada võimalikult lihtne, järgides samal ajal modulaarsuse põhimõtet. Esimene ja tagumine põrkeraud on identsed moodulid. Elektroonika osas on kasutatud kolme moodulit, mis on paigutatud üksteise peale, võimaldades nii lihtsaid ribakaabelühendusi ja tagades samal ajal moodulite suhteliselt lihtsa vahetatavuse. Mootoriteks on valitud Kodulabori komplektis olevad integreeritud reduktori ja koodriga mootorid, mis on ühendatud otse mootorite ajurplaadiga. Ratasteks on kasutatud mudellennuki rattaid, mis on väga kerged ja piisavalt tugevad antud roboti jaoks. Valmistamise lihtsuse huvides on roboti alusplaat ja pealmine plaat identsed. Plaadid on varustatud avadega, võimaldades nii pealmisele plaadile kinnitada erinevaid seadmeid. Kahe plaadi vahele mahub lisaks elektroonikamoodulitele ka aku.
Eraldi on projekteeritud roboti põrkeraud, mis on integreeritud puute- ja joonejälgimise anduritega. Põrkerauad on valmistatud trükiplaatidest, omades lisaks konstruktsioonile ka elektriühendusi. Joonejälgimise andurid on joodetud otse põrkeraua alumisele plaadile. Puuteandurid (mikrolülitid) on paigutatud kahe põrkeraua plaadi vahele ja eestpoolt kaetud ühtse kummiribaga. Kummiriba summutab põrkejõudu ja võimaldab samal ajal täpsemalt tuvastada, mis suunalt löök tuli.
Süsteemi elektroonika on kirjeldatud põhimõttelahendusena ja klassikalise elektriskeemina koos trükiplaadi pildiga.
Näitena on toodud roboti põrkeraua joonejälgimise andurite elektroonika skeem ja vastav trükiplaadi (PCB) skeem.
Roboti juhtimine tuleneb süsteemi käitumismudelist ja on määratud lähteülesande funktsionaalsusega ning nõuete ja piirangutega. Süsteemi käitumismudelist luuakse täpsustatud juhtprogrammi algoritm, millest omakorda lähtutakse tarkvara programmikoodi koostamisel. Kõik kolm taset (käitumismudel-algoritm-lähtekood) peavad olema omavahel kooskõlas.
Algoritm kirjeldab süsteemi juhtloogikat ja on esitatud plokkdiagrammina. Lihtsama algoritmi koostamiseks piisab paarist elemendist ja nendevaheliste seoste kirjeldamisest. Kui roboti algoritm on koostatud korrektselt, siis on sellest roboti juhtprogrammi suhteliselt lihtne koostada. Algoritmis on kasutatud põhiliselt kahte erinevat objekti: ümardatud nurkadega ristkülik tähistab mingit tegevust, väike romb mingi tingimuse kontrollimist ja vastavalt kontrolli tulemusena järgneb edasiste tegevuste käivitamine.
Algoritmis kasutatud tähiste tähendused:
Tähis | Tähendus | 0 | 1 | -1 |
---|---|---|---|---|
M0 | parem mootor | seisab | pöörleb päripäeva | pöörleb vastupäeva |
M1 | vasak mootor | seisab | pöörleb päripäeva | pöörleb vastupäeva |
F | esimene keskmine puuteandur | signaal puudub | signaal olemas | |
FR | esimene parem puuteandur | signaal puudub | signaal olemas | |
FL | esimene vasak puuteandur | signaal puudub | signaal olemas |
Lihtne navigeerimine
#include <homelab/module/motors.h> #include <homelab/pin.h> #include <homelab/delay.h> // Põrkeandurite viikude defineerimine pin front = PIN(C, 0); pin frontleft = PIN(C, 1); pin frontright = PIN(C, 2); // // Põhiprogramm // int main(void) { // Mootorite 0 ja 1 algseadistamine dcmotor_init(0); dcmotor_init(1); // Lõputu tsükkel while (true) { // Mootorite päripäeva käivitamine dcmotor_drive(0, 1); dcmotor_drive(1, 1); // Esimeste puuteandurite signaalide kontroll if (pin_get_value(front) || pin_get_value(frontleft) || pin_get_value(frontright)) { // Keskmise anduri signaali kontroll if (pin_get_value(front)) { // Mootorite reverseerimine dcmotor_drive(0, -1); dcmotor_drive(1, -1); // Paus 1 sekund sw_delay_ms(1000); // Vasaku mootori päripäeva käivitamine dcmotor_drive(1, 1); } // Vasaku anduri signaali kontroll else if (pin_get_value(frontleft)) { // Vasaku mootori päripäeva käivitamine dcmotor_drive(1, 1); } else { // Parema mootori vastupäeva käivitamine // Vasaku mootori päripäeva käivitamine dcmotor_drive(0, -1); dcmotor_drive(1, 1); } // Paus 2 sekundit sw_delay_ms(2000); } } }
Projekti raames valminud robotplatvorm on valmistatud üldjoontes plastikust, välja arvatud mootori kinnitused, mis on valmistatud alumiiniumprofiilist. Elektroonikamoodulid on paigutatud üksteise peale, aku on lahtiselt kahe plaadi vahel. Põrkerauad on valmistatud trükkplaadist ja värvitud mustaks. Roboti pealmine plaat on täiesti sile, võimaldades sinna kinnitada erinevaid soovitud seadmeid. Projekti raames paigaldati robotplatvormile lihtne radar, mis koosnes väikesest RC servomootorist ja infrapunaandurist. Teiseks seadmeks katsetati standardmanipulaatoreid, mille lülisid juhitakse samuti standardsete RC servodega. Mõlemad variandid on näidatud allolevatel piltidel.
Majanduslik kalkulatsioon hõlmab endas komponentide maksumust ja roboti detailide valmistamise ning koostamise kulusid.
Komponentide maksumuse tabel
Komponent | Mark | Kogus | Hind | Maksumus |
---|---|---|---|---|
Mootor | M LE149.6.43 | 2 | 500.- | 1000.- |
Mikrokontroller | uC ATmega128 | 1 | 900.- | 900.- |
Mootorite juhtplaat | Actuator Board v1.2 | 1 | 700.- | 700.- |
Toiteplaat | TP | 1 | 500.- | 500.- |
Joonejälgimise andurid | LFS QRD1114 | 8 | 30.- | 240.- |
TS Microswitch | Puuteandurid | 8 | 25.- | 150.- |
Kere plaat | ABS | 4 | 50.- | 200.- |
Trükiplaadi toorik | 2 | 50.- | 100.- | |
Mootorikinnituse profiil | Al-L | 2 | 10.- | 20.- |
Ratas | 60/10 mm | 2 | 30.- | 60.- |
Aku | NI-MH 9,6 V | 1 | 350.- | 350.- |
Erinevad kaablid | 10 | 20.- | 200.- | |
Mutrid poldid | 1 | 50.- | 50.- | |
Muud tarvikud | 1 | 100.- | 100.- | |
Kokku | 4570.- |
Hinnanguline tööjõu- ja tootmiskulu üksikeksemplari korral.
Töö | Aeg (h) | Hind | Maksumus |
---|---|---|---|
Konstruktsioonidetailide freesimine | 1 | 300.- | 300.- |
Trükiplaatide (põrkerauad) freesimine | 0,5 | 500.- | 250.- |
Roboti konstruktsiooni koostamine | 0,5 | 250.- | 125.- |
Põrkeraudade koostamine (komponentide jootmine) | 1 | 300.- | 300.- |
Programmeerimine | 5 | 300.- | 1500.- |
Dokumentatsiooni koostamine | 3 | 250.- | 750.- |
Kokku | 11 | 3225.- |
Roboti hinnanguline maksumus kokku 7795.-
Arvutatud roboti maksumus on siiski hinnanguline, kuna tegemist on õppeotstarbelise projektiga, kus enamik tööd ja koostamist on tehtud oluliselt suuremas mahus, kuid otsese rahalise tasuta. Seetõttu on töö- ja ajakulu ligikaudne ja ei kajasta tegelikku olukorda.
Mehhatroonikasüsteem (Robot) on loodud meeskonnatööna ja kindla ajakava ning eelarvega, omades seega enamuse olulisi projekti tunnuseid. Projektijuhtimise seisukohalt olid olulised tegevused: aja planeerimine, meeskonnatöö planeerimine ja juhtimine, eelarve jälgimine ja vahendite hankimine, jooksev aruandlus juhendajale, lõpptulemuse presentatsioon ja dokumenteerimine. Projekti aruandele lisatakse töögruppide koosolekute protokollid, projekti plaan (soovitavalt Gantti diagrammina), ressursijaotus (k.a. inimressurss) ja planeeritud ning tegelik eelarve. Näiteks on toodud lihtne tegevuste plaan Gantti diagrammina.
Majanduslik kalkulatsioon näitas meile, et roboti tootmishind on üsna kõrge, eriti kui tegemist on ainueksemplariga, kuid jäi siiski lähteülesandes etteantud piiridesse. Tootmise hinda saaks kindlasti oluliselt alandada, optimeerides komponentide ja materjalikulu ning tootes korraga suurema koguse roboteid. Projekti käigus tutvusime mehhatroonikasüsteemi projekteerimise, valmistamise ja testimisega, mis andis meile esmakordse sellelaadse kogemuse.
Töö lõpus selgus tõsiasi, et roboti korralikuks töötamiseks on vaja oluliselt rohkem aega planeerida testimisele, seda eriti tarkvara osas. Erinevad moodulid ei pruugi alati koos korrektselt töötada, kuigi eraldi katsetades oli kõik korras. See näitab, et süsteemi moodulite integreerimine on tõsine väljakutse ja selleks tuleb planeerida oluliselt rohkem aega ja ressurssi.
Kokkuvõteks arvame, et projekt oli väga huvitav ja hariv ning andis aimu integreeritud süsteemide projekteerimisest ja valmistamisest.