Python CLI and module for k-mer profiles, similarities, and graph files
NOTE: Beta-stage .bgzf
and zlib
compatible k-mer count vectors and DeBruijn graph edge-list formats.
kmerdb
is a Python CLI designed for k-mer counting and k-mer graph edge-lists. It addresses the 'k-mer' problem (substrings of length k) in a simple and performant manner. It stores the k-mer counts in a columnar format (input checksums, total and unique k-mer counts, nullomers, mononucleotide counts) with a YAML formatted metadata header in the first block of a bgzf
formatted file.
- [ x ] Homepage:
- [ x ] Quick Start guide
- [ x ]
kmerdb usage subcommand_name
profile
- Make k-mer count vectors/profiles, calculate unique k-mer counts, total k-mer counts, nullomer counts. Import to read/write NumPy arrays from profile object attributes.graph
- Make a weighted edge list of kmer-to-kmer relationships, akin to a De Bruijn graph.usage
- Display verbose input file/parameter and algorithm details of subcommands.help
- Display verbose input file/parameter and algorithm details of subcommands.view
- View .tsv count/frequency vectors with/without preamble.header
- View YAML formatted header and aggregate countsmatrix
- Collate multiple profiles into a count matrix for dimensionality reduction, etc.kmeans
- k-means clustering on a distance matrix via Scikit-learn or BioPython with kcluster distanceshierarchical
- hierarchical clustering on a distance matrix via BioPython with linkage choicesdistance
- Distance matrices (from kmer count matrices) including SciPy distances, a Pearson correlation coefficient implemented in Cython, and Spearman rank correlation included as additional distances.index
- Create an index file for the kmer profile (Delayed:)shuf
- Shuffle a k-mer count vector/profile (Delayed:)version
- Display kmerdb version numbercitation
- Silence citation suggestion
- [ x ]
kmerdb subcommand -h|--help
k-mer counts from .fa(.gz)/.fq(.gz) sequence data can be computed and stored for access to metadata and count aggregation faculties. For those familiar with .bam
, a view
and header
functions are provided. This file is compatible with zlib
.
Install with pip install kmerdb
Please see the Quickstart guide for more information about the format, the library, and the project.
# Usage --help option --debug mode
kmerdb --help # [+ --debug mode]
kmerdb usage profile
# +
# [ 3 main features: ] [ 1. - k-mer counts ]
# Create a [composite] profile of k-mer counts from sequence files. (.fasta|.fastq|.fa.gz|.fq.gz)
kmerdb profile -vv -k 8 --output-name sample_1 sample_1_rep1.fq.gz [sample_1_rep2.fq.gz]
# Creates k-mer count vector/profile in sample_1.8.kdb. This is the input to other steps, including count matrix aggregation. --minK and --maxK options can be specified to create multiple k-mer profiles at once.
<!-- # Alternatively, can also take a plain-text samplesheet.txt with one filepath on each line. -->
# De Bruijn graphs (not a main feature yet, delayed)
# Build a weighted edge list (+ node ids/counts = De Bruijn graph)
kmerdb graph -vv -k 12 example_1.fq.gz example_2.fq.gz edges_1.kdbg
# View k-mer count vector
kmerdb view -vv profile_1.8.kdb # -H for full header
# Note: zlib compatibility
#zcat profile_1.8.kdb
# View header (config.py[kdb_metadata_schema#L84])
kmerdb header -vv profile_1.8.kdb
## [ 3 main features: ] [ 2. Optional normalization, PCA/tSNE, and distance metrics ]
# K-mer count matrix - Cython Pearson coefficient of correlation [ ssxy/sqrt(ssxx*ssyy) ]
kmerdb matrix -vv from *.8.kdb | kmerdb distance pearson STDIN
#
# kmerdb matrix -vv DESeq2 *.8.kdb
# kmerdb matrix -vv PCA *.8.kdb
# kmerdb matrix -vv tSNE *.8.kdb
# # <from> just makes a k-mer count matrix from k-mer count vectors.
#
# Distances on count matrices [ SciPy ] pdists + [ Cython ] Pearson correlation, scipy Spearman and scipy correlation pdist calculations are available ]
kmerdb distance -h
#
#
# usage: kmerdb distance [-h] [-v] [--debug] [-l LOG_FILE] [--output-delimiter OUTPUT_DELIMITER] [-p PARALLEL] [--column-names COLUMN_NAMES] [--delimiter DELIMITER] [-k K]
# {braycurtis,canberra,chebyshev,cityblock,correlation,cosine,dice,euclidean,hamming,jaccard,jensenshannon,kulsinski,mahalanobis,matching,minkowski,pearson,rogerstanimotorusselrao,seuclidean,sokalmichener,sokalsneath,spearman,sqeuclidean,yule} [<kdbfile1 kdbfile2 ...|input.tsv|STDIN> ...]
# [ 3 main features: ] [ 3. Clustering: k-means and hierarchical with matplotlib ]
# Kmeans (sklearn, BioPython)
kmerdb kmeans -vv -k 4 -i dist.tsv
# BioPython Phylip tree + upgma
kmerdb hierarchical -vv -i dist.tsv
pip install kmerdb
DESeq2 is an optional R dependency for rpy2-mediated normalization. Make sure development libraries are installed from the repository.
pip install -r requirements-dev.txt
Next, install DESeq2 via bioconductor.
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("DESeq2")
kmerdb profile -k $k -o output input.fa # This simply discards non-IUPAC characters.
IUPAC residues (ATCG+RYSWKM+BDHV) are kept throughout the k-mer counting. But non-IUPAC residues (N) and characters are trimmed from the sequences prior to k-mer counting. Non-standard IUPAC residues are counted as doublets or triplets.
Check out the main webpage and the Readthedocs documentation, with examples and descriptions of the module usage.
Important features to usage that may be important may not be fully documented as the project is in beta.
For example, the IUPAC treatment is largely custom, and does the sensible thing when ambiguous bases are found in fasta files, but it could use some polishing. For example, the 'N
' residue rejection creates gaps in the k-mer profile from the real dataset by admittedly ommitting certain k-mer counts.
This is one method for counting k-mers and handling ambiguity. Fork it and play with it a bit.
Also, the parallel handling may not always be smooth, if you're trying to load dozens of 12+ mer profiles into memory. This would especially matter in the matrix command, before the matrix is generated. You can use single-core if your machine can't collate that much into main memory at once, depending on how deep the fastq dataset is. Even when handling small-ish k-mer profiles, you may bump into memory overheads rather quickly.
Besides that, I'd suggest reading the source, the differente elements of the main page or the RTD documentation.
Calculate relevant metadata from k-mer profiles, manipulate count matrices and distance matrices on inter-species inter-profile distances, perform exploartory analysis using tools such as UPGMA hierarchical clustering, k-means clustering, PCA, and others.
Currently unsupported but targeted features include regression modeling, strassen multiplication, NumPy CPU multipication option, least squares and associated regression code.
Currently in-progress is the application note. I wouldn't mind ironing out a few more components of the program for the application note.
Biologists and researchers using metagenomics and genomics tools for the assessment of inter-genomic distances, k-mer counts, nullomer counts, unique counts, and other metadata.
Features currently implemented in kmerdb
include:
- k-mer counting and profile generation
- multiplexed profiles
- De Bruijn graph structures
- Count aggergation and normalization (DESeq2)
- PCA
- t-Stochastic Neighbor Embedding
- Cython Pearson correlation coefficient
- Other correlation coefficients (Spearman, Pearson via scipy)
- hierarchical clustering
- k-means clustering
- data pipelining (Unix pipelines)
Features currently under consideration include:
- regression modeling for metagenomnic populations
- alternative k-mer count vector distances
- alignment using k-mers as seed regions
- De Bruijn graph traversals and contig generation using DBA (De Bruijn graph) assembly
-
2/24 - 6/24 v0.7.7+ - appmap, De Bruijn parser, other updates
-
10/23 -
https://matthewralston.github.io/kmerdb/developing
python setup.py test
Created by Matthew Ralston - Scientist, Programmer, Musician - Email
Distributed under the Apache license. See LICENSE.txt
for the copy distributed with this project. Open source software is not for everyone, and im the author and maintainer. cheers, on me. You may use and distribute this software, gratis, so long as the original LICENSE.txt is distributed along with the software. This software is distributed AS IS and provides no warranties of any kind.
Copyright 2020 Matthew Ralston
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
- Fork it (https://github.com/MatthewRalston/kmerdb/fork)
- Create your feature branch (
git checkout -b feature/fooBar
) - Commit your changes (
git commit -am 'Add some fooBar'
) - Push to the branch (
git push origin feature/fooBar
) - Create a new Pull Request
Thanks mom and dad and my hometown, awesome hs, and the University of Delaware faculty for support and encouragement. Thanks to my former mentors, bosses, and coworkers. It's been really enjoyable anticipating what the metagenomics community might want from a tool that can handle microbial k-mers well.
Thank you to the authors of kPAL and Jellyfish for the inspiration and bit shifting trick. And thank you to others for the encouragement along the way, who shall remain nameless.
The intention is that more developers would want to add functionality to the codebase or even just utilize things downstream, but to build out directly with numpy and scipy/scikit as needed to suggest the basic infrastructure for the ML problems and modeling approaches that could be applied to such datasets. This project began under GPL v3.0 and was relicensed with Apache v2. Hopefully this project could gain some interest. I have so much fun working on this project. There's more to it than meets the eye. I'm working on a preprint, and the draft is included in some of the latest versions of the codebase, specifically .Rmd files.
More on the flip-side. It's so complex with technology these days...