Skip to main content

Extension of the UMIC-seq Pipeline - Complete pipeline for dictionary building and NGS count inetgration, with fitness calculations, error modelling and mutation analysis

Project description

uht-DMSlibrarian

Complete Pipeline

For dictinary generation from long reads, use the complete pipeline entry-point that handles the entire workflow from UMI extraction to final variant analysis:

Example with custom parameters:

umic-seq-pacbio all \
  --input reads.fastq.gz \
  --probe probe.fasta \
  --reference reference.fasta \
  --output_dir /path/to/output \
  --umi_len 52 \
  --umi_loc up \
  --min_probe_score 30 \
  --identity 0.95 \
  --size_thresh 15 \
  --max_reads 30 \
  --max_workers 8 \
  --report pipeline_report.txt

External dependancies:

  • `CD-HIT'
  • Abpoa

Please install both of these and ensure they are in the PATH of your environment. Use e.g. conda to install these.

Required Arguments:

  • --input: Input FASTQ file (can be .gz compressed)
  • --probe: Probe FASTA file containing an approximately 50 bp sequence adjacent to the UMI
  • --reference: Reference FASTA file containing the reference gene sequence
  • --output_dir: Output directory where all results will be written

Optional Arguments (with defaults):

UMI Extraction:

  • --umi_len (default: 52): Length of the UMI in base pairs
  • --umi_loc (default: 'up'): Location of UMI relative to probe. Options: 'up' (upstream) or 'down' (downstream)
  • --min_probe_score (default: 15): Minimum alignment score required for probe matching. For a 50bp probe, perfect match = 50. Lower values accept more mismatches.

Clustering:

  • --fast (default: True): Use fast CD-HIT clustering (recommended)
  • --slow: Use slow alignment-based clustering (alternative to --fast, legacy)
  • --identity (default: 0.90): Sequence identity threshold for fast clustering (0-1). 0.90 = 90% identity = allows up to 10% mismatch. For a 52bp UMI, this allows ~5 mismatches.
  • --aln_thresh (default: 0.47): Alignment score threshold for slow clustering (only used with --slow). Converts to integer score: 0.47 → 47. For a 52bp UMI with perfect match ≈ 104, threshold 47 ≈ 45% of perfect. Note: This is legacy and will be removed in future versions.
  • Orientation normalization: When --probe is provided during clustering, sequences are automatically normalized to forward orientation based on probe alignment before being written to cluster files. This ensures all sequences in a cluster have the same orientation, improving consensus quality. If --probe is not provided, sequences are written as-is (backward compatible).

Cluster Filtering:

  • --size_thresh (default: 10): Minimum number of long reads required per cluster. Clusters with fewer reads are discarded. Lower values = more sensitive (detects rare variants), higher values = more conservative (only high-confidence variants).

Consensus Generation:

  • --max_reads (default: 20): Maximum number of reads per cluster used for consensus generation. Uses first N reads from each cluster. More reads = better consensus quality but slower. Fewer reads = faster.

Performance:

  • --max_workers (default: 4): Number of parallel workers for consensus generation and variant calling. Increase for faster processing if you have more CPU cores available.

Reporting:

  • --report (optional): Path to output report file. If provided, generates a comprehensive summary report including execution time, input parameters, pipeline statistics (UMIs extracted, clusters generated, consensus sequences, variants called), and output file locations.

Pipeline Steps

The all command runs the complete pipeline:

  1. UMI Extraction: Extract UMIs from long reads using probe alignment
  2. Clustering: Cluster similar UMIs using ultra-fast hash-based algorithm. Sequences are normalized to forward orientation (based on probe alignment) to ensure consistent orientation within clusters.
  3. Consensus Generation: Generate consensus sequences using abpoa from consistently oriented sequences
  4. Variant Calling: Call variants using minimap2 and bcftools
  5. Analysis: Generate detailed CSV with mutation analysis

Individual Commands

You can also run individual steps:

# Extract UMIs
umic-seq-pacbio extract \
  --input reads.fastq.gz \
  --probe probe.fasta \
  --umi_len 52 \
  --output ExtractedUMIs.fasta \
  --umi_loc up \
  --min_probe_score 15

# Cluster UMIs
umic-seq-pacbio cluster \
  --input_umi ExtractedUMIs.fasta \
  --input_reads reads.fastq.gz \
  --output_dir UMIclusterfull_fast \
  --probe probe.fasta \
  --identity 0.90 \
  --size_thresh 10

# Generate consensus sequences
umic-seq-pacbio consensus \
  --input_dir UMIclusterfull_fast \
  --output_dir consensus_results \
  --max_reads 20 \
  --max_workers 4

# Call variants
umic-seq-pacbio variants \
  --input_dir consensus_results \
  --reference reference.fasta \
  --output_dir variant_results \
  --combined_vcf combined_variants.vcf \
  --max_workers 4

# Analyze variants
umic-seq-pacbio analyze \
  --input_vcf combined_variants.vcf \
  --reference reference.fasta \
  --output final_results.csv

### NGS Pool Counting (Illumina) with UMI matching and haplotypes

This repository includes an NGS pooling/counting module to match Illumina paired-end reads back to consensus haplotypes and count per-variant and per-haplotype occurrences per pool.

Key features:
- PEAR-based merging of R1/R2 per pool (fallback to on-the-fly merge)
- UMI extraction from assembled reads by taking the internal window (ignores first 22 and last 24 bases by default, these numbers should be configured for your reads)
- Circular, strand-aware UMI-to-consensus matching
- Per-variant counts (rows = VCF entries; columns = pools)
- Per-haplotype counts that preserve multi-mutations with amino acid mutations (non-synonymous only)
- Deduplicated by non-synonamous amino acid mutational identity

Requirements:
- PEAR installed and available in PATH (e.g., `conda install -c bioconda pear`)

Usage:
```bash
umic-seq-pacbio ngs_count \
  --pools_dir /path/to/NGS_data \
  --consensus_dir /path/to/consensus \
  --variants_dir /path/to/variants \
  --probe /path/to/probe.fasta \
  --reference /path/to/reference.fasta \
  --umi_len 52 \
  --umi_loc up \
  --left_ignore 22 \
  --right_ignore 24 \
  --output /path/to/pool_variant_counts.csv

