Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add set_probe method to BaseRecordingExtractorInterface #639

Merged
merged 29 commits into from
Nov 28, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
d2c465f
add set_probe to BaseRecordingExtractorInterface
magland Nov 10, 2023
3a27e52
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 10, 2023
9983099
Adjust comment in baserecordingextractorinterface.py
magland Nov 10, 2023
9037c96
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 11, 2023
e2b459e
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 13, 2023
8332459
cover set_probe with tests
magland Nov 14, 2023
30b4b40
Merge branch 'set-probe' of https://github.com/magland/neuroconv into…
magland Nov 14, 2023
d3f6e20
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 14, 2023
1b189ce
only test probe for select interfaces
magland Nov 14, 2023
f2259df
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 14, 2023
18776a7
remove debug line
magland Nov 14, 2023
b8f793b
Merge branch 'set-probe' of https://github.com/magland/neuroconv into…
magland Nov 14, 2023
1b9d94c
Merge branch 'main' into set-probe
bendichter Nov 20, 2023
893ec14
Update src/neuroconv/datainterfaces/ecephys/baserecordingextractorint…
magland Nov 20, 2023
b946c64
adjust _create_mock_probe()
magland Nov 20, 2023
645c2c0
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 20, 2023
8cd1aa8
adjust _create_mock_probe() to be more realistic
magland Nov 20, 2023
de101e2
Merge branch 'set-probe' of https://github.com/magland/neuroconv into…
magland Nov 20, 2023
5dcc319
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 20, 2023
75aa8e1
fix _create_mock_probe()
magland Nov 20, 2023
d6cfc2f
Merge branch 'set-probe' of https://github.com/magland/neuroconv into…
magland Nov 20, 2023
6f5f9ba
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 21, 2023
9afd9a9
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 28, 2023
46f592d
adjust set_probe tests
magland Nov 28, 2023
d781a46
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 28, 2023
3f8cab5
RecordingExtractorInterfaceTestMixin: remove check for testing probe
magland Nov 28, 2023
e2298fa
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 28, 2023
69e5d94
recording extractor interface tests
magland Nov 28, 2023
5b3a999
Merge branch 'main' into set-probe
CodyCBakerPhD Nov 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

### Features
* Added Pydantic data models of `BackendConfiguration` for both HDF5 and Zarr datasets (container/mapper of all the `DatasetConfiguration`s for a particular file). [PR #568](https://github.com/catalystneuro/neuroconv/pull/568)
* Added set_probe() method to BaseRecordingExtractorInterface



Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,29 @@ def set_aligned_segment_starting_times(self, aligned_segment_starting_times: Lis
]
self.set_aligned_segment_timestamps(aligned_segment_timestamps=aligned_segment_timestamps)

def set_probe(self, probe, *, group_mode: Union[Literal["by_shank"], Literal["by_probe"]]):
magland marked this conversation as resolved.
Show resolved Hide resolved
"""
Set the probe information via a ProbeInterface object.

Parameters
----------
probe : probeinterface.Probe
The probe object.
group_mode : {'by_shank', 'by_probe'}
How to group the channels. If 'by_shank', channels are grouped by the shank_id column.
If 'by_probe', channels are grouped by the probe_id column.
This is a required parameter to avoid the pitfall of using the wrong mode.
"""
# Set the probe to the recording extractor
self.recording_extractor.set_probe(
probe,
in_place=True,
group_mode=group_mode,
Comment on lines +242 to +245
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just one note: if the probe has less channels than the recording (e.g., you want to only select the A channels from an Intan recording), the set_probe(..., in_place=True) will fail.

We can't do anything about it, just something to keep in mind :)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@alejoe91 What would this represent in a real world case?

Would it be indicative of a bad probe definition by the user?

Or are there cases where the user might actually specify a probe correctly, but extra channels show up (possibly from auxiliary sources or a mistake in SI/neo)?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes I think the second option is what I had in mind. You have a recording with Ephys + Aux channels and you might want to select ephys channels with the probe slicing

)
# Spike interface sets the "group" property
# Buy neuroconv expects "group_name" to be set
magland marked this conversation as resolved.
Show resolved Hide resolved
self.recording_extractor.set_property("group_name", self.recording_extractor.get_property("group").astype(str))
CodyCBakerPhD marked this conversation as resolved.
Show resolved Hide resolved

def align_by_interpolation(
self,
unaligned_timestamps: np.ndarray,
Expand Down
Loading