AI avec Python - Jeux

Les jeux se jouent avec une stratégie. Chaque joueur ou équipe ferait une stratégie avant de commencer le jeu et ils doivent changer ou construire une nouvelle stratégie en fonction de la ou des situations actuelles du jeu.

Algorithmes de recherche

Vous devrez également envisager les jeux informatiques avec la même stratégie que ci-dessus. Notez que les algorithmes de recherche sont ceux qui déterminent la stratégie dans les jeux informatiques.

Comment ça fonctionne

Le but des algorithmes de recherche est de trouver l'ensemble optimal de coups afin qu'ils puissent atteindre la destination finale et gagner. Ces algorithmes utilisent l'ensemble des conditions gagnantes, différentes pour chaque partie, pour trouver les meilleurs coups.

Visualisez un jeu vidéo sous forme d'arbre. Nous savons que l'arbre a des nœuds. En partant de la racine, nous pouvons arriver au nœud final gagnant, mais avec des mouvements optimaux. C'est le travail des algorithmes de recherche. Chaque nœud d'un tel arbre représente un état futur. Les algorithmes de recherche parcourent cet arbre pour prendre des décisions à chaque étape ou nœud du jeu.

Recherche combinée

L'inconvénient majeur de l'utilisation d'algorithmes de recherche est qu'ils sont de nature exhaustive, c'est pourquoi ils explorent l'ensemble de l'espace de recherche pour trouver la solution qui conduit au gaspillage de ressources. Ce serait plus compliqué si ces algorithmes avaient besoin de rechercher tout l'espace de recherche pour trouver la solution finale.

Pour éliminer ce genre de problème, nous pouvons utiliser la recherche combinatoire qui utilise l'heuristique pour explorer l'espace de recherche et réduit sa taille en éliminant les éventuels faux mouvements. Par conséquent, de tels algorithmes peuvent économiser les ressources. Certains des algorithmes qui utilisent l'heuristique pour rechercher l'espace et économiser les ressources sont discutés ici -

Algorithme Minimax

C'est la stratégie utilisée par la recherche combinatoire qui utilise l'heuristique pour accélérer la stratégie de recherche. Le concept de stratégie Minimax peut être compris avec l'exemple des jeux à deux joueurs, dans lesquels chaque joueur essaie de prédire le prochain mouvement de l'adversaire et essaie de minimiser cette fonction. De plus, pour gagner, le joueur essaie toujours de maximiser sa propre fonction en fonction de la situation actuelle.

L'heuristique joue un rôle important dans ce type de stratégies comme Minimax. Chaque nœud de l'arbre serait associé à une fonction heuristique. Sur la base de cette heuristique, il faudra prendre la décision de se diriger vers le nœud qui leur profiterait le plus.

Taille alpha-bêta

Un problème majeur avec l'algorithme Minimax est qu'il peut explorer les parties de l'arbre qui ne sont pas pertinentes, ce qui entraîne un gaspillage de ressources. Par conséquent, il doit y avoir une stratégie pour décider quelle partie de l'arbre est pertinente et laquelle n'est pas pertinente et laisser la partie non pertinente inexplorée. L'élagage alpha-bêta est l'un de ces types de stratégie.

L'objectif principal de l'algorithme d'élagage Alpha-Beta est d'éviter de rechercher les parties de l'arbre qui n'ont pas de solution. Le concept principal de la taille Alpha-Beta est d'utiliser deux bornes nomméesAlpha, la limite inférieure maximale, et Beta, la limite supérieure minimale. Ces deux paramètres sont les valeurs qui restreignent l'ensemble des solutions possibles. Il compare la valeur du nœud actuel avec la valeur des paramètres alpha et bêta, afin de pouvoir se déplacer vers la partie de l'arborescence qui contient la solution et ignorer le reste.

Algorithme Negamax

Cet algorithme n'est pas différent de l'algorithme Minimax, mais il a une implémentation plus élégante. Le principal inconvénient de l'utilisation de l'algorithme Minimax est que nous devons définir deux fonctions heuristiques différentes. Le lien entre ces heuristiques est que, meilleur est l'état d'un jeu pour un joueur, pire c'est pour l'autre joueur. Dans l'algorithme Negamax, le même travail de deux fonctions heuristiques est effectué à l'aide d'une seule fonction heuristique.

Construire des robots pour jouer à des jeux

Pour créer des bots pour jouer à des jeux à deux joueurs en IA, nous devons installer le easyAIbibliothèque. Il s'agit d'un framework d'intelligence artificielle qui fournit toutes les fonctionnalités pour créer des jeux à deux joueurs. Vous pouvez le télécharger à l'aide de la commande suivante -

pip install easyAI

Un bot pour jouer la dernière pièce debout

Dans ce jeu, il y aurait une pile de pièces. Chaque joueur doit prendre un certain nombre de pièces de cette pile. Le but du jeu est d'éviter de prendre la dernière pièce de la pile. Nous utiliserons la classeLastCoinStanding hérité du TwoPlayersGame classe de la easyAIbibliothèque. Le code suivant montre le code Python pour ce jeu -

Importez les packages requis comme indiqué -

from easyAI import TwoPlayersGame, id_solve, Human_Player, AI_Player
from easyAI.AI import TT

