Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/juntyr/necsim-rust
Spatially explicit biodiversity simulations using a parallel library written in Rust
https://github.com/juntyr/necsim-rust
biodiversity cuda mpi necsim rust simulation
Last synced: 3 months ago
JSON representation
Spatially explicit biodiversity simulations using a parallel library written in Rust
- Host: GitHub
- URL: https://github.com/juntyr/necsim-rust
- Owner: juntyr
- License: apache-2.0
- Created: 2020-10-12T18:10:52.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-26T10:25:22.000Z (5 months ago)
- Last Synced: 2024-10-14T15:43:25.212Z (4 months ago)
- Topics: biodiversity, cuda, mpi, necsim, rust, simulation
- Language: Rust
- Homepage: https://juntyr.github.io/necsim-rust-docs/
- Size: 8.15 MB
- Stars: 2
- Watchers: 5
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
- Citation: CITATION.cff
Awesome Lists containing this project
README
# necsim-rust [![CI Status]][workflow] [![Rust Doc]][docs] [![License Status]][fossa] [![Code Coverage]][codecov] [![Binder Demo]][binder] [![Gitpod Ready-to-Code]][gitpod] [![DOI]][zenodo]
[CI Status]: https://img.shields.io/github/actions/workflow/status/juntyr/necsim-rust/ci.yml?branch=main
[workflow]: https://github.com/juntyr/necsim-rust/actions/workflows/ci.yml?query=branch%3Amain[Rust Doc]: https://img.shields.io/badge/docs-main-blue
[docs]: https://juntyr.github.io/necsim-rust-docs/[License Status]: https://app.fossa.com/api/projects/custom%2B26490%2Fgithub.com%2Fjuntyr%2Fnecsim-rust.svg?type=shield
[fossa]: https://app.fossa.com/projects/custom%2B26490%2Fgithub.com%2Fjuntyr%2Fnecsim-rust?ref=badge_shield[Code Coverage]: https://img.shields.io/codecov/c/github/juntyr/necsim-rust?token=DCT0WVLU5V
[codecov]: https://codecov.io/gh/juntyr/necsim-rust[Binder Demo]: https://img.shields.io/badge/binder-demo-579ACA.svg?logo=
[binder]: https://mybinder.org/v2/gh/juntyr/necsim-rust-demo/main?urlpath=tree/demo.ipynb[Gitpod Ready-to-Code]: https://img.shields.io/badge/Gitpod-ready-blue?logo=gitpod
[gitpod]: https://gitpod.io/#https://github.com/juntyr/necsim-rust[DOI]: https://zenodo.org/badge/DOI/10.5281/zenodo.5220080.svg
[zenodo]: https://doi.org/10.5281/zenodo.5220080## Introduction
necsim-rust is a Rust reimplementation of the C++ library [necsim](https://bitbucket.org/thompsonsed/necsim) and its Python wrapper [pycoalescence](https://bitbucket.org/thompsonsed/pycoalescence), which are used to run neutral coalescence biodiversity simulations.
necsim-rust aims to provide a smaller, more concise subset of the functionality of necsim and pycoalescence but be easier to use and extend. For instance, necsim-rust contains the classical coalescence algorithm. Additionally, it implements two Gillespie-based algorithms and a novel independent algorithm with a CPU and a CUDA variant. Furthermore, necsim-rust can use MPI to parallelise the simulation.
necsim-rust is built in a modular way to reduce code duplication and allow the user (and other programmers) to plug together different components to customise the simulated scenario, the algorithm it is simulated with as well as finer implementation details. Currently, necsim-rust supports four built-in scenarios:
- non-spatial model
- spatially implicit model with migration from a non-spatial metacommunity to a non-spatial local community
- spatially explicit (almost) infinite model with Gaussian Normal dispersal
- spatially-explicit simulation with habitat and dispersal maps## Prerequisites
First, you need to clone the necsim-rust GitHub repository:
```shell
git clone https://github.com/juntyr/necsim-rust.git
```
necsim-rust is written in the [Rust language](https://www.rust-lang.org/tools/install), which must be installed in your `PATH` first. necsim-rust includes a `rust-toolchain` file that configures Rust to use a working nightly toolchain version and install all components required for compilation. If you want to use necsim-rust on a target different than `x86_64-unknown-linux-gnu`, please update the [rust-toolchain](rust-toolchain) config file accordingly.The `necsim-plugins-species` reporter depends on `libsqlite3-dev`, and the `necsim-plugins-tskit` reporter and the `necsim-partitioning-mpi` parallelisation backend (enabled with the `mpi-partitioning` feature) depend on `libclang-dev`. You can install these optional packages using
```shell
sudo apt-get install libclang-dev libsqlite3-dev
```## Installation
To install `rustcoalescence`, you need to decide which algorithms you want to compile with it. You can enable the provided algorithms by enabling their corresponding features. For instance, to compile all CPU-based algorithms with all scenarios, you can use
```shell
cargo install --path rustcoalescence --locked --features gillespie-algorithms --features independent-algorithm --features all-scenarios
```
To install with CUDA support, you first need to ensure that the dynamic CUDA libraries are in the `LD_LIBRARY_PATH` and enable the `cuda-algorithm` feature:
```shell
LIBRARY_PATH="$LD_LIBRARY_PATH" cargo install --path rustcoalescence --locked [...] --features cuda-algorithm
```
To compile with MPI support, you need to enable the `mpi-partitioning` feature:
```shell
cargo install --path rustcoalescence --locked [...] --features mpi-partitioning
```
After compilation, you can then run `rustcoalescence` using:
```shell
rustcoalescence [...]
```
If you want to use any of the provided reporter analysis plugins, you have to compile them manually. For instance, to compile the `common` plugin which includes the `Biodiversity()`, `Counter()`, `Execution()`, `Progress()` and `Verbose()` reporters, you can run:
```shell
> cargo build --release --manifest-path necsim/plugins/common/Cargo.toml
```## Compiling for Development
If you want to compile the library for development, you can use any of the above installation commands, but replace
```shell
cargo install --path rustcoalescence --locked [...]
```
with
```shell
cargo build --release [...]
```## Running rustcoalescence
`rustcoalescence` has two subcommands: `simulate` and `replay` and accepts command-line arguments in the following format:
```shell
rustcoalescence args..
```
Here, `args..` is a configuration string in [RON](https://github.com/ron-rs/ron) format, which can also directly be read from a configuration file:
```shell
rustcoalescence "$(