The project aims to teach a neural net how to play the famous game 'Flappy Bird'. To play the game deep learning and genetic algorithms are applied.
For applying genetic algorithm NEAT(Neuro Evolution of Augemting Topologies) is used. It alters both the weighting parameters and structures of networks, attempting to find a balance between the fitness of evolved solutions and their diversity. It is based on applying three key techniques: tracking genes with history markers to allow crossover among topologies, applying speciation (the evolution of species) to preserve innovations, and developing topologies incrementally from simple initial structures ("complexifying").
- base.py → stores the class for the base of the game
- bird.py → stores the class for the bird of the game
- pipe.py → stores the class for the pipe in the games
- game.py → stores the game object and has the 'run' method which is used by the genomes to generate birds in the game
- visualize.py → stores the visualization methods
- runner.py → main file and generates the config and the genome and runs the game for the genome
- configs/config-feedforward.txt → stores the neat configuration and all the weights/initializarions/activation functions are defined using this configuration file.
- neat-python
- numpy
- graphviz
- pygame
Open terminal/cmd in current working directory.
Enter python runner.py and see the AI learn flappy bird.
Game |
---|
Cmd Output |
---|
Average Fitness Plot |
---|