| 
									
										
										
										
											2012-06-10 11:31:09 +08:00
										 |  |  | % VisualISAMPlot: plot current state of visualSLAM::iSAM object | 
					
						
							|  |  |  | % Authors: Duy Nguyen Ta and Frank Dellaert | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % global variables, input | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  | global data frame_i isam result | 
					
						
							| 
									
										
										
										
											2012-06-10 11:31:09 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | % options | 
					
						
							|  |  |  | global CAMERA_INTERVAL DRAW_TRUE_POSES SAVE_FIGURES SAVE_GRAPHS | 
					
						
							| 
									
										
										
										
											2012-06-10 13:00:42 +08:00
										 |  |  | global SAVE_GRAPH PRINT_STATS | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | %% Plot results | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  | h=gca; | 
					
						
							|  |  |  | cla(h); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | hold on; | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  | for j=1:size(data.points,2) | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     point_j = result.point(symbol('l',j)); | 
					
						
							|  |  |  |     plot3(point_j.x, point_j.y, point_j.z,'marker','o'); | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  |     if (frame_i>1)  | 
					
						
							|  |  |  |         P = isam.marginalCovariance(symbol('l',j)); | 
					
						
							|  |  |  |         covarianceEllipse3D([point_j.x;point_j.y;point_j.z],P);  | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | end | 
					
						
							|  |  |  | for ii=1:CAMERA_INTERVAL:frame_i | 
					
						
							|  |  |  |     pose_ii = result.pose(symbol('x',ii)); | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  |     if (frame_i>1) | 
					
						
							|  |  |  |         P = isam.marginalCovariance(symbol('x',ii)); | 
					
						
							|  |  |  |     else  | 
					
						
							| 
									
										
										
										
											2012-06-10 11:31:09 +08:00
										 |  |  |         P = []; | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     plotPose3(pose_ii,P,10); | 
					
						
							|  |  |  |     if DRAW_TRUE_POSES % show ground truth | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |         plotPose3(data.cameras{ii}.pose,0.001*eye(6),10); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     end | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | axis([-40 40 -40 40 -10 20]);axis equal | 
					
						
							|  |  |  | view(3) | 
					
						
							|  |  |  | colormap('hot') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if SAVE_FIGURES | 
					
						
							| 
									
										
										
										
											2012-06-09 12:01:37 +08:00
										 |  |  |     fig2 = figure('visible','off'); | 
					
						
							|  |  |  |     newax = copyobj(h,fig2); | 
					
						
							|  |  |  |     colormap(fig2,'hot'); | 
					
						
							|  |  |  |     set(newax, 'units', 'normalized', 'position', [0.13 0.11 0.775 0.815]); | 
					
						
							|  |  |  |     print(fig2,'-dpng',sprintf('VisualiSAM%03d.png',frame_i)); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | end | 
					
						
							| 
									
										
										
										
											2012-06-09 12:01:37 +08:00
										 |  |  | if SAVE_GRAPHS && (frame_i>1) | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     isam.saveGraph(sprintf('VisualiSAM%03d.dot',frame_i)); | 
					
						
							|  |  |  | end | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-10 13:00:42 +08:00
										 |  |  | if SAVE_GRAPH | 
					
						
							|  |  |  |     isam.saveGraph(sprintf('VisualiSAM.dot',frame_i)); | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if PRINT_STATS | 
					
						
							|  |  |  |     isam.printStats(); | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-09 06:36:34 +08:00
										 |  |  | drawnow |