A cellular automaton devised by British mathematician John Horton Conway in 1970.
Conway's Game of Life, or simply "Life," is a cellular automaton devised by British mathematician John Horton Conway in 1970. It is a zero-player game, meaning its evolution is determined by its initial state, requiring no further input. Players interact with the game by creating an initial configuration and observing how it evolves. The game is Turing complete and can simulate a universal constructor or any other Turing machine.
The universe of the Game of Life is an infinite, two-dimensional orthogonal grid of square cells. Each cell is in one of two possible states: ALIVE
or DEAD
. Every cell interacts with its eight neighbors, which are the cells that are horizontally, vertically, or diagonally adjacent.
- Any live cell with fewer than two live neighbors dies, as if by underpopulation.
- Any live cell with two or three live neighbors lives on to the next generation.
- Any live cell with more than three live neighbors dies, as if by overpopulation.
- Any dead cell with exactly three live neighbors becomes a live cell, as if by reproduction.
The first generation is created by applying the above rules simultaneously to every cell in the seed, alive or dead; births and deaths occur simultaneously, and the discrete moment at which this happens is sometimes called a tick. Each generation is a pure function of the preceding one.
Buttons | What they do |
---|---|
Starts the animation after you've set the initial pattern | |
⏸️ | Pauses the animation |
⏩ | Increases the speed of the animation |
⏪ | Decreases the speed of the animation |
Clear |
Clears the grid on click, only if the game is not animating at that moment |
Random |
Randomly initializes the grid with initial randomness as 20% |
Settings | What are they for? |
---|---|
Gridlines |
Toggles visibility of the gridlines |
Warp on Edges |
Warps the patterns across the edges - Initially set as true |
Randomness |
Allows you to set custom randomness percent for random initialization |
Themes | The Colors |
---|---|
Blue (default) | |
Red | |
Green | |
Purple | |
Dark Cyan | |
Dark Neon |
Stores history of patterns that user has played with, up to 5 recent patterns.
The glider is the smallest, most common, and first-discovered spaceship in Game of Life. It travels diagonally across the grid. Gliders are important because they are easily produced, can be collided with each other to form more complicated patterns, and can be used to transmit information over long distances.
The big glider was found by Dean Hickerson in December 1989 and was the first known diagonal spaceship other than the glider. Two gliders can be temporarily seen at the front of the ship; these do not stay gliders but still move like them.
The Gosper glider gun is the first known gun, and indeed the first known finite pattern with unbounded growth, found by Bill Gosper in November 1970. It consists of two queen bee shuttles stabilized by two blocks.
Explore more patterns at ConwayLife Patterns.
This project is part of GirlScript Summer of Code. We welcome contributions from the community to help enhance gameoflife.
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
This project is licensed under the GPL-3.0 License.
Thank you for contributing to our project! Your help is greatly appreciated in making gameoflife even better. 😊