HyperEx ๐Ÿ”ฌ๐Ÿงฌ

June 13, 2025 ยท View on GitHub

CI Status Crates.io License Code Coverage

HyperEx Logo

HyperEx (Hypervariable region Extractor) is a high-performance tool for precise extraction of 16S rRNA hypervariable regions using primer-based approaches. Built in Rust for speed and reliability.

Features โœจ

  • ๐Ÿงฌ Built-in universal 16S primer sequences
  • ๐Ÿ” Supports IUPAC ambiguity codes in primers
  • โšก Multi-threaded processing for large datasets
  • ๐Ÿ“ Handles compressed inputs (gzip, xz, bzip2)
  • ๐Ÿ“Š Generates both FASTA and GFF3 outputs
  • ๐ŸŽฏ Configurable mismatch tolerance

Installation ๐Ÿ“ฆ

Quick Install (via Cargo)

cargo install hyperex

Prebuilt Binaries

Download from our Releases Page

Download from Source

git clone https://github.com/Ebedthan/hyperex.git
cd hyperex
cargo install --path .

Usage ๐Ÿš€

Basic Extraction

hyperex input.fasta

Extract Specific Regions

hyperex --region v3v4 --region v4v5 input.fasta

Custom Primers

hyperex -f CCTACGGGNGGCWGCAG -r GGACTACHVGGGTWTCTAAT input.fasta

With Mismatches

hyperex --region v1v2 --mismatch 2 input.fasta

Advanced Options โš™๏ธ

OptionDescription
-f, --forward-primerForward primer sequence (IUPAC supported)
-r, --reverse-primerReverse primer sequence (IUPAC supported)
--regionPredefined region (v1v2, v3v4, etc.) or primer file
-m, --mismatchAllowed mismatches (default: 0)
-p, --prefixOutput file prefix (default: hyperex_out)
--forceOverwrite existing files
-q, --quietReduce verbosity

Primer File Format ๐Ÿ“

Create a CSV file with primer pairs:

FORWARD_1,REVERSE_1
FORWARD_2,REVERSE_2
...

Examples ๐Ÿงช

Multiple regions from compressed input:

xzcat big_file.fa.xz | hyperex --region v1v2 --region v3v4 -p results

Custom primers with 1 mismatch:

hyperex -f ATCG -r GGCC -m 1 input.fasta

Requirements โœ…

  • Rust 1.60+ (for source builds)
  • Compression libraries (optional for compressed inputs):
  • libz (gzip)
  • liblzma (xz)
  • libbz2 (bzip2)

Support ๐Ÿ†˜

Found an issue? File it on our Issue Tracker.