COmparative GENomics Toolkit 3: genomic sequence analysis within notebooks or on compute systems with 1000s of CPUs.
Project description
cogent3 is a mature python library for analysis of genomic sequence data. We endeavour to provide a first-class experience within Jupyter notebooks, but the algorithms also support parallel execution on compute systems with 1000's of processors.
📣 Feature Announcements 📣
We now support third-party plugins for annotation databases 📚🔌
If you want to contribute a third-party backend, get in touch!
diverse-seq has been rewritten in rust 🚀!
The sequence sampling tool diverse-seq, which provides multiple apps for sampling representative sequences, just got faster! The performance critical code has been rewritten in Rust. Give it a try 😀.
A new rust-based plugin for k-mer counting
We recently added a new count_kmers() method to the SequenceCollection and Sequence classes. Then, the developers of Pykmertools (with a bit of help from us) have released a cogent3-pykmertools app which makes their rust-based python module for counting k-mers available as seqs.count_kmers(k=k, use_hook="cogent3_pykmertools"). Install it with pip install cogent3-pykmertools and give it a try. And add a star to the Pykmertools repo!
Major advances in our progress towards a fully plugin-based architecture!
Cogent3 supports sequence storage plugins 📦🔌🚀
We have implemented the infrastructure to support alternative sequence storage plugins. These provide the backend storage for the new type sequence collections. We have implemented a proof-of-principle plugin cogent3-h5seqs for sequence storage based on the HDF5 format. This allows efficient storage of very large sequence collections (aligned or unaligned). See the readme for that project on how to use it.
Cogent3 supports sequence format parser and writer plugins 👓✍️🔌
We have implemented the infrastructure to support third-party provision of every bioinformaticians favourite game -- parsing / writing the multitude of sequence file formats. All builtin format parsers / writers are implemented as plugins. We use third-party versions by default.
Cogent3 implements plugin hooks 🔌🪝🎉
We have implemented the infrastructure to support hook-style plugins. We have defined a single hook now -- the new type Alignment.quick_tree() method checks for an external plugin for calculation. The developers of piqtree have made the rapid-NJ algorithm available for this hook! Once installed, it is used as aln.quick_tree(use_hook="piqtree").
Note For assistance in writing your own plugins, contact us via the cogent3 discussions page.
Now distributed with sample data!
We have added sample data sets for quick testing of different features. Check out cogent3.available_datasets() to see the available datasets. You can load one using cogent3.get_dataset(name).
Who is it for?
Anyone who wants to analyse sequence divergence using robust statistical models
cogent3 is unique in providing numerous non-stationary Markov models for modelling sequence evolution, including codon models. cogent3 also includes an extensive collection of time-reversible models (again including novel codon models). We have done more than just invent these new methods, we have established the most robust algorithms for their implementation and their suitability for real data. Additionally, there are novel signal processing methods focussed on statistical estimation of integer period signals.
🎬 Demo non-reversible substitution model
Anyone who wants to undertake exploratory genomic data analysis
Beyond our novel methods, cogent3 provides an extensive suite of capabilities for manipulating and analysing sequence data. You can manipulate sequences by their annotations, e.g.
🎬 Demo sequences with annotations
Plus, you can read standard tabular and biological data formats, perform multiple sequence alignment using any cogent3 substitution models, phylogenetic reconstruction and tree manipulation, manipulation of tabular data, visualisation of phylogenies and much more.
Beginner friendly approach to genomic data analysis
Our cogent3.app module provides a very different approach to using the library capabilities. Expertise in structural programming concepts is not essential!
🎬 Demo friendly coding
Installation
For most users we recommend
$ pip install "cogent3[extra]"
which installs support for data visualisation and jupyter notebooks.
If you're running on a high-performance computing system we recommend
$ pip install cogent3
which skips the data visualisation and notebook support.
To install the development version directly from GitHub
$ pip install git+https://github.com/cogent3/cogent3.git@develop#egg=cogent3
Project Information
cogent3 is released under the BSD-3 license, documentation is at cogent3.org, while cogent3 code is on GitHub. If you would like to contribute (and we hope you do!), we have created a companion c3dev GitHub repo which provides details on how to contribute and some useful tools for doing so.
Project History
cogent3 is a descendant of PyCogent. While there is much in common with PyCogent, the amount of change has been substantial, motivating the name change to cogent3. This name has been chosen because cogent was always the import name (dating back to PyEvolve in 2004) and it's Python 3 only.
Given this history, we are grateful to the multitude of individuals who have made contributions over the years. Many of these contributors were also co-authors on the original PyEvolve and PyCogent publications. Individual contributions can be seen by using "view git blame" on individual lines of code on GitHub, through git log in the terminal, and more recently the changelog.
Funding
Cogent3 has received funding support from the Australian National University and an Essential Open Source Software for Science Grant from the Chan Zuckerberg Initiative.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cogent3-2026.2.3a1.tar.gz.
File metadata
- Download URL: cogent3-2026.2.3a1.tar.gz
- Upload date:
- Size: 17.9 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
033caf7f83a5ba03e119fd58c917352beef2a5e3b915e2a415fbccc24496c28e
|
|
| MD5 |
58636b141c515f6d5814791606d964d0
|
|
| BLAKE2b-256 |
0f1ffa03641619a862dd5a310afafb388d7f5ccd6fdebabd8106d46243f975a1
|
Provenance
The following attestation bundles were made for cogent3-2026.2.3a1.tar.gz:
Publisher:
release.yml on cogent3/cogent3
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cogent3-2026.2.3a1.tar.gz -
Subject digest:
033caf7f83a5ba03e119fd58c917352beef2a5e3b915e2a415fbccc24496c28e - Sigstore transparency entry: 906556765
- Sigstore integration time:
-
Permalink:
cogent3/cogent3@de89403be1df5bc9f8391ed787f29d9bfc4890c9 -
Branch / Tag:
refs/tags/2026.2.3a1 - Owner: https://github.com/cogent3
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@de89403be1df5bc9f8391ed787f29d9bfc4890c9 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file cogent3-2026.2.3a1-py3-none-any.whl.
File metadata
- Download URL: cogent3-2026.2.3a1-py3-none-any.whl
- Upload date:
- Size: 712.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
31ad483f48e1511d2f2b078c15b9c635c2197f9e5e01a1d1622d4ccef0d47ba2
|
|
| MD5 |
e00a699434cef9c61e9a990b94051d64
|
|
| BLAKE2b-256 |
a1331bf474f6d935ceb9388059b03536673fa7936af94b67c25f98235895c003
|
Provenance
The following attestation bundles were made for cogent3-2026.2.3a1-py3-none-any.whl:
Publisher:
release.yml on cogent3/cogent3
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cogent3-2026.2.3a1-py3-none-any.whl -
Subject digest:
31ad483f48e1511d2f2b078c15b9c635c2197f9e5e01a1d1622d4ccef0d47ba2 - Sigstore transparency entry: 906556766
- Sigstore integration time:
-
Permalink:
cogent3/cogent3@de89403be1df5bc9f8391ed787f29d9bfc4890c9 -
Branch / Tag:
refs/tags/2026.2.3a1 - Owner: https://github.com/cogent3
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@de89403be1df5bc9f8391ed787f29d9bfc4890c9 -
Trigger Event:
workflow_dispatch
-
Statement type: