-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathbinit.m
124 lines (111 loc) · 3.16 KB
/
binit.m
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
function [time,psth,rawspikes,sums,rawstruct]=binit(sd,binwidth,startmod,endmod,starttrial,endtrial,wrapped,cor,reset)
% This function will take an lsd structure file and construct a
% timebase and psth at a given binwidth, wrapped or unwrapped.
% binwidth needs to be called *10 as data here is in 10th's ms.
%
% The binning algorithm is taken from the VS manual
%
% [time,psth]=binit(file,binwidth,startmod,endmod,wrapped);
% where wrapped is 1 (yes) or 0(no)
% reset allows other programs to use starttrial differently from spikes,
% e.g. computefft
%
% Allowed raw spike times to be extracted
global data
global xdata
rawspikes=[];
sums=[];
rawstruct=[];
xcinuse=0;
if isempty(endmod) || endmod>sd.nummods || endmod<1
endmod=sd.nummods;
end
if isempty(endtrial) || endtrial>sd.totaltrials || endtrial<1
endtrial=sd.totaltrials;
end
if isempty(startmod) || startmod<1 || startmod>endmod
startmod=1;
end
if isempty(starttrial) || starttrial<1 || starttrial>endtrial
starttrial=1;
end
if exist('cor','var')
if isempty(cor)
else
xcinuse=1;
end
end
if (xcinuse==1)
if isfield(xdata,'modtime')
modtime=xdata.modtime;
else
modtime=round(sd.maxtime/sd.nummods);
end
else
if isfield(data,'modtime')
modtime=data.modtime;
else
modtime=round(sd.maxtime/sd.nummods);
end
end
if modtime==0
errordlg(['It looks as if ' sd.name ' is corrupted as modulationtime is zero!']);
error(['BINIT: error on ' sd.name ', modtime is zero']);
end
if wrapped==1 % Wrapped is ON
time=0:binwidth:modtime;
psth=zeros(1,size(time,2));
if exist('reset','var')
a=starttrial;
else
a=1; %we use this because lsd2 has already removed the trials, so we reset the index
end
sloop=1;
for i=starttrial:endtrial
for j=startmod:endmod
reftime=sd.trial(a).modtimes(j); % The reference time is each modtime
x=sd.trial(a).mod{j};
sums=[sums;length(x)];
rawspikes=[rawspikes;x-reftime];
rawstruct(sloop).trial=(x-reftime)/10;
x=(x-reftime)/binwidth;
x=floor(x);
x=x+1; % We need to do this because binning starts from 0, but the index starts from 1
%add the spikes into the accumulation buffer
for k=1:size(x,1)
psth(x(k))=psth(x(k))+1; % Add the spikes into the accumulation buffer
end
sloop=sloop+1;
end
a=a+1;
end
else % Wrapped is OFF, we thus don't care about mod selection
time=0:binwidth:sd.maxtime;
psth=zeros(1,size(time,2));
a=1;
for i=starttrial:endtrial
sumst=[];
rawtemp=[];
for j=1:sd.nummods
reftime=sd.trial(a).modtimes(1); % The reference time is the 1st modtime
x=sd.trial(a).mod{j};
sumst=[sumst;length(x)];
rawspikes=[rawspikes;x-reftime];
rawtemp=[rawtemp;x-reftime];
x=(x-reftime)/binwidth;
x=floor(x);
x=x+1; % We need to do this because binning starts from 0, but the index starts from 1
x(x>length(psth)) = [];
if ~isempty(x)
for k=1:size(x,1)
psth(x(k))=psth(x(k))+1;
end
end
end
sums=[sums;sum(sumst)];
rawstruct(a).trial=rawtemp/10;
a=a+1;
end
end
rawspikes=sort(rawspikes/10);
time=time/10; %convert back to ms