Source code for neuroconv.datainterfaces.ecephys.spike2.spike2datainterface
from pathlib import Path
from pydantic import FilePath, validate_call
from ..baserecordingextractorinterface import BaseRecordingExtractorInterface
from ....tools import get_package
from ....utils import get_json_schema_from_method_signature
def _test_sonpy_installation() -> None:
get_package(
package_name="sonpy",
excluded_python_versions=["3.10", "3.11"],
excluded_platforms_and_python_versions=dict(darwin=dict(arm=["3.9", "3.10", "3.11", "3.12"])),
)
[docs]class Spike2RecordingInterface(BaseRecordingExtractorInterface):
"""
Data interface class for converting Spike2 data from CED (Cambridge Electronic
Design) using the :py:class:`~spikeinterface.extractors.CedRecordingExtractor`."""
display_name = "Spike2 Recording"
keywords = BaseRecordingExtractorInterface.keywords + ("CED",)
associated_suffixes = (".smrx",)
info = "Interface for Spike2 recording data from CED (Cambridge Electronic Design)."
ExtractorName = "CedRecordingExtractor"
[docs] @classmethod
def get_source_schema(cls) -> dict:
source_schema = get_json_schema_from_method_signature(method=cls.__init__, exclude=["smrx_channel_ids"])
source_schema.update(additionalProperties=True)
source_schema["properties"]["file_path"].update(description="Path to .smrx file.")
return source_schema
[docs] @classmethod
def get_all_channels_info(cls, file_path: FilePath):
"""
Retrieve and inspect necessary channel information prior to initialization.
Parameters
----------
file_path : FilePath
Path to .smr or .smrx file.
Returns
-------
dict
Dictionary containing information about all channels in the Spike2 file.
"""
_test_sonpy_installation()
return cls.get_extractor().get_all_channels_info(file_path=file_path)
@validate_call
def __init__(self, file_path: FilePath, verbose: bool = False, es_key: str = "ElectricalSeries"):
"""
Initialize reading of Spike2 file.
Parameters
----------
file_path : FilePath
Path to .smr or .smrx file.
verbose : bool, default: False
es_key : str, default: "ElectricalSeries"
"""
_test_sonpy_installation()
stream_id = "1" if Path(file_path).suffix == ".smr" else None
super().__init__(file_path=file_path, stream_id=stream_id, verbose=verbose, es_key=es_key)
# Subset raw channel properties
signal_channels = self.recording_extractor.neo_reader.header["signal_channels"]
channel_ids_of_raw_data = [channel_info[1] for channel_info in signal_channels if channel_info[4] == "mV"]
self.recording_extractor = self.recording_extractor.channel_slice(channel_ids=channel_ids_of_raw_data)