-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgetSpeckleNum.m
38 lines (30 loc) · 1.42 KB
/
getSpeckleNum.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
function ptNum = getSpeckleNum(start_path)
candsPath = strcat(uigetdir(start_path, 'Please choose the directory for the cands files.'), '\');
startID = 11;
endID = 50;
total_frame_num = endID - startID + 1;
MAX_SPECKLE_NUM = 3000; % This is mainly for allocation of memory.
ptNum = [];
h = waitbar(0, 'Reading speckle data files, Please wait...');
im_base = startID; % This provides an offset so that it is not necessary to have to start from the first frame.
for i = 1 : (endID - startID + 1)
if ((i + im_base - 1) < 10)
cands_name = strcat(candsPath, 'cands15', num2str(i + im_base - 1),'.mat');
elseif ((i + im_base - 1) <100)
cands_name = strcat(candsPath, 'cands15', num2str(i + im_base - 1),'.mat');
else
cands_name = strcat(candsPath, 'cands15', num2str(i + im_base - 1),'.mat');
end
temp1 = load(cands_name);
cands_dim = size(temp1.cands);
frame_speckle(i) = struct('length', 0, 'coordinate', zeros(MAX_SPECKLE_NUM, 3), 'total_lmax_num', 0, 'typeone_num', 0, 'typetwo_num',0, 'typethree_num', 0);
for j = 1 : cands_dim(2)
if (temp1.cands(j).status == 1) % only consider primary speckles
frame_speckle(i).length = frame_speckle(i).length + 1;
end
end
ptNum = [ptNum; frame_speckle(i).length];
waitbar(i / (endID - startID + 1), h);
end
close(h);
fprintf('Speckle numbers have been computed.\n');