GitXplorerGitXplorer
S

SBCLL

public
0 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
29bf8f434ed25c03032b5013463e5669f8e9f688

recode run situation

committed 5 years ago
Unverified
17b10019e2f1ab9d258a4fb3c141f13d9c872fa6

reduce complexity by skipping combinations

committed 5 years ago
Verified
a653268c4078f8b2abe36cb623dad05a970fcb04

Update README.md

SSaulLu committed 5 years ago
Verified
2cf77d61c33dcd2bd1c02df071094bd98b8fd345

minor change readme

SSaulLu committed 5 years ago
Verified
166eea462b2be1d4fb9eed0656519468e4b2309b

Update README.md

EEtWnn committed 5 years ago
Verified
fd04e82b1bef6b955e85cf0a27007dccad971456

Update README.md

EEtWnn committed 5 years ago

README

The README file for this repository.

Vampires vs Loups Garous - Groupe 1

Ce projet consiste en l'implémentation d'une IA pouvant jouer au jeu "Vampires vs Loups Garous" en utilisant plusieurs stratégies différentes.

Mode d'emploi de l'IA

Pour installer l'IA

  1. Cloner ce repository
  2. Dans un terminal, lancer la commande python setup.py build_ext --inplace dans le dossier SBCLL\cpp\target_module\target_module_v1

Pour jouer :

  1. Lancer le serveur du jeu.
  2. Exécuter le fichier "player.py" (au niveau de la racine du projet) avec les paramètres suivants: python player.py -s target2 -he target_diff
  3. Les étapes importantes sont décrites dans la console.

Bonus, dans le terminal, il est possible de choisir pour "player.py":

    -n : le nom du joueur (par défaut, pioche le nom du joueur dans le fichier de config du jeu);
    -s : la stratégie utilisée - toutes les stratégie décrite en partie 3 sont disponibles (par défaut, utilise la stratégie "random");
    -he : l'heuristique utilisée - toutes les heuristiques décrites en partie 3 sont disponibles (par défaut, utilise l'heuristique "naive").

Structure du code

│
├── connector : le code relatif au serveur client
│   ├── client.py : le client et ses fonctions d'interaction 
│   ├── config.json : la config client
│   ├── connect.py : les fonctions pour encrypter / décrypter les commandes à envoyer / recevoir par le client 
├──  cpp \ target_module : module de calcul pour les stratégies de target en C++
│   ├── target_module_v1
│   ├── target_module.sln
├──  models : les classes du jeu et les machines de calcul
│   ├── battle_engine.py : fonctions de calculs des issues (espérances) des batailles aléatoires
│   ├── board.py : classe pour décrire le plateau de jeu
│   ├── cell.py : classe pour décrire une case du plateau de jeu
│   ├── check_engine.py : fonctions de vérifications intermédiaires
│   ├── engine.py : fonctions de calcul de base sur le plateau de jeu
│   ├── mov.py : classe pour décrire un mouvement dans le jeu, tel qu'attendu par la commande MOV
│   ├── target_engine.py : fonctions de calcul pour les stratégies de target
├──  strategies : les stratégies et heuristiques
│   ├── abstract_strategy.py : classe abstraite pour décrire une stratégie
│   ├── alpha_beta.py : classe pour calculer le meilleur prochain coup selon alpha-beta 
│   ├── heuristics.py : les heuristiques pour calculer le score d'un plateau
│   ├── next_best_strategy.py : l'une des classes implémentant une stratégie
│   ├── random_strategy.py : l'une des classes implémentant une stratégie
│   ├── random_target_strategy.py : l'une des classes implémentant une stratégie 
│   ├── random_walk_strategy.py : l'une des classes implémentant une stratégie
│   ├── target_strategy_v2.py : l'une des classes implémentant une stratégie
│   ├── target_strategy.py : l'une des classes implémentant une stratégie
│   ├── target_walk_strategy.py : l'une des classes implémentant une stratégie
├── .gitignore
├── config.json : la config du jeu
├── heuristics_tests.py : l'un des fichiers de tests
├── module_tests.py : l'un des fichiers de tests
├── parameters.py : les paramètres du jeu
├── player.py : le code relatif au joueur, gère l'interaction client et utilise une stratégie donnée 
├── README.md
├── speed_test.py : l'un des fichiers de tests
├── stat_test.py : l'un des fichiers de tests
└── tests.py : l'un des fichiers de tests

Algorithmes, stratégies et heuristiques

Heuristiques

Toutes les heuristiques sont présentées dans le fichier heuristics.py.

a. naive

Calcule la différence entre le nombre de nos créatures et le nombre de créatures adverses (ne prend pas en compte les humains).

b. target_diff

