Source code for allensdk.api.queries.ontologies_api

# Allen Institute Software License - This software license is the 2-clause BSD
# license plus a third clause that prohibits redistribution for commercial
# purposes without further permission.
#
# Copyright 2017. Allen Institute. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# 1. Redistributions of source code must retain the above copyright notice,
# this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions and the following disclaimer in the documentation
# and/or other materials provided with the distribution.
#
# 3. Redistributions for commercial purposes are not permitted without the
# Allen Institute's written permission.
# For purposes of this license, commercial purposes is the incorporation of the
# Allen Institute's software into anything for which you will charge fees or
# other compensation. Contact terms@alleninstitute.org for commercial licensing
# opportunities.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
#
from .rma_template import RmaTemplate
from ..cache import cacheable

from allensdk.core.structure_tree import StructureTree


[docs]class OntologiesApi(RmaTemplate): ''' See: `Atlas Drawings and Ontologies <http://help.brain-map.org/display/api/Atlas+Drawings+and+Ontologies>`_ ''' rma_templates = \ {"ontology_queries": [ {'name': 'structures_by_graph_ids', 'description': 'see name', 'model': 'Structure', 'criteria': '[graph_id$in{{ graph_ids }}]', 'order': ['structures.graph_order'], 'num_rows': 'all', 'count': False, 'criteria_params': ['graph_ids'] }, {'name': 'structures_by_graph_names', 'description': 'see name', 'model': 'Structure', 'criteria': 'graph[structure_graphs.name$in{{ graph_names }}]', 'order': ['structures.graph_order'], 'num_rows': 'all', 'count': False, 'criteria_params': ['graph_names'] }, {'name': 'structures_by_set_ids', 'description': 'see name', 'model': 'Structure', 'criteria': '[structure_set_id$in{{ set_ids }}]', 'order': ['structures.graph_order'], 'num_rows': 'all', 'count': False, 'criteria_params': ['set_ids'] }, {'name': 'structures_by_set_names', 'description': 'see name', 'model': 'Structure', 'criteria': 'structure_sets[name$in{{ set_names }}]', 'order': ['structures.graph_order'], 'num_rows': 'all', 'count': False, 'criteria_params': ['set_names'] }, {'name': 'structure_graphs_list', 'description': 'see name', 'model': 'StructureGraph', 'num_rows': 'all', 'count': False }, {'name': 'structure_sets_list', 'description': 'see name', 'model': 'StructureSet', 'num_rows': 'all', 'count': False }, {'name': 'atlases_list', 'description': 'see name', 'model': 'Atlas', 'num_rows': 'all', 'count': False }, {'name': 'atlases_table', 'description': 'see name', 'model': 'Atlas', 'criteria': '{% if atlas_ids is defined %}[id$in{{ atlas_ids }}],{%endif%}structure_graph(ontology),graphic_group_labels', 'include': 'structure_graph(ontology),graphic_group_labels', 'only': ['atlases.id', 'atlases.name', 'atlases.image_type', 'ontologies.id', 'ontologies.name', 'structure_graphs.id', 'structure_graphs.name', 'graphic_group_labels.id', 'graphic_group_labels.name'], 'num_rows': 'all', 'count': False, 'criteria_params': ['atlas_ids'] }, {'name': 'structures_with_sets', 'description': 'see name', 'model': 'Structure', 'include': 'structure_sets', 'criteria': '[graph_id$in{{ graph_ids }}]', 'order': ['structures.graph_order'], 'num_rows': 'all', 'count': False, 'criteria_params': ['graph_ids'] }, {'name': 'structure_sets_by_id', 'description': 'see name', 'model': 'StructureSet', 'criteria': '[id$in{{ set_ids }}]', 'num_rows': 'all', 'count': False, 'criteria_params': ['set_ids'] } ]} def __init__(self, base_uri=None): super(OntologiesApi, self).__init__(base_uri, query_manifest=OntologiesApi.rma_templates)
[docs] @cacheable() def get_structures(self, structure_graph_ids=None, structure_graph_names=None, structure_set_ids=None, structure_set_names=None, order=['structures.graph_order'], num_rows='all', count=False, **kwargs): '''Retrieve data about anatomical structures. Parameters ---------- structure_graph_ids : int or list of ints, optional database keys to get all structures in particular graphs structure_graph_names : string or list of strings, optional list of graph names to narrow the query structure_set_ids : int or list of ints, optional database keys to get all structures in a particular set structure_set_names : string or list of strings, optional list of set names to narrow the query. order : list of strings list of RMA order clauses for sorting num_rows : int how many records to retrieve Returns ------- dict the parsed json response containing data from the API Notes ----- Only one of the methods of limiting the query should be used at a time. ''' if structure_graph_ids is not None: data = self.template_query('ontology_queries', 'structures_by_graph_ids', graph_ids=structure_graph_ids, order=order, num_rows=num_rows, count=count) elif structure_graph_names is not None: data = self.template_query('ontology_queries', 'structures_by_graph_names', graph_names=structure_graph_names, order=order, num_rows=num_rows, count=count) elif structure_set_ids is not None: data = self.template_query('ontology_queries', 'structures_by_set_ids', set_ids=structure_set_ids, order=order, num_rows=num_rows, count=count) elif structure_set_names is not None: data = self.template_query('ontology_queries', 'structures_by_set_names', set_names=structure_set_names, order=order, num_rows=num_rows, count=count) return data
[docs] @cacheable() def get_structures_with_sets(self, structure_graph_ids, order=['structures.graph_order'], num_rows='all', count=False, **kwargs): '''Download structures along with the sets to which they belong. Parameters ---------- structure_graph_ids : int or list of int Only fetch structure records from these graphs. order : list of strings list of RMA order clauses for sorting num_rows : int how many records to retrieve Returns ------- dict the parsed json response containing data from the API ''' return self.template_query('ontology_queries', 'structures_with_sets', graph_ids=structure_graph_ids, order=order, num_rows=num_rows, count=count)
[docs] def unpack_structure_set_ancestors(self, structure_dataframe): '''Convert a slash-separated structure_id_path field to a list. Parameters ---------- structure_dataframe : DataFrame structure data from the API Returns ------- None A new column is added to the dataframe containing the ancestor list. ''' ancestors = structure_dataframe['structure_id_path'].apply( lambda e: [int(a) for a in e.split('/')[1:-1]]) structure_ancestors = [ [n for n in ancestors_n] for ancestors_n in ancestors ] structure_dataframe['structure_set_ancestor'] = structure_ancestors
[docs] @cacheable() def get_atlases_table(self, atlas_ids=None, brief=True): '''List Atlases available through the API with associated ontologies and structure graphs. Parameters ---------- atlas_ids : integer or list of integers, optional only select specific atlases brief : boolean, optional True (default) requests only name and id fields. Returns ------- dict : atlas metadata Notes ----- This query is based on the `table of available Atlases <http://help.brain-map.org/display/api/Atlas+Drawings+and+Ontologies>`_. See also: `Class: Atlas <http://api.brain-map.org/doc/Atlas.html>`_ ''' if brief is True: data = self.template_query('ontology_queries', 'atlases_table', atlas_ids=atlas_ids) else: data = self.template_query('ontology_queries', 'atlases_table', atlas_ids=atlas_ids, only=None) return data
[docs] @cacheable() def get_atlases(self): return self.template_query('ontology_queries', 'atlases_list')
[docs] @cacheable() def get_structure_graphs(self): return self.template_query('ontology_queries', 'structure_graphs_list')
[docs] @cacheable() def get_structure_sets(self, structure_set_ids=None): if structure_set_ids is None: return self.template_query('ontology_queries', 'structure_sets_list') else: return self.template_query('ontology_queries', 'structure_sets_by_id', set_ids=list(structure_set_ids))