AI z Pythonem - Gaming

Gry rozgrywane są według strategii. Każdy gracz lub zespół opracowałby strategię przed rozpoczęciem gry i musiałby zmienić lub zbudować nową strategię zgodnie z obecną sytuacją w grze.

Algorytmy wyszukiwania

Będziesz musiał rozważyć gry komputerowe również z taką samą strategią jak powyżej. Zwróć uwagę, że algorytmy wyszukiwania określają strategię w grach komputerowych.

Jak to działa

Celem algorytmów wyszukiwania jest znalezienie optymalnego zestawu ruchów, aby mogły dotrzeć do miejsca docelowego i wygrać. Algorytmy te wykorzystują zwycięski zestaw warunków, różnych dla każdej gry, aby znaleźć najlepsze ruchy.

Wizualizuj grę komputerową jako drzewo. Wiemy, że drzewo ma węzły. Zaczynając od korzenia, możemy dojść do końcowego zwycięskiego węzła, ale z optymalnymi ruchami. Na tym polega praca algorytmów wyszukiwania. Każdy węzeł w takim drzewie reprezentuje przyszły stan. Algorytmy wyszukiwania przeszukują to drzewo, aby podejmować decyzje na każdym etapie lub węźle gry.

Wyszukiwanie kombinacyjne

Główną wadą stosowania algorytmów wyszukiwania jest to, że mają one charakter wyczerpujący, dlatego eksplorują całą przestrzeń wyszukiwania, aby znaleźć rozwiązanie, które prowadzi do marnotrawstwa zasobów. Byłoby bardziej kłopotliwe, gdyby te algorytmy musiały przeszukiwać całą przestrzeń poszukiwań w celu znalezienia ostatecznego rozwiązania.

Aby wyeliminować tego rodzaju problem, możemy skorzystać z wyszukiwania kombinacyjnego, które wykorzystuje heurystykę do eksploracji przestrzeni poszukiwań i zmniejsza jej rozmiar, eliminując możliwe złe ruchy. Dlatego takie algorytmy mogą oszczędzać zasoby. Omówiono tutaj niektóre algorytmy, które używają heurystyki do przeszukiwania przestrzeni i oszczędzania zasobów -

Algorytm Minimax

Jest to strategia używana w wyszukiwaniu kombinowanym, która wykorzystuje heurystykę do przyspieszenia strategii wyszukiwania. Koncepcję strategii Minimax można zrozumieć na przykładzie rozgrywek dwuosobowych, w których każdy z graczy stara się przewidzieć kolejny ruch przeciwnika i stara się zminimalizować tę funkcję. Ponadto, aby wygrać, gracz zawsze stara się zmaksymalizować swoją funkcję w oparciu o aktualną sytuację.

Heurystyka odgrywa ważną rolę w takich strategiach jak Minimax. Każdy węzeł drzewa miałby przypisaną funkcję heurystyczną. Opierając się na tej heurystyce, podejmie decyzję o ruchu w kierunku węzła, który przyniesie im największe korzyści.

Przycinanie alfa-beta

Głównym problemem związanym z algorytmem Minimax jest to, że może on badać te części drzewa, które są nieistotne, co prowadzi do marnotrawstwa zasobów. Dlatego musi istnieć strategia decydowania, która część drzewa jest istotna, a która nieistotna, i pozostawia niezbadaną część nieistotną. Przycinanie alfa-beta jest jedną z takich strategii.

Głównym celem algorytmu przycinania Alpha-Beta jest uniknięcie przeszukiwania tych części drzewa, które nie mają żadnego rozwiązania. Główną koncepcją przycinania Alpha-Beta jest użycie dwóch nazwanych granicAlpha, maksymalna dolna granica i Beta, minimalna górna granica. Te dwa parametry są wartościami, które ograniczają zbiór możliwych rozwiązań. Porównuje wartość bieżącego węzła z wartością parametrów alfa i beta, dzięki czemu może przejść do części drzewa, w której znajduje się rozwiązanie, a resztę odrzucić.

