-
Notifications
You must be signed in to change notification settings - Fork 191
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add neuronexus allego recording Extractor (#3235)
* add neuronexus allego * add tests * fix neuronexus name * Heberto feedback * Fix capitalization * oops * add assert messaging * Update src/spikeinterface/extractors/neoextractors/neuronexus.py Co-authored-by: Zach McKenzie <[email protected]> --------- Co-authored-by: Heberto Mayorquin <[email protected]>
- Loading branch information
1 parent
275e501
commit bbf7daf
Showing
4 changed files
with
81 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
from __future__ import annotations | ||
|
||
from pathlib import Path | ||
|
||
from spikeinterface.core.core_tools import define_function_from_class | ||
|
||
from .neobaseextractor import NeoBaseRecordingExtractor, NeoBaseSortingExtractor | ||
|
||
|
||
class NeuroNexusRecordingExtractor(NeoBaseRecordingExtractor): | ||
""" | ||
Class for reading data from NeuroNexus Allego. | ||
Based on :py:class:`neo.rawio.NeuronexusRawIO` | ||
Parameters | ||
---------- | ||
file_path : str | Path | ||
The file path to the metadata .xdat.json file of an Allego session | ||
stream_id : str | None, default: None | ||
If there are several streams, specify the stream id you want to load. | ||
stream_name : str | None, default: None | ||
If there are several streams, specify the stream name you want to load. | ||
all_annotations : bool, default: False | ||
Load exhaustively all annotations from neo. | ||
use_names_as_ids : bool, default: False | ||
Determines the format of the channel IDs used by the extractor. If set to True, the channel IDs will be the | ||
names from NeoRawIO. If set to False, the channel IDs will be the ids provided by NeoRawIO. | ||
In Neuronexus the ids provided by NeoRawIO are the hardware channel ids stored as `ntv_chan_name` within | ||
the metada and the names are the `chan_names` | ||
""" | ||
|
||
NeoRawIOClass = "NeuroNexusRawIO" | ||
|
||
def __init__( | ||
self, | ||
file_path: str | Path, | ||
stream_id: str | None = None, | ||
stream_name: str | None = None, | ||
all_annotations: bool = False, | ||
use_names_as_ids: bool = False, | ||
): | ||
neo_kwargs = self.map_to_neo_kwargs(file_path) | ||
NeoBaseRecordingExtractor.__init__( | ||
self, | ||
stream_id=stream_id, | ||
stream_name=stream_name, | ||
all_annotations=all_annotations, | ||
use_names_as_ids=use_names_as_ids, | ||
**neo_kwargs, | ||
) | ||
|
||
self._kwargs.update(dict(file_path=str(Path(file_path).resolve()))) | ||
|
||
@classmethod | ||
def map_to_neo_kwargs(cls, file_path): | ||
|
||
neo_kwargs = {"filename": str(file_path)} | ||
|
||
return neo_kwargs | ||
|
||
|
||
read_neuronexus = define_function_from_class(source_class=NeuroNexusRecordingExtractor, name="read_neuronexus") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters