Predstavljam vam svoju master tezu.
Radi se o 2D RTS engine-u napisanom from the scratch za Java 7 platformu. Naglasak je na jednom primeru pathfinding-a za strateske igre (ili slicne interaktivne sisteme). Kao sto se moze videti, engine je napisan sa mogucnoscu render-ovanja Starcraft multimedijalnih resursa.
Resenje je hibridno. Zasnovano je na tzv. potencijalnim poljima, odnosno kontinualnom modelu, uz niz optimizacija (odnosno pojednostavljenja) da bi ono bilo primenljivo na interaktivne sisteme (RTS igre), izvrsivo samo na CPU-u i izvodljivo na Java-i.
Motivaciju sam dobio iz http://www.youtube.com/watch?v=jA2epda-RkM.
Sam kontinualni model je definisan ovde i to za sasvim drugu primenu - za crowd simulation.
Poenta cele price je da se za zadani cilj, za ceo prostor generise potencijalno polje realnih vrednosti koje obrazuju opadajuci gradijent do samog cilja u kome je vrednost 0. Jedinice iz bilo koje tacke u prostoru mogu da odrede optimalnu putanju do cilja prateci opadajuce vrednosti potencijalnog polja i ne moraju imati fiksnu putanju ka cilju odredjenu nekom pretragom (kao sto je A* algoritam). Dinamicke prepreke (ostale jedinice i sl.) mogu da projektuju porast vrednosti potencijalnog polja sto prouzrokuje njihovo izbegavanje.
U fizickom smislu, potencijalno polje je skalarna vremenska slika monotono sireceg talasa koji se siri iz ciljne tacke u prostoru, sto je definisano eikonal jednacinom. Potencijalno polje je u svakoj tacki jednako vremenskom trenutku u kome je talasni front dostigao tu tacku. Za numericku diskretizaciju eikonal jednacine koristi se upwind sema, a za sinlge-threaded procesorsku konstrukciju potencijalnog polja fast marching metoda.
Za razresavanje kolizije korisitio sam pojednostavljeni flocking mehanizam. Nisam previse eksperimentisao sa razlicitim kolizionim radijusima, ali sam primetio izvesne probleme ako su oni dovoljno veliki (jer kolizioni mehanizam nije dovoljno sofisticiran).
Ogromna prednost primene potencijalnih polja je cinjenica da jedinice ne moraju posedovati unapred isplaniranu putanju do cilja, vec planiraju samo jedan korak unapred, te pri otkrivanju kolizije ne moraju da skupo odredjuju alternativnu putanju. Mana je naravno hardverska zahtevnost, jer proracunavanje vrednosti potencijala za svako polje u grid-u nije nimalo naivno.
Implementacija broji blizu 200 klasa (odnosno interfejsa).
Kod sebe imam AMD Athlon X2 6000+ CPU. Proces zauzima do 500MB RAM-a i trpi do 1500 jedinica na mrezi rezolucije 512x512 sa 30+ fps. Konstrukcija potencijalnog polja traje oko 100ms.
AMD je sa Radeon HD4xxx serijom predstavio GPGPU optimizovanu implementaciju za crowd simulation probleme, sto svakao planiram da istrazim, ali onda cela prica ide na odgovarajucu C++ platformu (gde joj je i mesto).