Skip to content

Foundations for the Rust omics ecosystem.

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

stjude-rust-labs/omics

Repository files navigation

omics

CI: Status crates.io version crates.io downloads License: Apache 2.0 License: MIT

Foundations for the Rust omics ecosystem.
Explore the docs »

Request Feature · Report Bug · ⭐ Consider starring the repo! ⭐

Warning

Project Status: 🔴 Incubating 🔴

This crate is incubating and is not ready to be depended on—either in terms of correctness or stability. Certainly this is true for production, though we welcome anyone developing a tool to try out some of the more mature crates and give feeback. Just beware that the crate may change out from under you, may not be feature complete soon (or ever), or anything in-between.

🎨 Features

The omics crate provides foundational data structures for working with omics data. The following features are included and are top-level goals of the project.

  • Coordinate systems (omics::coordinate). Provides multiple genomic coordinate systems including both a 0-based, half-open coordinate system (also known as the interbase coordinate system) and 1-based, fully-closed coordinate system (also known as the in-base or just base coordinate system).
  • Biologically relevant molecules (omics::molecule). Representations of molecules relevant in omics including smaller compounds (e.g., nucleotides) and larger polymers (e.g., DNA, RNA).
  • Variation (omics::variation). Facilities for expressing common types of variation including single nucleotide variations (SNVs), insertions/deletions (INDELs), structural variations (SVs), and copy number variations (CNVs).

🖥️ Development

To bootstrap a development environment, please use the following commands.

# Clone the repository
git clone git@github.com:stjude-rust-labs/omics.git
cd omics

# Build the crate in release mode
cargo build --release

# List out the examples
cargo run --release --example

🚧️ Tests

Before submitting any pull requests, please make sure the code passes the following checks (from the root directory).

# Run the project's tests.
cargo test --all-features

# Run the tests for the examples.
cargo test --examples --all-features

# Ensure the project doesn't have any linting warnings.
cargo clippy --all-features

# Ensure the project passes `cargo fmt`.
cargo fmt --check

# Ensure the docs build.
cargo doc

🤝 Contributing

Contributions, issues and feature requests are welcome! Feel free to check issues page.

📝 License

This project is licensed as either Apache 2.0 or MIT at your discretion. Additionally, please see the disclaimer that applies to all crates and command line tools made available by St. Jude Rust Labs.

Copyright © 2024-Present St. Jude Children's Research Hospital.

About

Foundations for the Rust omics ecosystem.

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Packages

No packages published

Languages