Maintenant, héritez de la classe du TwoPlayerGame classe pour gérer toutes les opérations du jeu -

class LastCoin_game(TwoPlayersGame):
   def __init__(self, players):

Maintenant, définissez les joueurs et le joueur qui va commencer la partie.

self.players = players
self.nplayer = 1

Maintenant, définissez le nombre de pièces dans le jeu, ici nous utilisons 15 pièces pour le jeu.

self.num_coins = 15

Définissez le nombre maximum de pièces qu'un joueur peut prendre lors d'un mouvement.

self.max_coins = 4

Maintenant, il y a certaines choses à définir comme indiqué dans le code suivant. Définissez les mouvements possibles.

def possible_moves(self):
   return [str(a) for a in range(1, self.max_coins + 1)]

Définir la suppression des pièces

def make_move(self, move):
   self.num_coins -= int(move)

Définissez qui a pris la dernière pièce.

def win_game(self):
   return self.num_coins <= 0

Définissez quand arrêter le jeu, c'est-à-dire quand quelqu'un gagne.

def is_over(self):
   return self.win()

Définissez comment calculer le score.

def score(self):
   return 100 if self.win_game() else 0

Définissez le nombre de pièces restant dans la pile.

def show(self):
   print(self.num_coins, 'coins left in the pile')
if __name__ == "__main__":
   tt = TT()
   LastCoin_game.ttentry = lambda self: self.num_coins

Résoudre le jeu avec le bloc de code suivant -

r, d, m = id_solve(LastCoin_game,
   range(2, 20), win_score=100, tt=tt)
print(r, d, m)

Décider qui commencera le jeu

game = LastCoin_game([AI_Player(tt), Human_Player()])
game.play()

Vous pouvez trouver la sortie suivante et un jeu simple de ce jeu -

d:2, a:0, m:1
d:3, a:0, m:1
d:4, a:0, m:1
d:5, a:0, m:1
d:6, a:100, m:4
1 6 4
15 coins left in the pile
Move #1: player 1 plays 4 :
11 coins left in the pile
Player 2 what do you play ? 2
Move #2: player 2 plays 2 :
9 coins left in the pile
Move #3: player 1 plays 3 :
6 coins left in the pile
Player 2 what do you play ? 1
Move #4: player 2 plays 1 :
5 coins left in the pile
Move #5: player 1 plays 4 :
1 coins left in the pile
Player 2 what do you play ? 1
Move #6: player 2 plays 1 :
0 coins left in the pile

Un robot pour jouer au Tic Tac Toe

Tic-Tac-Toe est très familier et l'un des jeux les plus populaires. Créons ce jeu en utilisant leeasyAIbibliothèque en Python. Le code suivant est le code Python de ce jeu -

Importez les packages comme indiqué -

from easyAI import TwoPlayersGame, AI_Player, Negamax
from easyAI.Player import Human_Player

Hériter de la classe du TwoPlayerGame classe pour gérer toutes les opérations du jeu -

class TicTacToe_game(TwoPlayersGame):
   def __init__(self, players):

Maintenant, définissez les joueurs et le joueur qui va commencer le jeu -

self.players = players
self.nplayer = 1

Définir le type de carte -

self.board = [0] * 9

Maintenant, il y a certaines choses à définir comme suit -

Définir les mouvements possibles

def possible_moves(self):
   return [x + 1 for x, y in enumerate(self.board) if y == 0]

Définir le mouvement d'un joueur -

def make_move(self, move):
   self.board[int(move) - 1] = self.nplayer

Pour booster l'IA, définissez quand un joueur effectue un mouvement -

def umake_move(self, move):
   self.board[int(move) - 1] = 0

Définir la condition de perte qu'un adversaire a trois dans une ligne

def condition_for_lose(self):
   possible_combinations = [[1,2,3], [4,5,6], [7,8,9],
      [1,4,7], [2,5,8], [3,6,9], [1,5,9], [3,5,7]]
   return any([all([(self.board[z-1] == self.nopponent)
      for z in combination]) for combination in possible_combinations])

Définir un chèque pour la fin du jeu

def is_over(self):
   return (self.possible_moves() == []) or self.condition_for_lose()

Afficher la position actuelle des joueurs dans le jeu

def show(self):
   print('\n'+'\n'.join([' '.join([['.', 'O', 'X'][self.board[3*j + i]]
      for i in range(3)]) for j in range(3)]))

Calculez les scores.

def scoring(self):
   return -100 if self.condition_for_lose() else 0

Définir la méthode principale pour définir l'algorithme et démarrer le jeu -

if __name__ == "__main__":
   algo = Negamax(7)
   TicTacToe_game([Human_Player(), AI_Player(algo)]).play()

Vous pouvez voir la sortie suivante et un jeu simple de ce jeu -

. . .
. . .
. . .
Player 1 what do you play ? 1
Move #1: player 1 plays 1 :
O . .
. . .
. . .
Move #2: player 2 plays 5 :
O . .
. X .
121
. . .
Player 1 what do you play ? 3
Move #3: player 1 plays 3 :
O . O
. X .
. . .
Move #4: player 2 plays 2 :
O X O
. X .
. . .
Player 1 what do you play ? 4
Move #5: player 1 plays 4 :
O X O
O X .
. . .
Move #6: player 2 plays 8 :
O X O
O X .
. X .