% LSG-CPD: CPD with Local Surface Geometry
% Demo of teapot Experiment

% Read Data
clc
clear
close all
load("teapot.mat")

% GraphCPD
tic
% [xform, sigma2, loglikelihood, iter] = GraphCPD(cover, teapot, 'xform2center', 'true'); 
[xform, sigma2, loglikelihood, iter] = GraphCPD_opti(cover, teapot, 'outlierRatio', 0.1, 'xform2center', 'true');
toc

% Show result
figure(2)
pc_xform = pctransform(cover, xform);
ShowPointCloudPair(teapot, pc_xform, 'backgroundColor', 'white', 'grid', 'hide', 'axis', 'on')

angerr = angErr(R', xform.Rotation);