Dirbtinis neuroninis tinklas

Dirbtinis neuroninis tinklas – informacijos apdorojimo struktūra, sudaryta iš tarpusavyje sujungtų dirbtinių neuronų. Šis modelis mėgdžioja žmogaus ir gyvūnų galvos smegenų darbą, neuronų veikimą.[1]

Dirbtiniai neuroniniai tinklai yra tam tikros struktūros matematinės funkcijos, kurios naudojamos kaip funkcijų aproksimatoriai. Tai reiškia, jog neuroniniam tinklui suteikiant pavyzdinę informaciją (funkcijos įvestį ir rezultatą), jis geba išmokti imituoti pavyzdinę funkciją.

Dirbtinis neuronas

redaguoti
 
Dirbtinio neurono schema

Dirbtinis neuronas – biologinio neurono abstrakcija, pagrindinis dirbtinių neuroninių tinklų komponentas.

Dirbtinis neuronas turi keletą įėjimo signalų (x0, x1, x2, …, xn), su jais susietus svorius (w0, w1, w2, …, wn) ir vieną išėjimo vertę (y). Dažniausiai išėjimo reikšmė skaičiuojama sudedant įėjimo verčių ir atitinkamų svorių sandaugas, ir pritaikant aktyvacijos funkciją. Neuroniniai tinklai tapo tinkami naudoti praktiškai, suradus efektyvius algoritmus šiems svorio koeficientams surasti.

Išėjimo reikšmė gaunama pagal formulę:

 

Koeficientai   vadinami įėjimų svoriais, o funkcija   – aktyvacijos funkcija.

Aktyvacijos funkcija yra būtina, nes be jos visas tinklas supaprastėja į tiesinę regresiją. Toks tinklas negali išmokti daugelio akivaizdžių užduočių, pavyzdžiui, pasakyti, ar dvi reikšmės lygios tarpusavyje. Sakoma, jog tinklas apribotas tik tiesiškai atskiriamomis (angl. lineraly separable) užduotimis – vien tuo, ką ir tiesinė regresija gali padaryti.

Dažni aktyvacijos funkcijų pasirinkimai yra šie:

  – žingsninė funkcija. Ši funkcija naudota ankstyvojoje dirbtinių neuroninių tinklų stadijoje bet dabar ji mažai naudojama.

  – vadinamoji „lygintuvo“ funkcija (angl. Rectified Linear Unit (ReLU)). Apie 2016 metus buvo viena dažniausiai naudojamų.[1]

  – vadinamoji sigmoidė, kuri „suploja“ įėjimą į intervalą  . Tai yra lyg tam tikra visur diferencijuojama žingsninė funkcija. Praeityje atrodė labai svarbu, jog funkcija visur būtų diferencijuojama, bet vėliau buvo patebėta, jog tai nėra būtina.[1]

  – hiperbolinio tangento funkcija. Tai – ta pati sigmoidė, tačiau išvedamos reikšmės intervale  .

  – minkštojo maksimumo (angl. softmax) funkcija. Ji paverčia visas išėjimo komponentes į tikimybes, t. y. sunormuoja išėjimo vektorių į  . Ji daugiausia naudojama tinkluose, kurie ką nors klasifikuoja. Tuomet   kiekvienai komponentei priskirs klasės tikimybę.

Neuroninių tinklų klasifikacija

redaguoti

Esama įvairių rūšių neuroninių tinklų. Vieni iš jų apmokomi su mokytoju (žinant reikiamas tinklo išėjimų reikšmes), kiti – be mokytojo. Istoriškai pirmi neuroniniai tinklai buvo vienasluoksniai perceptronai. Šiuo metu plačiausiai taikomi konvoliuciniai neuroniniai tinklai, ypač su vaizdo aprodojimu susijusiose užduotyse[2].

Taikymas

redaguoti

Dirbtiniai neuroniniai tinklai taikomi šiose srityse:

  • grafinių vaizdų atpažinimas[3];
  • bioinformatikoje – dalinai kintančių, tačiau biologiškai reikšmingų nukleotidų bei aminorūgščių sekų fragmentų paieška. Sistema apmokoma naudojant žinomų sekų rinkinį ir randa naujas, panašiai atrodančias sekas.
  • finansuose – analizuojant ir prognozuojant akcijų kitimo kursus;
  • procesams modeliuoti ir valdyti: fizinės sistemos neuroninių tinklų modelis taikomas geriausiems valdymo parametrams nustatyti;
  • mašinų diagnostikai: stebi mašiną ir jai sugedus įspėja sistemą;
  • taikiniui atpažinti: karinėse programose padeda apdoroti paprastą arba infraraudonųjų spindulių vaizdą priešo taikiniui nustatyti.
  • medicininei diagnozei[4]: analizuodami simptomus ir vaizdo duomenis, pavyzdžiui, rentgeno nuotraukas, tinklai padeda gydytojams nustatyti diagnozę.


Šaltiniai

redaguoti
  NODES