Struct life_backend::Rule

source ·
pub struct Rule { /* private fields */ }
Expand description

A representation of a rule of Life-like cellular automata.

The following operations are supported:

  • Constructing from a pair of truth tables
  • Parsing a string into a value of this type, e.g., "B3/S23". The following notations are supported, see Rulestring:
    • The birth/survival notation (e.g., "B3/S23"). Lowercase 'b' or 's' are also allowed in the notation instead of 'B' or 'S'
    • S/B notation (e.g., "23/3")
  • Determining whether a new cell will be born from the specified number of alive neighbors
  • Determining whether a cell surrounded by the specified number of alive neighbors will survive
  • Converting into a String value, e.g., "B3/S23". This operation only supports the birth/survival notation

Examples

use life_backend::Rule;
let rule = "B3/S23".parse::<Rule>()?;
for i in 0..=8 {
    assert_eq!(rule.is_born(i), [3].iter().any(|&x| x == i));
    assert_eq!(rule.is_survive(i), [2, 3].iter().any(|&x| x == i));
}
assert_eq!(format!("{rule}"), "B3/S23");

Implementations§

source§

impl Rule

source

pub const fn new(birth: &[bool; 9], survival: &[bool; 9]) -> Self

Creates a new rule based on the specified pair of truth tables.

Examples
use life_backend::Rule;
let rule = Rule::new(
    &[false, false, false, true, false, false, false, false, false],
    &[false, false, true, true, false, false, false, false, false],
);
let b = [3];
let s = [2, 3];
for i in 0..=8 {
    assert_eq!(rule.is_born(i), b.iter().any(|&x| x == i));
    assert_eq!(rule.is_survive(i), s.iter().any(|&x| x == i));
}
source

pub const fn is_born(&self, count: usize) -> bool

Returns whether a new cell will be born from the specified number of alive neighbors.

Panics

Panics if the argument count is greater than 8.

Examples
use life_backend::Rule;
let rule = Rule::conways_life();
let b = [3];
for i in 0..=8 {
    assert_eq!(rule.is_born(i), b.iter().any(|&x| x == i));
}
source

pub const fn is_survive(&self, count: usize) -> bool

Returns whether a cell surrounded by the specified number of alive neighbors will survive.

Panics

Panics if the argument count is greater than 8.

Examples
use life_backend::Rule;
let rule = Rule::conways_life();
let s = [2, 3];
for i in 0..=8 {
    assert_eq!(rule.is_survive(i), s.iter().any(|&x| x == i));
}
source

pub const fn conways_life() -> Self

Returns the rule of Conway’s Game of Life.

Examples
use life_backend::Rule;
let rule = Rule::conways_life();
let b = [3];
let s = [2, 3];
for i in 0..=8 {
    assert_eq!(rule.is_born(i), b.iter().any(|&x| x == i));
    assert_eq!(rule.is_survive(i), s.iter().any(|&x| x == i));
}

Trait Implementations§

source§

impl Clone for Rule

source§

fn clone(&self) -> Rule

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Rule

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for Rule

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl FromStr for Rule

§

type Err = ParseRuleError

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl PartialEq<Rule> for Rule

source§

fn eq(&self, other: &Rule) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for Rule

source§

impl StructuralEq for Rule

source§

impl StructuralPartialEq for Rule

Auto Trait Implementations§

§

impl RefUnwindSafe for Rule

§

impl Send for Rule

§

impl Sync for Rule

§

impl Unpin for Rule

§

impl UnwindSafe for Rule

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.