Skip to content

Commit

Permalink
calculate refractory period violations with samples rather than time
Browse files Browse the repository at this point in the history
  • Loading branch information
zm711 authored Aug 25, 2023
1 parent 1104ebe commit cf5cb08
Showing 1 changed file with 4 additions and 6 deletions.
10 changes: 4 additions & 6 deletions src/spikeanalysis/spike_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -224,23 +224,21 @@ def refractory_violation(self, ref_dur_ms: float):
"""
print("calculating refractory period violation fraction")
self._goto_file_path()
ref_dur = ref_dur_ms / 1000
ref_dur_samples = ref_dur_ms / 1000 * self._sampling_rate
spike_clusters = np.squeeze(np.load("spike_clusters.npy"))
violations = np.zeros((len(set(spike_clusters))))
violations[:] = np.nan

try:
spike_times = self.spike_times
except AttributeError:
spike_times = self.raw_spike_times / self._sampling_rate

spike_times = self.raw_spike_times / self._sampling_rate

for idx, cluster in enumerate(tqdm(set(spike_clusters))):
spikes = spike_times[self.spike_clusters == cluster]
# print(len(spikes))
if len(spikes) < 10:
continue
else:
num_violations = float(len(np.where(np.diff(spikes) <= ref_dur)[0]))
num_violations = float(len(np.where(np.diff(spikes) <= ref_dur_samples)[0]))
total_spikes = len(spikes)
violations[idx] = num_violations / total_spikes

Expand Down

0 comments on commit cf5cb08

Please sign in to comment.