Sadržaj: 1. Uvod Heuristički algoritmi....1 Penjanje uzbrdo i mogućnosti njegove primjene.... Simulirano kaljenje Opis algoritma..... Nači
|
|
- Ξάνθη Κολιάτσος
- 6 χρόνια πριν
- Προβολές:
Transcript
1 SVEUČILIŠTE U ZAGREBU FAKULTET ELEKTROTEHNIKE I RAČUNARSTVA SEMINARSKI RAD IZ KOLEGIJA ALGORITMI U SUSTAVIMA UPRAVLJANJA USPOREDBA HEURISTIČKIH ALGORITAMA NA PROBLEMIMA OPTIMIRANJA, NAPRTNJAČE I PROBLEMU n-kraljica Ivica Martinjak Zagreb, ožujak 6.
2 Sadržaj: 1. Uvod Heuristički algoritmi....1 Penjanje uzbrdo i mogućnosti njegove primjene.... Simulirano kaljenje Opis algoritma..... Načini primjene Tabu pretraživanje i mogućnosti njegove primjene Genetski algoritam i mogućnosti njegove primjene Optimiranje realnih unkcija jedne varijable Prikaz realnog broja pomoću binarnog vektora Optimiziranje unkcija primjenom heurističkog algoritma penjanje uzbrdo Opis heuristike Rezultati testiranja Optimiranje unkcija primjenom simuliranog kaljenja Opis heuristike Rezultati testiranja Optimiranje unkcija primjenom tabu pretraživanja Opis heuristike Rezultati testiranja Optimiranje unkcija primjenom genetskog algoritma Uvod Genetski algoritmi s eliminacijskom selekcijom Rezultati testiranja Optimalni parametri jednostavnog genetskog algoritma s eliminacijskom selekcijom Usporedba heurističkih algoritama na primjeru optimiranja realne unkcije jedne varijable Osnovne karakteristike uspoređivanih algoritama Usporedni rezultati testiranja i zaključak Usporedba heurističkih algoritama na problemu naprtnjače....1 Problem naprtnjače.... Opis heuristika....3 Rezultati testiranja Zaključak Usporedba heurističkih algoritama na problemu n-kraljica Problem n-kraljica Opis heuristika Rezultati testiranja Zaključak Zaključak... 9 Literatura Prilog A: Ispitne unkcije... 3 Prilog B: Ispitni primjeri problema naprtnjače Prilog C: Rješenje 5-kraljica Prilog D: Praktični rad (CD)... 37
3 1. Uvod Determinističke tehnike ne daju rješenje NP teških 1 problema u prihvatljivom vremenskom okviru, obzirom na njihovu gornju granicu složenosti. Rješenje ovog problema predstavljaju heuristički algoritmi, čijom se primjenom NP klasa problema može uspješno rješavati u prihvatljivom vremenskom okviru. Osnovna karakteristika heurističkih algoritama je nesigurnost da li je dobiveno rješenje optimalno. Međutim, pokazalo se da iako nema garancije da je generirano rješenje najbolje moguće, heuristički algoritmi s visokom vjerojatnošću daju optimalno rješenje ili rješenje blisko optimalnom (obično -5% odstupanja). Teškoća pri korištenju heurističkih algoritama je kreiranje uspješne heuristike te pronalaženje optimalnih parametara za dani problem. Heuristika je vitalni dio svakog heurističkog algoritma, o kojem najviše ovisi uspješnost algoritma a čije ormiranje nije standardizirano već zahtijeva kreativnost i iskustvo. Može se reći da jedino genetski algoritam ima univerzalnu heuristiku oponašanje prirodnog evolucijskog procesa, no i pri tome je puno stupnjeva slobode. U ovom se radu heuristički algoritmi uspoređuju na trima primjerima. Kao prvo su osmišljene i implementirane heuristike za rješavanje odabranih problema 3 a zatim su napravljeni usporedni testovi. Penjanje uzbrdo, simulirano kaljenje, tabu pretraživanje i genetski algoritam uspoređeni su na primjeru optimiranja realne unkcije jedne varijable. Algoritmi simulirano kaljenje, tabu pretraživanje i genetski algoritam uspoređeni su na problemu naprtnjače i na problemu n-kraljica. U prvom dijelu rada opisuju se uspoređivani heuristički algoritmi s naglaskom na mogućnosti i načine njihove primjene. U drugom poglavlju opisuju se razvijene heuristike za optimiranje unkcija, rezultati testiranja kao i izvedeni zaključci. Na isti način prezentirana je usporedba algoritama na problemima naprtnjače i n-kraljica, u sljedećim poglavljima. Osnovni pojmovi iz područja kombinatoričkih i heurističkih algoritama se podrazumijevaju te uglavnom nisu deinirani, eventualno su opisani u usnotama. Implementacijski detalji također nisu opisivani već je naglasak stavljen na algoritme i rezultate testiranja (u prilogu rada nalazi se CD sa izvornim kodom). Algoritmi su implementirani u programskom jeziku C++. Graovi unkcija i drugi slikovni prikazi izrađeni su pomoću Matlab-a, programa za računanje u tehničkim znanostima. 1 NP klasu problema predstavljaju problemi koji se ne mogu riješiti u polinomijalnom vremenu. Može se, ipak, primijetiti da je vrlo često konceptualno sasvim jednostavna heuristika vrlo uspješna. 3 Genetski algoritam za rješavanje problema n-kraljica preuzet sa a izvorni kod za simulirano kaljenje prilagođeno za problem naprtnjače preuzet sa 3
4 . Heuristički algoritmi.1 Penjanje uzbrdo i mogućnosti njegove primjene Penjanje uzbrdo (hill climbing) je heuristički algoritam temeljen na logici najstrmijeg uspona. Osnovna strategija ovog algoritma je da radi tako dugo dok heuristika generira rješenje koje je bolje od prethodnog. Kada se dogodi da novi kandidat nije bliži optimalnom od prethodnog, algoritam završava s radom. Stoga je najzahtjevniji zadatak pri uporabi ovog algoritma, kao i kod ostalih, kreirati heuristiku, unkciju koja za trenutno rješenje daje još bolje. (Jedini izuzetak po ovom pitanju je genetski algoritam čija heuristika oponaša evolucijski proces, no i tu je puno slobode u prilagodbi algoritma problemu.) Budući da je priroda heuristike takva da traži takvog boljeg kanidata koji je sličan ili blizu trenutnom rješenju, penjanje uzbrdo nema mehanizam za bijeg iz lokalnog optimuma. Unatoč tome, moguće je za mnoge probleme osmisliti uspješnu heuristiku; međutim vrlo često se ova metoda pokazuje previše ograničavajućom za nalaženje globalnog optimuma. U načelu, penjanje uzbrdo najuspješnije je kod problema koji nemaju lokalnih optimuma. Glavna, pak, prednost ovog algoritma je što je konceptualno posve jednostavan, najjednostvniji među heurističkim algoritmima.. Simulirano kaljenje..1 Opis algoritma Simulirano kaljenje (simulated annealing) je heuristički algoritam za globalno optimiranje čije ime i ideja potiču od postupka kaljenja u metalurgiji. Tehnikom kaljenja dobiva se materijal povećane čvrstoće i tvrdoće što se postiže reduciranjem deekata kristalne rešetke odnosno dovođenjem sustava u stanje manje unutarnje energije od početnog stanja. Naime, u početku postupka, struktura materijala je u nekom lokalnom optimumu unutarnje energije. Zagrijavanjem sustava atomi napuštaju svoje prvobitne pozicije u kristalnoj rešetki te tijekom sporog hlađenja imaju šansu zauzeti neko drugo, povoljnije, mjesto i time sustav dovesti u stanje manje unutarnje energije nego je bila inicijalna (ili najmanje moguće globalni optimum). U algoritmu simulirano kaljenje svaki se element prostora rješenja može interpretirati kao stanje opisanog izikalnog sustava a unkcija cilja kao unutarnja energija sustava u tom stanju. Algoritmu je cilj pronaći globalni optimum unkcije cilja kao što je u procesu kaljenja cilj pronaći koniguraciju najmanje energije. Kao što je kod kaljenja moguće da neka prijelazna koniguracija ima veću unutarnju energiju od prethodne (a manju od inicijalne te veću od najmanje moguće) tako i simulirano kaljenje Heuristika je unkcija koja ima zadatak da u susjedstvu (dio prostora rješenje sličan ili blizu trenutnog rješenja) danog rješenja pronađe još boljeg kandidata, bilo iscrpnom pretragom, bilo nekom drugom metodom.
5 dopušta prijenos novog rješenja u sljedeću iteraciju čak i ako je lošije od prethodnog. Vjerojatnost za to je to manja što je temperatura manja. Dakle, kod prvih iteracija novo rješenje koje nije bolje od prethodnog s velikom se vjerojatnošću prenosi u sljedeću iteraciju (te se novi kandidat generira iz susjedstva tog rješenja). Kako se sustav hladi (broj iteracija približava maksimalnom broju) to je veća vjerojatnost da algoritam ustraje na trenutnom rješenju koje nije bolje od prethodnog. Ova mogućnost da se lošiji kanidat ipak prenese u sljedeći ciklus omogućuje pretragu novih, prije neispitanih područja prostora rješenja te šansu da se naiđe na područje globalnog minimuma odnosno maksimuma... Načini primjene Prema tome, osnovni način upravljanja ovim algoritom biti će reguliranjem brzine hlađenja. Što je hlađenje sporije to je veće raspršenje kandidata te algoritam teži ka slučajnom pretraživanju prostora rješenja. Druga je krajnost premali koeicijent hlađenja tada će vrlo vjerojatno algoritam pronaći lokalni optimum zbog preslabog raspršenja kanidata po prostoru rješenja. Od tri ulazna parametra, broj iteracija, početna temperatura i koeicijent hlađenja, algoritam je najosjetljiviji na koeicijent hlađenja. Broj iteracija obično se kreće od 1 do više 1-aka tisuća..3 Tabu pretraživanje i mogućnosti njegove primjene Osnovna je ideja kod heuristika da već male promjene mogu unaprijediti trenutno rješenje. Tako je u primjeni vrlo raširena heurisitka koja koristi binarni vektor za prikaz elemenata prostora rješenja te koja susjedstvom trenutnog rješenja smatra sve vektore koji se od danog razlikuju u jednome bitu (Hammingova udaljenost jednaka je 1). Posebnost tabu pretraživanja (tabu search) među heurističkim algoritmima je što heuristika vraća najboljeg kandidata iz susjedstva trenutnog rješenja. Dakle, u novi ciklus se prenosi onaj element susjedstva trenutnog rješenja za kojeg unkcija cilja ima najveću ili najmanju vrijednost ovisno o smjeru optimizacije. Često se za nalaženje najboljeg kandidata koristi iscrpna pretraga. Za razliku od penjanja uzbrdo i simuliranog kaljenja, tabu pretraživanje u sljedeći ciklus uvijek prenosti novokreiranog kandidata, i u slučaju ako je bolji od trenutnog rješenja i u slučaju ako to nije. Na taj se način pretražuju nova područja prostora rješenja, dok heuristika ima zadatak da u danom području pronađe najboljeg kandidata. Budući da heuristika kad ovog algoritma pronalazi najboljeg kandidata u susjedstvu, neracionalno bi bilo više puta generirati istog kandidata. Kako bi se to izbjeglo, ormira se tabu lista u koju se na neki način zapisuju kandidati čije je susjedstvo već pretraženo. Tako se u pojedinoj iteraciji ne pretražuje cijelo susjedsvo već samo oni njegovi elementi koji nisu zabilježeni u tabu listi. Obično se ne zapisuju sami kandidati već unkcije kojima su oni generirani. 5
6 . Genetski algoritam i mogućnosti njegove primjene Genetski algoritam 5 (genetic algorithm) je heuristička metoda rješavanja problema, obično optimiranja, koji oponaša prirodni evolucijski proces. Tako, prostor rješenja kod genetskog algoritma čine jedinke, predstavljene kromosomima 6. Jedinke su prepuštene procesu evolucije, koji u sljedeću generaciju prenosi one s najboljim svojstvima tj. one za koje unkcija cilja ima najveće vrijednosti. Trajanje evolucije unaprijed zadajemo (na više načina; primjerice brojem iteracija). Osnovni mehanizmi odabira sve boljih i boljih jedinki (kromosoma, tj. kanidata za rješenje), su kao i kod prirodnog procesa evolucije selekcija, križanje i mutacija. Točnije, selekcijom odabiremo određeni broj najboljih kromosoma za sljedeću generaciju (iteraciju), koji će križanjem ormirati nove kromosome s ciljem dobivanja još boljih kandidata. Nakon toga, djeluje genetski opetator mutiranja, čiji je zadatak ormiranje kanditata iz neistraženog prostora rješenja (obično se pritom čuva elitizam, tj. trenutno najbolje rješenje je zaštićeno od mutacije). Dakle, dok je križanje zaduženo za konvergenciju prema optimumu (budući da je velika vjerojatnost da se križanjem dobrih kandidata dođe do još boljih, a sličnih), mutacija omogućava stalnu potragu cijelog prostora rješenja i time bijeg iz lokalnog optimuma, tj. pronalaženje kandidata u području globalnog optimuma. Genetski algoritmi su se pokazali vrlo eikasnima u rješavanju raznih problema iz inžinjerske prakse, bilo da se radi o generiranju kombinatoričkih struktura ili opcimizacijskoj klasi problema. Opće osobine genetskog algoritma jesu robusnost, primjenjivost na široki spektar problema te pouzdanost (u smislu da nađeno rješenje, s velikom vjerojatnošću, ne odstupa puno od optimalnog). Za razliku od ostalih heurističkih algoritama, u svakoj iteraciji barataju sa skupom kadnidata za rješenje (populacijom) a ne jednim kandidatom. Jedna od teškoća u primjeni genetskog algoritma je veliki uticaj ulaznih parametara na eikasnost. Kao i kod ostalih heurističkih algoritama, jedini način optimiranja parametara je eksperimentiranjem. Ipak, neke vrijednosti parametara su se pokazale standardnima pa mogu poslužiti kao polazna točka za traženje optimalnih parametara danog problema (tablica.1) (Golub, a). Parametri Oznaka Mala populacija Velika populacija Veličina populacije VEL_POP 3 1 Vjerojatnost mutacije p m.1.1 Vjerojatnost križanja p c.9.6 Broj jedinki za eliminaciju M VEL_POP/ VEL_POP/ Tablica.1 Parametri genetskog algoritma s generacijskom i eliminacijskom reprodukcijom 5 Genetski algoritmi predloženi su od strane J. H. Hollanda ranih 7-ih godina. st. 6 Kada govorimo o genetskim algoritmima, jedinka i kromosom su sinomimi budući da kromosom sadrži sve inormacije o jedinki. 6
7 3. Optimiranje realnih unkcija jedne varijable 3.1 Prikaz realnog broja pomoću binarnog vektora Kod uspoređivanih heurističkih algoritama, osim kod penjanja uzbrdo, koristi se binarni x dg, gg. vektor za prikaz realnog broja, koji predstavlja kodiranu vrijednost [ ] Vektor čiji su svi bitovi postavljeni na nulu predstavlja donju granicu intervala a vektor sa svim jedinicama gornju granicu. Točna pretvorba kromosoma u realni broj izvodi se prema relaciji x dg b = + ( ) ( gg dg ) n 1 pri čemu je dg donja granica intervala, gg gornja granica a b broj kojeg predstavlja kromosom. Obrnuto, pretvorba realnog broja x u kromosom binarni zapis izvodi se prema relaciji: x dg n b= ( 1 ). gg dg, Broj bitova izračunava se prema relaciji [ p log ( gg dg) * ] n log. 3. Optimiziranje unkcija primjenom heurističkog algoritma penjanje uzbrdo 3..1 Opis heuristike Heuristika (xsd, xsg) { razdijeli interval [xsd, xsg] na n ekvidistantnih dijelova početak svakog intervala i kraj zadnjeg su kandidati odaberi najboljeg kadidata i zapamti njegove susjede return (najbolji kandidat) } Algoritam Penjanje_uzbrdo_OptFje(n){ Y=Heuristika (dg, gg); Xbest=Y; searching=true; while (searching) { Y=Heuristika (xsd, xsg); i Proit(Y) > Proit(Xbest) then Xbest=Y; else searching=alse; } return (Xbest); } Algoritam 3.1 Heuristički algoritam penjanje uzbrdo primijenjen na optimiranje unkcija 7
8 Budući da heuristički algoritam penjanje uzbrdo završava s radom ukoliko novi kandidat nije bolji od prethodnog, važno je da heuristika bude eikasna. Za problem optimiranja unkcija osmišljena je vrlo jednostavna heuristka koja, u prvom koraku, interval na kojem se traži optimum unkcije podijeli na određeni broj (n) ekvidistantnih intervala, čije granice predstavljaju susjedstvo trenutnog rješenja (algoritam 3.1). Najbolji kandidat postaje novo rješenje a njegovi susjedi postaju granice intervala na kojem se traži sljedeće bolje rješenje. Broj podjela intervala n je ulazni parametar algoritma. Nedostatak pristupa je mogućnost preskakanja globalnog optimuma ako je podjela danog intervala pregruba. To se, dakako, može popraviti preciznijom podjelom intervala, no tada se povećava broj izračunavanja vrijednosti unkcije cilja. Što unkcija ima manji omjer širine globalnog optimuma i prostora rješenja, to će podjela trebati biti preciznija. 3.. Rezultati testiranja Rezultate testiranja prikazuje tablica 3.1. Prva tri stupca prikazuju testiranu unkciju, interval na kojem se tražio optimum i vrijednost optimuma na 6 decimala točnosti. U prvom testu pokrenut je algoritam sa 1 podjela intervala (n=1); rezultate prikazuje. stupac tablice. Nakon toga, postavilo se pitanje za koliki n (u koracima 5, 1, ) će optimum biti precizno određen; rezultate tog, drugog, testa prikazuje zadnji stupac tablice. n=1 (x best ) - o p t = Funkcija Interval opt (x best ) - opt numiter n numiter 3 = x x [-, ] p 1 3 p 1 = x x x p = (35x 3x + 3) 8 1+ xsin(1π ) x [-, 5] [-1, 1] = [-1, ] [-1, ] sin(1πx ) 1( x) = x = x sin(1πx ) [1, ] ( x sin = x [, 5] ) [ tg( )] = x cos x [-, 6] = x cos( tg x) [, 5] π [-1, 8] = xsin arctg( x) x sin.5 [-1, =.5 1] (1+.1x ) Tablica 3.1 Rezultati optimiranja unkcija penjanjem uzbrdo Odmah se uočava da je algoritam vrlo osjetljiv na oblik unkcije. Za prve tri, polinomske unkcije koje imaju jedan ili dva lokalna maksimuma, kao i za ostale slične, algoritam je bio vrlo eikasan. Pronašao je optimalno rješenje na traženu točnost u svega nekoliko iteracija. Može se zaključiti da što je veća gustoća lokalnih optimuma na prostoru rješenja odnosno što 8
9 je njihova vrijednost bliža vrijednosti globalnog optimuma to algoritam teže nalazi točno rješenje (odnosno n treba biti veći da bi algoritam bio uspješan). Može se još reći da n treba biti to veći što je omjer širine prostora na kojem se nalazi globalni maksimum i širine prostora rješenja manji, i što je vrijednost lokalnih optimuma bliža vrijednsti globalnog optimuma. Druga karakteristika algoritma koja se uočava je brzina algoritma tj. mali broj potrebnih izračunavanja vrijednosti unkcije cilja. U najgorem slučaju (kod unkcije 3 ) vrijednost unkcije cilja se izračunala 7 puta, a za usporedbu može se navesti da se kod genetskog algoritma s populacijom od 5 i vremenom evolucije od 1 iteracija proit računa 5 puta (uz izvođenje ostalih operacija). Slika 3.1 prikazuje taj brzi napredak prema optimalnom rješenju tijekom iteracija. Za primijetiti je da je u prvom testu najveće odstupanje od optimuma bilo kod unkcije, koja će se kasnije pokazati za sve algoritme najzahtjevnijom. (xbest) iteracija Slika 3.1 Poboljšavanje rješenja tijekom iteracija za unkciju 5 9
10 3.3 Optimiranje unkcija primjenom simuliranog kaljenja Opis heuristike Odabrana je posve jednostavna heuristika: susjedstvo danog vektora čine vektori s Hammingovom udaljenošću jednakom 1. Za dani vektor (koji predstavlja realni broj-kandidat za rješenje) heuristika vraća vektor koji se od ulaznog razlikuje u jednom, slučajno odabranom, bitu (algoritam 3.). Algoritam Simulirano_kaljenje_OptFje(c max, T, α){ T= T X=[X, X n-1 ] X best =X or c= to cmax { j=random(, n-1) // klasična heuristika Y=X, Yj=1-Xj i P(Y) > P(X) then { i P(Y) > P(X best ) then X best =Y X=Y } else r=random(-1) i r<e ((P(y)-P(x))/T then X=Y T=αT } return (xbest) } Algoritam 3. Za optimiranje unkcija korišteno je simulirano kaljenje s heuristikom koja mijenja slučajno odabrani bit 3.3. Rezultati testiranja Unatoč ovako jednostavnoj heuristici, rezultati su vrlo dobri, kako prikazuje tablica 3.. c m a x =1, α=.98 c m a x =, α=.985 Funkcija Interval opt Broj nađenih Odstupanje Broj nađenih Odstupanje optimuma u najlošijeg optimuma u najlošijeg 1 pokretanja rješenja od optimuma 1 pokretanja rješenja od optimuma p [-, ] % 6.3 % p1 [-, 5] % 1 p [-1, 1] % 7.1 % [-1, ] % % 1 [-1, ] %.8 % [1, ] % % 3 [, 5] % 1.8 % [-, 6] % % 5 [, 5] % 1. % 6 [-1, 8] % 6.1 % 7 [-1, 1] % % Tablica 3. Rezultati optimiranja unkcija simuliranim kaljenjem 1
11 3. Optimiranje unkcija primjenom tabu pretraživanja 3..1 Opis heuristike Za problem optimiranja realnih unkcija jedne varijable najprije je primijenjen osnovni, konceptualno posve jednostavni, algoritam tabu pretraživanja. Za zapis realnog broja koristi se binarni vektor a susjedstvo predstavljaju svi vektori koji se od danog razlikuju u jednom bitu (kao i kod simuliranog kaljenja). Tabu lista je osmišljena tako da se u nju zapisuje redni broj promijenjenog bita. Na taj način heuristika neće ponovo razmatrati već generirane kandidate; točnije, za to je manja vjerojatnost (to manja što je duljina tablu liste veća). Nakon prvog testa optimiranja, rezultati, koje prikazuje tablica 3. nisu bili zadovoljavajući. Funkcija Interval opt Broj nađenih optimuma u 1 pokretanja [-, ] p p1 [-, 5] -31 p [-1, 1] [-1, ].8575 [-1, ] [1, ] [, 5] [-, 6] [, 5] [-1, 8] [-1, 1] Tablica 3.3 Rezultati sa prvom heuristikom, c max =1, L=1 Osim male vjerojatnosti nalaženja globalnog optimuma na zadanu točnost, odstupanja od otpimuma su bila velika (veća od karakterističnih za heursitičke algoritme - cca 5%). Takvi rezultati ukazivali su da algoritam ima preslab mehanizam za raspršivanje kandidata po prostoru rješenja. Stoga je poboljšan algoritam tako da je generiran slučajni vektor svaki puta kad novoormirani kandidat nije predstavljao bolje rješenje od prethodnog. 3.. Rezultati testiranja Rezultate testiranja s poboljšanim algoritmom prikazuje tablica
12 c m a x =5, L=1 c m a x =1, L=1 Funkcija Interval opt Broj nađenih Odstupanje Broj nađenih optimuma najlošijeg optimuma rješenja p [-, ] % 1 p1 [-, 5] % 1 p [-1, 1] [-1, ] <.1% 1 1 Odstupanje najlošijeg rješenja [-1, ] % 9.1% [1, ] % 6.% [, 5] % 6.9% 3 [-, 6] [, 5] % 6.1% 5 [-1, 8] [-1, 1] Tablica 3. Rezultati optimiranja unkcija tabu pretraživanjem Tabu pretraživanje se pokazalo vrlo pouzdanim algoritmom za optimiranje unkcija. U većini slučaja generirano je točno rješenje na traženu preciznost ili je odstupanje bilo vrlo malo. Sumarne rezultate prikazuje sljedeća tablica, 3.5 Parametri algoritma c m a x =5, L=1 c m a x =1, L=1 Vjerojatnost da algoritam nađe 7% 88% globalni optimum Očekivano odstupanje najlošijeg.%.% rješenja Broj izračuna je cilja cca 1 cca Tablica 3.5 Pouzdanost i eikasnost tabu pretraživanja kod optimiranja realnih unkcija jedne varijable 1
13 3.5 Optimiranje unkcija primjenom genetskog algoritma Uvod Dosezi i mogućnosti genetskog algoritma testirani su na problemu optimizacije unkcija. Odabrano je 11 različitih realnih unkcija jedne varijable, od polinoma do zahtjevnih unkcija s mnoštvom lokalnih optimuma. Ispitne unkcije odabrane su s nastojanjem da budu reprezentativne, kako bi se, eventualno, došlo do nekih generalizacija o ponašanju genetskog algoritma na ovoj klasi problema. Konkretno, cilj je ustanoviti eikasnost genetskog algoritma na ovoj klasi problema. Što je broj generacija (iteracija) potrebnih da se dođe do globalnog opitimuma, odnosno broj izračuna unkcije cilja, manji to je algoritam eikasniji. Karakteristika heurističkih algoritama je da, u pravilu, daju ili optimalno rješenje ili rješenje koje je blisko opitmalnom; međutim za to nema nikakve čvrste garancije. Načelno, za realni problem koji se rješava heurističkim algoritmom ne može se znati koliko je algoritam pouzdan, tj. koliko se dobiveno rješenje razlikuje od optimalnog. Međutim, određena sigurnost ipak postoji zbog statističke zakonitosti; u većini slučajeva pouzdanost algoritma je velika pa očekujemo da će tako biti i za rješavani problem. Posebice će to vrijediti ako je primijenjeno na određenu klasu problema. Zato će se u testiranjima ustanoviti koliko se prosječno rješenje razlikuje od optimalnog kako bi se utvrdila očekivana pouzdanost za cijelu klasu problema. Treća mjerena karakteristika algoritma je preciznost. Na osnovi dobivenih rezultata nastojati će se standardizirati ulazni parametri genetskog algoritma kada se on primjenjuje na optimiranje realnih unkcija jedne varijable. Promatrati će se da li se uopće može utvrditi neka zakonitost, da li se parametri podudaraju sa općim parametrima, predstavljenim u tablici.1, ili postoje neke speciičnosti Genetski algoritmi s eliminacijskom selekcijom Genetski_algoritam { } Generiraj slučajno VEL_POP jedinki; Sve dok (ima_vremena) radi Evaluiraj i selektiraj; - izračunaj vrijednosti je cilja za sve jedinke - primijeni translaciju - izračunaj vrijednosti je kazne za sve jedinke - izbriši M jedinki na način da je vjerojatnost brisanja prop. vrijednosti je kazne Križaj s jednom točkom prekida; //kod GA_ UniormnoKrižaj; - s jednakom vjerojatnošću odaberi roditelje od opstalih jedinki - ako su jedinke jednake tada mutiraj jednu od njih inače primijeni križanje s jednom točkom prekida - ponavljaj postupak sve dok se ne generira M djece Jednostavno mutiraj; - radi za svaku jedinku u populaciji, samo ne najbolju: - radi za svaki bit tekuće jedinke: - izračunaj vjerojatnost i po potrebi promijeni bit Ispiši zadnju generaciju; Algoritam 3.3 Jednostavni eleminacijski genetski algoritam 13
14 Razvijena su dva genetska algoritma, oba s eliminacijskom selekcijom i jednostavnom mutacijom koja čuva najbolje rješenje (algoritam 3.3). Kod oba algoritma prilikom križanja mutira jedan od roditelja ako se uspostavi da su oba kromosoma roditelja jednaka. Jedina razlika među algoritmima je što jedan algoritam (GA_1) koristi križanje s jednom točkom prekida a drugi (GA_) uniormnmo križanje. Algoritmi su pokrenuti sa sljedećim parametrima (tablica 3.6): Algoritam GA_1 GA_ Vrsta GA eliminacijski, M=5% Veličina populacije 5 Prikaz binarni, broj bitova=(dg,gg,p) Ispravak unkcije dobrote translacija Eliminacija duplikata da, prilikom križanja Križanje s jednom točkom prekida, p c =.5 uniormno Mutacija jednostavna Tablica 3.6 Tip i parametri ugrađenog genetskog algoritma Dakle, algoritmi koriste binarni prikaz kromosoma čija duljina (broj bitova) ovisi o granicama intervala i preciznosti. Ukoliko su roditelji jednaki, mutira jedan od njih. Kod prvog algoritma križanje je jednostavno, s jednom točkom prekida, a kod GA_ križanje je uniormno. Populaciju je, ovisno o testu, činilo 5 ili 1 jedinki a broj kromosoma za eliminaciju je uvijek iznosio 5% veličine populacije Rezultati testiranja Napravljene su dvije serije testova, čije rezulate prikazuju tablice 3.7 i 3.8. U prvoj seriji, cilj je bio maksimizirati eikasnost algoritama tj. pokrenuti algoritme sa što manjim brojem iteracija a da rezultati budu prihvaljivi. U drugoj seriji ispitivao se utjecaj povećanja populacije na rezultat. Broj nađenih optimuma u 1 pokretanja Funkcija Interval opt GA_1 GA_ (križanje s (uniormno jednom točkom križanje) pr.) p [-, ] p1 [-, 5] p [-1, 1] [-1, ] [-1, ] [1, ] [, 5] [-, 6] [, 5] [-1, 8] [-1, 1] Tablica 3.7 Genetski algoritmi pokrenuti s parametrima VEL_POP=5, t=1, M=5% i p m =.1 1
15 Primijećen je veći broj nađenih optimalnih rješenja kod drugog algoritma, s uniormnim križanjem. Dok je kod GA_1 ukupno 63 nađenih optimuma, kod GA_ taj broj iznosi 7. Rijetko se koji rezultat poboljšao povećanjem broja iteracija sa 1 na 3, a sa 3 na 1 niti jedan (osim ako je ujedno bila povećana vjerojatnost mutacije). Pokazalo se da je algoritam s ovim ulaznim parametrima najsenzitivniji na vjerojatnost mutacije. U drugoj seriji testova ispitivano je kako pouzdanost i preciznost algoritma ovise o veličini početne populacije. Budući da je veličina populacije sada povećana, smanjena je stopa mutacije, kako sugeriraju drugi radovi (Golub, a). Broj nađenih optimuma u 1 pokretanja Funkcija Interval opt GA_1 GA_ (križanje s (uniormno jednom točkom križanje) prekida) p [-, ] p1 [-, 5] p [-1, 1] [-1, ] [-1, ] [1, ] [, 5] [-, 6] [, 5] [-1, 8] [-1, 1] Tablica 3.8 Genetski algoritmi pokrenuti s parametrima VEL_POP=1, t=1, M=5% i p m = Optimalni parametri jednostavnog genetskog algoritma s eliminacijskom selekcijom Primijenjeni algoritmi (s križanjem s jednom točkom prekida i s uniormnim križanjem) uspješni su u optimiranju unkcija te pokazuju karakteristike koje su u skladu s dosadašnjim rezultatima u primjeni genetskih algoritama. Tako su u provedenim testovima algoritmi bili najosjetljivi na stopu mutacije. Također se pokazalo da je algoritam s uniormnim križanjem bio uspješniji od algoritma s križanjem s jednom točkom prekida, generiravši više optimalnih rješenja. Najprije su algoritmi testirani u stanju velike eikasnosti (tako da broj iteracija bude što manji -1) (tablica 3.7). S dotičnim su parametrima algoritmi pokazivali slabo povećanje preciznosti i pozdanosti s povećanjem broja iteracija. Algoritmi su bili najsenzitivniji na stupu mutacije te je variranjem iste od.1 do.3 (ili još nešto više) posve precizno, na traženih 6 decimala, određen optimum svake ispitne unkcije u samo jednom pokretanju algoritma. 15
16 Druga serija testova, u kojoj je povećana veličina populacije (s ciljem da se ispita ovisnost pouzdanosti i preciznosti o veličini populacije) pokazuje da povećanje broja iteracija značajno doprinosi boljem rješenju ukoliko je populacija veća (a vjerojatnost mutacije manja). Dakle, općenito se može reći da kada se jednostavni genetski algoritam s eliminacijskom selekcijom, a isto tako i opisani genetski algoritam s uniormnim križanjem, primjenjuje za optimiranje realnih unkcija jedne varijable, s većom populacijom (1), većim brojem iteracija (1) i manjom stopom mutacije (.7) dobivamo precizniji i pouzdaniji rezultat. 16
17 3.6 Usporedba heurističkih algoritama na primjeru optimiranja realne unkcije jedne varijable Osnovne karakteristike uspoređivanih algoritama Tablica 3.11 prikazuje nam osnovne karakteristike uspoređivanih algoritama. Heuristički algoritam Zapis elemenata prostora rješenja Heuristika Penjanje uzbrdo Broj s pomičnom točkom Susjedstvo čini n brojeva između prvog donjeg i prvog gornjeg susjeda trenutnog rješenja Simulirano Tabu Genetski kaljenje pretraživanje algoritam Binarni vektor Binarni vektor Binarni vektor Susjedstvo čine vektori koji se od danog razlikuju u jednom bitu Susjedstvo čine vektori koji se od danog razlikuju u jednom bitu a nisu u tabu listi Susjedstvo čini populacija koja se od dane ormira križanjem Mehanizam konvergencije Mehanizam raspršenja Ulazni parametri Vraća najboljeg od ispitanih kandidata i pamti njegove susjede U svakoj iteraciji interval na kojem se traži rješenje je sve uži Kandidati su ekvidistantno raspoređeni po intervalu - broj razmatranih kandidata na intervalu (n) Vraća slučajno generiranog kandidata Novoormirani kandidat se vrlo često ne razlikuje puno od prethodnog I lošiji kandidat ima šansu (to veću što je temp. veća) ići u sljedeću iteraciju - broj iteracija (c max ) - početna temperatura (T ) - koeicijent hlađenja (α) Vraća najboljeg mogućeg kandidata (iscrpna pretraga) Iscrpna pretraga susjedstva trenutnog kandidata Zamjena novog, lošijeg kandidata sluč. generiranim vektorom - broj iteracija (c max ) - kapacitet tabu liste (L) Vraća novu generaciju te odabire ponajboje kandidate Križanje Mutacija - broj iteracija (t) - veličina populacije (VEL_POP) - postotak selekcije (M) - vjerojatnost mutacije (p m ) Tablica 3.11 Osnovne karakteristike uspoređivanih heurističkih algoritama 17
18 3.6. Usporedni rezultati testiranja i zaključak Heuristički algoritam HC SA TS GA_1 GA_ test 1 test 1 test test 1 test test 1 test test 1 test Ulazni numiter parametri n=1 c max =1 α=.98 c max = α=.985 L=1 L=1 VEL_POP=5 p m =.3 M=5 VEL_POP=1 p m =.7 M=5 VEL_POP=5 p m =.3 M=5 VEL_POP=1 p m =.7 M=5 PRECIZNOST broj decimala POUZDANOST vjerojatnost optimalnog rješenja 7 1% 39% 5% 7% 88% 57% 71% 63% 89% EFIKASNOST odstupanje najlošijeg rješenja od optimuma 8 broj izračuna vrijednosti unkcije cilja Osjetljivost na ulazne parametre na c max gotovo neosjetljiv na α vrlo osjetljiv 6% 35%.%.% 5% 5% 5%.7% na L 1 gotovo neosjetljiv vrlo osjetljiv na p m veća populacija sa većim t doprinosi pouzdanosti vrlo osjetljiv na p m veća populacija sa većim t doprinosi pouzdanosti Tablica 3.1 Usporedni test heurističkih algoritama penjanja uzbrdo, simuliranog kaljenja, tabu pretraživanja i genetskog algoritma na primjeru optimiranja realnih unkcija jedne varijable 7 Na osnovi 1 testova za pojedinu unkciju 8 Kod svakog algoritma najveće je ostupanje od optimuma zabilježeno kod unkcije, osim u jednom testu sa simuliranim kaljenjem 18
19 Tablica 3.1 prikazuje uspoređene rezultate optimiranja realnih unkcija jedne varijable heurističkim algoritmima penjanje uzbrdo, simulirano kaljenje, tabu pretraživanje i genetskim algoritmima. Algoritmi su primijenjeni na uzorku od 11 unkcija, odabranih s nastojanjem da budu reprezentativne za ovu klasu problema. Svi su se algoritmi pokazali uspješnima u rješavanju zadanog problema, došavši do rješenja tražene točnosti u većini pokretanja. Kao najeikasniji, najprecizniji i najpouzdaniji pokazao se algoritam penjanje uzbrdo, koji je ujedno i konceptualno najjednostavniji među analiziranim algoritmima. Sa zadanim parametrom n=1 u svakom pokretanju, za svaku unkciju, dobiveno je rješenje na 15 decimala točnosti. Općenito, može se primijetiti da povećanje broja iteracija ne dovodi uvijek do boljeg rješenja. Primjerice, kod genetskog algoritma nakon nekog određenog broja (t=3) dalnjim povećanjem iteracija za dane parametre ne dobivamo bolje rješenje. Tek ako se uz povećanje broja iteracija poveća i populacija dobivaju se stabilniji rezultati. Druga izražena karakteristika svih algoritama je osjetljivost na tip unkcije. Tako se praktički u svim testovima najzahtjevnijom pokazala unkcija. 19
20 . Usporedba heurističkih algoritama na problemu naprtnjače U radu se uspoređuju heuristički algoritmi simulirano kaljenje, tabu pretraživanje i genetski algoritam na primjeru problema naprtnjače. Prikazuju se heuristike kao i rezultati testiranja za pojedini algoritam. Izvedeni su zaključci o primjeni heurističkih algoritama na ovoj NP klasi problema, kao i njihova usporedba..1 Problem naprtnjače Problem naprtnjače je kombinatorički problem u kojem je potrebno maksimizirati unkciju cilja. Dano je n grumena koji sadrže ''zlato'' i naprtnjača kapaciteta W. U torbu treba spremiti onu kombinaciju grumena koja je najvrednija tj. koja sadrži najviše ''zlata'' (slika.1). Dano je: proiti p, p1,... p n 1 težine ω, ω1,... ω n 1 kapacitet W x,... x n 1, 1 takvu da Treba naći: n-torku [ ] { } n n 1 P = i= n 1 w i xi i= p x i i max, i W. Slika.1 Problem naprtnjače Problem naprtnjače je NP težak problem; budući da za n grumena prostor rješenja broji n vektora. Tablica.7 prikazuje veličinu prostora rješenja za nekoliko dimenzija problema. Iako i među determinstičkim tehnikama ima onih koje reduciraju prostor rješenja, one nisu praktične za n>( ) (Kreher, Stinson, 1999). Inače, problem naprtnjače ima važnu primjenu u kriptograiji, poslovnom sektoru i drugdje.. Opis heuristika Kod simuliranog kaljenja korištena je konceptualno jednostavna heuristika, ista kao i kod optimiranja unkcija: za dano rješenje heuristika vraća vektor koji se od danog razlikuje u jednom, slučajno odabranom bitu. Heuristika kod tabu pretraživanja je konceptualno složenija; ponaša se prema algoritmu.1. Ideja je te heuristike da se naprtnjača stalno ''puni i prazni'', na način da se u nju doda grumen s najvećim relativnim doprinosom proita a kada to nije moguće onda se oduzme grumen s najmanjim omjerom proita i težine.
21 Algoritam TS_Heuristika_Naprtanjaca (x[]) 1. ako postoji barem jedan i za koji vrijedi x = i i nije u tabu listi tada i među takvim i-evima nađi onaj za kojeg je te promijeni pripadni bit u 1. inače razmatraj i-eve za koje = 1 među njima nađi onaj za kojeg je te promijeni pripadni bit u x i p w i i p w min i i max Algoritam.1 Heuristika tabu pretraživanja za problem naprtnjače Korištene su dvije inačice genetskog algoritma, koje se razlikuju jedino u vrsti križanja. Uspoređen je genetski algoritam s eliminacijskom selekcijom, jednostavnom mutacijom i križanjem s jednom točkom prekida (GA_1), te genetski algoritam koji se od prethodnog razlikuje jedino po uniormnom križanju (GA_)..3 Rezultati testiranja Za testne primjere su odabrani primjeri s dimenzijama od 15, 5, 5 i 1. U prilogu B su prikazani dotični primjeri problema naprtnjače. Za primjere sa 15 i 5 ''grumena'' rješenje je provjereno determinističkim metodama. Slijedi opis rješavanja problema dimenzija 15 i 5, a analogno vrijedi i za ostala dva primjera. Eikasnost algoritama uspoređena je na sva primjera, a sumarne rezultate prikazuje tablica.7. α c max Min Max Prosjek Broj nađenih optimuma u 1 pokretanja Tablica.1 Rezultati rješavanja problema naprtnjače sa 15 grumena simuliranim kaljenjem α c max Min Max Prosjek Broj nađenih optimuma u 1 pokretanja Tablica. Rezultati rješavanja problema naprtnjače sa 5 grumena dobiveni simuliranim kaljenjem 1
22 Kod rješavanja problema naprtnjače simuliranim kaljenjem, u svakom pokretanju početna temperatura je bila postavljena na 1. Za svaki par parametaraα, cmax napravljeno je 1 pokretanja programa. Rezultate prikazuju tablice.1 i.. Testiranja pokazuju da rezultat nije nužno bolji što je broj iteracija veći. Iz rezultata je vidljivo kako se s većim c max povećava prosjek nađenih rješenja, međutim puni se eekt postiže ako se zajedno s povećanjem broja iteracija poveća koeicijent hlađenja (hlađenje je tada sporije). Obzirom na jednostavnost heuristike, relativno veliki broj potrebnih iteracija može se smatrati očekivanim. Kod tabu pretraživanja također je za svaku kombinaciju ulaznih parametara program pokrenut 1 puta za dani problem. Inače, kod zahtjevnijih problema, ponekad je potrebno i više pokretanja obzirom na prirodu heuristike. Naime, pretraga prostora rješenja je donekle limitirana inicijalnim rješenjem pa se pokazalo dobrim algoritam pokretati s više različitih početnih rješenja. Sva testiranja pokazuju da se rezultat poboljšava do oko -te iteracije. S većim brojem iteracija u svim je testovima dobiven istovjetan rezultat. Ovo se zapažanje slaže sa zaključcima drugih autora (Kreher, Stinson, 1999, ''...We ound c max = to be suicient or the problem instances we considered.''). Za dani primjer naprtnjače potreno je optimirati duljinu tabu liste. Tablice.3 i. prikazuju rezultate za dva primjera. L Min Max Prosjek Broj nađenih optimuma u 1 pokretanja Tablica.3 Rezultati rješavanja problema naptranjače sa 15 grumena tabu pretraživanjem, sa c max = L Min Max Prosjek Broj nađenih optimuma u 1 pokretanja Tablica. Rezultati rješavanja problema naptranjače sa 5 grumena tabu pretraživanjem, sa c max =
23 Genetski algoritam je primijenjen s populacijom od 5 vektora i postotkom jedinki određenih za eliminaciju M od 5%. Parametri koji su varirali su bili broj iteracija i vjerojatnost mutacije. Vjerojatnost mutacije se kretala od.3 do.5. Dulje vrijeme evolucije je donosilo i bolji rezultat, no algoritam je bio osjetljiviji (sukladno općoj karakteristici genetskog algoritma) na vjerojatnost mutacije. Iako je za svaki primjer potrebno optimirati vjerojatnost mutacije, algoritam se pokazao vrlo pouzdanim i od uspoređivanih algoritama najmanje osjetljiv na ulazne parametre. Rezultati su prikazani u tablicama.5 i.6. GA_1 (križanjem s jednom točkom prekida) p m Min Max Prosjek Broj nađenih optimuma u 1 pokretanja GA_ (uniormno križanje) Broj nađenih optimuma u 1 pokretanja Tablica.5 Rezultati rješavanja problema naptranjače sa 15 grumena jednostavnim genetskim algoritmom s eliminacijskom selekcijom, za t=3, VEL_POP=5 GA_1 (križanjem s jednom točkom prekida) p m Min Max Prosjek Broj nađenih optimuma u 1 pokretanja GA_ (uniormno križanje) Broj nađenih optimuma u 1 pokretanja Tablica.6 Rezultati rješavanja problema naptranjače sa 5 grumena jednostavnim genetskim algoritmom s eliminacijskom selekcijom, za t=3, VEL_POP=5 Kod primjera dimenzija 15 i 5 uspoređivani genetski algoritmi su podjednako uspješni, dok je kod primjera dimenzija 5 i 1 genetski algoritam s uniormnim križanjem generirao više opitmalnih rješenja u 1 pokretanja. Za dimenzije 15 i 5 rješenja su provjerena deterministički (prikazuju ih tablice.5,.6 i prilog B), za dimenziju 5 maksimalna vrijednost unkcije cilja (''najveća vrijednost zlata koje može stati u naprtnjaču'') iznosi 155, a za dimenziju 1 maksimalna vrijednost iznosi 671. Pritom je rješenje za n=5 vrlo vjerojatno optimalno rješenje jer su svi algoritmi došli do tog rješenja a osim toga rješenje je bilo vrlo učestalo kod robusnijeg pokretanja algoritma (primjerice, kod genetskog 3
24 algoritma sa uniormnim križanjem pokrenutog s parametrima t=1, VEL_POP=1, p m =.1, 9 od 1 rezultata iznosilo je 155).. Zaključak Kobminatorički problem poznat pod nazivom problem naptrnjače, koji spada u klasu NP teških problema i koji ima značajnu primjenu kod matematičkog modeliranja, rješavan je pomoću heurističkih algoritama s ciljem njihove usporedbe. Simulirano kaljenje zahtijeva relativno velik broj iteracija a koeicijent hlađenja je potrebno optimirati za dani primjer. Primijećeno je da, kod rješavanja problema s velikim dimenzijama, veći broj iteracija treba pratiti sporije hlađenje (primjerice, rezultat 155 kod trećeg primjera je dosegnut sa brojem iteracija od milijuna i koeicijentom hlađenja ; povećanje samo jednog od tih parametara ne dovodi do boljeg rezultata). Kod tabu pretraživanja nije potreban broj iteracija veći od a duljinu liste je potrebno optimirati za dani primjer. Kako prikazuje tablica.7 ovaj algoritam se pokazao najeikasnijim. Genetski algoritam se pokazao kao najrobusniji te najpouzdaniji za dimenzije do 5. Zabilježen je ponajveći broj nađenih optimalnih rješenja a ostala su bila s malim odstupanjem od optimuma. Algoritam je najosjetljiviji na vjerojatnost mutacije, koju je potrebno optimirati za dani primjer. Primijećeno je da je kod većih dimenzija eikasniji genetski algoritam s uniormnim križanjem, dok su kod manjih dimenzija genetski algoritmi podjednako eikasni. Broj izračuna unkcije cilja n Prostor GA, GA, rješenja ( n SA TS ) jednostavni s uniorm. s elim. sel. križanjem >1 18 >5 >5 Tablica.7 Usporedba eikasnosti algoritama na problemu naprtnjače Budući da je kod algoritama temeljna operacija, o kojoj najviše ovisi vrijeme rada algoritma, izračun unkcije cilja 9 algoritme smo usporedili po broju izračuna unkcije cilja (jedino je genetski algoritam vremenski još zahtjevniji zbog operacija selekcije, križanja i mutacije). 9 Kod simuliranog kaljenja, broj izračuna unkcije cilja jednak je broju iteracija, kod tabu pretraživanja u svakoj se iteraciji izračuna n-l vrijednosti unkcija proita a kod genetskog algoritma u svakoj se generaciji-iteraciji svakoj jedinki u populaciji računa proit.
25 5. Usporedba heurističkih algoritama na problemu n- kraljica U radu se uspoređuju heuristički algoritmi simulirano kaljenje, tabu pretraživanje i genetski algoritam na primjeru problema n-kraljica. Opisane su heuristike i prikazani rezultati testiranja za pojedini algoritam. Izvedeni su zaključci o primjeni heurističkih algoritama na ovoj NP klasi problema, kao i njihova usporedba. 5.1 Problem n-kraljica Problem 8 kraljica je klasični kombinatorički problem u kojem se traži takav raspored kraljica na šahovskoj ploči da se kraljice međusobno ne napadaju. Ovaj se problem može poopćiti zadavanjem bilo kojeg broja kraljica, odnosno dimenzija šahovske ploče (na šahovski ploču n n treba smjestiti n kraljica; n>3), pa govorimo o problemu n-kraljica. Dok je za manji broj kraljica problem još moguće riješiti determinističkim metodama, za veći n to postaje nepraktično. Budući da je složenost ovog problema O (n!) koristiti će se heuristički algoritmi. U svakom od uspoređivanih algoritama, rješenje će se zapisivati u obliku uređene n- torke ( q 1, q,..., qn ) koja može biti bilo koja permutacija skupa ( 1,,..., n ). Pri tome indeks, tj. pozicija broja u vektoru, predstavlja stupac a njegova vrijednost redak u kojem se kraljica nalazi (brojeći odozdo prema gore). Slika 5.1 prikazuje notacije rješenja za problem -kraljice. K K K K K K K (,,3,1) (3,1,,) Slika 5.1 Primjeri notacije rješenja za problem -kraljice Budući da se prema ovako zapisanom raporedu kraljica one ne mogu napadati horizontalno niti vertikalno, unkcija cilja jedino treba obraćati pozornost na konlikte po dijagonalama. Stoga se unkcija cilja 1 deinira na način: ako je na nekoj dijagonali n kraljica, broj konlikata je n-1. Prebrojiti treba lijeve i desne dijagonale (sl. 5.), a unkcija vraća ukupni broj konikata. K Treća lijeva dijagonala Druga desna dijagonala Slika 5. Funkcija cilja vraća broj konlikata po dijagonalama 1 Pseudokod unkcije preuzet iz rada Božiković, Golub, Budin, ''Solving n-queen problem using global parallel genetic algorithm'', Eurocon 3, Ljubljana, Slovenija 5
26 5. Opis heuristika Kao i u prethodna dva istraživanja i u ovome radu se nastojalo da heuristike budu što je moguće jednostavnije i što sličnije kako bi algoritmi bili što usporedljiviji; dakako vodeći brigu o tome da što uspješnije rješavaju zadani problem. Element koji se javlja u sva tri algoritma je zamjena dvaju slučajno odabranih pozicija. Točnije, u simuliranom kaljenju taj mehanizam čini cijelu heuristiku, dok se kod tabu pretraživanja pozicije zamjenjuju slijedno kako bi se susjedstvo danog rješenja iscrpno pretražilo. Dakle, kod tabu pretraživanja susjedstvo čine ona rješenja koja se od danog mogu generirati zamjenom svih parova pozicija. Takav odabir čini ovu heuristiku prilično složenom, gornja granica složenosti iznosi ( n 1) n O. Broj izračuna unkcije cilja u pojedinoj iteraciji onoliko je manji je od ovog broja koliko je parova u tabu listi. Kod genetskog algoritma zamjena dvaju slučajno odabranih pozicija prisutna je u operatoru mutacije. Koristi se 3-turnirska selekcija a križanje se izvodi tako da se podudarne pozicije kod roditelja prenose na dijete a preostale pozicije se generiraju slučajno - pazeći da kromosom bude pravilan Rezultati testiranja Rezultate rješavanja problema n-kraljica simuliranim kaljenjem prikazuje tablica 5.1. Vidljiva je korelacija između broja potrebnih iteracija i broja kraljica. Što je n veći to je više iteracija potrebno da bi se generiralo rješenje, no rast je puno sporiji sa n nego prostor rješenja (n!). U načelu, paramerar α potrebno je optimirati za pojedini slučaj, međutim pokazalo se da je za sve n optimum oko.99. α c max n Broj rješenja u 1 pokretanja Tablica 5.1 Rezultati rješavanja n-kraljica simuliranim kaljenjem, T =1 11 Prema Božiković, Golub, Budin, ''Solving n-queen problem using global parallel genetic algorithm'', Eurocon 3, Ljubljana, Slovenija 6
27 Kod tabu pretraživanja primjetno je da je bolje kad su za veći n veći i L i broj iteracija. Primjerice, za n>=3 nije bilo moguće pronaći traženi raspored kraljica sa c ma x =1. Rezultate prikazuje tablica 5.. L c max n Broj rješenja u 1 pokretanja (od pokretanja) Tablica 5. Rezultati rješavanja n-kraljica tabu pretraživanjem Opisani genetski algoritam pokrenut je s populacijom od 1 jedinki i vjerojatnošću mutacije., dok je kao uvjet završetka evolucije postavljeno nalaženje traženog rješenja (tj. da unkcija cilja vrati nulu). Rezultate prikazuje tablica 5.3. n Broj iteracija do prvog rješenja Tablica 5.3 Rezultati rješavanja n-kraljica genetskim algoritmom, za p m =., VEL_POP=1 5. Zaključak I kod ovog je problema temeljna operacija, o kojoj najviše ovisi vrijeme rada algoritma, izračun unkcije cilja. Kod simuliranog kaljenja broj izračuna unkcije cilja jednak je broju iteracija, dok su kod ostala dva algoritma heuristike složenije te u pojedinom koraku unkciju cilja računaju više puta. Simulirano kaljenje je jedini algoritam koji je u praktičnom vremenu sposoban riješiti probleme s vrlo velikim brojem kraljica. Isto je moguće postići i genetskim algoritmom ako se koriste paralelna računala (Božiković, Golub, Budin, 3). Algoritme smo usporedili po broju izračuna unkcije cilja (tablica 5.). Pokazalo se da je simulirano kaljenje najeikasniji algoritam. Kod tog algoritma broj izračuna unkcije cilja najsporije raste s dimenzijom problema. 7
28 n Prostor rješenja Broj izračuna unkcije cilja (n!) SA TS GA Tablica 5. Usporedba algoritama na problemu n-kraljica 8
29 6. Zaključak Rad se bavi usporedbom heurističkih agloritama na tri klase problema. Heuristički algoritmi penjanje uzbrdo, simulirano kaljenje, tabu pretraživanje i genetski algoritam uspoređeni su na primjeru optimiranja realne unkcije jedne varijable. Na NP teškim problemima naprtnjače i n-kraljica uspoređeni su algoritmi simulirano kaljenje, tabu pretraživanje i genetski algoritmi. Za svaku od tri odabrane klase problema najprije su osmišljene i implementirane heuristike, nakon čega su provedeni usporedni testovi te izvedeni zaključci. Pri kreiranju heuristika pokazalo se da konceptualno vrlo jednostavne ideje mogu biti vrlo uspješne u rješavanju danog problema (kao, primjerice, kad susjedstvo čine vektori s Hammingovom udaljenošću jednakom 1). Također je za primijetiti da iste heuristike mogu biti primjenjive na različitim problemima. Tako kod simuliranog kaljenja, heuristika koja od danog rješenja novog kandidata generira promjenom slučajno odabranog bita, uspješno rješava i optimiranje unkcija i problem naprtnjače. Analogno vrijedi i za genetski algoritam, kojem je to opća karakteristika. Kod optimiranja unkcija sva četiri uspoređivana algoritma pokazala su se vrlo uspješna, došavši do rješenja tražene točnosti u većini pokretanja. Budući da je od tri klase problema optimiranje unkcija bilo najmanje zahtjevno, ovdje su algoritmi uspoređivani po kriterijima eikasnosti (broj potrebnih iteracija/izračuna vrijednosti unkcije cilja) i pouzdanosti (vjerojatnost da je dobiveno rješenje optimalno, te očekivano odstupanje najlošijeg rješenja). Usporedne rezultate prikazuje tablica 3.1. Kao najeikasniji, najprecizniji i najpouzdaniji pokazao se algoritam penjanje uzbrdo, koji je ujedno i konceptualno najjednostavniji među analiziranim algoritmima. Za sve testirane unkcije, penjanjem uzbrdo, optimumi su nađeni u svakom pokretanju na točnost od 15 decimala u svega nekoliko iteracija. Primijećeno je, sukladno očekivanju, da je globalni optimum to teže pronaći što je omjer širine prostora rješenja na kojem se nalazi globalni optimum i prostora rješenja manji i što je vrijednost lokalnih optimuma bliža vrijednosti globalnog optimuma. Kod problema naprtnjače i problema n-kraljica algoritmi su uspoređivani prema broju izračuna unkcije cilja za zadanu dimenziju problema, budući da o toj operaciji najviše ovisi vrijeme rada algoritma. Izuzetak po tom pitanju je jedino genetski algoritam koji još dodatno zahtijeva vrijeme za križanje i druge operacije. Za problem naprtnjače sumarne rezultate prikazuje tablica.7. Kod problema n-kraljica najeikasnijim se pokazalo simulirano kaljenje. Jedino je tim algoritmom bilo moguće riješiti probleme s velikim brojem kraljica (1) u praktičnom vremenu. Usporedne testove, koji prikazuju ovisnost broja izračuna unkcije cilja o dimenziji problema, za pojedini algoritam, prikazuje tablica 5.. Kod genetskih algoritama, uniormno križanje se pokazalo uspješnije od križanja s jednom točkom prekida. Svi testovi potvrđuju opće karakteristike genetskih algoritama kao što su univerzalnost u rješavanju problema, pouzdanost i osjetljivost na vjerojatnost mutacije. 9
3.1 Granična vrednost funkcije u tački
3 Granična vrednost i neprekidnost funkcija 2 3 Granična vrednost i neprekidnost funkcija 3. Granična vrednost funkcije u tački Neka je funkcija f(x) definisana u tačkama x za koje je 0 < x x 0 < r, ili
2 tg x ctg x 1 = =, cos 2x Zbog četvrtog kvadranta rješenje je: 2 ctg x
Zadatak (Darjan, medicinska škola) Izračunaj vrijednosti trigonometrijskih funkcija broja ako je 6 sin =,,. 6 Rješenje Ponovimo trigonometrijske funkcije dvostrukog kuta! Za argument vrijede sljedeće formule:
ELEKTROTEHNIČKI ODJEL
MATEMATIKA. Neka je S skup svih živućih državljana Republike Hrvatske..04., a f preslikavanje koje svakom elementu skupa S pridružuje njegov horoskopski znak (bez podznaka). a) Pokažite da je f funkcija,
M086 LA 1 M106 GRP. Tema: Baza vektorskog prostora. Koordinatni sustav. Norma. CSB nejednakost
M086 LA 1 M106 GRP Tema: CSB nejednakost. 19. 10. 2017. predavač: Rudolf Scitovski, Darija Marković asistent: Darija Brajković, Katarina Vincetić P 1 www.fizika.unios.hr/grpua/ 1 Baza vektorskog prostora.
Linearna algebra 2 prvi kolokvij,
1 2 3 4 5 Σ jmbag smjer studija Linearna algebra 2 prvi kolokvij, 7. 11. 2012. 1. (10 bodova) Neka je dano preslikavanje s : R 2 R 2 R, s (x, y) = (Ax y), pri čemu je A: R 2 R 2 linearan operator oblika
TRIGONOMETRIJSKE FUNKCIJE I I.1.
TRIGONOMETRIJSKE FUNKCIJE I I Odredi na brojevnoj trigonometrijskoj kružnici točku Et, za koju je sin t =,cost < 0 Za koje realne brojeve a postoji realan broj takav da je sin = a? Izračunaj: sin π tg
UNIVERZITET U NIŠU ELEKTRONSKI FAKULTET SIGNALI I SISTEMI. Zbirka zadataka
UNIVERZITET U NIŠU ELEKTRONSKI FAKULTET Goran Stančić SIGNALI I SISTEMI Zbirka zadataka NIŠ, 014. Sadržaj 1 Konvolucija Literatura 11 Indeks pojmova 11 3 4 Sadržaj 1 Konvolucija Zadatak 1. Odrediti konvoluciju
radni nerecenzirani materijal za predavanja R(f) = {f(x) x D}
Matematika 1 Funkcije radni nerecenzirani materijal za predavanja Definicija 1. Neka su D i K bilo koja dva neprazna skupa. Postupak f koji svakom elementu x D pridružuje točno jedan element y K zovemo funkcija
Sortiranje prebrajanjem (Counting sort) i Radix Sort
Sortiranje prebrajanjem (Counting sort) i Radix Sort 15. siječnja 2016. Ante Mijoč Uvod Teorem Ako je f(n) broj usporedbi u algoritmu za sortiranje temeljenom na usporedbama (eng. comparison-based sorting
Riješeni zadaci: Limes funkcije. Neprekidnost
Riješeni zadaci: Limes funkcije. Neprekidnost Limes funkcije Neka je 0 [a, b] i f : D R, gdje je D = [a, b] ili D = [a, b] \ { 0 }. Kažemo da je es funkcije f u točki 0 jednak L i pišemo f ) = L, ako za
Linearna algebra 2 prvi kolokvij,
Linearna algebra 2 prvi kolokvij, 27.. 20.. Za koji cijeli broj t je funkcija f : R 4 R 4 R definirana s f(x, y) = x y (t + )x 2 y 2 + x y (t 2 + t)x 4 y 4, x = (x, x 2, x, x 4 ), y = (y, y 2, y, y 4 )
18. listopada listopada / 13
18. listopada 2016. 18. listopada 2016. 1 / 13 Neprekidne funkcije Važnu klasu funkcija tvore neprekidne funkcije. To su funkcije f kod kojih mala promjena u nezavisnoj varijabli x uzrokuje malu promjenu
1.4 Tangenta i normala
28 1 DERIVACIJA 1.4 Tangenta i normala Ako funkcija f ima derivaciju u točki x 0, onda jednadžbe tangente i normale na graf funkcije f u točki (x 0 y 0 ) = (x 0 f(x 0 )) glase: t......... y y 0 = f (x
INTEGRALNI RAČUN. Teorije, metodike i povijest infinitezimalnih računa. Lucija Mijić 17. veljače 2011.
INTEGRALNI RAČUN Teorije, metodike i povijest infinitezimalnih računa Lucija Mijić lucija@ktf-split.hr 17. veljače 2011. Pogledajmo Predstavimo gornju sumu sa Dodamo još jedan Dobivamo pravokutnik sa Odnosno
Osnovni primer. (Z, +,,, 0, 1) je komutativan prsten sa jedinicom: množenje je distributivno prema sabiranju
RAČUN OSTATAKA 1 1 Prsten celih brojeva Z := N + {} N + = {, 3, 2, 1,, 1, 2, 3,...} Osnovni primer. (Z, +,,,, 1) je komutativan prsten sa jedinicom: sabiranje (S1) asocijativnost x + (y + z) = (x + y)
Strukture podataka i algoritmi 1. kolokvij 16. studenog Zadatak 1
Strukture podataka i algoritmi 1. kolokvij Na kolokviju je dozvoljeno koristiti samo pribor za pisanje i službeni šalabahter. Predajete samo papire koje ste dobili. Rezultati i uvid u kolokvije: ponedjeljak,
1 Promjena baze vektora
Promjena baze vektora Neka su dane dvije različite uredene baze u R n, označimo ih s A = (a, a,, a n i B = (b, b,, b n Svaki vektor v R n ima medusobno različite koordinatne zapise u bazama A i B Zapis
radni nerecenzirani materijal za predavanja
Matematika 1 Funkcije radni nerecenzirani materijal za predavanja Definicija 1. Kažemo da je funkcija f : a, b R u točki x 0 a, b postiže lokalni minimum ako postoji okolina O(x 0 ) broja x 0 takva da je
Računarska grafika. Rasterizacija linije
Računarska grafika Osnovni inkrementalni algoritam Drugi naziv u literaturi digitalni diferencijalni analizator (DDA) Pretpostavke (privremena ograničenja koja se mogu otkloniti jednostavnim uopštavanjem
Matematička analiza 1 dodatni zadaci
Matematička analiza 1 dodatni zadaci 1. Ispitajte je li funkcija f() := 4 4 5 injekcija na intervalu I, te ako jest odredite joj sliku i inverz, ako je (a) I = [, 3), (b) I = [1, ], (c) I = ( 1, 0].. Neka
Trigonometrija 2. Adicijske formule. Formule dvostrukog kuta Formule polovičnog kuta Pretvaranje sume(razlike u produkt i obrnuto
Trigonometrija Adicijske formule Formule dvostrukog kuta Formule polovičnog kuta Pretvaranje sume(razlike u produkt i obrnuto Razumijevanje postupka izrade složenijeg matematičkog problema iz osnova trigonometrije
a M a A. Može se pokazati da je supremum (ako postoji) jedinstven pa uvodimo oznaku sup A.
3 Infimum i supremum Definicija. Neka je A R. Kažemo da je M R supremum skupa A ako je (i) M gornja meda skupa A, tj. a M a A. (ii) M najmanja gornja meda skupa A, tj. ( ε > 0)( a A) takav da je a > M
7 Algebarske jednadžbe
7 Algebarske jednadžbe 7.1 Nultočke polinoma Skup svih polinoma nad skupom kompleksnih brojeva označavamo sa C[x]. Definicija. Nultočka polinoma f C[x] je svaki kompleksni broj α takav da je f(α) = 0.
DISKRETNA MATEMATIKA - PREDAVANJE 7 - Jovanka Pantović
DISKRETNA MATEMATIKA - PREDAVANJE 7 - Jovanka Pantović Novi Sad April 17, 2018 1 / 22 Teorija grafova April 17, 2018 2 / 22 Definicija Graf je ure dena trojka G = (V, G, ψ), gde je (i) V konačan skup čvorova,
Ĉetverokut - DOMAĆA ZADAĆA. Nakon odgledanih videa trebali biste biti u stanju samostalno riješiti sljedeće zadatke.
Ĉetverokut - DOMAĆA ZADAĆA Nakon odgledanih videa trebali biste biti u stanju samostalno riješiti sljedeće zadatke. 1. Duljine dijagonala paralelograma jednake su 6,4 cm i 11 cm, a duljina jedne njegove
numeričkih deskriptivnih mera.
DESKRIPTIVNA STATISTIKA Numeričku seriju podataka opisujemo pomoću Numeričku seriju podataka opisujemo pomoću numeričkih deskriptivnih mera. Pokazatelji centralne tendencije Aritmetička sredina, Medijana,
Numerička matematika 2. kolokvij (1. srpnja 2009.)
Numerička matematika 2. kolokvij (1. srpnja 29.) Zadatak 1 (1 bodova.) Teorijsko pitanje. (A) Neka je G R m n, uz m n, pravokutna matrica koja ima puni rang po stupcima, tj. rang(g) = n. (a) Napišite puni
PRAVA. Prava je u prostoru određena jednom svojom tačkom i vektorom paralelnim sa tom pravom ( vektor paralelnosti).
PRAVA Prava je kao i ravan osnovni geometrijski ojam i ne definiše se. Prava je u rostoru određena jednom svojom tačkom i vektorom aralelnim sa tom ravom ( vektor aralelnosti). M ( x, y, z ) 3 Posmatrajmo
Operacije s matricama
Linearna algebra I Operacije s matricama Korolar 3.1.5. Množenje matrica u vektorskom prostoru M n (F) ima sljedeća svojstva: (1) A(B + C) = AB + AC, A, B, C M n (F); (2) (A + B)C = AC + BC, A, B, C M
Tri osnovna tipa optimizacije struktura. Topološka optimizacija betonskih konstrukcija. Dimenzionalna optimizacija. Optimizacija oblika
Topološka optimizacija betonskih konstrukcija Tri osnovna tipa optimizacije struktura. Dimenzionalna optimizacija (sizing optimization). Optimizacija oblika (shape optimization) 3. Topološka optimizacija
3 Populacija i uzorak
3 Populacija i uzorak 1 3.1 Slučajni uzorak X varijabla/stat. obilježje koje izučavamo Cilj statističke analize na osnovi uzorka izvesti odredene zaključke o (populacijskoj) razdiobi od X 2 Primjer 3.1.
Računarska grafika. Rasterizacija linije
Računarska grafika Osnovni inkrementalni algoritam Drugi naziv u literaturi digitalni diferencijalni analizator (DDA) Pretpostavke (privremena ograničenja koja se mogu otkloniti jednostavnim uopštavanjem
Iskazna logika 3. Matematička logika u računarstvu. novembar 2012
Iskazna logika 3 Matematička logika u računarstvu Department of Mathematics and Informatics, Faculty of Science,, Serbia novembar 2012 Deduktivni sistemi 1 Definicija Deduktivni sistem (ili formalna teorija)
Elementi spektralne teorije matrica
Elementi spektralne teorije matrica Neka je X konačno dimenzionalan vektorski prostor nad poljem K i neka je A : X X linearni operator. Definicija. Skalar λ K i nenula vektor u X se nazivaju sopstvena
(P.I.) PRETPOSTAVKA INDUKCIJE - pretpostavimo da tvrdnja vrijedi za n = k.
1 3 Skupovi brojeva 3.1 Skup prirodnih brojeva - N N = {1, 2, 3,...} Aksiom matematičke indukcije Neka je N skup prirodnih brojeva i M podskup od N. Ako za M vrijede svojstva: 1) 1 M 2) n M (n + 1) M,
Neka je a 3 x 3 + a 2 x 2 + a 1 x + a 0 = 0 algebarska jednadžba trećeg stupnja. Rješavanje ove jednadžbe sastoji se od nekoliko koraka.
Neka je a 3 x 3 + a x + a 1 x + a 0 = 0 algebarska jednadžba trećeg stupnja. Rješavanje ove jednadžbe sastoji se od nekoliko koraka. 1 Normiranje jednadžbe. Jednadžbu podijelimo s a 3 i dobivamo x 3 +
Pismeni ispit iz matematike Riješiti sistem jednačina i diskutovati rješenja sistema u zavisnosti od parametra: ( ) + 1.
Pismeni ispit iz matematike 0 008 GRUPA A Riješiti sistem jednačina i diskutovati rješenja sistema u zavisnosti od parametra: λ + z = Ispitati funkciju i nacrtati njen grafik: + ( λ ) + z = e Izračunati
VJEROJATNOST I STATISTIKA Popravni kolokvij - 1. rujna 2016.
Broj zadataka: 5 Vrijeme rješavanja: 120 min Ukupan broj bodova: 100 Zadatak 1. (a) Napišite aksiome vjerojatnosti ako je zadan skup Ω i σ-algebra F na Ω. (b) Dokažite iz aksioma vjerojatnosti da za A,
Veleučilište u Rijeci Stručni studij sigurnosti na radu Akad. god. 2011/2012. Matematika. Monotonost i ekstremi. Katica Jurasić. Rijeka, 2011.
Veleučilište u Rijeci Stručni studij sigurnosti na radu Akad. god. 2011/2012. Matematika Monotonost i ekstremi Katica Jurasić Rijeka, 2011. Ishodi učenja - predavanja Na kraju ovog predavanja moći ćete:,
( , 2. kolokvij)
A MATEMATIKA (0..20., 2. kolokvij). Zadana je funkcija y = cos 3 () 2e 2. (a) Odredite dy. (b) Koliki je nagib grafa te funkcije za = 0. (a) zadanu implicitno s 3 + 2 y = sin y, (b) zadanu parametarski
Kontrolni zadatak (Tačka, prava, ravan, diedar, poliedar, ortogonalna projekcija), grupa A
Kontrolni zadatak (Tačka, prava, ravan, diedar, poliedar, ortogonalna projekcija), grupa A Ime i prezime: 1. Prikazane su tačke A, B i C i prave a,b i c. Upiši simbole Î, Ï, Ì ili Ë tako da dobijeni iskazi
IZVODI ZADACI (I deo)
IZVODI ZADACI (I deo) Najpre da se podsetimo tablice i osnovnih pravila:. C`=0. `=. ( )`= 4. ( n )`=n n-. (a )`=a lna 6. (e )`=e 7. (log a )`= 8. (ln)`= ` ln a (>0) 9. = ( 0) 0. `= (>0) (ovde je >0 i a
Riješeni zadaci: Nizovi realnih brojeva
Riješei zadaci: Nizovi realih brojeva Nizovi, aritmetički iz, geometrijski iz Fukciju a : N R azivamo beskoači) iz realih brojeva i ozačavamo s a 1, a,..., a,... ili a ), pri čemu je a = a). Aritmetički
Kaskadna kompenzacija SAU
Kaskadna kompenzacija SAU U inženjerskoj praksi, naročito u sistemima regulacije elektromotornih pogona i tehnoloških procesa, veoma često se primenjuje metoda kaskadne kompenzacije, u čijoj osnovi su
Apsolutno neprekidne raspodele Raspodele apsolutno neprekidnih sluqajnih promenljivih nazivaju se apsolutno neprekidnim raspodelama.
Apsolutno neprekidne raspodele Raspodele apsolutno neprekidnih sluqajnih promenljivih nazivaju se apsolutno neprekidnim raspodelama. a b Verovatno a da sluqajna promenljiva X uzima vrednost iz intervala
π π ELEKTROTEHNIČKI ODJEL i) f (x) = x 3 x 2 x + 1, a = 1, b = 1;
1. Provjerite da funkcija f definirana na segmentu [a, b] zadovoljava uvjete Rolleova poučka, pa odredite barem jedan c a, b takav da je f '(c) = 0 ako je: a) f () = 1, a = 1, b = 1; b) f () = 4, a =,
IspitivaƬe funkcija: 1. Oblast definisanosti funkcije (ili domen funkcije) D f
IspitivaƬe funkcija: 1. Oblast definisanosti funkcije (ili domen funkcije) D f IspitivaƬe funkcija: 1. Oblast definisanosti funkcije (ili domen funkcije) D f 2. Nule i znak funkcije; presek sa y-osom IspitivaƬe
Eliminacijski zadatak iz Matematike 1 za kemičare
Za mnoge reakcije vrijedi Arrheniusova jednadžba, koja opisuje vezu koeficijenta brzine reakcije i temperature: K = Ae Ea/(RT ). - T termodinamička temperatura (u K), - R = 8, 3145 J K 1 mol 1 opća plinska
( ) ( ) 2 UNIVERZITET U ZENICI POLITEHNIČKI FAKULTET. Zadaci za pripremu polaganja kvalifikacionog ispita iz Matematike. 1. Riješiti jednačine: 4
UNIVERZITET U ZENICI POLITEHNIČKI FAKULTET Riješiti jednačine: a) 5 = b) ( ) 3 = c) + 3+ = 7 log3 č) = 8 + 5 ć) sin cos = d) 5cos 6cos + 3 = dž) = đ) + = 3 e) 6 log + log + log = 7 f) ( ) ( ) g) ( ) log
21. ŠKOLSKO/OPĆINSKO/GRADSKO NATJECANJE IZ GEOGRAFIJE GODINE 8. RAZRED TOČNI ODGOVORI
21. ŠKOLSKO/OPĆINSKO/GRADSKO NATJECANJE IZ GEOGRAFIJE 2014. GODINE 8. RAZRED TOČNI ODGOVORI Bodovanje za sve zadatke: - boduju se samo točni odgovori - dodatne upute navedene su za pojedine skupine zadataka
Funkcije dviju varjabli (zadaci za vježbu)
Funkcije dviju varjabli (zadaci za vježbu) Vidosava Šimić 22. prosinca 2009. Domena funkcije dvije varijable Ako je zadano pridruživanje (x, y) z = f(x, y), onda se skup D = {(x, y) ; f(x, y) R} R 2 naziva
IZRAČUNAVANJE POKAZATELJA NAČINA RADA NAČINA RADA (ISKORIŠĆENOSTI KAPACITETA, STEPENA OTVORENOSTI RADNIH MESTA I NIVOA ORGANIZOVANOSTI)
IZRAČUNAVANJE POKAZATELJA NAČINA RADA NAČINA RADA (ISKORIŠĆENOSTI KAPACITETA, STEPENA OTVORENOSTI RADNIH MESTA I NIVOA ORGANIZOVANOSTI) Izračunavanje pokazatelja načina rada OTVORENOG RM RASPOLOŽIVO RADNO
41. Jednačine koje se svode na kvadratne
. Jednačine koje se svode na kvadrane Simerične recipročne) jednačine Jednačine oblika a n b n c n... c b a nazivamo simerične jednačine, zbog simeričnosi koeficijenaa koeficijeni uz jednaki). k i n k
PARCIJALNI IZVODI I DIFERENCIJALI. Sama definicija parcijalnog izvoda i diferencijala je malo teža, mi se njome ovde nećemo baviti a vi ćete je,
PARCIJALNI IZVODI I DIFERENCIJALI Sama definicija parcijalnog ivoda i diferencijala je malo teža, mi se njome ovde nećemo baviti a vi ćete je, naravno, naučiti onako kako vaš profesor ahteva. Mi ćemo probati
Dijagonalizacija operatora
Dijagonalizacija operatora Problem: Može li se odrediti baza u kojoj zadani operator ima dijagonalnu matricu? Ova problem je povezan sa sljedećim pojmovima: 1 Karakteristični polinom operatora f 2 Vlastite
9. GRANIČNA VRIJEDNOST I NEPREKIDNOST FUNKCIJE GRANIČNA VRIJEDNOST ILI LIMES FUNKCIJE
Geodetski akultet, dr sc J Beban-Brkić Predavanja iz Matematike 9 GRANIČNA VRIJEDNOST I NEPREKIDNOST FUNKCIJE GRANIČNA VRIJEDNOST ILI LIMES FUNKCIJE Granična vrijednost unkcije kad + = = Primjer:, D( )
MATEMATIKA Pokažite da za konjugiranje (a + bi = a bi) vrijedi. a) z=z b) z 1 z 2 = z 1 z 2 c) z 1 ± z 2 = z 1 ± z 2 d) z z= z 2
(kompleksna analiza, vježbe ). Izračunajte a) (+i) ( i)= b) (i+) = c) i + i 4 = d) i+i + i 3 + i 4 = e) (a+bi)(a bi)= f) (+i)(i )= Skicirajte rješenja u kompleksnoj ravnini.. Pokažite da za konjugiranje
SISTEMI NELINEARNIH JEDNAČINA
SISTEMI NELINEARNIH JEDNAČINA April, 2013 Razni zapisi sistema Skalarni oblik: Vektorski oblik: F = f 1 f n f 1 (x 1,, x n ) = 0 f n (x 1,, x n ) = 0, x = (1) F(x) = 0, (2) x 1 0, 0 = x n 0 Definicije
Više dokaza jedne poznate trigonometrijske nejednakosti u trokutu
Osječki matematički list 000), 5 9 5 Više dokaza jedne poznate trigonometrijske nejednakosti u trokutu Šefket Arslanagić Alija Muminagić Sažetak. U radu se navodi nekoliko različitih dokaza jedne poznate
Modificiran genetski algoritam za konstrukciju BIBD-a. Odjel za matematiku, Sveučilište u Rijeci
Modificiran genetski algoritam za konstrukciju BIBD-a Doris Dumičić (ddumicic@math.uniri.hr) Odjel za matematiku, Sveučilište u Rijeci Doris Dumičić (ddumicic@math.uniri.hr) Odjel Modificiran za matematiku,
MATRICE I DETERMINANTE - formule i zadaci - (Matrice i determinante) 1 / 15
MATRICE I DETERMINANTE - formule i zadaci - (Matrice i determinante) 1 / 15 Matrice - osnovni pojmovi (Matrice i determinante) 2 / 15 (Matrice i determinante) 2 / 15 Matrice - osnovni pojmovi Matrica reda
( x) ( ) ( ) ( x) ( ) ( x) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( )
Zadatak 08 (Vedrana, maturantica) Je li unkcija () = cos (sin ) sin (cos ) parna ili neparna? Rješenje 08 Funkciju = () deiniranu u simetričnom području a a nazivamo: parnom, ako je ( ) = () neparnom,
( ) ( ) Zadatak 001 (Ines, hotelijerska škola) Ako je tg x = 4, izračunaj
Zadaak (Ines, hoelijerska škola) Ako je g, izračunaj + 5 + Rješenje Korisimo osnovnu rigonomerijsku relaciju: + Znači svaki broj n možemo zapisai n n n ( + ) + + + + 5 + 5 5 + + + + + 7 + Zadano je g Tangens
RIJEŠENI ZADACI I TEORIJA IZ
RIJEŠENI ZADACI I TEORIJA IZ LOGARITAMSKA FUNKCIJA SVOJSTVA LOGARITAMSKE FUNKCIJE OSNOVE TRIGONOMETRIJE PRAVOKUTNOG TROKUTA - DEFINICIJA TRIGONOMETRIJSKIH FUNKCIJA - VRIJEDNOSTI TRIGONOMETRIJSKIH FUNKCIJA
Zadaci sa prethodnih prijemnih ispita iz matematike na Beogradskom univerzitetu
Zadaci sa prethodnih prijemnih ispita iz matematike na Beogradskom univerzitetu Trigonometrijske jednačine i nejednačine. Zadaci koji se rade bez upotrebe trigonometrijskih formula. 00. FF cos x sin x
TRIGONOMETRIJA TROKUTA
TRIGONOMETRIJA TROKUTA Standardne oznake u trokutuu ABC: a, b, c stranice trokuta α, β, γ kutovi trokuta t,t,t v,v,v s α,s β,s γ R r s težišnice trokuta visine trokuta simetrale kutova polumjer opisane
Determinante. a11 a. a 21 a 22. Definicija 1. (Determinanta prvog reda) Determinanta matrice A = [a] je broj a.
Determinante Determinanta A deta je funkcija definirana na skupu svih kvadratnih matrica, a poprima vrijednosti iz skupa skalara Osim oznake deta za determinantu kvadratne matrice a 11 a 12 a 1n a 21 a
Ispitivanje toka i skiciranje grafika funkcija
Ispitivanje toka i skiciranje grafika funkcija Za skiciranje grafika funkcije potrebno je ispitati svako od sledećih svojstava: Oblast definisanosti: D f = { R f R}. Parnost, neparnost, periodičnost. 3
PRIMJENA GENETSKIH ALGORITAMA U MREŽNOM PLANIRANJU
SVEUČILIŠTE U ZAGREBU FAKULTET ELEKTROTEHNIKE I RAČUNARSTVA ZAVOD ZA ELEKTRONIKU, MIKROELEKTRONIKU, RAČUNALNE I INTELIGENTNE SUSTAVE SEMINARSKI RAD PRIMJENA GENETSKIH ALGORITAMA U MREŽNOM PLANIRANJU Toni
Zavrxni ispit iz Matematiqke analize 1
Građevinski fakultet Univerziteta u Beogradu 3.2.2016. Zavrxni ispit iz Matematiqke analize 1 Prezime i ime: Broj indeksa: 1. Definisati Koxijev niz. Dati primer niza koji nije Koxijev. 2. Dat je red n=1
Matematičke metode u marketingumultidimenzionalno skaliranje. Lavoslav ČaklovićPMF-MO
Matematičke metode u marketingu Multidimenzionalno skaliranje Lavoslav Čaklović PMF-MO 2016 MDS Čemu služi: za redukciju dimenzije Bazirano na: udaljenosti (sličnosti) među objektima Problem: Traži se
Sume kvadrata. mn = (ax + by) 2 + (ay bx) 2.
Sume kvadrata Koji se prirodni brojevi mogu prikazati kao zbroj kvadrata dva cijela broja? Propozicija 1. Ako su brojevi m i n sume dva kvadrata, onda je i njihov produkt m n takoder suma dva kvadrata.
Teorijske osnove informatike 1
Teorijske osnove informatike 1 9. oktobar 2014. () Teorijske osnove informatike 1 9. oktobar 2014. 1 / 17 Funkcije Veze me du skupovima uspostavljamo skupovima koje nazivamo funkcijama. Neformalno, funkcija
4. poglavlje (korigirano) LIMESI FUNKCIJA
. Limesi funkcija (sa svim korekcijama) 69. poglavlje (korigirano) LIMESI FUNKCIJA U ovom poglavlju: Neodređeni oblik Neodređeni oblik Neodređeni oblik Kose asimptote Neka je a konačan realan broj ili
GENETSKI ALGORITMI KAO OPTIMIZACIJSKI ALAT - prednosti i nedostaci u odnosu na egzaktne matematičke metode
Fakultet SEMINARKO http://seminarko.weebly.com Seminarski rad iz kolegija XY ak. godina 2008/09. GENETSKI ALGORITMI KAO OPTIMIZACIJSKI ALAT - prednosti i nedostaci u odnosu na egzaktne matematičke metode
INTELIGENTNO UPRAVLJANJE
INTELIGENTNO UPRAVLJANJE Fuzzy sistemi zaključivanja Vanr.prof. Dr. Lejla Banjanović-Mehmedović Mehmedović 1 Osnovni elementi fuzzy sistema zaključivanja Fazifikacija Baza znanja Baze podataka Baze pravila
6 Polinomi Funkcija p : R R zadana formulom
6 Polinomi Funkcija p : R R zadana formulom p(x) = a n x n + a n 1 x n 1 +... + a 1 x + a 0, gdje su a 0, a 1,..., a n realni brojevi, a n 0, i n prirodan broj ili 0, naziva se polinom n-tog stupnja s
Linearna algebra I, zimski semestar 2007/2008
Linearna algebra I, zimski semestar 2007/2008 Predavanja: Nenad Bakić, Vježbe: Luka Grubišić i Maja Starčević 22. listopada 2007. 1 Prostor radijvektora i sustavi linearni jednadžbi Neka je E 3 trodimenzionalni
IZVODI ZADACI ( IV deo) Rešenje: Najpre ćemo logaritmovati ovu jednakost sa ln ( to beše prirodni logaritam za osnovu e) a zatim ćemo
IZVODI ZADACI ( IV deo) LOGARITAMSKI IZVOD Logariamskim izvodom funkcije f(), gde je >0 i, nazivamo izvod logarima e funkcije, o jes: (ln ) f ( ) f ( ) Primer. Nadji izvod funkcije Najpre ćemo logarimovai
5. Karakteristične funkcije
5. Karakteristične funkcije Profesor Milan Merkle emerkle@etf.rs milanmerkle.etf.rs Verovatnoća i Statistika-proleće 2018 Milan Merkle Karakteristične funkcije ETF Beograd 1 / 10 Definicija Karakteristična
PT ISPITIVANJE PENETRANTIMA
FSB Sveučilišta u Zagrebu Zavod za kvalitetu Katedra za nerazorna ispitivanja PT ISPITIVANJE PENETRANTIMA Josip Stepanić SADRŽAJ kapilarni učinak metoda ispitivanja penetrantima uvjeti promatranja SADRŽAJ
- pravac n je zadan s točkom T(2,0) i koeficijentom smjera k=2. (30 bodova)
MEHANIKA 1 1. KOLOKVIJ 04/2008. grupa I 1. Zadane su dvije sile F i. Sila F = 4i + 6j [ N]. Sila je zadana s veličinom = i leži na pravcu koji s koordinatnom osi x zatvara kut od 30 (sve komponente sile
Matematika 1 - vježbe. 11. prosinca 2015.
Matematika - vježbe. prosinca 5. Stupnjevi i radijani Ako je kut φ jednak i rad, tada je veza između i 6 = Zadatak.. Izrazite u stupnjevima: a) 5 b) 7 9 c). d) 7. a) 5 9 b) 7 6 6 = = 5 c). 6 8.5 d) 7.
PRIMJER 3. MATLAB filtdemo
PRIMJER 3. MATLAB filtdemo Prijenosna funkcija (IIR) Hz () =, 6 +, 3 z +, 78 z +, 3 z +, 53 z +, 3 z +, 78 z +, 3 z +, 6 z, 95 z +, 74 z +, z +, 9 z +, 4 z +, 5 z +, 3 z +, 4 z 3 4 5 6 7 8 3 4 5 6 7 8
MATEMATIKA 1 8. domaća zadaća: RADIJVEKTORI. ALGEBARSKE OPERACIJE S RADIJVEKTORIMA. LINEARNA (NE)ZAVISNOST SKUPA RADIJVEKTORA.
Napomena: U svim zadatcima O označava ishodište pravokutnoga koordinatnoga sustava u ravnini/prostoru (tj. točke (0,0) ili (0, 0, 0), ovisno o zadatku), označava skalarni umnožak, a vektorski umnožak.
Uvod u teoriju brojeva
Uvod u teoriju brojeva 2. Kongruencije Borka Jadrijević Borka Jadrijević () UTB 2 1 / 25 2. Kongruencije Kongruencija - izjava o djeljivosti; Teoriju kongruencija uveo je C. F. Gauss 1801. De nicija (2.1)
Umjetna inteligencija
Umjetna inteligencija Genetski algoritam Doc. dr. sc. Edouard Ivanjko Sadržaj Uvod Optimizacijski problemi Princip evolucije Koncept genetskog algoritma Kôdiranje rješenja Genetski operatori Primjer primjene
APROKSIMACIJA FUNKCIJA
APROKSIMACIJA FUNKCIJA Osnovni koncepti Gradimir V. Milovanović MF, Beograd, 14. mart 2011. APROKSIMACIJA FUNKCIJA p.1/46 Osnovni problem u TA Kako za datu funkciju f iz velikog prostora X naći jednostavnu
Grafičko prikazivanje atributivnih i geografskih nizova
Grafičko prikazivanje atributivnih i geografskih nizova Biserka Draščić Ban Pomorski fakultet u Rijeci 17. veljače 2011. Grafičko prikazivanje atributivnih nizova Atributivni nizovi prikazuju se grafički
Osnovne teoreme diferencijalnog računa
Osnovne teoreme diferencijalnog računa Teorema Rolova) Neka je funkcija f definisana na [a, b], pri čemu važi f je neprekidna na [a, b], f je diferencijabilna na a, b) i fa) fb). Tada postoji ξ a, b) tako
POTPUNO RIJEŠENIH ZADATAKA PRIRUČNIK ZA SAMOSTALNO UČENJE
**** MLADEN SRAGA **** 011. UNIVERZALNA ZBIRKA POTPUNO RIJEŠENIH ZADATAKA PRIRUČNIK ZA SAMOSTALNO UČENJE SKUP REALNIH BROJEVA α Autor: MLADEN SRAGA Grafički urednik: BESPLATNA - WEB-VARIJANTA Tisak: M.I.M.-SRAGA
math.e Genetski algoritmi i biomorfi 1 Inspiracija u biologiji Genetski algoritmi i biomorfi math.e Vol of 11
1 of 11 math.e Hrvatski matematički elektronički časopis Genetski algoritmi i biomorfi genetski algoritam grafovi heuristički algoritmi optimizacija Nela Bosner (nela.bosner@math.hr ) i Tomislav Droždjek
Pismeni ispit iz matematike GRUPA A 1. Napisati u trigonometrijskom i eksponencijalnom obliku kompleksni broj, zatim naći 4 z.
Pismeni ispit iz matematike 06 007 Napisati u trigonometrijskom i eksponencijalnom obliku kompleksni broj z = + i, zatim naći z Ispitati funkciju i nacrtati grafik : = ( ) y e + 6 Izračunati integral:
Prostorni spojeni sistemi
Prostorni spojeni sistemi K. F. (poopćeni) pomaci i stupnjevi slobode tijela u prostoru: 1. pomak po pravcu (translacija): dva kuta kojima je odreden orijentirani pravac (os) i orijentirana duljina pomaka
Akvizicija tereta. 5660t. Y= masa drva, X=masa cementa. Na brod će se ukrcati 1733 tona drva i 3927 tona cementa.
Akvizicija tereta. Korisna nosivost broda je 6 t, a na brodu ia 8 cu. ft. prostora raspoloživog za sještaj tereta pod palubu. Navedeni brod treba krcati drvo i ceent, a na palubu ože aksialno ukrcati 34
STATISTIKA S M E I M N I AR R 7 : METODE UZORKA
Fakultet za menadžment u turizmu i ugotiteljtvu, Opatija Sveučilišni preddiplomki tudij Polovna ekonomija u turizmu i ugotiteljtvu Noitelj kolegija: Prof. dr. c. Suzana Marković Aitentica: Jelena Komšić
4 Funkcije. 4.1 Pojam funkcije
4 Funkcije 4.1 Pojam unkcije Neka su i neprazni skupovi i pravilo koje svakom elementu skupa pridružuje točno jedan element skupa. Tada se uredena trojka (,, ) naziva preslikavanje ili unkcija sa skupa
Prikaz sustava u prostoru stanja
Prikaz sustava u prostoru stanja Prikaz sustava u prostoru stanja je jedan od načina prikaza matematičkog modela sustava (uz diferencijalnu jednadžbu, prijenosnu funkciju itd). Promatramo linearne sustave
PISMENI ISPIT IZ STATISTIKE
1. a) Trgovina odjeće prodaje odjeću u tri različite veličine: 32% veličine S, 44% veličine M i ostatak veličine L. Pokazalo se da je postotak odjeće s greškom redom 1%, 5% i 2%. Ako je trgovina ustanovila
Zadaci iz trigonometrije za seminar
Zadaci iz trigonometrije za seminar FON: 1. Vrednost izraza sin 1 cos 6 jednaka je: ; B) 1 ; V) 1 1 + 1 ; G) ; D). 16. Broj rexea jednaqine sin x cos x + cos x = sin x + sin x na intervalu π ), π je: ;