Skip to content

Latest commit

 

History

History
98 lines (79 loc) · 2.73 KB

README.org

File metadata and controls

98 lines (79 loc) · 2.73 KB

Neural Networks To Solve Simple Games

The purpose of the project is to better understand, how neural networks work from top to bottom. To do that we built a mini library in python to create and train a Multilayer Perceptron on a simple problem. The problem we choose was to approximate a reasonable player of a strategy board game.

Showcase

To see the final results to this moment, you can simply run the file “main.py” where you will be presented with a prompt. This will allow you to choose to play against the two neural networks that where train, or to simulate games between both neural networks and random generated moves.

py main.py

Play around

You can also play around with the code we write by simply using a python prompt or writing on a new python file. Everything we wrote here are simply functions that can be imported and used whenever.

Playing each game is easy, and each one comes with options related to the types of players…

import connect4 as c4
import tic_tac_toe as tic

# To play Tic Tac Toe against the MLP...
tic.play("nn", "p")

# To play Connect Four against the MLP...
c4.play("nn", "p")

There is also the possibility of simulating many games against random opponents to test how well our MLP is doing in the long run.

import connect4 as c4
import tic_tac_toe as tic

# Simulating games for Tic Tac Toe
print("Tic Tac Toe")
tic.simulate_games(1000, "nn", "r")

print()

# Simulating games for Connect Four
print("Connect Four")
c4.simulate_games(1000, "nn", "r")
Tic Tac Toe
Player 1 Wins: 73.5 %
Player 2 Wins: 14.099999999999998 %
Draw: 12.4 %

Connect Four
Player 1 Wins: 69.6 %
Player 2 Wins: 30.2 %
Draw: 0.2 %

There are many more functions to generate, train and use the MLP’s, all of those can be found on the neural_net.py file.

Things to do next

  • [X] Organize all the files in separate folders.
  • [ ] Getting good data of Tic Tac Toe games for testing.
  • [ ] Adapt playing function for the NN to train on the game it just played
  • [ ] Consider looking into reinforcement learning.
  • [ ] Correct default files in Games package
  • [ ] Correct README.org