# rs_isl
[data:image/s3,"s3://crabby-images/ddd97/ddd97467b6996f83829cabe05807c4ee4a3d513e" alt="Crates.io Version"](https://crates.io/crates/rs_isl)
[data:image/s3,"s3://crabby-images/a5c5e/a5c5ec98f1ec707945c8a91df2dc64854a2df1e8" alt="docs.rs page"](https://docs.rs/rs_isl)
[data:image/s3,"s3://crabby-images/3a720/3a7207439dec79ad8699c8880fb3ddb5155fe48b" alt="Crates.io Downloads"](https://crates.io/crates/rs_isl)
[data:image/s3,"s3://crabby-images/8534b/8534b93f6e600cdb78d2d88a2d6a701550f8ee5f" alt="Crates.io License"](https://crates.io/crates/rs_isl)
[data:image/s3,"s3://crabby-images/27fd3/27fd33d01cdba6ea55bd9c48ded6a9583121fc22" alt="CI"](https://github.com/KonradKaralus/rs_isl/actions)
rs_isl is an implementation of Iterative Stencil Loops in Rust.
ISLs can be used in a variety of scenarios such as image processing, fluid simulation and the calculation of PDEs.
For more information see [Wikipedia](https://wikipedia.org/wiki/Iterative_Stencil_Loops).
## Example
This animation was created with [Paraview](https://www.paraview.org/) from the data created by the example [two_waves](examples/two_waves.rs).
## Output
rs_isl writes [.vtk](https://vtk.org/) output files to a specified path. Their contents may be defined by the user.
To create those files rs_isl uses the [vtkio](https://github.com/elrnv/vtkio) crate.
## Usage
### General
```rust
use core::f64;
use std::{cmp::max, path::PathBuf};
use rs_isl::*;
fn main() {
// create a domain with a size of 200 by 100
let dim = (200, 100)
// we only access the left neighbour of every cell
let neighbours = vec![(-1, 0)];
// take neighbours value, if there is no neighbour decrease by 3
let op = |num: &f32, nb: Vec