Arvutinägemine

Allikas: Vikipeedia
Arvutinägemist kasutatakse igapäevaelus inimeste töö lihtsustamiseks

Arvutinägemine on teadusharu, mis üritab anda arvutile inimese omaga sarnase või kohati paremagi nägemisvõime. Arvutinägemine on eelkõige huvitatud pildil oleva info automaatse eraldamisega muust, konkreetse ülesande jaoks kasutust infost ning kättesaadud info analüüsimisest. Arvutinägemise puhul kasutatakse nii staatilisi ühekordseid pilte kui ka videolõike või reaalajas sissetulevat videomaterjali, mille abil üritatakse arvutile anda võime efektiivselt tajuda, analüüsida ning mõista visuaalseid andmeid.[1][2]

Arvutinägemist võib käsitleda kui inverteeritud versiooni arvutigraafikast. Kui arvutigraafika puhul loob inimene arvuti abil stseeni, teades, mida stseeni soovitakse ning mis omadused erinevatel objektidel on, siis arvutinägemise puhul on ette antud stseen ning tuleb piiratud infokogusest tuletada objektide kirjeldusi ning omadusi.[3]

Tehisnägemine[muuda | muuda lähteteksti]

Inimesele nähtav valgus on vaid väike osa kogu elektromagnetilisest spektrist

Arvutinägemise süsteemid üritavad emuleerida inimese silma ja aju koostööd ning kohati on võimalik arvutil inimese võimetest ka üle olla.[4] Tehislikel süsteemidel on võimalik kasutada palju enam erinevaid andureid kui on inimesel. Inimesele nähtav valgus on vaid väike osa kogu elektromagnetilisest spektrist, mida on elektrooniliselt vähemalt teoreetiliselt võimalik mõõta. Kui inimese puhul on eelkõige infoallikaks meile harjumuspärane värvi- ning tänu kahele silmale ka sügavusinfo, siis masinatel on lisaks tavapärasele kaamerale kasutada muuhulgas näiteks soojus- või kiirgusandureid. Seeläbi on masinatel võimalik mõõta ning kujutada palju suurem kogus infot, mis jääks inimvaatlejale nähtamatuks. Kõige levinumaks näiteks selles vallas oleks lisaks soojusinfole röntgenpilt. Arvutinägemine on äärmiselt lai teema, mille alla kuulub kõik, mida arvutil on võimalik lahendada „vaatamise“ teel. Selle alla kuuluvad muuhulgas teemad nagu pildi taastamine, pildikvaliteedi tõstmine, automaatne visuaalne inspektsioon, robotnägemine, arvutil põhinev kolmedimensioonilise stseeni mõistmine.[1]

Probleemid[muuda | muuda lähteteksti]

Bioloogiline- ja tehisnägemine[muuda | muuda lähteteksti]

Inimestena on visuaalne info meie jaoks kõige suurem infoallikas ning selle töötlemine meie peas paistab toimuvat lihtsasti ning hetkega. Vaadates näiteks kapil asuvat vaasi lilledega ei paku meile mingisugust väljakutset kapi, vaasi ega lillede tuvastamine. Me saame lihtsasti ja intuitiivselt aru, milline osa meie vaateväljast on lilled, milline osa vaas ning milline kapp. Raskust ei paku ka see, kui toas on mitmeid erineva eredusega valgusteid ning vaas on näiteks läbipaistev. Me saame aru, mis värvi on lill erinevates valgustingimustes ning võime lihtsasti kokku lugeda lillede arvu vaasis ning ennustada, mis juhtuks lillede või vaasiga näiteks maha kukkudes. Me saame hetkega intuitiivse arusaama objektidest ning nende omadustest ilma selleks eriliselt pingutamata. Sellise ülesande lihtsus meie jaoks paneb meid alahindama sellise süsteemi tegelikku keerukust, mida üritatakse arvutinägemise puhul jäljendada.[3]

Probleemid sensorite ja kogutud infoga[muuda | muuda lähteteksti]

Arvutisüsteemides taandub igasugune info binaarsele kujule ning sellest ei pääse ka visuaalsete andmete kogumisel. Kaamera kui elektrooniline süsteem on alati piirangutega. Piiranguteks võib olla näiteks eraldusvõime ehk kogus piksleid, mille abil kaamera esitab tehtud pilti. Päris maailmas ei ole teadupärast pikslitelaadset diskreetset süsteemi ning üks piksel kaamera puhul hoiab endas tegelikult keskmist pildisensorile jõudnud valgusest. Kui elektroonilised süsteemid on nii-öelda astmelised (diskreetselt), siis reaalses maailmas toimuvad protsessid on pidevad ehk sujuvad. Tihtipeale ongi arvutinägemise sisuks kadumaläinud informatsiooni taastamine[1].

