cdot provides the transcript data needed to map and validate HGVS variants — the gene/transcript coordinates, exon structure and genome alignments — for the two most popular Python HGVS libraries: biocommons HGVS and PyHGVS.
To do HGVS work (e.g. convert NM_001637.3:c.1582G>A to genomic coordinates) those libraries need a
transcript data source. The usual source, UTA, is a PostgreSQL
database that's slow and heavy to run. cdot instead converts the official RefSeq/Ensembl annotation
files (GTF/GFF3) into compact JSON and ships fast loaders for the HGVS libraries. You can use it via:
- Local
JSON.gzfiles — download a release and load it into RAM (fastest). - REST API — query a cdot_rest server (no local data needed).
Because it reads the released annotation files directly, cdot covers 1.58 million transcript/genome alignments, including historical transcript versions — vs ~141k in UTA (v.20210129) — which matters when resolving legacy HGVS. See cdot vs UTA for the trade-offs.
Recent changes are in the changelog.
pip install cdot
Optional extras:
pip install cdot[fasta] # local genome FASTA sequence fetching (pysam) - needed for the PyHGVS example below
(hgvs is a core dependency, so the biocommons HGVS examples work out of the box.)
Biocommons HGVS example:
import hgvs
from hgvs.assemblymapper import AssemblyMapper
from cdot.hgvs.dataproviders import JSONDataProvider, RESTDataProvider
hdp = RESTDataProvider() # Uses API server at cdotlib.org
# hdp = JSONDataProvider(["./cdot-0.2.32.refseq.grch37.json.gz"]) # Uses local JSON file
am = AssemblyMapper(hdp,
assembly_name='GRCh37',
alt_aln_method='splign', replace_reference=True)
hp = hgvs.parser.Parser()
var_c = hp.parse_hgvs_variant('NM_001637.3:c.1582G>A')
am.c_to_g(var_c)
For fixing messy HGVS input and fast bulk processing, see Advanced usage.
PyHGVS example (needs pip install cdot[fasta] for pysam):
import pyhgvs
from pysam.libcfaidx import FastaFile
from cdot.pyhgvs.pyhgvs_transcript import JSONPyHGVSTranscriptFactory, RESTPyHGVSTranscriptFactory
genome = FastaFile("/data/annotation/fasta/GCF_000001405.25_GRCh37.p13_genomic.fna.gz")
factory = RESTPyHGVSTranscriptFactory()
# factory = JSONPyHGVSTranscriptFactory(["./cdot-0.2.32.refseq.grch37.json.gz"]) # Uses local JSON file
pyhgvs.parse_hgvs_name('NM_001637.3:c.1582G>A', genome, get_transcript=factory.get_transcript_grch37)
See docs/ for reference and how-to guides:
- JSON data format — every field in a cdot JSON(.gz) file
- Coordinates & exon alignments — how exon coordinates and gap strings work
- Advanced usage — fixing messy HGVS input, and bulk read-ahead retrieval
See the docs index for the full list (examples, FastaSeqFetcher, creating data, cdot vs UTA, …).
- UTA public DB: 1-1.5 seconds / transcript
- cdot REST service: 10/second
- cdot JSON.gz: 500-1k/second
Download from GitHub releases - RefSeq (37/38) - 72M, Ensembl (37/38) 61M
Details on what the files contain here
Both projects have similar goals of providing transcripts for loading HGVS, but they approach it from different ways
- UTA aligns sequences, then stores coordinates in an SQL database.
- cdot convert existing Ensembl/RefSeq GTFs into JSON
See cdot vs UTA for more details
See the JSON data format reference for a full description of every field, with a machine-readable JSON Schema alongside it. Coordinates & exon alignments explains how exon coordinates and the alignment gap strings work. See also design notes on why the format looks the way it does.
You can also read the data with typed Python objects (no extra install required):
from cdot import models
data = models.load("cdot-0.2.32.refseq.GRCh38.json.gz")
tx = data.transcripts["NM_001637.3"]
print(tx.gene_name, tx.protein)We think a standard for JSON gene/transcript information would be a great thing, and am keen to collaborate to make it happen!
cdot, pronounced "see dot", is a play on the HGVS coding-sequence prefix :c.
This was developed for the Australian Genomics Shariant project, due to the need to load historical HGVS from lab archives.