Fungi DNA barcoder based on semantic searching
Project description
TaxoTagger
TaxoTagger is a Python library for DNA barcode identification, powered by semantic searching.
Features:
- 🚀 Effortlessly build vector databases from DNA sequences (FASTA files)
- ⚡ Achieve highly efficient and accurate semantic searching
- 🔥 Easily extend support for various embedding models
Installation
TaxoTagger requires Python 3.10 or later.
# create an virtual environment
conda create -n venv-3.10 python=3.10
conda activate venv-3.10
# install the `taxotagger` package
pip install --pre taxotagger
Usage
Build a vector database from a FASTA file
from taxotagger import ProjectConfig
from taxotagger import TaxoTagger
config = ProjectConfig()
tt = TaxoTagger(config)
# creating the database will take ~30s
tt.create_db('data/database.fasta')
By default, the ~/.cache/mycoai
folder is used to store the vector database and the embedding model. The MycoAI-CNN.pt
model is automatically downloaded to this folder if it is not there, and the vector database is created and named after the model.
Conduct a semantic search with FASTA file
from taxotagger import ProjectConfig
from taxotagger import TaxoTagger
config = ProjectConfig()
tt = TaxoTagger(config)
# semantic search and return the top 1 result for each query sequence
res = tt.search('data/query.fasta', limit = 1)
The data/query.fasta
file contains two query sequences: KY106088
and KY106087
.
The search results res
will be a dictionary with taxonomic level names as keys and matched results as values for each of the two query sequences. For example, res['phylum']
will look like:
[
[{"id": "KY106088", "distance": 1.0, "entity": {"phylum": "Ascomycota"}}],
[{"id": "KY106087", "distance": 0.9999998807907104, "entity": {"phylum": "Ascomycota"}}]
]
The first inner list is the top results for the first query sequence, and the second inner list is the top results for the second query sequence.
The id
field is the sequence ID of the matched sequence. The distance
field is the cosine similarity between the query sequence and the matched sequence with a value between 0 and 1, the closer to 1, the more similar. The entity
field is the taxonomic information of the matched sequence.
We can see that the top 1 results for both query sequences are exactly themselves. This is because the query sequences are also in the database. You can try with different query sequences to see the search results.
Docs
Please visit the official documentation for more details.
Question and feedback
Please submit an issue if you have any question or feedback.
Citation
If you use TaxoTagger in your work, please cite it by clicking the Cite this repository
on right top of this page.
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
File details
Details for the file taxotagger-0.0.1a4.tar.gz
.
File metadata
- Download URL: taxotagger-0.0.1a4.tar.gz
- Upload date:
- Size: 18.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b4b45f7276fe58ac73fcc6dbe154ca30d1edb0869915c2a3a571af5603a0923 |
|
MD5 | f9b5ee075bee7ecae8b860e65456e2d1 |
|
BLAKE2b-256 | 2ed137bb5c81eb406e6c77ec4fd5684a9c9f1b4157fe7c96334eee333250f24b |
File details
Details for the file taxotagger-0.0.1a4-py3-none-any.whl
.
File metadata
- Download URL: taxotagger-0.0.1a4-py3-none-any.whl
- Upload date:
- Size: 19.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 775dd4b448bdcf390dc7a7f17145decce5b614f9c92f7507bc22bd46daa1e920 |
|
MD5 | 1b5db0789d347d955729245e167e2aab |
|
BLAKE2b-256 | 86744f553648eb7477cc2c39b5886b9543661a51f40720cc77256dca56c2b53f |