From 93169704d6bde21f4fdc7a27079c90503a7b65a7 Mon Sep 17 00:00:00 2001
From: Pietro Quaglio
Date: Tue, 16 May 2017 09:56:44 +0200
Subject: [PATCH] Bug fixing for isi function (#104)
Bug fix for the isi function:
* Fixed bug for t_start larger than minimum isi and for non-sorted spiketrains
---
elephant/statistics.py | 8 +++++---
elephant/test/test_statistics.py | 3 ++-
2 files changed, 7 insertions(+), 4 deletions(-)
diff --git a/elephant/statistics.py b/elephant/statistics.py
index 7b5fc2278..42c729b77 100644
--- a/elephant/statistics.py
+++ b/elephant/statistics.py
@@ -46,9 +46,11 @@ def isi(spiketrain, axis=-1):
"""
if axis is None:
axis = -1
- intervals = np.diff(spiketrain, axis=axis)
- if hasattr(spiketrain, 'waveforms'):
- intervals = pq.Quantity(intervals.magnitude, units=spiketrain.units)
+ if isinstance(spiketrain, neo.SpikeTrain):
+ intervals = np.diff(
+ np.sort(spiketrain.times.view(pq.Quantity)), axis=axis)
+ else:
+ intervals = np.diff(np.sort(spiketrain), axis=axis)
return intervals
diff --git a/elephant/test/test_statistics.py b/elephant/test/test_statistics.py
index 4b013fe79..f611c0b39 100644
--- a/elephant/test/test_statistics.py
+++ b/elephant/test/test_statistics.py
@@ -34,7 +34,8 @@ def setUp(self):
self.targ_array_1d = self.targ_array_2d_1[0, :]
def test_isi_with_spiketrain(self):
- st = neo.SpikeTrain(self.test_array_1d, units='ms', t_stop=10.0)
+ st = neo.SpikeTrain(
+ self.test_array_1d, units='ms', t_stop=10.0, t_start=0.29)
target = pq.Quantity(self.targ_array_1d, 'ms')
res = es.isi(st)
assert_array_almost_equal(res, target, decimal=9)