Se base sur sur l'heuristique naive mais ajoute un terme qui prend en compte les potentialités de chaque case de créature. Pour chaque case de créature, on somme toutes les créatures qu'elle peux absorber ou détruire instantanément, pondéré par le carré de l'inverse de la distance qui les sépare. Ce terme est ajouté pour nos créatures et soustrait pour les créatures adverses.

Alpha-bêta

Nous proposons notre propre implémentation du principe alpha-bêta dans le fichier alpha_beta.py, sous forme d'une classe. Cette classe a pour attributs :

  • la profondeur maximale que nous souhaitons atteindre ;
  • la méthode permettant de calculer à partir d'un plateau ses noeuds fils ;
  • l'heuristique permettant d'attribuer un score à chaque plateau ;
  • des attributs permettant de calculer si l'on effectue un time-out avant d'atteindre la profondeur souhaitée pour chaque branche ; Parmi ces derniers attributs, timed_out peut être utilisé au sein d'une stratégie pour adapter la profondeur maximale entre chaque tour. Il est intéressant d'adapter cette profondeur maximale car en cas de time-out, certaines branches ne sont pas du tout explorées à la même profondeur que celles pour lesquelles on avait encore le temps ; éviter le timeout permet une exploration équilibrée et donc plus juste. Notons que chaque fils d'un plateau est un noeud obtenu à partir d'une liste d'objets "mov", qui mène à plusieurs plateaux possibles associés à des probabilités (en fonction des batailles aléatoires). Le score d'un tel noeud est la somme des multiplications du score de chaque plateau fils et de la probabilité d'apparition dudit plateau.

Stratégies

Toutes les stratégies découlent de la classe abstraite Strategy. Cette classe abstraite contient une méthode permettant de mettre le plateau à jour déjà implémentée, et une méthode next_moves décidant du prochain coup du joueur selon le plateau actuel à overrider.

a. random (random_strategy.py)

Cette stratégie choisit pour chaque cellule un coup aléatoire parmi tous les coups légaux ; elle prend bien garde à bouger au moins une créature. Attention, cette dernière n'est à utiliser que sur des boards simples.

b. random_walk (random_walk_strategy.py)

Cette stratégie calcule tous les coups (liste de "mov") possibles à partir du plateau actuel. Elle calcule ensuite des marches aléatoires de profondeur 5 pour chacun de ces coups tant qu'elle a du temps. Enfin, elle choisit le coup menant le plus probablement à des plateaux ayant une bonne heuristique.

c. next_best (next_best_strategy.py)

Cette stratégie calcule tous les coups possibles à partir du plateau actuel et les plateaux résultants. Elle calcule l'heuristique de chaque plateau et choisit le coup menant au meilleur plateau. Attention, cette dernière n'est à utiliser que sur des boards simples.

d. target (target_strategy.py)

Cette stratégie utilise un arbre de décision alpha-bêta. Les fils d'un plateau donné sont calculés à l'aide de fonctions calculant :

  • Pour chacune de nos cases, les cases adverses (humaines ou de l'autre type de créature) pouvant être attaquées sans risques. Ces cases adverses sont les targets potentielles de chacune de nos cases.
  • Pour le plateau, toutes les combinaisons possibles d'attributions de nos cases vers des targets potentielles (en prenant en compte le fait qu'une case puisse se diviser en plusieurs, ou que deux cases peuvent fusionner si aucune target adverse n'est possible).
  • Pour chaque combinaison de nos targets potentielles, la prochaine listes de "mov" que nous devons faire pour avancer vers les-dites targets en essayant d'emprunter le chemin le plus court entre la case initiale et celle de la target et en allant uniquement sur des cases disponibles (ie, la case d'arrivée ne peut pas être une case occupée par notre créature ou par un humain ou l'adversaire si ce n'est pas la target). Ce calcul de fils élague donc tous les coups ne nous dirigeant pas vers des targets potentielles.

e. target2 (target_strategy_v2.py)

Cette stratégie agit quasiment selon les mêmes principes que la précédentes. Seulement, les fonctions de calcul des target et de leurs attributions se fait grâce à un module en C++ que nous avons créé afin de gagner du temps. Nous avons également ajouté une fonction pour limiter l'explosion combinatoire. On limite le nombre de targets par angle de vue pour chacune des cases attaquantes. Par exemple pour chaque cône de 30°, l'attaquant retiendra seulement la target la plus proche dans ce cône. Nous partons du principe que pour aller chercher une target ignorée par cette règle, il faut déja avancer vers la target retenue.

f. target_walk (random_target_strategy.py)

Cette stratégie est un mélange entre target_walk et target. On utilise un alpha_bêta comme dans target mais les noeuds fils sont tirés aléatoirements. On a alors seulement un échantillon des fils disponibles. Cette stratégie privilégie la profondeur d'exlploration à l'exactitude des scores attribués à chaque noeuds de l'arbre. Elle n'explore aussi qu'une partie des branches, certaines n'étant pas tirées par le hasard