Algorytm Negamax

Ten algorytm nie różni się od algorytmu Minimax, ale ma bardziej elegancką implementację. Główną wadą korzystania z algorytmu Minimax jest to, że musimy zdefiniować dwie różne funkcje heurystyczne. Związek między tymi heurystami polega na tym, że im lepszy stan gry jest dla jednego gracza, tym gorszy jest dla drugiego gracza. W algorytmie Negamax ta sama praca dwóch funkcji heurystycznych jest wykonywana za pomocą jednej funkcji heurystycznej.

Tworzenie botów do grania w gry

Aby zbudować boty do grania w gry dla dwóch graczy w AI, musimy zainstalować easyAIbiblioteka. Jest to szkielet sztucznej inteligencji, który zapewnia wszystkie funkcje potrzebne do tworzenia gier dla dwóch graczy. Możesz go pobrać za pomocą następującego polecenia -

pip install easyAI

Bot do gry w Last Coin Standing

W tej grze byłby stos monet. Każdy gracz musi pobrać określoną liczbę monet z tego stosu. Celem gry jest uniknięcie zabrania ostatniej monety ze stosu. Będziemy używać klasyLastCoinStanding odziedziczone z TwoPlayersGame klasa easyAIbiblioteka. Poniższy kod przedstawia kod Pythona dla tej gry -

Zaimportuj wymagane pakiety, jak pokazano -

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

Teraz odziedzicz klasę z TwoPlayerGame klasa do obsługi wszystkich operacji w grze -

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

Teraz określ graczy i gracza, który ma rozpocząć grę.

self.players = players
self.nplayer = 1

Teraz określ liczbę monet w grze, tutaj używamy 15 monet do gry.

self.num_coins = 15

Określ maksymalną liczbę monet, które gracz może wziąć w ruchu.

self.max_coins = 4

Teraz jest kilka rzeczy do zdefiniowania, jak pokazano w poniższym kodzie. Zdefiniuj możliwe ruchy.

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

Zdefiniuj usunięcie monet

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

Określ, kto wziął ostatnią monetę.

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

Określ, kiedy zakończyć grę, czyli kiedy ktoś wygrywa.

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

Określ, jak obliczyć wynik.

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

Określ liczbę monet pozostałych w stosie.

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

Rozwiązywanie gry za pomocą następującego bloku kodu -

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

Decydowanie, kto rozpocznie grę

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

Możesz znaleźć następujące dane wyjściowe i prostą grę w tę grę -

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

Bot do gry Tic Tac Toe

Kółko i krzyżyk to bardzo znajoma i jedna z najpopularniejszych gier. Stwórzmy tę grę za pomocąeasyAIbiblioteka w Pythonie. Poniższy kod to kod Pythona tej gry -

Zaimportuj pakiety, jak pokazano -

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

Dziedzicz klasę z TwoPlayerGame klasa do obsługi wszystkich operacji w grze -

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

Teraz zdefiniuj graczy i gracza, który ma rozpocząć grę -

self.players = players
self.nplayer = 1

Określ rodzaj tablicy -

self.board = [0] * 9

Teraz jest kilka rzeczy do zdefiniowania w następujący sposób -

Zdefiniuj możliwe ruchy

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

Zdefiniuj ruch gracza -

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

Aby wzmocnić AI, określ, kiedy gracz wykonuje ruch -

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

Określ warunek przegranej, w którym przeciwnik ma trzy w linii

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])

Zdefiniuj czek na zakończenie gry

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

Pokaż aktualną pozycję graczy w grze

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)]))

Oblicz wyniki.

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

Zdefiniuj główną metodę zdefiniowania algorytmu i rozpoczęcia gry -

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

Możesz zobaczyć następujące dane wyjściowe i prostą grę w tę grę -

. . .
. . .
. . .
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 .