Inputs:

  • pools_dir: directory containing one subfolder per pool; each subfolder has paired fastqs (*_R1*.fastq.gz and *_R2*.fastq.gz). You can have more than one pair in each subfolder. '*' indicates any valid character - the R1/R2 pairs are detected so e.g. L001_R1_001.fastq.gz and L001_R2_001.fastq.gz and L002_R1_001.fastq.gz and L002_R2_001.fastq.gz are a compatible 'pair of pairs' that will be easily detected.
  • consensus_dir: the consensus sequences directory (one FASTA per cluster)
  • variants_dir: per-consensus VCFs generated by the variant calling step
  • probe: probe FASTA (used only for logging; UMI extraction for Illumina uses your defined trimming rules)
  • reference: reference FASTA for amino acid mapping (fasta should be bases)

Outputs:

  • pool_variant_counts.csv: wide table, rows = VCF entries (CHROM, POS, REF, ALT), columns = pools
  • pool_haplotype_counts.csv: rows = consensus haplotypes (cluster), columns = pools
    • Columns: CONSENSUS, MUTATIONS (nucleotide, position-sorted), AA_MUTATIONS (non-synonymous only, grouped by codon)
    • Example AA format: S45F+Y76P; wild type is WT
  • merged_on_nonsyn_counts.csv: haplotype counts merged by identical non-synonymous amino acid patterns; includes the contributing consensus IDs, distinct nucleotide mutation strings, and per-pool totals

