# Simple-Matrix: A simple generic matrix library in Rust [![crates.io](https://img.shields.io/crates/v/simple-matrix.svg)](https://crates.io/crates/simple-matrix) [![docs.rs](https://docs.rs/simple-matrix/badge.svg)](https://docs.rs/simple-matrix) ## Who, What & Why? - *Who?* - I am a French student that is interested in programming (and in Rust for a couple months). - *What?* - It is a simple matrix library in Rust without dependencies. - It has no intention to be the *best/fastest/most feature-complete*. - Though, if optimizations keep the API simple, they will be included. - *Why?* - To be better in Rust and discover some of its numerous aspects. - To create a simple and reliable matrix library. ### Disclaimer This crate should not be considered mature enough for *professional use*, check alternatives like [cgmath](https://github.com/brendanzab/cgmath) or [nalgebra](https://github.com/sebcrozet/nalgebra) if you are in that case. If you are still interested, feel free to continue! ## Usage Link it in your project's `Cargo.toml` file: ```toml # Example Cargo.toml [dependencies] simple-matrix = "0.1" ``` Then, you can use it in your project: ### Rust 2015 ```rust // Specify the extern crate in your lib.rs or main.rs extern crate simple_matrix; // You can now use it use simple_matrix::Matrix; let mat: Matrix = Matrix::new(); ``` ### Rust 2018 ```rust // No need to specify an extern crate // You can use it directly use simple_matrix::Matrix; let mat: Matrix = Matrix::new(); ``` ### Example: Basic matrix usage ```rust // Create a matrix of default cells let zero: Matrix = Matrix::new(3, 3); // Create a 2x4 matrix from an iterator (fill it row by row) let mat1: Matrix = Matrix::from_iter(2, 4, 0..); // Clone a matrix let mat2 = mat1.clone(); // Add by reference (do not consume them) let mut add = &mat1 + &mat2; // Subtract by value (consume them) let mut sub = mat1 - mat2; // OpAssign are also available sub += &zero; sub -= zero; // Get cells let val: &u32 = add.get(0, 3).unwrap(); // Set cells add.set(0, 3, 0); // Iterate through the matrix (row by row) for val in add { print!("{} ", val); } ``` ### Example: Dot product ```rust let mat: Matrix = Matrix::from_iter(2, 4, 0..); // Construct the transposed matrix let mat_t = mat.transpose(); // Construct the dot product let dot = mat * mat_t; ``` ### Features - *Features are extensions of the library left to opt-in by the user.* - *They can increase compilation time and library size.* To include a feature, add it to your `Cargo.toml` file: ```toml # Example Cargo.toml with added feature (replace values with your own) [dependencies] simple-matrix = { version = "0.1", features = ["impl_from"] } ``` Current available features are listed below with a little description: #### impl_from Implements the *From* Trait for basic numeric types. ```rust let m1: Matrix = Matrix::new(3, 5); let m2: Matrix = m1.into(); ``` ### Tests - Run `cargo test` in the root of the project - Documentation tests are disabled for now (rustdoc does not seem to work with edition 2018) ### Benchmarks - Run `cargo bench` in the root of the project - Benchmarks are handled by the [Criterion](https://github.com/japaric/criterion.rs) crate, check its documentation for more detailled usage. Thoses benchmarks are not designed for comparison to other matrix crates, but for tracking speed-ups/regressions. Comparison benchmarks are left as an exercice to the reader. ## Want to participate? Create a new issue or a pull request and I will check them (as soon as I can).