Skip to content
/ rstm Public

rstm works to provide concrete abstractions for dynamic computational models; aka Turing Machines.

License

Notifications You must be signed in to change notification settings

FL03/rstm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rstm

crates.io docs.rs

clippy rust


The library is currently in the early stages of development and is not yet ready for production use.

This library focuses on building concrete implementations for Turing Machines.

Features

Getting Started

Building from the source

Start by cloning the repository

git clone https://github.com/FL03/rstm.git
cd rstm
cargo build --features full -r --workspace

Usage

Example

    extern crate rstm;

    use rstm::state::BinState::{Invalid, Valid};
    use rstm::{rule, Program, State, StdTape, TM};

    fn main() -> Result<(), Box<dyn std::error::Error>> {
        tracing_subscriber::fmt().with_target(false).init();

        // initialize the tape data
        let alpha: Vec<u8> = vec![1, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 1];
        // define the rules for the machine
        let rules = vec![
            rule![(Invalid, 0) -> Right(Invalid, 0)],
            rule![(Invalid, 1) -> Right(Valid, 0)],
            rule![(Valid, 0) -> Right(Valid, 1)],
            rule![(Valid, 1) -> Left(Valid, 0)],
        ];

        let tape = StdTape::from_iter(alpha);
        let program = Program::from_state(State(Invalid)).with_instructions(rules);
        // create a new instance of the machine
        let tm = TM::new(program, tape);
        tm.execute()?;
        Ok(())
    }

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License