-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjkfovmatch_mean_dual.m
71 lines (62 loc) · 2.55 KB
/
jkfovmatch_mean_dual.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
% pwd
close all
num_iter = 50;
mouse_num = '041';
layer = 2;
ref_fn_list1 = {'036_5555_001','037_5555_001','038_5555_001','039_5555_001','041_5555_001'};
ref_fn_list2 = {'036_5554_001','037_5554_001','038_5554_001','039_5554_001','041_5554_001'};
if layer == 1
for i = 1 : length(ref_fn_list1)
if strfind(ref_fn_list1{i},mouse_num) == 1
ref_fn = ref_fn_list1{i};
break
end
end
elseif layer == 2
for i = 1 : length(ref_fn_list2)
if strfind(ref_fn_list2{i},mouse_num) == 1
ref_fn = ref_fn_list2{i};
break
end
end
else
error('No filename list')
end
cd(['d:\2p\JK\',ref_fn(1:3)])
load([ref_fn,'.align'], '-mat')
ref1 = mat2gray(m1{end}); % all m's are cell from 2017/11/29. Every .align file now has m1 for green and m2 for red. empty if not taken.
ref2 = mat2gray(m2{end});
figure(1), imagesc(ref1(101:end-10,101:end-10)), axis image,
% figure(2), imagesc(ref2(101:end-10,101:end-10)), axis image
mmfile = memmapfile('scanbox.mmap','Writable',true, ...
'Format', { 'int16' [1 16] 'header' } , 'Repeat', 1);
fh1 = figure; h1 = axes('Parent',fh1);
fh2 = figure; h2 = axes('Parent',fh2);
% WinOnTop(fh);
while(true)
while(mmfile.Data.header(1)<0) % wait for a new frame...
if(mmfile.Data.header(1) == -2) % exit if Scanbox stopped
return;
end
end
mchA = [];
for i = 1 : num_iter
mmfile.Format = {'int16' [1 16] 'header' ; ...
'uint16' double([mmfile.Data.header(2) mmfile.Data.header(3)]) 'chA'; ...
'uint16' double([mmfile.Data.header(2) mmfile.Data.header(3)]) 'chB'};
% aaa = mmfile.Data;
if i == 1
mchA = double(intmax('uint16')-mmfile.Data.chA)/num_iter;
mchB = double(intmax('uint16')-mmfile.Data.chB)/num_iter;
else
mchA = mchA + double(intmax('uint16')-mmfile.Data.chA)/num_iter;
mchB = mchB + double(intmax('uint16')-mmfile.Data.chB)/num_iter;
end
mmfile.Data.header(1) = -1; % signal Scanbox that frame has been consumed!
end
% set(0,'CurrentFigure',fh1), imshowpair(mchA(101:end-10,101:end-10),ref1(101:end-10,101:end-10)), axis image,
% set(0,'CurrentFigure',fh1), imshowpair(mchB(101:end-10,101:end-10),ref2(101:end-10,101:end-10)), axis image,
imshowpair(mchA(101:end-10,101:end-10),ref1(101:end-10,101:end-10),'Parent',h1), axis image,
imshowpair(mchB(101:end-10,101:end-10),ref2(101:end-10,101:end-10),'Parent',h2), axis image,
drawnow limitrate;
end