-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdemo_classification.m
142 lines (106 loc) · 5 KB
/
demo_classification.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
125
126
127
128
129
130
131
132
133
134
135
136
% This code loads a dataset from the '/data' directory
% which should be a cell array of structures called
% subParticles with localizations in the 'point' field
% [x,y] and SQUARED uncertainties in 'sigma' field:
% subParticles{1}.points -> localization data (x,y) in camera pixel units
% subParticles{1}.sigma -> localization uncertainties (sigma) in SQUARED pixel units
%
% The following code will load the data from file and
% then performs the 4 (or 5) steps of the classification
% algorithm. Different example datasets are provided,
% both experimental as simulated data. You only need to
% provide the 'dataset' name, and the values for K (and
% optionally C)
%
% The code makes use of the parallel computing toolbox
% to distribute the load over different workers.
%
% (C) Copyright 2017 Quantitative Imaging Group
% All rights reserved Faculty of Applied Physics
% Delft University of Technology
% Lorentzweg 1
% 2628 CJ Delft
% The Netherlands
%
% Teun Huijben, 2020
%%
close all
clear all
clc
% add the required directory to path
addpath(genpath('datafusion2d'))
addpath(genpath('matlab_functions'))
%% LOAD DATASET
% -- select data set ---
dataset = '200x_simulated_TUD_flame'; %100 with flame, 100 without flame (80% DoL)
% dataset = '200x_simulated_TUD_mirror'; %10 mirrored, 190 normal (80% DoL)
% dataset = '456_experimental_TUD_mirror'; %experimental dataset of which a few (~2%) are mirrored
% -- choose number of particles --
N = 200; %length(subparticles)
load(['data/' dataset '/subParticles.mat'])
outdir = ['output/' dataset];
if ~exist(outdir,'dir')
mkdir(outdir);
else
disp('Warning: outdir already exists')
end
save([outdir '/subParticles'], 'subParticles');
%% STEP 1: all2all registration
% perform all2all registration and save results on disk (can take long for many particles)
scale = 0.01;
% 0.01 for experimental TUD (in camera pixel units)
% 0.03 for simulated TUD
% 0.1 for NPC
% 0.03 or Digits data
% 0.15 for Letters data
% Look at Online Methods for the description
%all2all registration
all2all(subParticles, [outdir '/all2all_matrix'], scale);
%optional fusion of all particles (not necessary for classification)
[initAlignedParticles, M1] = outlier_removal(subParticles, [outdir '/all2all_matrix/'], outdir); %Lie-algebraic averaging
iters = 3; %number of bootstrap iteration
[superParticle, ~] = one2all(initAlignedParticles, iters, M1, outdir,scale); %bootstrapping
%% STEP 2: Multi-dimensional scaling
% load the similarity matrix and normalize with respect to number of localizations;
[SimMatrix, SimMatrixNorm] = MakeMatrix(outdir,subParticles,N);
% dissimilarity matrix
D = SimMatrixNorm+SimMatrixNorm'; % convert upper-triangular matrix to full similarity matrix
D = max(D(:))-D; % convert to dissimilarity
D = D - diag(diag(D)); % set diagonal to 0
mds = mdscale(D,30,'Criterion','metricstress'); % perform multi-dimensional scaling
% show first three dimensions of MDS
figure, scatter3(mds(:,1),mds(:,2),mds(:,3),'o','filled'), title 'Multidimensional Scaling'
%% STEP3: k-means clustering
% -- set number of classes --
K = 4; %set to 2 for the simulated TUD_flame dataset, this will give the correct classes
%set to 4 for the other two datasets, and continue with STEP 5 using C=2
clus = kmeans(mds,K,'replicates',1000);
clear clusters
for i = 1:K
clusters{i} = find(clus==i);
end
figure, scatter3(mds(:,1),mds(:,2),mds(:,3),[],clus,'o','filled'), title 'Clustering result'
%% STEP 4: Reconstruction per cluster
iters = 2; %number of bootstraps
[~,classes] = reconstructPerClassFunction(subParticles,clusters,outdir,scale,iters);
%% Visualize results
close all
width = 0.6;
%random particle
ran = randi(N);
visualizeCloud2D(subParticles{ran}.points,200,width,0,'example particle');
%fusion of all particles without classification
% visualizeCloud2D(superParticle{end},200,width,0,'superParticle');
% reconstructed clusters
for i = 1:length(classes)
str = ['class ' num2str(i) ' (' num2str(length(clusters{i})) ' particles)' ];
visualizeCloud2D(classes{i}{end},200,width,0,str);
end
%% (optional) STEP 5: further clustering - Eigen image method (C<K)
% -- choose number of final classes (C<K) --
C = 2;
classes_aligned = alignClasses(subParticles, clusters, classes, scale);
classes_merged = eigenApproach(classes_aligned,C,width);
for i = 1:C
visualizeCloud2D(classes_merged{i},200,width,0,['class: ' num2str(i)]);
end