Mesterséges intelligencia 1 előadások
|
|
- Zsófia Gulyás
- 8 évvel ezelőtt
- Látták:
Átírás
1 VÁRTERÉSZ MAGDA Mesterséges intelligencia 1 előadások 2006/07-es tanév
2 Tartalomjegyzék 1. A problémareprezentáció Az állapottér-reprezentáció Példák állapottér-reprezentációra A nyolcas kirakó játék Az állapottérgráf A megoldást kereső rendszerek Nemmódosítható megoldáskereső rendszerek Módosítható megoldáskereső rendszerek Az alap visszalépéses megoldáskeresők Visszalépéses megoldáskeresés köröket is tartalmazó gráfokban Ág és korlát algoritmus Keresőfával keresők Szélességi és mélységi keresők Optimális kereső Best-first algoritmus Az A algoritmus Kétszemélyes stratégiai játékok és lépésajánló algoritmusok A játékok reprezentációja A stratégia
3 Tartalomjegyzék Tartalomjegyzék 3.3. Minimax algoritmus Negamax algoritmus Problémamegoldás redukcióval Problémaredukciós reprezentáció Példák problémaredukciós reprezentációra Hanoi tornyai A problémaredukciós reprezentációt szemléltető gráf Problémaredukcióval reprezentált feladatok megoldáskereső módszerei Visszalépéses megoldáskeresés ÉS/VAGY fák esetén Keresőfával megoldáskeresés ÉS/VAGY fák esetén
4 1. fejezet A problémareprezentáció A mesterséges intelligencia problémáinak megoldása a probléma megfogalmazásával kezdődik: a problémát leírjuk, reprezentáljuk. Az egyik legelterjedtebb reprezentációs technika az (state space representation). állapottér-reprezentáció 4
5 1. A problémareprezentáció 1.1. Az állapottér-reprezentáció 1.1. Az állapottér-reprezentáció Legyen adott egy probléma, amit jelöljünk p-vel. Megkeressük p világának legalább egy, de véges sok a probléma megoldása során fontosnak vélt meghatározóját. (pl. objektum, pozíció, méret, hőmérséklet, szín, stb) Tegyük fel, hogy m ilyen jellemzőt találtunk. Minden egyes jellemző p világát különböző értékekkel jellemzi. (pl. szín: fekete/fehér; hőmérséklet: [ 20, 40 ], stb) Ha a megadott jellemzők épp rendre a h 1,..., h m értékekkel rendelkeznek azt mondjuk, hogy p világa a (h 1,..., h m ) érték m-essel leírt állapotban (state) van. A világunk állapotainak halmaza az állapottér (state space).
6 1.1. Az állapottér-reprezentáció 1. A problémareprezentáció Jelölje az i-edik jellemző által felvehető értékek halmazát H i (i = 1,..., m). Ekkor p állapotai elemei a H 1 H m halmaznak. Azokat a feltételeket, amelyek meghatározzák, hogy ebből a halmazból mely érték m-esek állapotok, kényszerfeltételeknek nevezzük. Az állapottér tehát az értékhalmazok Descartes-szorzatának a kényszerfeltételekkel kijelölt részhalmaza: A = { a a H 1 H m és kényszerfeltétel(a) }
7 1. A problémareprezentáció 1.1. Az állapottér-reprezentáció Az A állapottér azon állapotát, amit a probléma világa jellemzőinek kezdőértékei határoznak meg, kezdőállapotnak (initial state) nevezzük és kezdő-vel jelöljük. A kezdőállapotból kiindulva a probléma világának sorban előálló állapotait rendre meg szeretnénk változtatni, míg végül valamely számunkra megfelelő ún. célállapotba (goal state) jutunk. Jelölje C A a célállapotok halmazát. Megadása kétféleképpen történhet: felsorolással: C = { c 1,..., c l c i A, i = 1,..., l, l 1 } célfeltételek megadásával: C = { c c A és célfeltételek(c) } Általában C A, hiszen kezdő / C, különben nincs megoldandó feladat.
8 1.1. Az állapottér-reprezentáció 1. A problémareprezentáció Hogy célállapotba juthassunk, meg kell tudnunk változtatni bizonyos állapotokat. Az állapotváltozásokat leíró leképezéseket operátoroknak (operator) nevezzük. Nem minden operátor alkalmazható feltétlenül minden állapotra, ezért meg szoktuk adni az operátorok értelmezési tartományát az operátoralkalmazási előfeltételek segítségével. Jelöljön az operátorok O véges halmazából o egy operátort. Ekkor és Dom(o) = { a a A és o-alkalmazásának-előfeltétele(a) } Rng(o) = { o(a) a Dom(o) és o(a) A}.
9 1. A problémareprezentáció 1.1. Az állapottér-reprezentáció 1.1. definíció. Legyen p egy probléma. Azt mondjuk, hogy a p problémát állapottér-reprezentáltuk, ha megadtuk az négyest, azaz A, kezdő, C, O az A = halmazt, a probléma állapotterét, a kezdő A kezdőállapotot, a célállapotok C A halmazát és az operátorok O = véges halmazát. Jelölése: p = A, kezdő, C, O.
10 1.1. Az állapottér-reprezentáció 1. A problémareprezentáció Legyen p egy probléma, A, kezdő, C, O p egy állapottér-reprezentációja és legyenek a, a A definíció. Az a állapotból az a állapot közvetlenül elérhető, ha van olyan o O operátor, hogy o-alkalmazásának-előfeltétele(a) és o(a) = a. Jelölése: a a, ha fontos, hogy o állítja elő a-ból a -t: a o a definíció. Az a állapotból az a állapot elérhető, ha vagy a = a, vagy van olyan a 1,..., a k A (k 2) (véges) állapotsorozat, hogy a = a 1, a = a k és a i a i+1 minden 1 i k 1 esetén. Jelölése: a a.
11 1. A problémareprezentáció 1.1. Az állapottér-reprezentáció 1.4. megjegyzés. Ha a i a i+1 minden 1 i k 1 esetén, akkor van olyan o 1, o 2,..., o k 1 operátorsorozat, hogy a i oi a i+1 (1 i k 1). Ilyenkor azt mondjuk, hogy az a állapotból az a állapot az o 1, o 2,..., o k 1 operátorsorozat segítségével elérhető. Jelölve: a a. o 1,...,o k definíció. Legyen p = A, kezdő, C, O. A p probléma megoldható ebben az állapottér-reprezentációban, ha van olyan c C célállapot, hogy kezdő c. Ha kezdő c (r 1), akkor az o 1,...,o r o 1,..., o r operátorsorozat a probléma egy megoldása.
12 1.1. Az állapottér-reprezentáció 1. A problémareprezentáció A feladatunk lehet annak eldöntése, hogy megoldható-e a probléma az adott állapottérreprezentációban, egy (esetleg az összes) megoldás előállítása, egy (esetleg az összes) célállapot előállítása, valamilyen minősítés alapján jó megoldás előállítása (a megoldások között különbséget tehetünk, pl. a megoldás költsége alapján).
13 1. A problémareprezentáció 1.1. Az állapottér-reprezentáció Jelölje költség(o, a) az o operátor a állapotra alkalmazásának a költségét definíció. Legyen p = A, kezdő, C, O és o 1,..., o r O a probléma egy megoldása, azaz kezdő c (c C). o 1,...,o r Legyen rendre a i oi a i+1 (1 i r), ahol a 1 = kezdő és a r+1 = c. Ekkor a megoldás költsége: r költség(o i, a i ). i=1 Ha költség(o, a) 1, akkor a megoldás költsége az alkalmazott operátorok száma.
14 1.1. Az állapottér-reprezentáció 1. A problémareprezentáció Ha az állapottér-reprezentációt valamilyen programozási nyelv segítségével szeretnénk leírni, akkor meg kell adni az állapotok típusát, továbbá a kényszerfeltételeket leíró, logikai értéket visszaadó függvényt; a kezdőállapotot egy állapot típusú konstanssal; a célállapotok halmazát: állapot típusú konstansok felsorolásával vagy a célfeltételt leíró logikai értéket visszaadó függvénnyel; az operátorokat: függvényekkel vagy eljárásokkal. Egy-egy operátorhoz az alkalmazásának előfeltételét leíró logikai függvény is tartozhat. Alkalmas függvénnyel ki lehet számolni (vagy táblázattal meg lehet adni) az operátorok alkalmazási költségeit is.
15 1. A problémareprezentáció 1.2. Példák állapottér-reprezentációra 1.2. Példák állapottér-reprezentációra A nyolcas kirakó játék Adott nyolc számozott, négyzetalakú lapocska, melyek egy táblán 3 3-as sémában helyezkednek el. Egy lapocskányi hely a táblán így nyilván üres. Az üres hellyel szomszédos bármelyik lapocskát az üres helyre tolhatjuk. A feladat az, hogy adott kezdőállásból kiindulva adott célállásnak megfelelő elrendezést alakítsunk ki. A probléma világa: a tábla a számozott lapocskákkal. A világ leírása: a tábla egyes pozícióin épp mely számozott lapocskák vannak. Egy-egy pozícióra hivatkozás: (sor,oszlop). pozíció (1, 1) (1, 2)... (3, 3) lapocska l 1,1 l 1,2... l 3,3 ahol 0 l i,j 8 minden 1 i, j 3 esetén.
16 1.2. Példák állapottér-reprezentációra 1. A problémareprezentáció Tehát H i,j = H = {0, 1,..., 8} minden 1 i, j 3-ra. A probléma világának egy-egy állapotát egy-egy olyan l 1,1 l 1,2 l 1,3 l 2,1 l 2,2 l 2,3 l 3,1 l 3,2 l 3,3 érték 9-es ((3 3)-as mátrix) határozza meg, melyben az értékek H- beli elemek, és az érték 9-esben minden egyes érték H-ból pontosan egyszer fordul elő: i j s o( (i = s) (j = o) (l i,j = l s,o )). A kezdőállapot és a célállapot: kezdő = c =
17 1. A problémareprezentáció 1.2. Példák állapottér-reprezentációra A számozott lapocskák tologatásai során az üres pozíciója mindig változik, az eredetihez képest fel, le, jobbra vagy balra kerül egyegy pozícióval. Így tehát négy operátor segítségével leírhatjuk az állapotváltozásokat. A l 1,1 l 1,2 l 1,3 l 1,1 fel : l 2,1 l 2,2 l 2,3 l 1,2 l 1,3 l 2,1 l 2,2 l 2,3 l 3,1 l 3,2 l 3,3 operátort akkor alkalmazhatjuk, ha l 3,1 l 3,2 l 3,3 i j((l i,j = 0) (i = 1)). Az alkalmazás eredménye, ha az éppen l s,o = 0: 0 ha i = s 1, j = o l i,j l s 1,o ha i = s, j = o l i,j egyébként.
18 1.3. Az állapottérgráf 1. A problémareprezentáció 1.3. Az állapottérgráf Legyen a p probléma az A, kezdő, C, O állapottér-reprezentációval megadva. Ez a reprezentáció egy irányított gráfot határoz meg. Az A állapottér elemei (az állapotok) a gráf csúcsai. Vezessük be az a A állapot által definiált csúcsra az n a jelölést. Ekkor a gráf csúcsainak halmaza N = {n a a A}. A gráf csúcsai közül kitüntetett szerepet játszanak a kezdőállapotot szemléltető ún. startcsúcs (jele: n kezdő vagy s) és a célállapotokat szemléltető terminális csúcsok. A terminális csúcsok halmaza tehát: T = {n c c C}.
19 1. A problémareprezentáció 1.3. Az állapottérgráf Minden a A-t szemléltető csúcsból irányított élt húzunk az a A -t szemléltető csúcsba, ha a-ból közvetlenül elérhető a, azaz a gráf irányított éleinek halmaza a következő: E = {(n a, n a ) a, a A és a a }. Az N, s, T, E irányított gráfot a p probléma A, kezdő, C, O állapottér-reprezentációjához tartozó állapottérgráfjának vagy reprezentációs gráfjának nevezzük.
20 1.3. Az állapottérgráf 1. A problémareprezentáció 1.7. lemma. Legyen N, s, T, E a p probléma A, kezdő, C, O állapottér-reprezentációjához tartozó állapottérgráfja. Pontosan akkor vezet az állapottérgráf n a csúcsából az ettől különböző n a csúcsba irányított út, ha az a állapotból az a állapot elérhető. Bizonyítás. 1. Tegyük fel, hogy a a (a a ). Ez azt jelenti, hogy van olyan a 1,..., a k A (k 2) (véges) állapotsorozat, hogy a = a 1, a = a k és a i a i+1 minden 1 i k 1 esetén. Tehát a reprezentációs gráfban minden 1 i k 1-re az n ai csúcsból irányított él vezet az n ai+1 csúcsba, azaz (n ai, n ai+1 ) E. Ez viszont azt jelenti, hogy n a1 = n a csúcsból irányított út vezet az n ak = n a csúcsba.
21 1. A problémareprezentáció 1.3. Az állapottérgráf 2. Tegyük fel azt, hogy az állapottérgráf n a csúcsából az ettől különböző n a csúcsba irányított út vezet. Ez azt jelenti, hogy van olyan (n a1, n a2 ), (n a2, n a3 ),..., (n ak 1, n ak ) E (k 2) irányított élsorozat az állapottérgráfban, hogy n a1 = n a és n ak = n a. Ekkor egyrészt a 1 = a és a k = a, továbbá (n ai 1, n ai ) E csak akkor, ha a i 1 a i. Ez azt jelenti, hogy a a, tehát az a állapotból az a állapot elérhető.
22 1.3. Az állapottérgráf 1. A problémareprezentáció 1.8. tétel. Legyen N, s, T, E a p probléma A, kezdő, C, O állapottér-reprezentációjához tartozó állapottérgráfja. Pontosan akkor megoldható p, ha van az állapottérgráfban a startcsúcsból valamelyik terminális csúcsba vezető irányított út. Bizonyítás. 1. Egyrészt ha p megoldható, van olyan c C célállapot, hogy kezdő c. De ekkor az állapottérgráfban irányított út vezet az n kezdő startcsúcsból az n c T terminális csúcsba. 2. Másrészt ha van az állapottérgáfban az n kezdő startcsúcsból valamely terminális csúcsba vezető irányított út, a kezdő állapotból elérhető ezen terminális csúcs által szemléltetett állapot. De a terminális csúcsok célállapotokat szemléltetnek. Tehát p megoldható.
23 1. A problémareprezentáció 1.3. Az állapottérgráf A p probléma A, kezdő, C, O állapottér-reprezentációjában vegyük figyelembe az operátorok alkalmazási költségeit. Rendeljünk ekkor minden (n a, n a ) élhez költséget: ha a o a, akkor költség(o, a) legyen ezen él költsége (jelölve: költség(n a, n a )). Egy (n a1, n a2 ), (n a2, n a3 ),..., (n ak 1, n ak ) E (k 2) irányított út költsége a benne szereplő élek költségösszege k 1 i=1 költség(n ai, n ai+1 ). Ha minden él költsége egységnyi, az irányított út költsége éppen az út éleinek a száma.
24 1.3. Az állapottérgráf 1. A problémareprezentáció Egy állapottér-reprezentált probléma megoldásának sikerét jelentősen befolyásolja a reprezentációs gráf bonyolultsága: a csúcsok száma, az egy csúcsból kiinduló élek száma, a hurkok és körök száma és hossza. Ezért célszerű minden lehetséges egyszerűsítést végrehajtani. A lehetséges egyszerűsítések: csúcsok számának csökkentése ügyes reprezentációval az állapottér kisebb méretű lehet; egy csúcsból kiinduló élek számának csökkentése az operátorok értelmezési tartományának alkalmas megválasztásával; fává alakítás a reprezentációs gráfban a hurkok, illetve körök kiegyenesítésével
25 2. fejezet A megoldást kereső rendszerek Az állapottérgráfban keressük a megoldást: a start csúcsból valamely terminális csúcsba vezető utat. Az állapottérgráfot implicit módon az állapottér-reprezentáció megadásával adjuk meg a megoldást kereső rendszereknek. Ezek a keresés során addig és úgy építik a gráfot, amíg megoldást nem találnak, vagy amíg valamilyen ok miatt kudarcot nem vallanak a kereséssel. 25
26 2. A megoldást kereső rendszerek A megoldást kereső rendszerek felépítése: Az adatbázis az állapottérgráfnak a keresés során előállított része, amit kiegészíthetünk a hatékony kereséshez szükséges bizonyos információkkal. A műveletek módosítják az adatbázist, azaz az állapottérgráf adatbázisbeli részéből az állapottérgráf egy újabb (további) részét állítják elő. A rendszer alkalmazhat állapottér-reprezentációs operátorokból származtatott műveleteket, technikai műveleteket (pl. visszalépést). A műveleteknek is vannak végrehajtási feltételeik.
27 2. A megoldást kereső rendszerek A vezérlő irányítja a keresést. Megmondja, hogy a megoldáskeresés folyamán az adatbázisra, annak mely részén, mikor, melyik a végrehajtási feltételeknek eleget tevő művelet hajtódjon végre. Figyeli azt is, hogy befejeződhet-e a keresés, azaz megvan-e a probléma megoldása, vagy kiderült, hogy nem megoldható a probléma.
28 1: procedure Kereső( A, kezdő, C, O ) 2: adatbázis Inicializál(kezdő) 3: while Igaz do 4: if Megoldás-Talál(adatbázis) then 5: break 6: end if 7: if Nem-Folytat(adatbázis) then 8: break 9: end if 10: művelet Választ(adatbázis, műveletek) 11: adatbázis Alkalmaz(adatbázis, művelet) 12: end while 13: if Megoldás-Talál(adatbázis) then 14: Megoldás-Kiír(adatbázis) 15: else 16: print Sikertelen keresés 17: end if 18: end procedure 2. A megoldást kereső rendszerek
29 2. A megoldást kereső rendszerek A megoldást kereső rendszerek osztályozhatók: Módosítható-e valahogy egy már alkalmazott művelet hatása? nem: nemmódosítható megoldáskeresők igen: módosítható megoldáskeresők visszalépéses (backtracking) keresők keresőfával keresők Használunk-e valamiféle speciális tudást a keresés során? nem: irányítatlan (vak, szisztematikus) megoldáskeresők igen: heurisztikus megoldáskeresők A heurisztika (heurisztikus szabály, módszer) olyan ökölszabály, stratégia, trükk, egyszerűsítés, vagy egyéb eszköz, amely drasztikusan korlátozza a megoldás keresését nagyméretű reprezentációs gráfokban. 1 1 Feigenbaum és Feldman
30 Milyen irányú a keresés? 2. A megoldást kereső rendszerek előrehaladó (forward) vagy adatvezérelt kereső rendszer: a kezdő állapotból kiindulva keresünk célállapotba vezető utat. visszafelé haladó (backward) vagy célvezérelt kereső rendszer: a célállapotból kiindulva visszafelé haladva próbáljuk rekonstruálni a kezdőállapotból odavezető utat. kétirányú (bidirectional) kereső rendszer: mindkét irányból elindul, s valahol találkozik
31 2. A megoldást kereső rendszerek A megoldáskereső rendszerek értékelési szempontjai: Teljesség (completeness): A rendszer minden olyan esetben megtaláljae a megoldást, amennyiben az létezik? Optimalitás (optimality): Több megoldás létezése esetén a rendszer az optimális megoldást találja-e meg? Időigény (time complexity): Mennyi ideig tart egy megoldás megtalálása? Tárigény (space complexity): Mekkora tároló területre van szükség a megoldás megtalálásához?
32 2.1. Nemmódosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 2.1. Nemmódosítható megoldáskereső rendszerek A MI módszereit nem használó, ún. hagyományos feladatmegoldási módoknál alkalmazzák. A MI problémák megoldása során nem tudjuk, hogy a reprezentációs gráf megfelelő a megoldást is tartalmazó részét építjük-e, ezért ritkán alkalmazunk nemmódosítható keresést az MI területén. Legyen p = A, kezd, C, O. Egy nemmódosítható megoldáskereső rendszer adatbázisa az állapottérgráf egyetlen csúcsa, az ún. aktuális csúcs; műveletei az állapottér-reprezentációs operátorok; vezérlője:
33 2. A megoldást kereső rendszerek 2.1. Nemmódosítható megoldáskereső rendszerek 1: procedure Nemmódosítható-Kereső( A, kezdő, C, O ) 2: aktuális kezdő 3: while Igaz do 4: if aktuális C then 5: break 6: end if 7: O {o o O Előfeltétel(aktuális, o)} 8: if O then 9: operátor Választ(O ) 10: aktuális Alkalmaz(aktuális, operátor) 11: else 12: break 13: end if 14: end while 15: if aktuális C then 16: print aktuális 17: else 18: print Sikertelen keresés 19: end if 20: end procedure
34 2.1. Nemmódosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Csak olyan probléma megoldásánál alkalmazzuk, ahol egy a célfeltételeknek eleget tevő állapotot kell előállítani! Ugyanazon probléma megoldásának keresése esetén a választás módjában lehet lényeges eltérés: irányítatlanul, szisztematikusan előre rögzített operátorsorrend alapján véletlenszerűen: próba-hiba módszer heurisztikusan: hegymászó módszer
35 2. A megoldást kereső rendszerek 2.1. Nemmódosítható megoldáskereső rendszerek Becsüljük meg a h : A R + ún. heurisztikus függvénnyel, hogy az egyes állapotokból legkevesebb hány operátor alkalmazásával érhetünk cálállapotba: { 0, ha a C h(a), ha c(c C a c), egyébként h(a) > 0. Ha az a állapot az aktuális, becsüljük meg h segítségével, hogy a milyen távol van a hozzá legközelebbi céltól: h(a). Legyen O = {o o O o-alkalmazásának-előfeltétele(a) h(o(a)) h(a)}. Azt az O -beli operátort fogjuk alkalmazni a-ra, amelyik a becslésünk szerint a legközelebb visz valamelyik terminálishoz: h(operátor(a)) = min { h(o(a)) o O }
36 2.1. Nemmódosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Hegymászó-Algoritmus( A, kezdő, C, O, h) 2: aktuális kezdő 3: while Igaz do 4: if aktuális C then 5: break 6: end if 7: O {o o O Előfeltétel(aktuális, o) h(alkalmaz(aktuális, o)) h(aktuális)} 8: if O then 9: operátor Választ({o o O o (o O h(alkalmaz(aktuális, o)) h(alkalmaz(aktuális, o )))}) 10: aktuális Alkalmaz(aktuális, operátor) 11: else 12: break 13: end if 14: end while 15: if aktuális C then 16: print aktuális 17: else 18: print Sikertelen keresés 19: end if 20: end procedure
37 2. A megoldást kereső rendszerek 2.1. Nemmódosítható megoldáskereső rendszerek A nemmódosítható megoldáskereső rendszerek értékelése: Teljesség : Nem teljesek. Próba-hiba módszer: Ha olyan kört nem tartalmazó véges állapottérgráfokban keresünk, melyekben minden csúcsból vezet valamelyik terminális csúcsba irányított út, akkor előállít egy célállapotot. A hegymászó módszer esetén a heurisztika pontosságától függ, hogy a megoldást megtaláljuk-e vagy sem. Tárigény : Rendkívül kis adatbázissal dolgozik.
38 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Az alap visszalépéses megoldáskeresők Legyen p = A, kezd, C, O. Az alap visszalépéses megoldáskereső adatbázisa egy a startcsúcsból induló az ún. aktuális csúcsba vezető utat, az aktuális utat tartalmazza, az út csúcsait és a csúccsal kapcsolatban lévő éleket nyilvántartó csomópontokból épül fel. Egy csomópont az alábbi információkat tartalmazza: egy a A állapotot; arra a csomópontra mutatót, mely a szülő állapotot (azt az állapotot, melyre operátort alkalmazva előállt a) tartalmazza; azt az operátort, melyet a szülő állapotra alkalmazva előállt a; a-ra a keresés során már alkalmazott (vagy még alkalmazható) operátorok halmazát.
39 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek műveletei az operátorokból származtatott műveletek: egy o operátor kiterjesztésével nyert művelet alkalmazási előfeltétele: az aktuális csomópont állapotára alkalmazható o, de még a keresés során erre az állapotra (ezen az úton) még nem alkalmaztuk. hatása: a visszalépés alkalmazási előfeltétele: van (aktuális) csomópont az aktuális úton. hatása: vezérlője eldönti, hogy az adatbázisra mikor melyik műveletet kell végrehajtani, ha még nem teljesülnek a megállási feltételek.
40 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Alap-Backtrack-1( A, kezdő, C, O ) 2: Állapot[aktuális-csomópont] kezdő 3: Szülő[aktuális-csomópont] Nil 4: Operátor[aktuális-csomópont] 5: Kipróbált[aktuális-csomópont] 6: while Igaz do 7: if aktuális-csomópont = Nil then 8: break 9: end if 10: if Állapot[aktuális-csomópont] C then 11: break 12: end if 13: O {o o O Előfeltétel(Állapot[aktuális-csomópont], o) o / Kipróbált[aktuális-csomópont]}
41 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 14: if O then 15: operátor Választ(O ) 16: Kipróbált[aktuális-csomópont] Kipróbált[aktuális-csomópont] {operátor} 17: Állapot[új] Alkalmaz(Állapot[aktuális-csomópont], operátor) 18: Szülő[új] aktuális-csomópont 19: Operátor[új] operátor 20: Kipróbált[új] 21: aktuális-csomópont új 22: else 23: aktuális-csomópont Szülő[aktuális-csomópont] 24: end if 25: end while 26: if aktuális-csomópont Nil then 27: Megoldás-Kiír(aktuális-csomópont) 28: else 29: print Nincs megoldás 30: end if 31: end procedure
42 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Alap-Backtrack-2( A, kezdő, C, O ) 2: Állapot[aktuális-csomópont] kezdő 3: Szülő[aktuális-csomópont] Nil 4: Operátor[aktuális-csomópont] 5: Alkalmazható[aktuális-csomópont] {o o O Előfeltétel(Állapot[aktuális-csomópont], o)} 6: while Igaz do 7: if aktuális-csomópont = Nil then 8: break 9: end if 10: if Állapot[aktuális-csomópont] C then 11: break 12: end if
43 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 13: if Alkalmazható[aktuális-csomópont] then 14: operátor Választ(Alkalmazható[aktuális-csomópont]) 15: Alkalmazható[aktuális-csomópont] Alkalmazható[aktuális-csomópont] \ {operátor} 16: Állapot[új] Alkalmaz(Állapot[aktuális-csomópont], operátor) 17: Szülő[új] aktuális-csomópont 18: Operátor[új] operátor 19: Alkalmazható[új] {o o O Előfeltétel(Állapot[új], o)} 20: aktuális-csomópont új 21: else 22: aktuális-csomópont Szülő[aktuális-csomópont] 23: end if 24: end while 25: if aktuális-csomópont Nil then 26: Megoldás-Kiír(aktuális-csomópont) 27: else 28: print Nincs megoldás 29: end if 30: end procedure
44 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Ugyanazon probléma megoldásának keresése esetén a választás módjában lehet lényeges eltérés: irányítatlanul, szisztematikusan előre rögzített operátorsorrend alapján véletlenszerűen heurisztikusan: Becsüljük meg a h : A R + heurisztikával, hogy az egyes csúcsok milyen távol vannak a hozzájuk legközelebbi terminális csúcstól. Legyen O = {o o O o-alkalmazásának-előfeltétele(a)}. Azt az O -beli operátort fogjuk alkalmazni a-ra, amelyik a becslésünk szerint a legközelebb visz valamelyik terminálishoz: h(operátor(a)) = min { h(o(a)) o O }.
45 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Az alap visszalépéses megoldáskeresők értékelése Teljesség : Ha a reprezentációs gráf köröket nem tartalmazó véges gráf, akkor az alap visszalépéses megoldáskereső véges sok keresőlépés megtétele után befejezi a keresést, ha van megoldás, előállít egy lehetséges megoldást, ha nincs megoldás, azt felismeri. Tárigény : Kis méretű az adatbázis.
46 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Visszalépéses megoldáskeresés köröket is tartalmazó gráfokban Visszalépéses megoldáskeresés körfigyeléssel: Ha van megoldás, akkor van körmentes megoldás is. A vezérlő a visszalépést választja, ha az aktuális csúcs szerepelt már az aktuális úton. Visszalépéses megoldáskeresés úthosszkorláttal: Úthosszkorlátot vezetünk be, mely megakadályozza, hogy a köröket végtelen sokszor járjuk be. A vezérlő a visszalépést választja, ha az aktuális út hossza eléri, vagy meghaladja az úthosszkorlátot.
47 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 1: procedure Körfigyeléses-Backtrack( A, kezdő, C, O ) 2: Állapot[aktuális-csomópont] kezdő 3: Szülő[aktuális-csomópont] Nil 4: Operátor[aktuális-csomópont] 5: Alkalmazható[aktuális-csomópont] {o o O Előfeltétel(Állapot[aktuális-csomópont], o)} 6: while Igaz do 7: if aktuális-csomópont = Nil then 8: break 9: end if 10: if Állapot[aktuális-csomópont] C then 11: break 12: end if 13: if VoltMár(Állapot[aktuális-csomópont]) then 14: aktuális-csomópont Szülő[aktuális-csomópont] 15: end if
48 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 16: if Alkalmazható[aktuális-csomópont] then 17: operátor Választ(Alkalmazható[aktuális-csomópont]) 18: Alkalmazható[aktuális-csomópont] Alkalmazható[aktuális-csomópont] \ {operátor} 19: Állapot[új] Alkalmaz(Állapot[aktuális-csomópont], operátor) 20: Szülő[új] aktuális-csomópont 21: Operátor[új] operátor 22: Alkalmazható[új] {o o O Előfeltétel(Állapot[új], o)} 23: aktuális-csomópont új 24: else 25: aktuális-csomópont Szülő[aktuális-csomópont] 26: end if 27: end while 28: if aktuális-csomópont Nil then 29: Megoldás-Kiír(aktuális-csomópont) 30: else 31: print Nincs megoldás 32: end if 33: end procedure
49 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 1: procedure Úthosszkorlátos-Backtrack( A, kezdő, C, O, korlát) 2: Állapot[aktuális-csomópont] kezdő 3: Szülő[aktuális-csomópont] Nil 4: Mélység[aktuális-csomópont] 0 5: Operátor[aktuális-csomópont] 6: Alkalmazható[aktuális-csomópont] {o o O Előfeltétel(Állapot[aktuális-csomópont], o)} 7: while Igaz do 8: if aktuális-csomópont = Nil then 9: break 10: end if 11: if Állapot[aktuális-csomópont] C then 12: break 13: end if 14: if Mélység[aktuális-csomópont] = korlát then 15: aktuális-csomópont Szülő[aktuális-csomópont] 16: end if
50 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 17: if Alkalmazható[aktuális-csomópont] then 18: operátor Választ(Alkalmazható[aktuális-csomópont]) 19: Alkalmazható[aktuális-csomópont] Alkalmazható[aktuális-csomópont] \ {operátor} 20: Állapot[új] Alkalmaz(Állapot[aktuális-csomópont], operátor) 21: Szülő[új] aktuális-csomópont 22: Mélység[új] Mélység[aktuális-csomópont] : Operátor[új] operátor 24: Alkalmazható[új] {o o O Előfeltétel(Állapot[új], o)} 25: aktuális-csomópont új 26: else 27: aktuális-csomópont Szülő[aktuális-csomópont] 28: end if 29: end while 30: if aktuális-csomópont Nil then 31: Megoldás-Kiír(aktuális-csomópont) 32: else 33: print Sikertelen keresés 34: end if 35: end procedure
51 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Teljesség : Értékelés A körfigyeléses backtrack ha a reprezentációs gráf véges, akkor véges sok keresőlépés megtétele után befejezi a keresést, és ha van megoldás, előállít egy körmentes megoldást, ha nincs megoldás, azt felismeri. Az úthosszkorlátos backtrack tetszőleges reprezentációs gráf esetén véges sok keresőlépés megtétele után befejezi a keresést, ha van az úthosszkorlátnál nem hosszabb megoldás, előállít egy ilyen megoldást. Ha keresés nem egy megoldás megtalálásával ér véget, akkor az úthosszkorlátnál csak hosszabb megoldás lehet a reprezentációs gráfban. (Vagy nincs megoldás, vagy az úthosszkorlát túl kicsi.)
52 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Időigény : A körfigyeléses backtrack időigényes (főleg hosszú körök esetén). Tárigény : Az úthosszkorlátos backtrack adatbázisa legfeljebb úthosszkorlátnyi elemet tartalmaz. A megtalált megoldás nem feltétlen körmentes.
53 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Ág és korlát algoritmus A backtrack alkalmas optimális (legrövidebb) megoldás keresésére is. Egy induló úthosszkorlátnál nem hosszabb megoldást keresünk. Ha találunk ilyet, tároljuk, majd ennek hosszát új úthosszkorlátnak választva folytatjuk a keresést megjegyzés. Úthosszkorlát helyett költségkorlátot, csomópont mélysége helyett pedig az addig tartó út költségét is használhatjuk az algoritmusban. Ekkor legkisebb költségű megoldás előállítása lehet a cél.
54 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Ág-és-Korlát( A, kezdő, C, O, korlát) 2: talált Hamis 3: Állapot[aktuális-csomópont] kezdő 4: Szülő[aktuális-csomópont] Nil 5: Mélység[aktuális-csomópont] 0 6: Operátor[aktuális-csomópont] 7: Alkalmazható[aktuális-csomópont] {o o O Előfeltétel(Állapot[aktuális-csomópont], o)} 8: while Igaz do 9: if aktuális-csomópont = Nil then 10: break 11: end if 12: if Állapot[aktuális-csomópont] C then 13: talált Igaz 14: Megoldás-Feljegyez(aktuális-csomópont) 15: korlát Mélység[aktuális-csomópont] 16: end if 17: if Mélység[aktuális-csomópont] = korlát then 18: aktuális-csomópont Szülő[aktuális-csomópont] 19: end if
55 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 20: if Alkalmazható[aktuális-csomópont] then 21: operátor Választ(Alkalmazható[aktuális-csomópont]) 22: Alkalmazható[aktuális-csomópont] Alkalmazható[aktuális-csomópont] \ {operátor} 23: Állapot[új] Alkalmaz(Állapot[aktuális-csomópont], operátor) 24: Szülő[új] aktuális-csomópont 25: Mélység[új] Mélység[aktuális-csomópont] : Operátor[új] operátor 27: Alkalmazható[új] {o o O Előfeltétel(Állapot[új], o)} 28: aktuális-csomópont új 29: else 30: aktuális-csomópont Szülő[aktuális-csomópont] 31: end if 32: end while 33: if talált then 34: Megoldás-Kiír 35: else 36: print Sikertelen keresés 37: end if 38: end procedure
56 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Értékelés Optimalitás : Az ág és korlát algoritmus tetszőleges reprezentációs gráf esetén véges sok keresőlépés megtétele után befejezi a keresést, ha van az induló úthosszkorlátnál nem hosszabb megoldás, a legrövidebb megoldást állítja elő, ha a keresés nem megoldás megtalálásával ér véget, akkor az induló úthosszkorlátnál csak hosszabb megoldás lehet a reprezentációs gráfban. (Vagy nincs megoldás, vagy az induló úthosszkorlát túl kicsi.) Tárigény : Az ág és korlát adatbázisa legfeljebb kétszer az induló úthosszkorlátnyi csomópontot tartalmaz.
57 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Keresőfával keresők Legyen p = A, kezd, C, O. A keresőfával kereső rendszerek adatbázisa a reprezentációs gráf már bejárt részét feszítő fa, az ún. keresőfa. A keresőfa csúcsait és a velük kapcsolatban lévő éleket (explicit vagy implicit módon) nyilvántartó csomópontok az alábbi információkat tartalmazzák: egy a A állapotot; arra a csomópontra mutatót, mely a szülő állapotot tartalmazza; azt az operátort, melyet a szülő állapotra alkalmazva előállt a; státusz: zárt, ha a utódait tartalmazó csomópontokat a keresés során már előállítottuk; nyílt, egyébként.
58 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek művelete a kiterjesztés: a keresőfát annak egy nyílt csomópontján keresztül kibővíti. alkalmazási előfeltétele: a keresőfában van nyílt csomópont. hatása: alkalmazzuk az összes alkalmazható operátort a nyílt csomópont állapotára, az előálló állapotok közül amelyek még nem szerepeltek a keresőfa egyetlen csomópontjában sem, azokból a keresőfába felfűzött új nyílt csomópont készül, amelyek már szerepeltek a keresőfa valamely csomópontjában, azok sorsa keresőfüggő. a kiterjesztett csomópont zárttá válik.
59 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek vezérlő megmondja, hogy melyik nyílt csomópont legyen a következő lépésben kiterjesztve. Ha a kiválasztott nyílt csomópont állapota teljesíti a célfeltételeket, a keresőfában a szülőre mutatók mentén elő tudunk állítani egy megoldást is. Nincs megoldás, ha egyetlenegy nyílt csomópont sincs a keresőfában.
60 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Keresőfával-Kereső( A, kezdő, C, O ) 2: Állapot[csomópont] kezdő 3: Szülő[csomópont] Nil 4: Operátor[csomópont] 5: nyíltak {csomópont}; zártak 6: while Igaz do 7: if nyíltak = then 8: break 9: end if 10: csomópont Választ(nyíltak) 11: if Állapot[csomópont] C then 12: break 13: end if 14: Kiterjeszt(csomópont, nyíltak, zártak) 15: end while 16: if nyíltak then 17: Megoldás-Kiír(csomópont) 18: else 19: print Nincs megoldás 20: end if 21: end procedure
61 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Ugyanazon probléma megoldásának keresése esetén lényeges eltérés lehet 1. a választás módjában. A vezérlő választhat irányítatlanul, szisztematikusan a csomópontok keresőgráfbeli mélysége alapján: szélességi és mélységi keresők; a csomópontok állapotait előállító költség alapján: optimális kereső; heurisztikusan: best-first algoritmus; A algoritmusok. 2. abban, hogy mi történik, ha a keresőgráf egy csúcsához a keresés során újabb odavezető utat tár fel a vezérlő. 3. a célfeltételek vizsgálatának időpontjában.
62 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Szélességi és mélységi keresők 1. Egy csomópont előállításakor követjük, hogy a csomópontban nyilvántartott csúcs a keresőfában milyen mélyen van: { 0 ha m = s mélység(m) mélység(n) + 1 (n, m) E. Kiterjesztésre a szélességi kereső vezérlője a legkisebb mélységi számú a mélységi kereső vezérlője a legnagyobb mélységi számú nyílt csomópontot választja ki. 2. Ha a vezérlő a keresőgráf egy csúcsához a keresés során újabb odavezető utat tár fel, ezt nem tárolja, elfelejti. 3. A tesztelést előre hozhatjuk.
63 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 1: procedure Kiterjeszt( A, kezdő, C, O, csomópont, nyíltak, zártak) 2: for all o O do 3: if Előfeltétel(Állapot[csomópont], o) then 4: állapot Alkalmaz(Állapot[csomópont],o) 5: ny Keres(nyíltak, állapot) 6: z Keres(zártak, állapot) 7: if ny = Nil and z = Nil then 8: Állapot[új-csomópont] állapot 9: Szülő[új-csomópont] csomópont 10: Operátor[új-csomópont] o 11: Mélység[új-csomópont] Mélység[csomópont] : nyíltak nyíltak {új-csomópont} 13: end if 14: end if 15: end for 16: nyíltak nyíltak \ {csomópont} 17: zártak zártak {csomópont} 18: end procedure
64 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 19: procedure Szélességi-Kereső( A, kezdő, C, O ) 20: Állapot[új-csomópont] kezdő 21: Szülő[új-csomópont] Nil 22: Operátor[új-csomópont] 23: Mélység[új-csomópont] 0 24: nyíltak {új-csomópont} 25: zártak 26: while Igaz do 27: if nyíltak = then 28: break 29: end if 30: csomópont Választ({cs cs nyíltak cs (cs nyíltak Mélység[cs] Mélység[cs ])}) 31: if Állapot[csomópont] C then 32: break 33: end if 34: Kiterjeszt( A, kezdő, C, O, csomópont, nyíltak, zártak) 35: end while
65 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 36: if nyíltak then 37: Megoldás-Kiír(csomópont) 38: else 39: print Nincs megoldás 40: end if 41: end procedure
66 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Mélységi-Kereső( A, kezdő, C, O ) 2: Állapot[új-csomópont] kezdő 3: Szülő[új-csomópont] Nil 4: Operátor[új-csomópont] 5: Mélység[új-csomópont] 0 6: nyíltak {új-csomópont} 7: zártak 8: while Igaz do 9: if nyíltak = then 10: break 11: end if 12: csomópont Választ({cs cs nyíltak cs (cs nyíltak Mélység[cs] Mélység[cs ])}) 13: if Állapot[csomópont] C then 14: break 15: end if 16: Kiterjeszt( A, kezdő, C, O, csomópont, nyíltak, zártak) 17: end while
67 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 18: if nyíltak then 19: Megoldás-Kiír(csomópont) 20: else 21: print Nincs megoldás 22: end if 23: end procedure
68 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Teljesség : A vezérlő, A szélességi kereső értékelése ha van megoldás, tetszőleges reprezentációs gráfban véges sok keresőlépés után előállít egy megoldást, ha nincs az adott reprezentációban megoldás, akkor véges gráf esetén azt a nyílt csomópontok elfogyásával felismeri. Optimalitás : Ha van megoldás, tetszőleges reprezentációs gráfban a vezérlő a legrövidebb megoldást állítja elő. Tárigény : Nagy az adatbázis. Legyen a reprezentációs fa minden csúcsának d gyermeke, és l hosszúságú a legrövidebb megoldás. Ekkor a keresőgráf csomópontjainak száma a keresés végére (a legrosszabb esetben): 1 + d + d 2 + d d l+1 d O(d l+1 ).
69 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek A mélységi kereső értékelése Teljesség : A vezérlő véges reprezentációs gráfban, ha van megoldás, véges sok keresőlépés után előállít egy megoldást, ha nincs a problémának az adott reprezentációban megoldása, akkor azt a nyílt csomópontok elfogyásával felismeri megjegyzés. A nyílt csomópontokat gyakran a szélességi kereső sorban, a mélységi kereső veremben tartja nyilván, melyből mélységi szám szerint ezek épp megfelelő sorrendben kerülnek ki.
70 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Optimális kereső 1. Minden csomópontnál számon tartjuk az odavezető nyilvántartott út költségét: { 0 ha m = s útköltség(m) útköltség(n) + költség(n, m) (n, m) E. útköltség (n) jelölje a startcsúcsból n-be jutás optimális költségét. Ekkor útköltség(n) útköltség (n), minden n N-re. Kiterjesztésre az optimális kereső vezérlője a legkisebb költségű nyílt csomópontot választja ki.
71 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 2. Ha a vezérlő a keresőgráf egy csúcsához a keresés során újabb odavezető utat tár fel, azaz az n csomópont kiterjesztéskor előállt állapot szerepel már a keresőgráf m csomópontjában nyíltként: ha az útköltség(n) + költség(n, m) < útköltség(m), ekkor az új kisebb költségű utat tároljuk, a régit elfelejtjük. zártként: az m csomópontot már n kiterjesztése előtt kiterjesztette a vezérlő, azaz útköltség(m) útköltség(n) volt, így útköltség(n) + költség(n, m) > útköltség(m). Az m-hez feltárt új út költségesebb. 3. A tesztelést nem hozhatjuk előre.
72 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Kiterjeszt( A, kezdő, C, O, költség, csomópont, nyíltak, zártak) 2: for all o O do 3: if Előfeltétel(Állapot[csomópont], o) then 4: állapot Alkalmaz(Állapot[csomópont],o) 5: ny Keres(nyíltak, állapot) 6: z Keres(zártak, állapot) 7: if ny = Nil and z = Nil then 8: Állapot[új-csomópont] állapot 9: Szülő[új-csomópont] csomópont 10: Operátor[új-csomópont] o 11: Útköltség[új-csomópont] Útköltség[csomópont] + költség(o, Állapot[csomópont]) 12: nyíltak nyíltak {új-csomópont} 13: else if ny Nil then 14: új-út-költség Útköltség[csomópont] + költség(o, Állapot[csomópont]) 15: if új-út-költség < Útköltség[ny] then 16: Szülő[ny] csomópont 17: Operátor[ny] o 18: Útköltség[ny] új-út-költség 19: end if 20: end if 21: end if 22: end for 23: nyíltak nyíltak \ {csomópont} 24: zártak zártak {csomópont} 25: end procedure
73 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 26: procedure Optimális-Kereső( A, kezdő, C, O, költség) 27: Állapot[új-csomópont] kezdő 28: Szülő[új-csomópont] Nil 29: Operátor[új-csomópont] 30: Útköltség[új-csomópont] 0 31: nyíltak {új-csomópont} 32: zártak 33: while Igaz do 34: if nyíltak = then 35: break 36: end if 37: csomópont Választ({cs cs nyíltak cs (cs nyíltak Útköltség[cs] Útköltség[cs ])}) 38: if Állapot[csomópont] C then 39: break 40: end if 41: Kiterjeszt( A,kezdő, C, O, költség, csomópont, nyíltak, zártak) 42: end while 43: if nyíltak then 44: Megoldás-Kiír(csomópont) 45: else 46: print Nincs megoldás 47: end if 48: end procedure
74 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Teljesség : A vezérlő, Az optimális kereső értékelése ha van megoldás, tetszőleges reprezentációs gráfban véges sok keresőlépés után előállít egy megoldást, ha nincs a problémának az adott reprezentációban megoldása, akkor véges gráf esetén azt a nyílt csomópontok elfogyásával felismeri. Optimalitás : Ha van megoldás, tetszőleges reprezentációs gráfban a vezérlő véges sok keresőlépés után az optimális megoldást állítja elő.
75 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Best-first algoritmus 1. A keresőfa minden csomópontjánál nyilvántartjuk, hogy a csomópontbeli állapot a h heurisztikus függvény szerint milyen távol van a hozzá legközelebbi céltól. Kiterjesztésre a best-first vezérlője a legkisebb heurisztikájú nyílt csomópontot választja ki (legjobb irányban haladó keresés). 2. Ha a vezérlő a keresőgráf egy csúcsához a keresés során újabb odavezető utat tár fel, ezt nem tárolja, elfelejti. 3. A tesztelést előre hozhatjuk.
76 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Kiterjeszt( A, kezdő, C, O, h, csomópont, nyíltak, zártak) 2: for all o O do 3: if Előfeltétel(Állapot[csomópont], o) then 4: állapot Alkalmaz(Állapot[csomópont],o) 5: ny Keres(nyíltak, állapot) 6: z Keres(zártak, állapot) 7: if ny = Nil and z = Nil then 8: Állapot[új-csomópont] állapot 9: Szülő[új-csomópont] csomópont 10: Operátor[új-csomópont] o 11: Heurisztika[új-csomópont] h(állapot) 12: nyíltak nyíltak {új-csomópont} 13: end if 14: end if 15: end for 16: nyíltak nyíltak \ {csomópont} 17: zártak zártak {csomópont} 18: end procedure
77 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 19: procedure Best-First( A, kezdő, C, O, h) 20: Állapot[új-csomópont] kezdő 21: Szülő[új-csomópont] Nil 22: Operátor[új-csomópont] 23: Heurisztika[új-csomópont] h(kezdő) 24: nyíltak {új-csomópont} 25: zártak 26: while Igaz do 27: if nyíltak = then 28: break 29: end if 30: csomópont Választ({cs cs nyíltak cs (cs nyíltak Heurisztika[cs] Heurisztika[cs ])}) 31: if Állapot[csomópont] C then 32: break 33: end if 34: Kiterjeszt( A,kezdő, C, O, h, csomópont, nyíltak, zártak) 35: end while
78 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 36: if nyíltak then 37: Megoldás-Kiír(csomópont) 38: else 39: print Nincs megoldás 40: end if 41: end procedure
79 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek A best-first algoritmus értékelése Teljesség : A vezérlő tetszőleges véges reprezentációs gráfban, ha van megoldás, véges sok keresőlépés után előállít egy megoldást, ha nincs a problémának az adott reprezentációban megoldása, akkor azt a nyílt csomópontok elfogyásával felismeri. Tárigény : Perfekt heurisztika esetén, ha a reprezentációs fa minden csúcsának d gyermeke van, s l hosszú a legrövidebb megoldás, a keresőgráf csomópontjainak száma a keresés végére: 1 + d + d d = O(l d).
80 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Az A algoritmus 1. A keresőgráf minden csomópontjában megbecsüljük a rajta keresztülhaladó megoldás költségét. Ez egyrészt a csomópontig vezető nyilvántartott út költsége, amihez hozzászámítjuk a célig hátralevő út becsült költségét: azaz összköltség(m) = útköltség(m) + heurisztika(m), összköltség(m) = útköltség(n) + költség(n, m) + heurisztika(m), ha (n, m) E. Ha összköltség (m)-mel jelöljük az m csúcson keresztül célba jutás optimális költségét, akkor minden m csúcsra összköltség (m) összköltség(m) Kiterjesztésre az A algoritmus vezérlője a legkisebb összköltségű nyílt csomópontot választja ki.
81 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 2. Ha a vezérlő a keresőgráf egy csúcsához a keresés során újabb odavezető utat tár fel, azaz az n csomópont kiterjesztéskor előállt állapot szerepel már a keresőgráf m csomópontjában, és az útköltség(n) + költség(n, m) < útköltség(m), ekkor az új kisebb költségű utat tároljuk, a régit elfelejtjük. Ha m nyílt volt, más teendő nincs. Ha m zárt volt, a keresőfa m-ből induló részének csomópontjaiban az útköltség-et frissíteni kell, ami problémát okoz: külön eljárást írunk a frissítésre; az A algoritmussal frissíttetjük a részgráfot; megelőzzük a probléma kialakulását. 3. A tesztelést nem hozhatjuk előre.
82 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 1: procedure Kiterjeszt( A, kezdő, C, O, költség, h, csomópont, nyíltak, zártak) 2: for all o O do 3: if Előfeltétel(Állapot[csomópont], o) then 4: állapot Alkalmaz(Állapot[csomópont],o) 5: ny Keres(nyíltak, állapot) 6: z Keres(zártak, állapot) 7: if ny = Nil and z = Nil then 8: Állapot[új-csomópont] állapot 9: Szülő[új-csomópont] csomópont 10: Operátor[új-csomópont] o 11: Útköltség[új-csomópont] Útköltség[csomópont] + költség(o, Állapot[csomópont]) 12: Heurisztika[új-csomópont] h(állapot) 13: nyíltak nyíltak {új-csomópont} 14: else 15: új-út-költség Útköltség[csomópont] + költség(o, Állapot[csomópont])
83 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 16: if ny Nil then 17: if új-út-költség < Útköltség[ny] then 18: Szülő[ny] csomópont 19: Operátor[ny] o 20: Útköltség[ny] új-út-költség 21: end if 22: else 23: if új-út-költség < Útköltség[z] then 24: Szülő[z] csomópont 25: Operátor[z] o 26: Útköltség[z] új-út-költség 27: zártak zártak \ {z} 28: nyíltak nyíltak {z} 29: end if 30: end if 31: end if 32: end if 33: end for 34: nyíltak nyíltak \ {csomópont} 35: zártak zártak {csomópont} 36: end procedure
84 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 37: procedure A-algoritmus( A, kezdő, C, O, költség, h) 38: Állapot[új-csomópont] kezdő 39: Szülő[új-csomópont] Nil 40: Operátor[új-csomópont] 41: Útköltség[új-csomópont] 0 42: Heurisztika[új-csomópont] h(kezdő) 43: nyíltak {új-csomópont} 44: zártak 45: while Igaz do 46: if nyíltak = then 47: break 48: end if 49: csomópont Választ({cs cs nyíltak cs (cs nyíltak (Útköltség[cs]+Heurisztika[cs]) (Útköltség[cs ]+Heurisztika[cs ]))}) 50: if Állapot[csomópont] C then 51: break 52: end if 53: Kiterjeszt( A, kezdő, C, O, költség, h, csomópont, nyíltak, zártak) 54: end while 55: if nyíltak then 56: Megoldás-Kiír(csomópont) 57: else 58: print Nincs megoldás 59: end if 60: end procedure
85 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek Teljesség : A vezérlő, Az A algoritmus értékelése ha van megoldás, tetszőleges reprezentációs gráfban véges sok keresőlépés után előállít egy megoldást, ha nincs a problémának az adott reprezentációban megoldása, akkor véges gráf esetén azt a nyílt csomópontok elfogyásával felismeri. Optimalitás : Nincs garancia az optimális megoldás előállítására. De ha minden a A esetén h(a) h (a), ahol h (a) az a állapotból célba jutás optimális költsége, akkor az A algoritmus az optimális megoldást állítja elő, ha van megoldás. Ez az A algoritmus.
86 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek 2.3. lemma. Az A algoritmus a működése során egy csúcsot legföljebb véges sokszor terjeszt ki. Bizonyítás. Egy csúcsot csak akkor terjeszthetünk ki, ha nyílt. A nyílt csúcsok közé legfeljebb annyiszor kerülhet, ahányszor egy minden addiginál olcsóbb utat találunk hozzá. Belátjuk, hogy véges sok ilyen út van. Jelölje δ az élek költségének pozitív alsó korlátját, vagyis minden (n, m) esetén költség(n, m) δ > 0. Tegyük föl, hogy a p csúcsba először egy útköltség(p) költségű úton jutunk el. Ez az út legfeljebb útköltség(p)/δ hosszú lehet. Az ennél olcsóbb p-be vezető utak útköltség(p)/δ-nál biztosan rövidebbek. A útköltség(p)/δ korlátnál rövidebb p-be vezető utak száma viszont véges.
87 2. A megoldást kereső rendszerek 2.2. Módosítható megoldáskereső rendszerek 2.4. lemma. Az A algoritmus, hacsak közben nem fejezi be sikeresen a keresést, minden a nyíltak halmazba bekerülő csomópontot véges sok lépés után kiterjeszt. Bizonyítás. Legyen p nyíltak. Megmutatjuk, hogy p kiválasztása előtt kiterjesztendő (nála kisebb összköltséggel rendelkező) csomópontok száma véges és a 2.3 lemma miatt egy ilyen csak véges sokszor kerülhet vissza a nyílt csomópontok közé. Először belátjuk, hogy egy csomópont összköltsége arányos a csomópont mélységével. Amikor egy n csomópont bekerül a nyíltak halmazba, akkor összköltség(n) = útköltség(n) + heurisztika(n) útköltség(n) útköltség (n) úthossz (n) δ, ahol úthossz (n) az s-ből n-be vezető optimális költségű út hossza.
88 2.2. Módosítható megoldáskereső rendszerek 2. A megoldást kereső rendszerek Most egy mélységi korlátot adunk meg. Legyen [ ] összköltség(p) K = + 1. (Nyilván K összköltség(p)/δ). δ Ennél a korlátnál mélyebben fekvő csomópontokra az összköltség nagyobb, mint összköltség(p). Ugyanis ha egy k csomópontra úthossz (k) > K, akkor összköltség(k) úthossz (k) δ > K δ összköltség(p). Tehát összköltség(k) > összköltség(p), azaz az összköltség(p)-nél nem nagyobb összköltséggel rendelkező csomópontok a K mélységi korlátnál magasabban helyezkednek el. Mivel az egyes csomópontokból kiinduló élek száma fölülről korlátos, így egy adott mélységi korlátnál magasabban fekvő csomópontok száma véges.
Mesterséges intelligencia 1 előadások
VÁRTERÉSZ MAGDA Mesterséges intelligencia 1 előadások 2006/07-es tanév Tartalomjegyzék 1. A problémareprezentáció 4 1.1. Az állapottér-reprezentáció.................................................. 5
A mesterséges intelligencia alapjai
A mesterséges intelligencia alapjai Az előadások mellé vetített anyag Várterész Magda A mesterséges intelligencia alapjai: Az előadások mellé vetített anyag Várterész Magda A tananyag a TÁMOP-4.1.2-08/1/A-2009-0046
Eloadó: Dr. Várterész Magdolna
Eloadó: Dr. Várterész Magdolna Tartalomjegyzék: 1. Bevezetés 1.1. A jegyzet megtekintéséhez ajánlott környezet 1.2. Információ a mesterséges intelligencia kurzusról 1.3. Röviden a mesterséges intelligenciáról
Problémamegoldás kereséssel. Mesterséges intelligencia március 7.
Problémamegoldás kereséssel Mesterséges intelligencia 2014. március 7. Bevezetés Problémamegoldó ágens Kívánt állapotba vezető cselekvéseket keres Probléma megfogalmazása Megoldás megfogalmazása Keresési
2. Visszalépéses keresés
2. Visszalépéses keresés Visszalépéses keresés A visszalépéses keresés egy olyan KR, amely globális munkaterülete: egy út a startcsúcsból az aktuális csúcsba (az útról leágazó még ki nem próbált élekkel
Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008
Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008 Az Előadások Témái Bevezető: mi a mesterséges intelligencia... Tudás reprezentáció Gráfkeresési stratégiák Szemantikus hálók
2. Visszalépéses stratégia
2. Visszalépéses stratégia A visszalépéses keres rendszer olyan KR, amely globális munkaterülete: út a startcsúcsból az aktuális csúcsba (ezen kívül a még ki nem próbált élek nyilvántartása) keresés szabályai:
Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008
Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 007/008 Az Előadások Témái Bevezető: mi a mesterséges intelligencia... Tudás reprezentáció i stratégiák Szemantikus hálók / Keretrendszerek
Mesterséges Intelligencia MI
Mesterséges Intelligencia MI Problémamegoldás kereséssel ha sötétben tapogatózunk Dobrowiecki Tadeusz Eredics Péter, és mások BME I.E. 437, 463-28-99 dobrowiecki@mit.bme.hu, http://www.mit.bme.hu/general/staff/tade
Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2010/2011 1/363
1/6 Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2010/2011 Az Előadások Témái 46/6 Bevezető: mi a mesterséges intelligencia... Tudás reprezentáció stratégiák Szemantikus hálók
Mesterséges intelligencia 2. laborgyakorlat
Mesterséges intelligencia 2. laborgyakorlat Keresési módszerek A legtöbb feladatot meg lehet határozni keresési feladatként: egy ún. állapottérben, amely tartalmazza az összes lehetséges állapotot fogjuk
V. Kétszemélyes játékok
Teljes információjú, véges, zéró összegű kétszemélyes játékok V. Kétszemélyes játékok Két játékos lép felváltva adott szabályok szerint. Mindkét játékos ismeri a maga és az ellenfele összes választási
Kereső algoritmusok a diszkrét optimalizálás problémájához
Kereső algoritmusok a diszkrét optimalizálás problémájához A. Grama, A. Gupta, G. Karypis és V. Kumar: Introduction to Parallel Computing, Addison Wesley, 2003. könyv anyaga alapján A kereső eljárások
Kereső algoritmusok a diszkrét optimalizálás problémájához
Kereső algoritmusok a diszkrét optimalizálás problémájához A. Grama, A. Gupta, G. Karypis és V. Kumar: Introduction to Parallel Computing, Addison Wesley, 2003. könyv anyaga alapján A kereső eljárások
Intelligens Rendszerek Elmélete IRE 4/32/1
Intelligens Rendszerek Elmélete 4 IRE 4/32/1 Problémamegoldás kereséssel http://nik.uni-obuda.hu/mobil IRE 4/32/2 Egyszerű lények intelligenciája? http://www.youtube.com/watch?v=tlo2n3ymcxw&nr=1 IRE 4/32/3
Keresések Gregorics Tibor Mesterséges intelligencia
Keresések ADAT := kezdeti érték while terminálási feltétel(adat) loop SELECT SZ FROM alkalmazható szabályok ADAT := SZ(ADAT) endloop KR vezérlési szintjei vezérlési stratégia általános modellfüggő heurisztikus
Adatszerkezetek 2. Dr. Iványi Péter
Adatszerkezetek 2. Dr. Iványi Péter 1 Fák Fákat akkor használunk, ha az adatok között valamilyen alá- és fölérendeltség van. Pl. könyvtárszerkezet gyökér (root) Nincsennek hurkok!!! 2 Bináris fák Azokat
SZOFTVERES SZEMLÉLTETÉS A MESTERSÉGES INTELLIGENCIA OKTATÁSÁBAN _ Jeszenszky Péter Debreceni Egyetem, Informatikai Kar jeszenszky.peter@inf.unideb.
SZOFTVERES SZEMLÉLTETÉS A MESTERSÉGES INTELLIGENCIA OKTATÁSÁBAN _ Jeszenszky Péter Debreceni Egyetem, Informatikai Kar jeszenszky.peter@inf.unideb.hu Mesterséges intelligencia oktatás a DE Informatikai
Kétszemélyes játékok Gregorics Tibor Mesterséges intelligencia
Kétszemélyes játékok Kétszemélyes, teljes információjú, véges, determinisztikus,zéró összegű játékok Két játékos lép felváltva adott szabályok szerint, amíg a játszma véget nem ér. Mindkét játékos ismeri
Amortizációs költségelemzés
Amortizációs költségelemzés Amennyiben műveleteknek egy M 1,...,M m sorozatának a futási idejét akarjuk meghatározni, akkor egy lehetőség, hogy külön-külön minden egyes művelet futási idejét kifejezzük
Mesterséges Intelligencia MI
Mesterséges Intelligencia MI Problémamegoldás kereséssel vakon http://mialmanach.mit.bme.hu/aima/ch03s03 3. fejezet 3.4 alfejezet Pataki Béla, (Hullám Gábor) BME I.E. 414, 463-26-79 pataki@mit.bme.hu,
MESTERSÉGES INTELLIGENCIA DR. KOVÁSZNAI GERGELY JEGYZETE. Verziószám: 1.0 2008. május 19.
MESTERSÉGES INTELLIGENCIA DR. KOVÁSZNAI GERGELY JEGYZETE Verziószám: 1.0 2008. május 19. 1 Tartalomjegyzék 1. A mesterséges intelligencia története...4 1.1. Korai lelkesedés, nagy elvárások (az 1960-as
Modellezés Gregorics Tibor Mesterséges intelligencia
Modellezés 1. Állapottér-reprezentáció Állapottér: a probléma leírásához szükséges adatok által felvett érték-együttesek (azaz állapotok) halmaza az állapot többnyire egy összetett szerkezetű érték gyakran
Adatszerkezetek 7a. Dr. IványiPéter
Adatszerkezetek 7a. Dr. IványiPéter 1 Fák Fákat akkor használunk, ha az adatok között valamilyen alá- és fölérendeltség van. Pl. könyvtárszerkezet gyökér () Nincsennek hurkok!!! 2 Bináris fák Azokat a
Algoritmuselmélet. Gráfok megadása, szélességi bejárás, összefüggőség, párosítás. Katona Gyula Y.
Algoritmuselmélet Gráfok megadása, szélességi bejárás, összefüggőség, párosítás Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 2. előadás
Algoritmuselmélet. Mélységi keresés és alkalmazásai. Katona Gyula Y.
Algoritmuselmélet Mélységi keresés és alkalmazásai Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 9. előadás Katona Gyula Y. (BME SZIT) Algoritmuselmélet
Gráfok 2. Legrövidebb utak, feszítőfák. Szoftvertervezés és -fejlesztés II. előadás. Szénási Sándor
Gráfok 2. Legrövidebb utak, feszítőfák előadás http://nik.uni-obuda.hu/sztf2 Szénási Sándor Óbudai Egyetem,Neumann János Informatikai Kar Legrövidebb utak keresése Minimális feszítőfa keresése Gráfok 2
Mesterséges intelligencia. Gregorics Tibor people.inf.elte.hu/gt/mi
people.inf.elte.hu/gt/mi Szakirodalom Könyvek Fekete István - - Nagy Sára: Bevezetés a mesterséges intelligenciába, LSI Kiadó, Budapest, 1990, 1999. ELTE-Eötvös Kiadó, Budapest, 2006. Russel, J. S., Norvig,
Mesterséges intelligencia 3. laborgyakorlat
Mesterséges intelligencia 3. laborgyakorlat Kétszemélyes játékok - Minimax A következő típusú játékok megoldásával foglalkozunk: (a) kétszemélyes, (b) determinisztikus, (c) zéróösszegű, (d) teljes információjú.
30. ERŐSEN ÜSSZEFÜGGŐ KOMPONENSEK
30. ERŐSEN ÜSSZEFÜGGŐ KOMPONENSEK A gráfos alkalmazások között is találkozunk olyan problémákkal, amelyeket megoldását a részekre bontott gráfon határozzuk meg, majd ezeket alkalmas módon teljes megoldássá
Ember módjára viselkedni: turing teszt Turing 1950 Tudnak a gépek gondolkodni? Korai agyszimulációs tesztek, Percepron hálók, celluláris automaták.
1. Milyen 4 nézet van az MI-ről? (ember módjára viselkedni,, példák) Ember módjára gondolkodni Ember módjára viselkedni racionálisan gondolkodni racionálisan viselkedni Ember módjára viselkedni: turing
Algoritmuselmélet. Legrövidebb utak, Bellmann-Ford, Dijkstra. Katona Gyula Y.
Algoritmuselmélet Legrövidebb utak, Bellmann-Ford, Dijkstra Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 3. előadás Katona Gyula Y. (BME
SZAKDOLGOZAT. Boros László
SZAKDOLGOZAT Boros László Debrecen 2008 Debreceni Egyetem Informatika Kar HATÉKONY KERESŐALGORITMUSOK A MESTERSÉGES INTELLIGENCIÁBAN Témavezető: Dr. Várterész Magda egyetemi docens Készítette: Boros László
Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008
Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008 Az Előadások Témái Bevezető: mi a mesterséges intelligencia... Tudás reprezentáció stratégiák Szemantikus hálók / Keretrendszerek
Algoritmizálás, adatmodellezés tanítása 7. előadás
Algoritmizálás, adatmodellezés tanítása 7. előadás Oszd meg és uralkodj! Több részfeladatra bontás, amelyek hasonlóan oldhatók meg, lépései: a triviális eset (amikor nincs rekurzív hívás) felosztás (megadjuk
26. MINIMÁLIS KÖLTSÉGŰ UTAK MINDEN CSÚCSPÁRRA
26. MINIMÁLIS KÖLTSÉGŰ UTAK MINDEN CSÚCSPÁRRA Az előző két fejezetben tárgyalt feladat általánosításaként a gráfban található összes csúcspárra szeretnénk meghatározni a legkisebb költségű utat. A probléma
Mesterséges intelligencia Gergely Kovásznay Gábor Kusper
Mesterséges intelligencia Gergely Kovásznay Gábor Kusper Mesterséges intelligencia Gergely Kovásznay Gábor Kusper Publication date 2011 Copyright 2011 Hallgatói Információs Központ Copyright 2011, Felhasználási
Struktúra nélküli adatszerkezetek
Struktúra nélküli adatszerkezetek Homogén adatszerkezetek (minden adatelem azonos típusú) osztályozása Struktúra nélküli (Nincs kapcsolat az adatelemek között.) Halmaz Multihalmaz Asszociatív 20:24 1 A
Gráfok, definíciók. Gráfok ábrázolása. Az adott probléma megoldásához ténylegesen mely műveletek szükségesek. Ábrázolások. Példa:
Gráfok, definíciók Irányítatlan gráf: G = (V,E), ahol E rendezetlen (a,b),a,b V párok halmaza. Irányított gráf: G = (V,E) E rendezett (a,b) párok halmaza; E V V. Címkézett (súlyozott) gráf: G = (V,E,C)
A MESTERSÉGES INTELLIGENCIA KÉRDÉSEI A KÖZÉPISKOLAI OKTATÁSBAN
Eszterházy Károly Főiskola Matematikai és Informatikai Intézet A MESTERSÉGES INTELLIGENCIA KÉRDÉSEI A KÖZÉPISKOLAI OKTATÁSBAN DR. KOVÁSZNAI GERGELY ÉS DR. KUSPER GÁBOR JEGYZETE Tartalomjegyzék 1. Bevezetés...4
Algoritmizálás és adatmodellezés tanítása 1. előadás
Algoritmizálás és adatmodellezés tanítása 1. előadás Algoritmus-leíró eszközök Folyamatábra Irányított gráf, amely csomópontokból és őket összekötő élekből áll, egyetlen induló és befejező éle van, az
Mesterséges Intelligencia MI
Mesterséges Intelligencia MI Problémamegoldás kereséssel - csak lokális információra alapozva Pataki Béla BME I.E. 414, 463-26-79 pataki@mit.bme.hu, http://www.mit.bme.hu/general/staff/pataki Lokálisan
Algoritmuselmélet. 2-3 fák. Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem. 8.
Algoritmuselmélet 2-3 fák Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 8. előadás Katona Gyula Y. (BME SZIT) Algoritmuselmélet 8. előadás
angolul: greedy algorithms, románul: algoritmi greedy
Mohó algoritmusok angolul: greedy algorithms, románul: algoritmi greedy 1. feladat. Gazdaságos telefonhálózat építése Bizonyos városok között lehet direkt telefonkapcsolatot kiépíteni, pl. x és y város
A félév során előkerülő témakörök
A félév során előkerülő témakörök rekurzív algoritmusok rendező algoritmusok alapvető adattípusok, adatszerkezetek, és kapcsolódó algoritmusok dinamikus programozás mohó algoritmusok gráf algoritmusok
KERESŐALGORITMUSOK OBJEKTUMORIENTÁLT IMPLEMENTÁCIÓJA A MESTERSÉGES INTELLIGENCIA TÁRGY GYAKORLATI KURZUSAIN
KERESŐALGORITMUSOK OBJEKTUMORIENTÁLT IMPLEMENTÁCIÓJA A MESTERSÉGES INTELLIGENCIA TÁRGY GYAKORLATI KURZUSAIN OBJECT-ORIENTED IMPLEMENTATION OF SEARCH ALGORITHMS AT THE INTRODUCTORY COURSE OF ARTIFICIAL
Gráfalgoritmusok ismétlés ősz
Gráfalgoritmusok ismétlés 2017. ősz Gráfok ábrázolása Egy G = (V, E) gráf ábrázolására alapvetően két módszert szoktak használni: szomszédsági listákat, illetve szomszédsági mátrixot. A G = (V, E) gráf
Algoritmuselmélet. Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem. 13.
Algoritmuselmélet NP-teljes problémák Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 13. előadás Katona Gyula Y. (BME SZIT) Algoritmuselmélet
Bevezetés az informatikába
Bevezetés az informatikába 6. előadás Dr. Istenes Zoltán Eötvös Loránd Tudományegyetem Informatikai Kar Programozáselmélet és Szoftvertechnológiai Tanszék Matematikus BSc - I. félév / 2008 / Budapest Dr.
Állapottér-reprezentálható problémák
1. fejezet Állapottér-reprezentálható problémák 1.1. Állati karácsony 1.1.1. A feladat A karácsonyra készülő Nagy családban a gyerekek (Botond, Emese, Karcsi, Orsi és Vanda) alaposan feladták a leckét
Állapottér-reprezentálható problémák
1. fejezet Állapottér-reprezentálható problémák 1.1. Állati karácsony 1.1.1. A feladat A karácsonyra készülő Nagy családban a gyerekek (Botond, Emese, Karcsi, Orsi és Vanda) alaposan feladták a leckét
Gráfelméleti feladatok. c f
Gráfelméleti feladatok d e c f a b gráf, csúcsok, élek séta: a, b, c, d, e, c, a, b, f vonal: c, d, e, c, b, a út: f, b, a, e, d (walk, lanţ) (trail, lanţ simplu) (path, lanţ elementar) 1 irányított gráf,
A MESTERSÉGES INTELLIGENCIA KÉRDÉSEI A KÖZÉPISKOLAI OKTATÁSBAN DR. KOVÁSZNAI GERGELY GÁBOR ÉS DR. KUSPER JEGYZETE
A MESTERSÉGES INTELLIGENCIA KÉRDÉSEI A KÖZÉPISKOLAI OKTATÁSBAN DR. KOVÁSZNAI GERGELY ÉS DR. KUSPER GÁBOR JEGYZETE Tartalomjegyzék 1. Bevezetés...4 2. A mesterséges intelligencia története...7 2.1. Korai
5. előadás. Programozás-elmélet. Programozás-elmélet 5. előadás
Elemi programok Definíció Az S A A program elemi, ha a A : S(a) { a, a, a, a,..., a, b b a}. A definíció alapján könnyen látható, hogy egy elemi program tényleg program. Speciális elemi programok a kövekezők:
Diszkrét matematika 2.C szakirány
Diszkrét matematika 2.C szakirány 2017. ősz 1. Diszkrét matematika 2.C szakirány 2. előadás Nagy Gábor nagygabr@gmail.com nagy@compalg.inf.elte.hu compalg.inf.elte.hu/ nagy Komputeralgebra Tanszék 2017.
út hosszát. Ha a két várost nem köti össze út, akkor legyen c ij = W, ahol W már az előzőekben is alkalmazott megfelelően nagy szám.
1 Az utazó ügynök problémája Utazó ügynök feladat Adott n számú város és a városokat összekötő utak, amelyeknek ismert a hossza. Adott továbbá egy ügynök, akinek adott városból kiindulva, minden várost
Állapottér-reprezentálható problémák
1. fejezet Állapottér-reprezentálható problémák 1.1. Irány a Margitsziget! 1.1.1. A feladat Végre itt a tavasz, irány a természet! Amennyiben a fővárosban élünk, s a zöldbe vágyunk, ám mégsem szeretnénk
Permutáció n = 3 esetében: Eredmény: permutációk száma: P n = n! romámul: permutări, angolul: permutation
Visszalépéses módszer (Backtracking) folytatás Permutáció n = 3 esetében: 1 2 3 2 3 1 3 1 2 Eredmény: 3 2 3 1 2 1 123 132 213 231 312 321 permutációk száma: P n = n! romámul: permutări, angolul: permutation
Algoritmizálás, adatmodellezés tanítása 8. előadás
Algoritmizálás, adatmodellezés tanítása 8. előadás Elágazás és korlátozás A backtrack alkalmas-e optimális megoldás keresésére? Van költség, és a legkisebb költségű megoldást szeretnénk előállítani. Van
Gráfkeresések A globális munkaterületén a startcsúcsból kiinduló már feltárt utak találhatók (ez az ún. kereső gráf), külön megjelölve az utak azon
ÖSSZEFOGLALÁS Az MI az intelligens gondolkodás számítógépes reprodukálása szempontjából hasznos elveket, módszereket, technikákat kutatja, fejleszti, rendszerezi. Miről ismerhető fel az MI? Megoldandó
ÖSSZEFOGLALÁS a Bsc záróvizsga mesterséges intelligenciáról szóló témaköréhez
ÖSSZEFOGLALÁS a Bsc záróvizsga mesterséges intelligenciáról szóló témaköréhez Az MI az informatikának az a területe, amelyik az intelligens gondolkodás számítógépes reprodukálása szempontjából hasznos
Algoritmusok és adatszerkezetek gyakorlat 07
Algoritmusok és adatszerkezetek gyakorlat 0 Keresőfák Fák Fa: összefüggő, körmentes gráf, melyre igaz, hogy: - (Általában) egy gyökér csúcsa van, melynek 0 vagy több részfája van - Pontosan egy út vezet
Algoritmusok bonyolultsága
Algoritmusok bonyolultsága 9. előadás http://www.ms.sapientia.ro/~kasa/komplex.htm 1 / 18 Közelítő algoritmusok ládapakolás (bin packing) Adott n tárgy (s i tömeggel) és végtelen sok 1 kapacitású láda
Sorozatok határértéke SOROZAT FOGALMA, MEGADÁSA, ÁBRÁZOLÁSA; KORLÁTOS ÉS MONOTON SOROZATOK
Sorozatok határértéke SOROZAT FOGALMA, MEGADÁSA, ÁBRÁZOLÁSA; KORLÁTOS ÉS MONOTON SOROZATOK Sorozat fogalma Definíció: Számsorozaton olyan függvényt értünk, amelynek értelmezési tartománya a pozitív egész
Gráfelmélet/Diszkrét Matematika MSc hallgatók számára. 3. Előadás
Gráfelmélet/Diszkrét Matematika MSc hallgatók számára 3. Előadás Előadó: Hajnal Péter Jegyzetelő: Pék Máté 2009. szeptember 21. 1. Folyamok 1.1. Definíció. G = (V, E, K, B) irányított gráf, ha e! v : ekv
GRÁFELMÉLET. 7. előadás. Javító utak, javító utak keresése, Edmonds-algoritmus
GRÁFELMÉLET 7. előadás Javító utak, javító utak keresése, Edmonds-algoritmus Definíció: egy P utat javító útnak nevezünk egy M párosításra nézve, ha az út páratlan hosszú, kezdő- és végpontjai nem párosítottak,
5/1. tétel: Optimalis feszítőfák, Prim és Kruskal algorithmusa. Legrövidebb utak graphokban, negatív súlyú élek, Dijkstra és Bellman Ford algorithmus.
5/1. tétel: Optimalis feszítőfák, Prim és Kruskal algorithmusa. Legrövidebb utak graphokban, negatív súlyú élek, Dijkstra és Bellman Ford algorithmus. Optimalis feszítőfák Egy összefüggő, irányítatlan
22. GRÁFOK ÁBRÁZOLÁSA
22. GRÁFOK ÁBRÁZOLÁSA A megoldandó feladatok, problémák modellezése során sokszor gráfokat alkalmazunk. A gráf fogalmát a matematikából ismertnek vehetjük. A modellezés során a gráfok több változata is
Diszkrét matematika 2. estis képzés
Diszkrét matematika 2. estis képzés 2018. tavasz 1. Diszkrét matematika 2. estis képzés 11. előadás Nagy Gábor nagygabr@gmail.com nagy@compalg.inf.elte.hu compalg.inf.elte.hu/ nagy Komputeralgebra Tanszék
EGYSZERŰ, NEM IRÁNYÍTOTT (IRÁNYÍTATLAN) GRÁF
Összefoglaló Gráfok / EGYSZERŰ, NEM IRÁNYÍTOTT (IRÁNYÍTATLAN) GRÁF Adott a G = (V, E) gráf ahol a V a csomópontok, E az élek halmaza E = {(x, y) x, y V, x y (nincs hurokél) és (x, y) = (y, x)) Jelölések:
Gráfelméleti alapfogalmak
1 Gráfelméleti alapfogalmak Gráf (angol graph= rajz): pontokból és vonalakból álló alakzat. pontok a gráf csúcsai, a vonalak a gráf élei. GRÁ Irányítatlan gráf Vegyes gráf Irányított gráf G H Izolált pont
Melykeres(G) for(u in V) {szin(u):=feher Apa(u):=0} for(u in V) {if szin(u)=feher then MBejar(u)}
Mélységi keresés Ez az algoritmus a gráf pontjait járja be, eredményképpen egy mélységi feszítőerdőt ad vissza az Apa függvény által. A pontok bejártságát színekkel kezeljük, fehér= érintetlen, szürke=meg-
Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2010/2011 1/363
1/363 Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2010/2011 Az Előadások Témái 69/363 Bevezető: mi a mesterséges intelligencia... Tudás reprezentáció Gráfkeresési stratégiák
Diszkrét matematika 2. estis képzés
Diszkrét matematika 2. estis képzés 2016. tavasz 1. Diszkrét matematika 2. estis képzés 9. előadás Nagy Gábor nagygabr@gmail.com nagy@compalg.inf.elte.hu compalg.inf.elte.hu/ nagy Komputeralgebra Tanszék
További forgalomirányítási és szervezési játékok. 1. Nematomi forgalomirányítási játék
További forgalomirányítási és szervezési játékok 1. Nematomi forgalomirányítási játék A forgalomirányítási játékban adott egy hálózat, ami egy irányított G = (V, E) gráf. A gráfban megengedjük, hogy két
end function Az A vektorban elõforduló legnagyobb és legkisebb értékek indexeinek különbségét.. (1.5 pont) Ha üres a vektor, akkor 0-t..
A Név: l 2014.04.09 Neptun kód: Gyakorlat vezető: HG BP MN l 1. Adott egy (12 nem nulla értékû elemmel rendelkezõ) 6x7 méretû ritka mátrix hiányos 4+2 soros reprezentációja. SOR: 1 1 2 2 2 3 3 4 4 5 6
Diszkrét matematika 2.
Diszkrét matematika 2. 2018. szeptember 21. 1. Diszkrét matematika 2. 2. előadás Fancsali Szabolcs Levente nudniq@cs.elte.hu www.cs.elte.hu/ nudniq Komputeralgebra Tanszék 2018. szeptember 21. Gráfelmélet
Algoritmuselmélet 7. előadás
Algoritmuselmélet 7. előadás Katona Gyula Y. Budapesti Műszaki és Gazdaságtudományi Egyetem Számítástudományi Tsz. I. B. 137/b kiskat@cs.bme.hu 2002 Március 11. ALGORITMUSELMÉLET 7. ELŐADÁS 1 Múltkori
Mesterséges Intelligencia MI
Mesterséges Intelligencia MI Keresés ellenséges környezetben Dobrowiecki Tadeusz Eredics Péter, és mások BME I.E. 437, 463-28-99 dobrowiecki@mit.bme.hu, http://www.mit.bme.hu/general/staff/tade Ellenség
bármely másikra el lehessen jutni. A vállalat tudja, hogy tetszőlegesen adott
. Minimális súlyú feszítő fa keresése Képzeljük el, hogy egy útépítő vállalat azt a megbízást kapja, hogy építsen ki egy úthálózatot néhány település között (a települések között jelenleg nincs út). feltétel
Teljes visszalépéses elemzés
Teljes visszalépéses elemzés adott a következő nyelvtan S» aad a A» b c elemezzük a következő szöveget: accd» ccd ddc S S a A d a A b c d a c c d a c c d Teljes visszalépéses elemzés adott a következő
Bonyolultságelmélet. Monday 26 th September, 2016, 18:50
Bonyolultságelmélet Monday 26 th September, 2016, 18:50 A kiszámítás modelljei 2 De milyen architektúrán polinom? A kiszámításnak számos (matematikai) modellje létezik: Általános rekurzív függvények λ-kalkulus
Algoritmusok bonyolultsága
Algoritmusok bonyolultsága 5. előadás http://www.ms.sapientia.ro/~kasa/komplex.htm 1 / 27 Gazdaságos faváz Kruskal-algoritmus Joseph Kruskal (1928 2010) Legyen V = {v 1, v 2,..., v n }, E = {e 1, e 2,...,
Programozási módszertan. Mohó algoritmusok
PM-08 p. 1/17 Programozási módszertan Mohó algoritmusok Werner Ágnes Villamosmérnöki és Információs Rendszerek Tanszék e-mail: werner.agnes@virt.uni-pannon.hu PM-08 p. 2/17 Bevezetés Dinamikus programozás
Diszkrét matematika 2.C szakirány
Diszkrét matematika 2.C szakirány 2017. tavasz 1. Diszkrét matematika 2.C szakirány 4. előadás Nagy Gábor nagygabr@gmail.com nagy@compalg.inf.elte.hu compalg.inf.elte.hu/ nagy Komputeralgebra Tanszék 2017.
III. Gráfok. 1. Irányítatlan gráfok:
III. Gráfok 1. Irányítatlan gráfok: Jelölés: G=(X,U), X a csomópontok halmaza, U az élek halmaza X={1,2,3,4,5,6}, U={[1,2], [1,4], [1,6], [2,3], [2,5], [3,4], [3,5], [4,5],[5,6]} Értelmezések: 1. Fokszám:
Számítógépes döntéstámogatás. Genetikus algoritmusok
BLSZM-10 p. 1/18 Számítógépes döntéstámogatás Genetikus algoritmusok Werner Ágnes Villamosmérnöki és Információs Rendszerek Tanszék e-mail: werner.agnes@virt.uni-pannon.hu BLSZM-10 p. 2/18 Bevezetés 1950-60-as
Mesterséges Intelligencia MI
Mesterséges Intelligencia MI Problémamegoldás kereséssel - ha segítenek útjelzések Dobrowiecki Tadeusz Eredics Péter, és mások BME I.E. 437, 463-28-99 dobrowiecki@mit.bme.hu, http://www.mit.bme.hu/general/staff/tade
Táblázatok fontosabb műveletei 1
Táblázatok fontosabb műveletei 1 - - Soros táblázat procedure BESZÚR1(TÁBLA, újelem) - - beszúrás soros táblázatba - - a táblázatot egy rekordokat tartalmazó dinamikus vektorral reprezentáljuk - - a rekordok
Az optimális megoldást adó algoritmusok
Az optimális megoldást adó algoritmusok shop ütemezés esetén Ebben a fejezetben olyan modellekkel foglalkozunk, amelyekben a munkák több műveletből állnak. Speciálisan shop ütemezési problémákat vizsgálunk.
Sapientia - Erdélyi Magyar TudományEgyetem (EMTE) Csíkszereda IRT- 4. kurzus. 3. Előadás: A mohó algoritmus
Csíkszereda IRT-. kurzus 3. Előadás: A mohó algoritmus 1 Csíkszereda IRT. kurzus Bevezetés Az eddig tanult algoritmus tipúsok nem alkalmazhatók: A valós problémák nem tiszta klasszikus problémák A problémák
1. Milyen hatással van a heurisztika általában a keresõ rendszerek mûködésére?
2012. 06. 20. 1. Milyen hatással van a heurisztika általában a keresõ rendszerek mûködésére? A heurisztika olyan, a feladathoz kapcsolódó ötlet, amelyet közvetlenül építünk be egy algoritmusba, azért,
Adatbázismodellek. 1. ábra Hierarchikus modell
Eddig az adatbázisokkal általános szempontból foglalkoztunk: mire valók, milyen elemekből épülnek fel. Ennek során tisztáztuk, hogy létezik az adatbázis fogalmi modellje (adatbázisterv), amely az egyedek,
Mátrixjátékok tiszta nyeregponttal
1 Mátrixjátékok tiszta nyeregponttal 1. Példa. Két játékos Aladár és Bendegúz rendelkeznek egy-egy tetraéderrel, melyek lapjaira rendre az 1, 2, 3, 4 számokat írták. Egy megadott jelre egyszerre felmutatják
9. előadás. Programozás-elmélet. Programozási tételek Elemi prog. Sorozatszámítás Eldöntés Kiválasztás Lin. keresés Megszámolás Maximum.
Programozási tételek Programozási feladatok megoldásakor a top-down (strukturált) programtervezés esetén három vezérlési szerkezetet használunk: - szekvencia - elágazás - ciklus Eddig megismertük az alábbi
Számítógép és programozás 2
Számítógép és programozás 2 11. Előadás Halmazkeresések, dinamikus programozás http://digitus.itk.ppke.hu/~flugi/ A keresési feladat megoldása Legyen a lehetséges megoldások halmaza M ciklus { X legyen
Programozás alapjai II. (7. ea) C++ Speciális adatszerkezetek. Tömbök. Kiegészítő anyag: speciális adatszerkezetek
Programozás alapjai II. (7. ea) C++ Kiegészítő anyag: speciális adatszerkezetek Szeberényi Imre BME IIT M Ű E G Y E T E M 1 7 8 2 C++ programozási nyelv BME-IIT Sz.I. 2016.04.05. - 1
Speciális adatszerkezetek. Programozás alapjai II. (8. ea) C++ Tömbök. Tömbök/2. N dimenziós tömb. Nagyméretű ritka tömbök
Programozás alapjai II. (8. ea) C++ Kiegészítő anyag: speciális adatszerkezetek Szeberényi Imre BME IIT Speciális adatszerkezetek A helyes adatábrázolás választása, a helyes adatszerkezet
Ellenőrző kérdések. 36. Ha t szintű indexet használunk, mennyi a keresési költség blokkműveletek számában mérve? (1 pont) log 2 (B(I (t) )) + t
Ellenőrző kérdések 2. Kis dolgozat kérdései 36. Ha t szintű indexet használunk, mennyi a keresési költség blokkműveletek számában mérve? (1 pont) log 2 (B(I (t) )) + t 37. Ha t szintű indexet használunk,
Korlátozás és szétválasztás elve. ADAGOLO adattípus
Korlátozás és szétválasztás elve ADAGOLO adattípus Értékhalmaz: E Adagolo : A E Műveletek: A : Adagolo, x : E {Igaz} Letesit(A) {A = /0} {A = A} Megszuntet(A) {Igaz} {A = A} Uresit(A) {A = /0} {A = A}