Skip to content

tudorcoman/flappy-bird-rl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Flappy Bird Reinforcement Learning 🐦 🎮 🤖

Prezentarea temei de proiect

Tema proiectului implementarea a doi algoritmi de Reinforcement Learning asupra mediului descris mai jos:

  • Q-Learning cu deep Q network (DQN)
  • SARSA cu neural network (Deep SARSA)

Descrierea mediului

Folosim un mediu gata implementat, compatibil cu OpenAI Gymnasium și implementat cu biblioteca PyGame. Acesta este identic cu jocul original de Flappy Bird. Jucătorul controlează o pasăre care trebuie să se strecoare printre stâlpii verticali (obstacole). Singura mișcare pe care o poate face pasărea este să sară (deplasare pe verticală). Mișcarea hărții pe orizontală este automată și constantă, până la finalizarea jocului. De asemenea, dacă utilizatorul nu apasă pe spațiu pentru a sări, pasărea va cădea (efect de "gravitație"). Jocul se termină atunci când pasărea nu se strecoară prin spațiul gol și lovește un obstacol sau atinge marginea mediului de joc. Pentru fiecare "strecurare", jucătorul câștigă un punct.

Descrierea agentilor

Pentru fiecare dintre cei 3 algoritmi pe care i-am implementat, avem câte un agent unic. Acestora le corespunde câte o politică distinctă.

1. DQN

Ideea de bază este ca agentul să învețe o politică, astfel încât să fie maximizată recompensa totală (scorul). Q-Function este o funcție care estimează valoarea de a face o anumită acțiune într-o stare specifică. În general, algoritmii de Q-Learning folosesc o tabelă pentru a reprezenta această funcție (Q-Table). Pentru mediile mai complexe, această tabelă devine foarte mare și algoritmul devine ineficient. Astfel, pentru a rezolva această problemă, folosim o rețea neuronală pentru a aproxima Q-Function. Deciziile agentului se bazează pe această aproximare.

Pentru a păstra echilibrul între explorare și exploatare, algoritmul folosește o strategie numită "ε-Greedy". Această strategie alege o acțiune aleatoare cu probabilitatea ε, și în rest alege acțiunea cu cea mai mare valoare Q.

DQN este un algoritm off-policy, adică agentul învață o politică diferită de cea pe care o folosește pentru a explora mediul. În cazul nostru, agentul folosește o politică ε-Greedy pentru a explora mediul, dar învață o politică care alege întotdeauna acțiunea cu cea mai mare valoare Q (o strategie de tip Greedy).

În cazul implementării noastre, am folosit două rețele neurale:

  1. Rețeaua principală (locală): rețeaua principală care învață la (aproape) fiecare pas

  2. Rețeaua secundară (țintă): o copie a primei rețele care nu este actualizată la fiecare pas și are rolul de a stabiliza actualizările valorilor Q. Astfel, este evitată și problema "moving target".

DQN Algorithm Evolution

Dacă utiliazm algoritmul DQN, recompensa medie crește de la episod la episod.

Micile fluctuații sunt din cauza faptului că algoritmul testează mai multe strategii înainte de a le alege pe cele optime.

Am putea obține un scor mai bun jucându-ne cu hiperparametri sau adaptând rețeaua neuronală, în detrimentul unui timp de antrenament mai lung.

2. (Deep) SARSA

SARSA este un algoritm de tip on-policy, acesta luându-și deciziile pe baza aceleiași politici pe care o folosește pentru a învața. Abordarea SARSA este de tip Temporal Difference (TD), care învață prin actualizarea funcției Q pe baza "diferenței temporale" dintre recompensa prezisă și cea observată și așa el poate să maximizeze mult mai bine recompensa. Această actualizare se face după fiecare pas dintr-o pereche stare-acțiune la următoarea, nu doar la final de episod. Asemănător cu DQN, SARSA folosește tot o strategie ε-Greedy pentru a alege acțiunile în mod aleatoriu, cu probabilitatea ε, iar în rest urmărește valoarea cea mai bună de pe politica actuală.

Principala caracteristică a SARSA este că este un algoritm de învățare mai sigur, în comparație cu DQN. Asta este un avantaj mare în mediile unde anumite acțiuni pot duce la consecințe negative. Din punct de vedere al timpului, SARSA este aproape optim, deși poate converge mai încet decât DQN în anumite medii pentru că prioritizează siguranța. Performanța depinde de echilibrul pe care îl găsește între explorare și exploatare, precum și de modul în care politica este actualizată în timp.

Într-adevăr, și în cazul nostru, acesta converge mai greu, obținând primele rezultate după 5000 de episoade. Similar cu DQN, și SARSA poate folosi rețele neurale pentru aproximarea funcției Q în cazul mediilor prea complexe. În acest caz se numește Deep SARSA și nu este așa frecvent ca DQN.

Deep Sarsa Algorithm Evolution

Discuție

  1. Se observă ca după aproape jumătate de antrenament, agentul învață și își îmbunătățește performanța, deoarece se adaptează la mediul de joc.
  2. Fluctuațiile care sunt vizibile pe grafic demonstrează încercările agentului de a explora diferite strategii, ținta fiind maximizarea recompensei.
  3. Tendința de creștere a recompensei medii sugerează optimizarea comportamentului agentului, un indicator pozitiv cu privire la evoluția acestuia.
  4. La fel ca la DQN, s-ar putea obține rezultate mai bune dacă am regla parametrii, sau adaptând rețeaua neurală, fapt ce va mări durata antrenamentului și timpul de așteptare.

3. PPO (attempt)

PPO este de asemenea un algoritm off-policy. Acesta face parte din categoria metodelor de policy gradient, pentru că el își parametrizează direct politica. Spre deosebire de DQN și SARSA (algoritmi bazați pe valori), obiectivul principal al acestui algoritm este să învețe o politică în care sunt mapate stările cu acțiuni, în așa fel încât să se maximizeze recompensa cumulativ.

Pentru a îmbunătăți politica și în același timp să nu fie alterată semnificativ, este folosită o funcție "obiectiv" (objective function) ce compară politica nouă (obținută prin modificările la un anumit pas) de cea curentă. Acest raport este controlat printr-un mecanism de "clipping", și are ca efect o antrenare mai stabilă și previne decizii mai riscante luate de agent.

Acest algoritm este foarte performant chiar și în medii mai complexe, pentru că este capabil să facă decizii mari și în același timp și sigure, prevenind schimbări majore în politică ce are duce la o antrenare instabilă.

Am încercat implementarea acestui algoritm, dar nu am reușit să facem agentul să învețe mediul. Probabil este nevoie să îmbunătățim arhitectura rețelelor și să hipertunăm parametrii mai mult.

Bibliografie

  1. Google DeepMind

  2. Deep Reinforcement Learning for Flappy Bird

  3. arXiv:2003.09579v2

  4. arXiv:1702.03118

About

Flappy Bird game Reinforcement Learning project

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages