From 065ed43363ed21c22a1922d3d2c20cd862b7c2fa Mon Sep 17 00:00:00 2001 From: Heberto Mayorquin Date: Thu, 20 Jun 2024 12:49:43 -0600 Subject: [PATCH] Bye bye spikeextractors (#349) * bye bye spikeextractors * use generate_sorting as the recording is not used * changelog --------- Co-authored-by: Paul Adkisson --- CHANGELOG.md | 2 +- requirements-testing.txt | 2 +- .../example_datasets/toy_example.py | 23 +++++++------------ 3 files changed, 10 insertions(+), 17 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index bbd88889..5455386e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -31,7 +31,7 @@ * Updated testing workflows to include python 3.12, m1/intel macos, and dev tests to check neuroconv: [PR #317](https://github.com/catalystneuro/roiextractors/pull/317) * Added daily testing workflow and fixed bug with python 3.12 by upgrading scanimage-tiff-reader version: [PR #321](https://github.com/catalystneuro/roiextractors/pull/321) * Remove wheel from requirements and move CI dependencies to test requirements [PR #348](https://github.com/catalystneuro/roiextractors/pull/348) - +* Use Spikeinterface instead of Spikeextractors for toy_example [PR #349](https://github.com/catalystneuro/roiextractors/pull/349) # v0.5.8 diff --git a/requirements-testing.txt b/requirements-testing.txt index 832cf9b5..3e67494c 100644 --- a/requirements-testing.txt +++ b/requirements-testing.txt @@ -1,5 +1,5 @@ pytest pytest-cov parameterized==0.8.1 -spikeextractors>=0.9.10 +spikeinterface>=0.100.7 pytest-xdist diff --git a/src/roiextractors/example_datasets/toy_example.py b/src/roiextractors/example_datasets/toy_example.py index f6dc99e6..dd9997d9 100644 --- a/src/roiextractors/example_datasets/toy_example.py +++ b/src/roiextractors/example_datasets/toy_example.py @@ -157,15 +157,9 @@ def toy_example( mode=mode, ) - # generate spike trains - import spikeextractors as se - - rec, sort = se.example_datasets.toy_example( - duration=duration, - K=num_rois, - num_channels=1, - sampling_frequency=sampling_frequency, - ) + from spikeinterface.core import generate_sorting + + sort = generate_sorting(durations=[duration], num_units=num_rois, sampling_frequency=sampling_frequency) # create decaying response resp_samples = int(decay_time * sampling_frequency) @@ -173,17 +167,16 @@ def toy_example( tresp = np.arange(resp_samples) resp = np.exp(-tresp / resp_tau) - num_frames = rec.get_num_frames() # TODO This should be changed to sampling_frequency x duration - num_of_units = sort.get_unit_ids() # TODO This to be changed by num_rois + num_frames = sampling_frequency * duration # convolve response with ROIs - raw = np.zeros(num_of_units, num_frames) # TODO Change to new standard formating with time in first axis - deconvolved = np.zeros(num_of_units, num_frames) # TODO Change to new standard formating with time in first axis + raw = np.zeros(num_rois, num_frames) # TODO Change to new standard formating with time in first axis + deconvolved = np.zeros(num_rois, num_frames) # TODO Change to new standard formating with time in first axis neuropil = noise_std * np.random.randn( - num_of_units, num_frames + num_rois, num_frames ) # TODO Change to new standard formating with time in first axis frames = num_frames - for u_i, unit in range(num_of_units): + for u_i, unit in range(num_rois): unit = u_i + 1 # spikeextractor toy example has unit ids starting at 1 for s in sort.get_unit_spike_train(unit): # TODO build a local function that generates frames with spikes if s < num_frames: