This is a project coming out of 1st NoB Hackathon.
The scope of this project is to aggregate existing annotations for genetic variants. Variant annotations have drawn huge amount of efforts from researchers, which made many variant annotation resources available, but also very scattered. Doing integration of all of them is hard, so we want to create a simple way to pool them together first, with high-performance programmatic access. That way, the further integration (e.g. deduplication, deriving higher-level annotations, etc) can be much easier.
From the discussion of the hackathon, we decided a strategy summarized as below:
- each variant is represented as a JSON document
- the only requirement of the JSON document is that the key of this JSON document ("_id" field in this document) follows HGVS nomenclature. For example:
{
'_id': 'chr1:g.35366C>T',
'allele1': 'C',
'allele2': 'T',
'chrom': 'chr1',
'chromEnd': 35367,
'chromStart': 35366,
'func': 'unknown',
'rsid': 'rs71409357',
'snpclass': 'single',
'strand': '-'
}
- that way, we can then merge multiple annotations for the same variant into a merged JSON document. Each resource of annotations is under its own field. Here is a merged example.
The query engine we developed for MyGene.info can be easily adapted to provide the high-performance and flexible query interface for programmatic access. MyGene.info follows the same spirit, but for gene annotations. It currently serves ~3M request per month.
User contribution is vital, given the scale of available (also increasing) resources. The simple rule we defined above makes the merging new annotation resource very easy, essentially writing a JSON importer. And the sophisticated query-engine we built can save users effort to build their own infrastructure, which provides the incentive for them to contribute.
Also note that it's not only the data-provider can write the importer, anyone who finds a useful resource can do that as well (of course, check to make sure the data release license allows that)
See the guideline below for contributing JSON importer.
See this How to contribute document.