-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathselectTemplates.m
More file actions
90 lines (64 loc) · 2.33 KB
/
selectTemplates.m
File metadata and controls
90 lines (64 loc) · 2.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
function [newTemplates,isNoise,splitted] = selectTemplates(templates,plotsOn)
%interface for selecting templates from data
if nargin < 2 || isempty(plotsOn)
plotsOn = true;
end
splitted = false;
maxTemplates = 100;
histogramBins = 50;
samplingRate = 1e-4;
N = length(templates);
d = length(templates{1}(1,:));
figure
makeTemplateHistograms(templates,histogramBins);
newTemplates = cell(maxTemplates,1);
noiseTemplates = cell(maxTemplates,1);
isNoise = true(maxTemplates,1);
count = 1;
countNoise = 1;
for i=1:N
figure(1101)
xx = linspace(-.5,.5,histogramBins);
Z = zeros(d,histogramBins);
for j=1:d
Z(j,:) = hist(templates{i}(:,j),xx);
end
pcolor((1:d).*samplingRate,xx,Z');
shading flat
hold on
plot((1:d).*samplingRate,mean(templates{i}),'k-','linewidth',2)
title(['Template #' num2str(i) ', N = ' num2str(length(templates{i}(:,1))) ...
', Signal (s), Noise (n), or Split (p)? ']);
template_action = '1';
while max(template_action ~= 's') && max(template_action ~= 'n') && max(template_action ~= 'p')
[~,~,template_action] = ginput(1);
end
if template_action == 'n'
noiseTemplates{countNoise} = templates{i};
countNoise = countNoise + 1;
end
if template_action == 's'
newTemplates{count} = templates{i};
count = count + 1;
end
if template_action == 'p'
idx = kmeans(templates{i},2);
newTemplates{count} = templates{i}(idx==1,:);
count = count + 1;
newTemplates{count} = templates{i}(idx==2,:);
count = count + 1;
splitted = true;
end
figure(1101)
hold off
end
close 1101
newTemplates = newTemplates(1:count-1);
isNoise(1:count-1) = false;
noiseTemplates = noiseTemplates(1:countNoise-1);
newTemplates = [newTemplates; noiseTemplates];
isNoise = isNoise(1:length(newTemplates));
if plotsOn
figure
makeTemplateHistograms(newTemplates,histogramBins);
end