gtsam/matlab/VisualISAMPlot.m

66 lines
1.6 KiB
Matlab
Raw Normal View History

function VisualISAMPlot(truth, data, isam, result, options)
% VisualISAMPlot: plot current state of visualSLAM::iSAM object
% Authors: Duy Nguyen Ta and Frank Dellaert
M = result.nrPoses;
N = result.nrPoints;
h=gca;
cla(h);
2012-06-09 04:08:53 +08:00
hold on;
2012-06-10 23:26:59 +08:00
%% Plot points
% Can't use data because current frame might not see all points
pointKeys = result.allPoints().keys();
for j=0:N-1 % NOTE: uses indexing directly from a C++ vector, so zero-indexed
jj = pointKeys.at(j);
point_j = result.point(jj);
plot3(point_j.x, point_j.y, point_j.z,'marker','o');
P = isam.marginalCovariance(jj);
covarianceEllipse3D([point_j.x;point_j.y;point_j.z],P);
2012-06-09 04:08:53 +08:00
end
2012-06-10 23:26:59 +08:00
%% Plot cameras
import gtsam.*
2012-06-10 23:26:59 +08:00
for i=1:options.cameraInterval:M
ii = symbol('x',i);
pose_i = result.pose(ii);
if options.hardConstraint && (i==1)
2012-06-10 23:26:59 +08:00
plotPose3(pose_i,[],10);
else
P = isam.marginalCovariance(ii);
plotPose3(pose_i,P,10);
end
2012-06-10 23:26:59 +08:00
if options.drawTruePoses % show ground truth
plotPose3(truth.cameras{i}.pose,[],10);
2012-06-09 04:08:53 +08:00
end
end
2012-06-10 23:26:59 +08:00
%% draw
2012-06-09 04:08:53 +08:00
axis([-40 40 -40 40 -10 20]);axis equal
view(3)
colormap('hot')
2012-06-10 23:26:59 +08:00
drawnow
%% do various optional things
2012-06-09 04:08:53 +08:00
2012-06-10 23:26:59 +08:00
if options.saveFigures
fig2 = figure('visible','off');
newax = copyobj(h,fig2);
colormap(fig2,'hot');
set(newax, 'units', 'normalized', 'position', [0.13 0.11 0.775 0.815]);
2012-06-10 23:26:59 +08:00
print(fig2,'-dpng',sprintf('VisualiSAM%03d.png',M));
2012-06-09 04:08:53 +08:00
end
2012-06-10 23:26:59 +08:00
if options.saveDotFiles
isam.saveGraph(sprintf('VisualiSAM%03d.dot',M));
2012-06-09 04:08:53 +08:00
end
2012-06-10 23:26:59 +08:00
if options.saveDotFile
isam.saveGraph(sprintf('VisualiSAM.dot'));
end
2012-06-10 23:26:59 +08:00
if options.printStats
isam.printStats();
end