Lisaks reaalse valgusinfo muundumisega tuleb arvestada veel lisaks ka sügavusinfo kadumisega. Et pikslid sisaldavad mustvalge pildi puhul ühte värvikanalit väärtustega 0–255 ning värvilise pildi puhul kolme värvikanalit samade väärtustega[5], siis ei ole võimalik pikslite infost üksinda taastada kolmedimensioonilist stseeni. Küll aga on sügavusinfot võimalik taastada stereokaamera abil, mis sisaldab kahte täpselt kalibreeritud kaamerat ning millest sügavusinfo eraldamine toimub analoogselt bioloogilise nägemissüsteemiga.

Samuti on jätkuvalt mureks ka sensoritel tekkiv müra, mis annab mingisugusele osale kogutud infost teistsuguse väärtuse kui see reaalsuses oli. Müra võib väljenduda kui vale värvi või heleduse info ning põhjustada kasutatavates algoritmides segadust või vale-positiive ja vale-negatiive.[6]

Probleemid saadud info tõlgendamisega[muuda | muuda lähteteksti]

Arvutinägemise kõige põhilisemad probleemid on seotud sensoritelt saadud info tõlgendamisega. Suureks probleemiks on näitseks stseenis kasutatud valgustus. Olenevalt valgustuse kogusest, asukohast ja temperatuurist võib üks ja sama objekt arvuti jaoks välja näha sootuks erinevalt. Üks ja sama objekt võib omada väga palju erinevaid väljanägemisi olenevalt sellest, mis nurga alt või kui suures koguses talle valgust peale paistab. Lisaks sellele muudab valguse temperatuur väga oluliselt kogu stseeni värviinfot. Külma valguse puhul saab näiteks inimese nahk küllaltki tugeva sinise tooni ning ei pruugi enam arvuti poolt olla tuvastatav nahatoonina. Just seoses valgustuse probleemidega on arvutinägemine kõige efektiivsem kontrollitud tingimustes. Siiski on tehtud edusamme valgustusega seonduvate probleemide lahendamisega, näiteks on laialdaselt kasutust leidnud Gabori lained, mis võimaldavad minimeerida valgustuse mõjud objektile[7].

Sarnaselt valgusega on probleemiks ka vaadeldava objekti poos. Näiteks ei näe tool kõrvaltvaates välja samasugune nagu see on eest- või ülevaltvaates. Seepärast ei ole võimalik tooli pildil lihtsalt ära tunda, vaid tuleb leida tooli matemaatiline esitus ehk numbrilisel kujul see, mis teeb ühest toolist tooli. Samal ajal tuleb meeles pidada, et maailmas on väga palju väga erinevaid toole. Tihtipeale ei ole mõistlik või võimalik inimesel sellist universaalset matemaatilist esitust tuletada ning appi võetakse masinõppe algoritmid, mis leiavad sellise esituse iseenesest.

Nägemise tasemed[muuda | muuda lähteteksti]

Künnisfilter – madalatasemelise nägemise meetod

Arvutinägemise võib ülesannete ning keerukuse järgi jagada tasanditeks. Igal tasand pakub uusi võimalusi ja keerukamaid meetodeid. Kõrgemad tasandid toimetavad enamasti madalamate tasandite meetodite poolt saadud infot.

Madalatasemeline nägemine[muuda | muuda lähteteksti]

Madalatasemeline nägemine hõlmab meetodeid, mis on kogu arvutinägemise alustaladeks ning selle eesmärk on töödelda pilt järgmistele tasemetele kasutatavamaks. Eesmärgiks on maksimeerida kasuliku info hulk ning minimeerida kasutu info. See on kõige põhilisem tasand, ilma milleta on võimatu lahendada keerulisemaid probleeme. Madala taseme operatsioonide hulka kuuluvad näiteks pilditüüpide teisendamine must-valgeks või binaarseks, müra vähendamine, ääretuvastus ja nurgatuvastus. Lisaks kuuluvad selle alla veel pikseloperatsioonid nagu kopeerimine, inverteerimine, künnisfilter (ingl thresholding). Künnisfiltri puhul on tegu pildiinfo binaarseks muutmisega. Sellisel puhul on võimalikud, vaid kaks olekut – must ja valge. Meid huvitav info muundatakse künnisfiltris üheks ja kasutu info teiseks väärtuseks ning seetõttu on tegu ühe kõige kasulikuma filtriga arvutinägemises.

Nurgatuvastus – kesktaseme nägemise meetod

Kesktaseme nägemine[muuda | muuda lähteteksti]

