Search
Vážení studenti, tato stránka a úloha je nová a není tudíž odladěna na vašich předchůdcích. Pokud by se vám cokoli nezdálo, něco nebylo jasné, nebo něco chybělo, pište ihned na petr.posik@fel.cvut.cz. Díky!
Jsme ve stavu, kdy bychom měli mít implementovány algoritmy lokálního prohledávání a evoluční algoritmus pro problémy s binární a reálnou reprezentací. Cílem 1. domácí úlohy je vyzkoušet tyto algoritmy na problému obchodního cestujícího.
Problém obchodního cestujícího je problém nalezení nejkratší hamiltonovské kružnice v grafu, jinými slovy problém nalezení nejkratší cesty, která zajistí, že navštívíte všechna místa a vrátíte se zpět do místa, z něhož jste vyrazili.
TSP není jediný problém, ale celá třída problémů. Instance se liší tím, kolik míst je třeba projet, a jaké jsou vzdálenosti mezi místy. Instance tedy bývá zadána buď maticí vzdáleností mezi místy, nebo souřadnicemi míst v nějakém metrickém prostoru.
My se soustředíme na symetrické instance (cesta z A do B stojí stejně jako cesta z B do A) z knihovny problémů TSPLIB.
Existuje mnoho reprezentací potenciálních řešení tohoto problému, ale tou nejpřirozenější je asi permutace čísel, která určuje pořadí, v němž místa navštívíte. Zvolte reprezentaci, kterou budete používat.
Vytvořte funkci, která bude umět vytvořit náhodné kandidátské řešení. Toto řešení by mělo být přípustné, tj. mělo by se jednat o platnou permutaci míst (každé by se mělo vyskytnout právě jednou).
Vytvořte účelovou funkci, pomocí níž bude možné kandidátské řešení ohodnotit. Měla by využít údaje z matice vzdáleností.
Vytvořte funkci, která bude mutovat řešení. Výsledkem mutace by mělo být opět platné řešení. Smysluplných mutačních operátorů existuje víc. Implementujte alespoň jeden. Promyslete si:
Máte-li vše vhodně naimplementované, mělo by být možné vzít váš algoritmus lokálního prohledávání, poskytnout mu účelovou funkci, inicializační proceduru a mutační operátor a měli byste mít funkční TSP solver. Zkuste jej aplikovat na TSP úlohy, zaznamenávejte si výsledky (nebo lépe, zaznamenávejte si celý časový průběh).
Opět existuje více smysluplných operátorů křížení pro TSP. Efektivní operátor křížení ale vyžaduje jisté přemýšlení. Jeho výsledkem by opět mělo být přípustné řešení. Implementujte alespoň jeden. Možnosti:
Inspiraci pro operátory křížení můžete najít třeba v článcích naween2013crossoversfortsp.pdf nebo puljic2013crossoversforvrp.pdf.
Nyní byste měli mít k dispozici všechny části EA pro TSP. Mělo by stačit EA správně nakonfigurovat a spustit. Zkuste jej aplikovat na různé TSP úlohy a porovnejte ho s výsledky lokálního prohledávání.
Implementujte funkci, jak si graficky znázornit řešení TSP problému. Ideální by bylo, kdybyste mohli průběh optimalizace sledovat, tj. vidět, jak se postupně nejlepší dosud nalezené řešení vylepšuje.
O memetických algoritmech jsme se dosud nezmiňovali. Dalo by se říct, že každý EA, který je nějak zkombinován s lokálním prohledáváním, je memetický algoritmus.
Možností, jak EA zkombinovat s LS, je opět víc:
Pokuste se nějaký memetický algoritmus sestavit a porovnat jej s LS a EA.
TSP obvykle nebývá tak úplně black-box problém, protože obvykle známe matici vzdáleností mezi místy. To nám umožňuje použít různé konstruktivní heuristiky k rychlému nalezení poměrně dobrého řešení. Tato řešení se opět dají použít pro inicializaci populace EA.
Zkuste nějakou konstruktivní heuristiku vytvořit a použít ji
Porovnejte výsledky obou metod, tj. zjistětě, o kolik byl EA schopný ještě vylepšit řešení nalezená pomocí konstruktivní heuristiky.
Zajímavým experimentem by mohlo být srovnání s úplným prohledáním prostoru možných cest. Velikost prostoru velmi rychle roste a brzy narazíte na limit počtu míst TSP, který jste schopni zvládnout. Pokud nebudete schopni řešit ani nejmenší instance z TSPLIB, zkuste si nagenerovat své, menší.
Úplné prohledání vyžaduje způsob, jak systematicky vygenerovat všechna přípustná řešení. I u něj se ale dá sestavit graf délky nejkratší dosud nalezené cesty v závislosti na počtu dosud využitých ohodnocení a lze jej tedy porovnat s algoritmy typu LS nebo EA.
Při hodnocení úlohy vám chceme dát jistou volnost v tom, jak moc se do úlohy chcete ponořit. Část úlohy proto tvoří jisté minimální požadavky, jejichž splněním si zajistíte minimální potřebný počet bodů. Každé další vylepšení vám přinese body navíc, až do maximálního počtu 10 bodů.
Abychom tuto úlohu považovali za splněnou, musíte provést porovnání
DO BRUTE do úlohy DU1 Budete odevzdávat ZIP archiv obsahující
Součástí hodnocení může být předvedení funkčnosti implementace na některém cvičení. Pokud jste si pro implementaci vybrali jiný jazyk než Python, Javu, nebo C/C++, bude předvedení funkčnosti povinné.
Očekávaný obsah reportu:
Za úlohu můžete získat maximálně 10 bodů.