Tic-Tac-Toe you can’t beat…

In order to make the traditional Tic Tac Toe Game unbeatable, it is necessary to create an algorithm that can calculate all the possible moves available for the Computer and can use that to determine the best possible move.

Introduction

T…


This content originally appeared on DEV Community and was authored by Dhruv Panchal

In order to make the traditional Tic Tac Toe Game unbeatable, it is necessary to create an algorithm that can calculate all the possible moves available for the Computer and can use that to determine the best possible move.

Tic Tac Toe GUI

Introduction

To solve games using AI, we will introduce the concept of a Game Tree followed by Minimax algorithm. This algorithm sees a few steps ahead and puts itself in the shoes of its opponent. It keeps playing ahead until it reaches a terminal arrangement of the board (terminal state) resulting in a tie, a win, or a loss. Once in a terminal state, the AI will assign an arbitrary positive score (+10) for a win, a negative score (-10) for a loss, or a neutral score (0) for a tie.

At the same time, the algorithm evaluates the moves that lead to a terminal state based on the players’ turn. It will choose the move with maximum score when it is the AI’s turn and choose the move with the minimum score when it is the human player’s turn. Using this strategy, Minimax avoids losing to the human player.

What is Minimax?

Minimax (sometimes MinMax, MM or saddle point) is a decision rule used in artificial intelligence, decision theory, game theory, statistics, and philosophy for minimizing the possible loss for a worst case (maximum loss) scenario. When dealing with gains, it is referred to as "maximin" - to maximize the minimum gain. Originally formulated for n-player zero-sum game theory (one player wins (+10) and other player loses (-10) or both of anyone not to win (0)), covering both the cases where players take alternate moves and those where they make simultaneous moves, it has also been extended to more complex games and to general decision-making in the presence of uncertainty.

How does it work?

To check whether or not the current move is better than the best move we take the help of minimax function which will consider all the possible ways the game can go and returns the best value for that move, assuming the opponent also plays optimally until it finds a terminal state (win, draw or lose).

Game Tree

Image:

Game Tree Image

Explanation:

This image depicts all the possible paths that the game can take from the root board state. It is often called the Game Tree.
The 3 possible scenarios in the above example are :

  • Left Move : If X plays [2,0]. Then O will play [2,1] and win the game. The value of this move is -10
  • Middle Move : If X plays [2,1]. Then O will play [2,2] which draws the game. The value of this move is 0
  • Right Move : If X plays [2,2]. Then he will win the game. The value of this move is +10;

Remember, even though X has a possibility of winning if he plays the middle move, O will never let that happen and will choose to draw instead.
Therefore the best choice for X, is to play [2,2], which will guarantee a victory for him.

GitHub Link for Source Code:

GitHub logo dhhruv / Tic-Tac-Toe

? Unbeatable Tic Tac Toe Game using Minimax Algorithm.

References:


This content originally appeared on DEV Community and was authored by Dhruv Panchal


Print Share Comment Cite Upload Translate Updates
APA

Dhruv Panchal | Sciencx (2021-04-17T18:13:29+00:00) Tic-Tac-Toe you can’t beat…. Retrieved from https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/

MLA
" » Tic-Tac-Toe you can’t beat…." Dhruv Panchal | Sciencx - Saturday April 17, 2021, https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/
HARVARD
Dhruv Panchal | Sciencx Saturday April 17, 2021 » Tic-Tac-Toe you can’t beat…., viewed ,<https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/>
VANCOUVER
Dhruv Panchal | Sciencx - » Tic-Tac-Toe you can’t beat…. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/
CHICAGO
" » Tic-Tac-Toe you can’t beat…." Dhruv Panchal | Sciencx - Accessed . https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/
IEEE
" » Tic-Tac-Toe you can’t beat…." Dhruv Panchal | Sciencx [Online]. Available: https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/. [Accessed: ]
rf:citation
» Tic-Tac-Toe you can’t beat… | Dhruv Panchal | Sciencx | https://www.scien.cx/2021/04/17/tic-tac-toe-you-cant-beat/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.