Oligo Designer Toolsuite: lightweight development of custom oligo design pipelines
Project description
Oligonucleotides (abbrev. oligos) are short, synthetic strands of DNA or RNA that are designed with respect to a specific target region and have many application areas, ranging from research to disease diagnosis or therapeutics. Oligos can be used as primers during DNA amplification, as probes for in situ hybridization or as guide RNAs for CRISPR-based gene editing. Based on the intended application and experimental design, researchers have to customize the length, sequence composition, and thermodynamic properties of the designed oligos.
Various tools exist that provide custom design of oligo sequences depending on the area of application. Even though most tools apply the same basic processing steps, ranging from the generation of custom-length oligo sequences, the filtering of oligo sequences based on thermodynamic properties as well as the selection of an optimal set of oligos, each newly developed tool uses its own implementation and different package dependencies. Consequently, not only the development of new tools is slowed down, but also the maintenance and modification of existing tools is hampered, because developers do not have a common resource for those functionalities to use. We tackle this issue with our open-source Oligo Designer Toolsuite.
🚀 Oligo Designer Toolsuite is a collection of modules that provides all basic functionalities for custom oligo design pipelines as well as advanced experiment-specific functionalities like machine learning models for oligo specificity prediction within a flexible Python framework.
To allow the flexible usage of different modules, depending on the required processing steps, we developed a common underlying data structure that ensures the cross-compatibility of all modules within the framework. This data structure is runtime and memory optimized to enable the processing of large sequence dataset in a reasonable time frame. With our Oligo Designer Toolsuite we aim to set new standards in the development of oligo design pipelines, helping to accelerate the development of new tools and facilitate the upgrade of existing tools with the latest developments in the field. We also provide ready-to-use oligo design pipelines for specific experimental setups, e.g. MERFISH or SeqFISH+ probe design for Spatial Transcriptomics.
Implemented Oligo Design Pipelines
The following pipelines are pre-implemented and ready-to-use:
If you would like to modify an existing pipeline for adjusted experimental settings or to design a new pipeline for a different experimental setup, feel free to reach out to us Lisa Barros de Andrade e Sousa or Jonas Hagenberg.
Installation
Requirements
This package was tested for Python 3.10 - 3.12 on Linux (x64) and macOS (arm64) but not tested on Windows.
Note: Intel-based macOS (osx64) installation is ⚠️ DEPRECATED ⚠️
For stable installation, we recommend to first setup a conda environment.
Note: if your institution does not support anaconda, you can use miniforge instead to run the conda installations.
First create a conda environment:
conda create -n odt python=3.12
conda activate odt
To install the additional required tools via conda, please activate the bioconda and conda-forge channels in your conda environment and update conda and all packages in your environment:
conda config --add channels bioconda
conda config --add channels conda-forge
conda update --all
The additional tools need to be installed independently:
conda install "blast>=2.15.0"
conda install "bedtools>=2.30"
conda install "bowtie>=1.3.1"
conda install "bowtie2>=2.5"
conda install "bcftools>=1.22"
conda install "samtools>=1.22"
All other required packages are automatically installed if installation is done via pip (see below).
Install Options
The installation of the package is done via pip. Note: if you are using conda, first install pip with: conda install pip.
PyPI install:
pip install oligo-designer-toolsuite
Installation from source:
git clone https://github.com/HelmholtzAI-Consultants-Munich/oligo-designer-toolsuite.git
cd oligo-designer-toolsuite
-
Installation as python package (run inside directory):
pip install . -
Development installation as python package (run inside directory):
pip install -e .[dev]
Contributing
Contributions are more than welcome! Everything from code to notebooks to examples and documentation are all equally valuable so please don't feel you can't contribute. To contribute please fork the project make your changes and submit a pull request. We will do our best to work through any issues with you and get your code merged into the main branch.
For any further inquiries please send an email to Lisa Barros de Andrade e Sousa or Jonas Hagenberg.
How to cite
If the Oligo Designer Toolsuite is useful for your research, consider citing the package:
@software{
author = { Barros de Andrade e Sousa L.,
Mekki I.,
Campi F.,
Kümmerle L.,
Bright C.,
Lücken M.,
Theis F.,
Piraud M.
},
title = {Oligo Designer Toolsuite},
year = {2025},
publisher = {GitHub},
journal = {GitHub repository},
url = {https://github.com/HelmholtzAI-Consultants-Munich/oligo-designer-toolsuite}
}
If you are using the SCRINSHOT, MERFISH or SeqFISH+ pipeline provided along the Oligo Designer Toolsuite, consider citing in addition the paper:
@article{
author = {
Louis B. Kuemmerle,
Malte D. Luecken,
Alexandra B. Firsova
Lisa Barros de Andrade e Sousa
Lena Strasser
Ilhem Isra Mekki
Francesco Campi
Lukas Heumos
Maiia Shulman
Valentina Beliaeva
Soroor Hediyeh-Zadeh
Anna C. Schaar
Krishnaa T. Mahbubani
Alexandros Sountoulidis
Tamas Balassa
Ferenc Kovacs
Peter Horvath
Marie Piraud
Ali Ertürk
Christos Samakovlis
Fabian J. Theis
},
title = {Probe set selection for targeted spatial transcriptomics},
year = {2024},
publisher = {Nature Publishing Group US New York},
journal = {Nature methods},
doi = {10.1038/s41592-024-02496-z},
URL = {https://doi.org/10.1038/s41592-024-02496-z}
}
License
oligo-designer-toolsuite is released under the MIT license. See LICENSE for additional details about it.
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
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 oligo_designer_toolsuite-2.0.1.tar.gz.
File metadata
- Download URL: oligo_designer_toolsuite-2.0.1.tar.gz
- Upload date:
- Size: 71.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ca6f50ec55fe469c47bf67273132b230d71eb01209228c67a04adc5fdbe61eb
|
|
| MD5 |
0153cce69fd206ff63d93233c09358e1
|
|
| BLAKE2b-256 |
abdd980713594ae4e8d9228919f67a65b059b7ea740d6b308d1bdd48850189a9
|
File details
Details for the file oligo_designer_toolsuite-2.0.1-py3-none-any.whl.
File metadata
- Download URL: oligo_designer_toolsuite-2.0.1-py3-none-any.whl
- Upload date:
- Size: 258.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5ffb840e2e9a999ecb3296528e4e384b244e7612c5a7bb4bb3a85df5592c85fa
|
|
| MD5 |
0afdf6312f28183a40d99793f5332cfe
|
|
| BLAKE2b-256 |
df3162f69036179c9dd13382076263283c7595178c4a1fba7722c0218ef179e5
|