-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathdemo_GPLmkMatching.m
70 lines (55 loc) · 2.55 KB
/
demo_GPLmkMatching.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
%% init
clear
close all;
initialize;
yalmip('clear');
rng(1);
%% data
dataFolder = 'sample_data/';
params.GTLmk.numLmk = 16;
dataFileNames = {'a16_sas_aligned', 'b02_sas_aligned'};
%% Landmark Matching Method (see Table 1 in the paper)
params.typeLmkMatching = 'GP_BD'; % {'GP_BD','GP_Euc_BD','GP_nW_BD','GT_BD','GT2_BD','GT3'};
%% parameters
visualize = true;
params.preprocess.dataFileType = 'off';
params.typeLmk = 'GP';
params.GPLmk.numLmk = 40;
params.computePutativeMatches.forceIdentity = false; % enabling makes sense only for GT landmarks
params.computePutativeMatches.WKSNN = 2;
params.matchSurfaceLmksBD.visualize = visualize;
params.matchSurfaceLmksBD.forceIdentity = false; % enabling makes sense only for GT landmarks
params.matchSurfaceLmksBD.paramBDfilt.K = 1.5;
params.matchSurfaceLmksBD.paramBDfilt.pnorm = 0.1;
params.matchSurfaceLmksBD.paramBDfilt.initdelta = 1;
params.matchSurfaceLmksBD.paramBDfilt.boundaryConstraintType = 'similarity+translation'; %{'none','fixed','linear','similarity','affine','similarity+translation'}
params.visualizeCorrepsondences2D.offsetFactors = [-1.1 0];
params.visualizeCorrepsondences2D.rotationAngle = 0*(pi/180);
%% load meshes and preprocess
for j = 1:2
% load
Gs{j} = Mesh(params.preprocess.dataFileType,...
fullfile(dataFolder,[dataFileNames{j} '.' params.preprocess.dataFileType]));
% normalize (center and scale to unit area)
Gs{j}.Normalize();
% reorient (outward facing normals)
[~,~,flip] = Gs{j}.ComputeNormal();
if flip
Gs{j}.F = Gs{j}.F([1 3 2],:);
end
% compute WKS
Gs{j}.Aux.WKS = Gs{j}.ComputeWKS([]);
end
%% Lmk Matching
[distBD, Lmks, putativeInds, matchIndsBD, regParamBD, isoParamBD] = wrapperLmkMatch(Gs,params);
%% visualize results
% 2d parameterizations
visualizeCorrepsondences2D(Gs, isoParamBD, putativeInds, false, 'Putative correspondences (iso parameterization)', params.visualizeCorrepsondences2D);
visualizeCorrepsondences2D(Gs, regParamBD, putativeInds, false, 'Putative correspondences (registered parameterization)', params.visualizeCorrepsondences2D);
visualizeCorrepsondences2D(Gs, regParamBD, matchIndsBD, true, 'BD-filtered correpsondences', params.visualizeCorrepsondences2D);
% 3d and texture map
h{1} = visualizeCorrespondences3D(Gs, Lmks, false, 'Landmarks');
h{2} = visualizeCorrespondences3D(Gs, matchIndsBD, true, 'BD-filtered correpsondences');
h{3} = visualizeMapping3D(Gs, regParamBD, [], sprintf('Lmk-BD: Induced CP distance = %f', distBD));
% link
linkprop([h{:}], {'CameraUpVector', 'CameraPosition', 'CameraTarget', 'CameraViewAngle'});