-
Notifications
You must be signed in to change notification settings - Fork 0
/
buildWT_2pad_error.m
90 lines (85 loc) · 3.88 KB
/
buildWT_2pad_error.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
function buildWT_2pad_error(mouseName, sessionName, d, bSession, videoFreq, ppm, barRadius)
curr_d = pwd;
whisker_d = [d, mouseName, sessionName, filesep];
cd(whisker_d)
tsflist = dir('*_timestamp.mat');
if ~isempty(tsflist) && length(tsflist) > 50 % at least 50 trials with time stamps
xmlflist = dir('*.xml');
if ~isempty(xmlflist)
xmltn = zeros(length(xmlflist),1);
for i = 1 : length(xmlflist)
xmltn(i) = str2double(strtok(xmlflist(i).name, '.'));
end
else
xmltn = [];
end
meanITI = zeros(length(tsflist),1);
for i = 1 : length(tsflist)
tn = str2double(strtok(tsflist(i).name, '_'));
if ~ismember(tn, xmltn)
load(tsflist(i).name) % loading tsSec, tsMilli, and tsMicro
meanITI(i) = mean(diff(tsSec) + diff(tsMilli)/1000 + diff(tsMicro)/1000000);
end
end
meanITI = meanITI(find(meanITI));
videoFreq = 1/mean(meanITI);
end
load([whisker_d, mouseName, sessionName, '_post.mat']) % for maskx and masky. Ignoring includef from this one. It will be re-defined.
if size(maskx{1},1) > size(maskx{1},2)
maskx{1} = maskx{1}'; masky{1} = masky{1}';
maskx{2} = maskx{2}'; masky{2} = masky{2}';
end
filelist=dir([whisker_d '*.measurements']);
dirTrialNums=zeros(1,size(filelist,1));
% %%
% Assign the trial numbers to existing .measurements files in the directory
% NOTE : This assumes that the .measurements files have leading numbers
% corresponding to trial number in string positions 1:end-13 of the file
% name. These index numbers may need to be changed to match up to the
% numerical code of the trial number. (2016/09/05 JK)
if contains(sessionName, 'spont')
includef = cell(size(filelist,1),1);
for i = 1 : length(includef)
includef{i} = filelist(i).name(1:end-13);
end
trialNums = [];
else
for i=1:length(filelist)
dirTrialNums(i)=str2double(filelist(i).name(1:end-13)); % extract out the trial number from each measurements file present in directory
end
trialNums = sort(dirTrialNums);
trialNums = trialNums(~isnan(trialNums));
if ~isempty(bSession) % try only the ones with behavior session
trialNums = intersect(trialNums,bSession.trialNums); % try only the ones with behavior trials
%
%
% tinds = (cellfun(@(x) (x.servoAngle == 90) * x.trialNum, bSession.trials));
% trialNums = tinds(find(tinds));
%
%
end
includef=cell(size(trialNums,1),1);
for i = 1: length(trialNums)
includef{i} = num2str(trialNums(i));
end
end
wsArray = Whisker.WhiskerSignalTrialArray_2pad(pwd);
inds = union(find(cellfun(@(x) isempty(x.nof), wsArray.trials)), setdiff(find(cellfun(@(x) isempty(x.poleMovingFrames), wsArray.trials)), find(cellfun(@(x) strcmp(x.trialType, 'oo'), wsArray.trials)) ));
if length(inds) >= 10
tns = cellfun(@(x) x.trialNum, wsArray.trials(inds));
includef = strsplit(num2str(tns), ' ');
%%
if ~isempty(bSession)
Whisker.makeAllDirectory_WhiskerTrial_2pad(whisker_d,[0 1],'mask', {[maskx{1};masky{1}],[maskx{2};masky{2}]},...
'trial_nums',trialNums,'include_files',includef,...
'barRadius',barRadius,'faceSideInImage', 'bottom', 'framePeriodInSec',1/videoFreq,...
'imagePixelDimsXY',[width height],'pxPerMm',ppm,'mouseName',mouseName,'sessionName',sessionName,'protractionDirection','rightward', 'behavior', bSession);
else
Whisker.makeAllDirectory_WhiskerTrial_2pad(whisker_d,[0 1],'mask', {[maskx{1};masky{1}],[maskx{2};masky{2}]},...
'trial_nums',trialNums,'include_files',includef,...
'barRadius',barRadius,'faceSideInImage', 'bottom', 'framePeriodInSec',1/videoFreq,...
'imagePixelDimsXY',[width height],'pxPerMm',ppm,'mouseName',mouseName,'sessionName',sessionName,'protractionDirection','rightward');
end
cd(curr_d)
end
end