Kesktaseme puhul on tegu juba keerukamate ülesannetega, mis hõlmavad madala taseme operatsioonide kasutamist. Kesktasemel ei olda niivõrd mures enam piksliinfo muutmisega või info leidmisega päris maailma kohta, vaid soovitakse saada pildi kohta abstraktset infot. Otsitavaks infoks võib olla näiteks huvipunktide või -objektide orientatsioon ja positsioon. Lisaks kuuluvad kesktasemele ka sellised funktsioonid, mis leiavad infot näiteks ringi või nelinurga olemasolu kohta pildil. Tüüpiliste meetodite hulka sellel tasandil kuuluvad kujutuvastus-, mustrituvastus-, joonetuvastusmeetodid.

Kõrgtaseme nägemine, 3D-nägemine[muuda | muuda lähteteksti]

Kõrgtaseme puhul on eesmärgiks saada infot päris maailmas toimuva kohta. Selle tasandi eesmärgiks oleks eelkõige sügavusinfo leidmine stereonägemist kasutades või taastamine ning liikumisinfo leidmine ja analüüs. Sellele tasandile jõuab üldiselt maksimaalselt töödeldud info, sest kõrgtasemelised algoritmid on tihti väga keerukad ning kulutavad suurte andmehulkade puhul väga palju aega.

Klassifitseerimine[muuda | muuda lähteteksti]

Tehisnägemise üheks haruks võib lugeda ka objektide klassifitseerimise, mille juures võetakse enamasti abiks masinõpe. Klassifitseerimine viiakse tavapäraselt läbi tehisnärvivõrkude, Support Vector Machine või mõne muu klassifitseerimisalgoritmi abil. Näiteks tehisnärvivõrkude puhul antakse algoritmile ette kogumik näiteid ning andmed näidete kohta, et algoritm saaks aru, milline on õige ja milline on vale näide. Algoritm käib andmed mitmekordselt läbi ning kohandab ennast iga korraga ning on piisava treeningmahu korral pärast võimeline uusi näiteid klassifitseerima. Selline operatsioon on aga väga ajakulukas, nõuab suurt andmebaasi näidetega ning ei ole sajaprotsendilise täpsusega. Siiski on olenevalt ülesandest võimalik saavutada tulemusi, mis konkureerivad inimestega või on inimestest juba natuke ees.

Kasutusalad[muuda | muuda lähteteksti]

Automaatne käekirjatuvastus: käsikirjalist teksti on arvutil võimalik suhteliselt lihtsasti lugeda ning teisendada tavaliseks trükitud tekstiks.

Automaatne tooteinspektsioon: masinnägemist kasutatakse väga laialdlaselt tööstuses toodete kvaliteedi kontrolliks ning tooteliinide juhtimiseks tänu arvuti võimele teha väga suur hulk tööd väga kiiresti ilma väsimata ning ühtlase kvaliteediga. Masin võib märgata olukordi, mida inimene ei pruugiks.

Automaatne sõiduki juhtimine: teadupärast on Google car üks esimesi täiesti ise sõitvaid autosid. Automaatne sõiduki juhtimine on äärmiselt keeruline probleem ning nõuab väga kõrgekvaliteedilist arusaamist sõidukit ümbritsevast maailmast. Kuigi ladudes on kaupade transpordiks kasutatud täisautomaatseid süsteeme juba ammu, on edukas ja turvaline auto juhtimine täiesti kontrollimatutes olukordades hüppeline edasiminek selles valdkonnas.

Turvatööstuses: inimesi, objekte ja nende liikumist on tänapäeval võimalik jälgida edukalt ka olukordades, kus inimesele oleks samasugune ülesanne üle jõu käiv. Samuti kasutatakse masinnägemist sõrmejälgede lugemisel ja võrdlemisel ning üritatakse lahendada ka töökindlat isiku identifitseerimise probleemi, kuid selles vallas on mitmete probleemide tõttu veel väga pikk maa minna.

Viited[muuda | muuda lähteteksti]

  1. 1,0 1,1 1,2 D. Vernon; Machine Vision : Automated Visual Inspection and Robot Vision, Prentice Hall, 1991, ISBN 0-13-543398-3.
  2. The British Machine Vision Association and Society for Pattern Recognition – What is computer vision? http://www.bmva.org/visionoverview
  3. 3,0 3,1 R. Szeliski; Computer Vision: Algorithms and Applications, Springer, 2011 edition, ISBN-13: 978-1848829343
  4. Microsof Research – Computer Vision, http://research.microsoft.com/en-us/research-areas/computer-vision.aspx
  5. Computer graphics – Pixel, http://graphics.wikia.com/wiki/Pixel
  6. Digital Camera Image Noise: Concept and Types, http://www.cambridgeincolour.com/tutorials/image-noise.htm
  7. W. Fellenz, J. Taylor, N. Tsapatsoulis, S. Kollias, Comparing template-based, feature-based and supervised classification of facial expressions from static images, Proceedings of Circuits, Systems, Communications and Computers (CSCC’99), Nugata, Japan, 1999, pp. 5331–5336.