Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
alejoe91 committed Jun 21, 2024
1 parent 9a31eac commit d652e63
Show file tree
Hide file tree
Showing 8 changed files with 36 additions and 26 deletions.
4 changes: 2 additions & 2 deletions pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[project]
name = "spikeinterface"
version = "0.100.7"
version = "0.100.8"
authors = [
{ name="Alessio Buccino", email="[email protected]" },
{ name="Samuel Garcia", email="[email protected]" },
Expand All @@ -20,7 +20,7 @@ classifiers = [


dependencies = [
"numpy",
"numpy>=1.20, <2.0", # 1.20 np.ptp, 1.26 might be necessary for avoiding pickling errors when numpy >2.0
"threadpoolctl>=3.0.0",
"tqdm",
"zarr>=2.16,<2.18",
Expand Down
7 changes: 6 additions & 1 deletion src/spikeinterface/core/core_tools.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,12 @@ def default(self, obj):
if isinstance(obj, np.generic):
return obj.item()

if np.issctype(obj): # Cast numpy datatypes to their names
# Standard numpy dtypes like np.dtype('int32") are transformed this way
if isinstance(obj, np.dtype):
return np.dtype(obj).name

# This will transform to a string canonical representation of the dtype (e.g. np.int32 -> 'int32')
if isinstance(obj, type) and issubclass(obj, np.generic):
return np.dtype(obj).name

if isinstance(obj, np.ndarray):
Expand Down
1 change: 0 additions & 1 deletion src/spikeinterface/core/tests/test_jsonification.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,6 @@ def test_numpy_dtype_alises_encoding():
# People tend to use this a dtype instead of the proper classes
json.dumps(np.int32, cls=SIJsonEncoder)
json.dumps(np.float32, cls=SIJsonEncoder)
json.dumps(np.bool_, cls=SIJsonEncoder) # Note that np.bool was deperecated in numpy 1.20.0


def test_recording_encoding(numpy_generated_recording):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,8 @@
import spikeinterface.preprocessing as spre
import spikeinterface.extractors as se
from spikeinterface.core import generate_recording
import spikeinterface.widgets as sw
import importlib.util

try:
import spikeglx
import neurodsp.voltage as voltage

HAVE_IBL_NPIX = True
except ImportError:
HAVE_IBL_NPIX = False

ON_GITHUB = bool(os.getenv("GITHUB_ACTIONS"))

Expand All @@ -31,7 +24,10 @@
# ----------------------------------------------------------------------------------------------------------------------


@pytest.mark.skipif(not HAVE_IBL_NPIX or ON_GITHUB, reason="Only local. Requires ibl-neuropixel install")
@pytest.mark.skipif(
importlib.util.find_spec("neurodsp") is not None or importlib.util.find_spec("spikeglx") or ON_GITHUB,
reason="Only local. Requires ibl-neuropixel install",
)
@pytest.mark.parametrize("lagc", [False, 1, 300])
def test_highpass_spatial_filter_real_data(lagc):
"""
Expand All @@ -56,6 +52,9 @@ def test_highpass_spatial_filter_real_data(lagc):
use DEBUG = true to visualise.
"""
import spikeglx
import neurodsp.voltage as voltage

options = dict(lagc=lagc, ntr_pad=25, ntr_tap=50, butter_kwargs=None)
print(options)

Expand Down Expand Up @@ -118,6 +117,8 @@ def get_ibl_si_data():
"""
Set fixture to session to ensure origional data is not changed.
"""
import spikeglx

local_path = si.download_dataset(remote_path="spikeglx/Noise4Sam_g0")
ibl_recording = spikeglx.Reader(
local_path / "Noise4Sam_g0_imec0" / "Noise4Sam_g0_t0.imec0.ap.bin", ignore_warnings=True
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,8 @@
import spikeinterface.preprocessing as spre
import spikeinterface.extractors as se
from spikeinterface.core.generate import generate_recording
import importlib.util

try:
import spikeglx
import neurodsp.voltage as voltage

HAVE_IBL_NPIX = True
except ImportError:
HAVE_IBL_NPIX = False

ON_GITHUB = bool(os.getenv("GITHUB_ACTIONS"))

Expand All @@ -30,7 +24,10 @@
# -------------------------------------------------------------------------------


@pytest.mark.skipif(not HAVE_IBL_NPIX or ON_GITHUB, reason="Only local. Requires ibl-neuropixel install")
@pytest.mark.skipif(
importlib.util.find_spec("neurodsp") is not None or importlib.util.find_spec("spikeglx") or ON_GITHUB,
reason="Only local. Requires ibl-neuropixel install",
)
def test_compare_real_data_with_ibl():
"""
Test SI implementation of bad channel interpolation against native IBL.
Expand All @@ -42,6 +39,9 @@ def test_compare_real_data_with_ibl():
voltage.interpolate_bad_channel() with ibl_channel geometry to
si_scaled_recordin.get_traces(0) is also close to 1e-2.
"""
import spikeglx
import neurodsp.voltage as voltage

# Download and load data
local_path = si.download_dataset(remote_path="spikeglx/Noise4Sam_g0")
si_recording = se.read_spikeglx(local_path, stream_id="imec0.ap")
Expand Down Expand Up @@ -80,7 +80,10 @@ def test_compare_real_data_with_ibl():
assert np.mean(is_close) > 0.999


@pytest.mark.skipif(not HAVE_IBL_NPIX, reason="Requires ibl-neuropixel install")
@pytest.mark.skipif(
importlib.util.find_spec("neurodsp") is not None or importlib.util.find_spec("spikeglx") is not None,
reason="Requires ibl-neuropixel install",
)
@pytest.mark.parametrize("num_channels", [32, 64])
@pytest.mark.parametrize("sigma_um", [1.25, 40])
@pytest.mark.parametrize("p", [0, -0.5, 1, 5])
Expand All @@ -90,6 +93,8 @@ def test_compare_input_argument_ranges_against_ibl(shanks, p, sigma_um, num_chan
Perform an extended test across a range of function inputs to check
IBL and SI interpolation results match.
"""
import neurodsp.voltage as voltage

recording = generate_recording(num_channels=num_channels, durations=[1])

# distribute default probe locations across 4 shanks if set
Expand Down
4 changes: 2 additions & 2 deletions src/spikeinterface/sortingcomponents/peak_localization.py
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ def compute(self, traces, peaks, waveforms):
wf = waveforms[idx][:, :, chan_inds]

if self.feature == "ptp":
wf_data = wf.ptp(axis=1)
wf_data = np.ptp(wf, axis=1)
elif self.feature == "mean":
wf_data = wf.mean(axis=1)
elif self.feature == "energy":
Expand Down Expand Up @@ -292,7 +292,7 @@ def compute(self, traces, peaks, waveforms):

wf = waveforms[i, :][:, chan_inds]
if self.feature == "ptp":
wf_data = wf.ptp(axis=0)
wf_data = np.ptp(wf, axis=0)
elif self.feature == "energy":
wf_data = np.linalg.norm(wf, axis=0)
elif self.feature == "peak_voltage":
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ def test_waveform_thresholder_ptp(extract_waveforms, generated_recording, detect
recording, peaks, nodes=pipeline_nodes, job_kwargs=chunk_executor_kwargs
)

data = tresholded_waveforms.ptp(axis=1) / noise_levels
data = np.ptp(tresholded_waveforms, axis=1) / noise_levels
assert np.all(data[data != 0] > 3)


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ def __init__(

def compute(self, traces, peaks, waveforms):
if self.feature == "ptp":
wf_data = waveforms.ptp(axis=1) / self.noise_levels
wf_data = np.ptp(waveforms, axis=1) / self.noise_levels
elif self.feature == "mean":
wf_data = waveforms.mean(axis=1) / self.noise_levels
elif self.feature == "energy":
Expand Down

0 comments on commit d652e63

Please sign in to comment.