Notes:

  • For Illumina reads, UMIs are taken from the internal region of merged reads (default first 22 and last 24 bases ignored, change this for your UMIs).
  • Amino acid numbering is 1-indexed; multiple nucleotide changes within a codon are combined into a single AA mutation.

Fitness Analysis

The fitness analysis module processes merged_on_nonsyn_counts.csv to calculate fitness from input/output pool comparisons and generate comprehensive visualizations.

Key Features:

  • Filters variants by minimum input count threshold
  • Calculates relative frequencies (column normalization)
  • Computes log fitness ratios: log(rel_output / rel_input) for each input/output pair
  • Calculates average fitness across all pairs
  • Bootstrap confidence intervals for fitness estimates (when multiple replicates available)
  • Generates mutability, epistasis, fitness distribution, reproducibility, and substitution matrix plots

Usage:

umic-seq-pacbio fitness \
  --input merged_on_nonsyn_counts.csv \
  --output_dir fitness_results/ \
  --input_pools pool1 pool2 \
  --output_pools pool3 pool4 \
  --min_input 10 \
  --aa_filter 'S'

Arguments:

  • --input: Path to merged_on_nonsyn_counts.csv (from ngs_count step)
  • --output_dir: Directory to save plots and processed data
  • --input_pools: Space-separated list of input pool names (e.g., pool1 pool2)
  • --output_pools: Space-separated list of output pool names, paired with inputs (e.g., pool3 pool4)
  • --min_input (default: 10): Minimum count threshold in input pools; variants below this in any input are filtered out
  • --aa_filter (optional): Filter mutability plot to specific mutant amino acid (e.g., S for serine, P for proline, * for stop codons)

Outputs:

  • fitness_analysis_results.csv: Processed data with fitness calculations, relative frequencies, mutation annotations, and bootstrap confidence intervals (if multiple replicates)
  • mutability_plot.png: Average fitness at each position for Hamming 1 (single) mutants, relative to WT
  • mutability_plot_{AA}.png: Mutability plot filtered to specific amino acid (if --aa_filter used)
  • epistasis_plot.png: Scatter plot of sum of single mutant fitnesses (x-axis) vs double mutant fitness (y-axis)
    • Only includes double mutants where both constituent singles are present in the dataset
    • Includes additivity line and correlation coefficient
  • fitness_distributions.png: Overlaid KDE plots for single mutants:
    • Stop codons
    • Proline mutations
    • All other mutations
  • hamming_distributions.png: Overlaid KDE plots for fitness distributions at Hamming distances 1-5
  • reproducibility_plot.png: Pairwise comparison heatmaps of fitness across replicate pairs (only generated if ≥2 replicates)
    • Shows correlation between replicates with density heatmaps (blue→red color scheme)
  • substitution_matrix.png: Heatmap showing average fitness for each amino acid substitution type (21×21 matrix including stop codons)
    • Amino acids arranged by similarity (hydrophobic, polar, charged, etc.)
    • Red = beneficial, Blue = deleterious
  • substitution_matrix.csv: Full substitution matrix data for further analysis

Example with multiple input/output pairs:

umic-seq-pacbio fitness \
  --input merged_on_nonsyn_counts.csv \
  --output_dir fitness_results/ \
  --input_pools input_pool1 input_pool2 \
  --output_pools output_pool1 output_pool2 \
  --min_input 15

Notes:

  • Fitness is calculated as log(rel_output / rel_input) where relative frequencies are column-normalized
  • Average fitness is the mean across all input/output pairs
  • Bootstrap confidence intervals (95% CI) are calculated using replicate-level resampling (1000 iterations) when multiple replicates are available
  • Epistasis analysis requires both single and double mutants to be present in the dataset
  • Mutability plots show average fitness aggregated across all single mutants at each position, relative to WT
  • Reproducibility plot requires at least 2 replicate pairs

Threshold Selection Guide

Quick reference:

  • High-quality data: Use --min_probe_score 30-40, --identity 0.90-0.95, --size_thresh 10-20
  • Lower-quality data: Use --min_probe_score 15-20, --identity 0.85-0.90, --size_thresh 5-10
  • Rare variant detection: Lower --size_thresh (e.g., 3)
  • High-confidence only: Higher --size_thresh (e.g., 20)

Output Files

The pipeline generates:

  • ExtractedUMIs.fasta: Extracted UMI sequences
  • pipeline_report.txt: Execution report (if --report specified) containing summary statistics, execution time, and parameters used
  • UMIclusterfull_fast/: Cluster files (cluster_1.fasta, cluster_2.fasta, ...)
  • consensus_results/: Consensus sequences per cluster
  • variant_results/: Individual VCF files per cluster
  • combined_variants.vcf: Combined variant calls
  • final_results.csv: Detailed analysis with amino acid mutations, Hamming distance, stop codons, and indels
  • pool_variant_counts.csv: wide table, rows = VCF entries (CHROM, POS, REF, ALT), columns = pools
  • pool_haplotype_counts.csv: rows = consensus haplotypes (cluster), columns = pools
    • Columns: CONSENSUS, MUTATIONS (nucleotide, position-sorted), AA_MUTATIONS (non-synonymous only, grouped by codon)
    • Example AA format: S45F+Y76P; wild type is WT
  • merged_on_nonsyn_counts.csv: haplotype counts merged by identical non-synonymous amino acid patterns; includes the contributing consensus IDs, distinct nucleotide mutation strings, and per-pool totals
  • fitness_analysis_results.csv: Processed fitness data with log ratios, annotations, and bootstrap CIs (from fitness analysis step)
  • mutability_plot.png: Average fitness by position for single mutants (from fitness analysis step)
  • epistasis_plot.png: Epistasis analysis plot (from fitness analysis step)
  • fitness_distributions.png: Fitness distributions by mutation type (from fitness analysis step)
  • hamming_distributions.png: Fitness distributions by Hamming distance (from fitness analysis step)
  • reproducibility_plot.png: Replicate comparison heatmaps (from fitness analysis step, if ≥2 replicates)
  • substitution_matrix.png: Amino acid substitution fitness heatmap (from fitness analysis step)
  • substitution_matrix.csv: Substitution matrix data (from fitness analysis step)

Note that this pipeline has been used for both PacBio and ONT data.

OS requirements: Unix (MacOS or Linux)

Estimated wallclock runtime benchmarks:

  • Generates a dictionary and UMI-gene counts in ~2h on an Apple M2 for library size 200k unique variants
  • Integrates approx 25 M illumina reads to the same dictionary in around 1 h
  • Fitness analysis runs in seconds

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uht_dmslibrarian-0.1.4.tar.gz (58.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

uht_dmslibrarian-0.1.4-py3-none-any.whl (55.8 kB view details)

Uploaded Python 3

File details

Details for the file uht_dmslibrarian-0.1.4.tar.gz.

File metadata

  • Download URL: uht_dmslibrarian-0.1.4.tar.gz
  • Upload date:
  • Size: 58.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.15

File hashes

Hashes for uht_dmslibrarian-0.1.4.tar.gz
Algorithm Hash digest
SHA256 d666ed6bc01c5e874076288f6a9d0979d712e4012d8177fa4193711af846a5e8
MD5 b6a169c55683ef6353ec75c504bc384d
BLAKE2b-256 8026b74e688679be7d615f9e59835a7af979ef9ae89ca0639d91ac846ec31f28

See more details on using hashes here.

File details

Details for the file uht_dmslibrarian-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for uht_dmslibrarian-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0a471e57ef604c7cf4c6fdc1a9f1d05f78e30d4b743db5d994a2fa86d3a585a9
MD5 d37cf1dd95cea9c8807cd25f82079bca
BLAKE2b-256 76cd531d1b503b6d0e05e7a0aaea4a27e09400ddd7555b2b03e1ddf7fe7d0b8b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page