Source code for allensdk.brain_observatory.nwb.nwb_api
import pandas as pd
import pynwb
import SimpleITK as sitk
import os
from allensdk.brain_observatory.running_speed import RunningSpeed
from allensdk.brain_observatory.behavior.image_api import ImageApi
from pynwb import load_namespaces
namespace_path = os.path.join(os.path.dirname(__file__), 'AIBS_ophys_behavior_namespace.yaml')
load_namespaces(namespace_path)
[docs]class NwbApi:
__slots__ = ('path', '_nwbfile')
@property
def nwbfile(self):
if hasattr(self, '_nwbfile'):
return self._nwbfile
io = pynwb.NWBHDF5IO(self.path, 'r')
return io.read()
def __init__(self, path, **kwargs):
''' Reads data for a single Brain Observatory session from an NWB 2.0 file
'''
self.path = path
[docs] @classmethod
def from_nwbfile(cls, nwbfile, **kwargs):
obj = cls(path=None, **kwargs)
obj._nwbfile = nwbfile
return obj
[docs] @classmethod
def from_path(cls, path, **kwargs):
with open(path, 'r'):
pass
return cls(path=path, **kwargs)
[docs] def get_running_speed(self) -> RunningSpeed:
values = self.nwbfile.modules['running'].get_data_interface('speed').data[:]
timestamps = self.nwbfile.modules['running'].get_data_interface('speed').timestamps[:]
return RunningSpeed(
timestamps=timestamps,
values=values,
)
[docs] def get_stimulus_presentations(self) -> pd.DataFrame:
table = pd.DataFrame({
col.name: col.data for col in self.nwbfile.epochs.columns
if col.name not in set(['tags', 'timeseries', 'tags_index', 'timeseries_index'])
}, index=pd.Index(name='stimulus_presentations_id', data=self.nwbfile.epochs.id.data))
table.index = table.index.astype(int)
return table[sorted(table.columns)]
[docs] def get_invalid_times(self) -> pd.DataFrame:
container = self.nwbfile.invalid_times
if container:
return container.to_dataframe()
else:
return pd.DataFrame()
[docs] def get_image(self, name, module, image_api=None) -> sitk.Image:
if image_api is None:
image_api = ImageApi
nwb_img = self.nwbfile.modules[module].get_data_interface('images')[name]
data = nwb_img.data
resolution = nwb_img.resolution # px/cm
spacing = [resolution * 10, resolution * 10]
return ImageApi.serialize(data, spacing, 'mm')