Let's talk about the rules of the game of life:
In the game of life, every cell has two states, life and death. In our implementation, chloragogen cell represents living cells and red cells represent dead cells. The next state of each cell is determined by the current state of the cell and its surrounding eight cells.
Specifically:
The current cell is a living cell.
The current cell is a dead cell.
Not installed standard library:
Third-party libraries:
Import module:
First of all, we should know that the living space of cells is an N * N square, and each cell has two states: ON and off. On is 255, off is 0. We use numpy to generate a square matrix of N * N Np.random, and choice is to randomly select an element in State.on and State.off with equal probability to construct an N * N square matrix.
Secondly, we need to know how to calculate the number of living cells around cells, especially those with a circle around the boundary. We can use the remainder method, assuming that the chessboard size is 9 * 9, then for the left and right boundaries, the calculation method of the left element of the left boundary is-1% 9 = 8, which will automatically fold to the right boundary. Add the values of eight cells around the cell and divide by 255 to get the number of living cells around the cell.
The next step is the translation of rules, that is, according to the state of the current generation, the state of the next generation of cells is deduced. Initial is the matrix of the current generation and data is the matrix of the next generation. We calculate the value of the data according to the initial value. The total number is the number of living cells around. If the current cells are alive and the total number is greater than three or less than two, the next generation will die. If the current cell dies, the total number is equal to three, and the next generation of living cells will multiply to this cell.
Next is the process of making animation, and the first few lines are the basic operations of drawing. Then we use the method of matplotlib.animation, in which the meaning of the parameters accepted by Funanimation: fig is the image handle, and the generate function is the function that we need to update the data of each frame of image, which will be introduced below. Fargs is the other parameters of the genrate function except the first parameter, and the first parameter is passed to the generate function through the framenum (number of frames) specified by Funanimation. Frames is the number of frames, interval is the interval for updating images, and save_count is the number of values from frames to cache.
If a save path (html) is specified, it will be saved as an html animation.
Let's look at the generate function, where NUM is the number of iterations and frame_num receives the number of frames from FuncAnimation. Through the nested for loop, we update the state of each element in the square matrix one by one.
Finally, we can run our program through command line parameters:
The -size parameter is the size of the chessboard, and-seed is a random seed to generate different random squares.
Gospa glider gun
You can change the glider into a glider. -Save the address saved for animation.