#cellular-automata #framework #game-of-life

lifers

An advanced cellular automata creation framework

3 unstable releases

0.2.1 Jun 1, 2024
0.2.0 May 26, 2024
0.1.0 May 5, 2024

#49 in Simulation

Download history 129/week @ 2024-04-30 18/week @ 2024-05-07 3/week @ 2024-05-14 163/week @ 2024-05-21 194/week @ 2024-05-28

398 downloads per month
Used in 2 crates

MIT license

14KB
246 lines

lifers

A Rust crate that aims to generalize cellular automata creation. Current features include:

  • Easy creation using the builder pattern
  • Fast simulation engine
    • SIMD potential
  • Very ergonomic design for creating simulations
    • Full support for the builder pattern
    • Multiple data collection functions for an automaton
  • Arbitrary types support for cells' state and associated data
  • Interface to create custom frontends

Usage

An example illustrating Conway's Game of Life implementation in lifers:

use lifers::prelude::*;
use rand::random;

fn main() {
    // Use a 100x100 grid
    let mut game = Automaton::build((100, 100))
        // Initialize all cells with random states (alive or dead)
        .init(|_| random::<bool>())
        // Count neighbors in radius of 1 for each cell
        .map(|(x, y), _, cells| count_neighbors(cells, (x, y), 1, |b| *b))
        // Change cells' state depending on the number of neighbors
        .run(|_, is_alive, neighbors_n| match is_alive {
            true => (2..=3).contains(neighbors_n),
            false => *neighbors_n == 3,
        });
    
    // Compute the next generation
    game.step();
}

No runtime deps