| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | % Set up a small SLAM example in MATLAB | 
					
						
							|  |  |  | % Authors: Christian Potthast, Frank Dellaert | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | clear; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | n = 1000; | 
					
						
							|  |  |  | m = 200; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | % Set up the map  | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  |     map = create_random_landmarks(n,[1000,1000]); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | figure(1);clf; | 
					
						
							|  |  |  | plot(map(1,:), map(2,:),'g.'); hold on; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % have the robot move in this world | 
					
						
							|  |  |  | trajectory = random_walk([0.1,0.1],5,m); | 
					
						
							|  |  |  | plot(trajectory(1,:),trajectory(2,:),'b+'); | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | axis([0 1000 0 1000]);axis square; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | % Check visibility and plot this on the problem figure | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | visibility = create_visibility(map, trajectory,50); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | gplot(visibility,[map trajectory]'); | 
					
						
							|  |  |  | figure(2);clf; | 
					
						
							|  |  |  | spy(visibility) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % simulate the measurements | 
					
						
							|  |  |  | measurement_sigma = 1; | 
					
						
							|  |  |  | odo_sigma = 0.1; | 
					
						
							|  |  |  | [measurements, odometry] = simulate_measurements(map, trajectory, visibility, measurement_sigma, odo_sigma); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % create a configuration of all zeroes | 
					
						
							|  |  |  | config = create_config(n,m); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % create the factor graph | 
					
						
							|  |  |  | linearFactorGraph = create_linear_factor_graph(config, measurements, odometry, measurement_sigma, odo_sigma, n); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % create an ordering | 
					
						
							|  |  |  | ord = create_ordering(n,m); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % show the matrix | 
					
						
							|  |  |  | figure(3); clf; | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | [A_dense,b] = linearFactorGraph.matrix(ord); | 
					
						
							|  |  |  | %spy(A); | 
					
						
							|  |  |  |  A=sparse(A_dense); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | % eliminate with that ordering | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | ck = cputime; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | BayesNet = linearFactorGraph.eliminate(ord); | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | time_gtsam = cputime - ck | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ckqr = cputime; | 
					
						
							|  |  |  | R = qr(A); | 
					
						
							|  |  |  | time_qr = cputime - ckqr | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | %time_gtsam=[time_gtsam,(cputime-ck)] | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | % show the eliminated matrix | 
					
						
							|  |  |  | figure(4); clf; | 
					
						
							|  |  |  | [R,d] = BayesNet.matrix(); | 
					
						
							|  |  |  | spy(R); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % optimize in the BayesNet | 
					
						
							|  |  |  | optimal = BayesNet.optimize; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % plot the solution | 
					
						
							|  |  |  | figure(5);clf;  | 
					
						
							|  |  |  | plot_config(optimal,n,m);hold on | 
					
						
							|  |  |  | plot(trajectory(1,:),trajectory(2,:),'b+'); | 
					
						
							|  |  |  | plot(map(1,:), map(2,:),'g.'); | 
					
						
							| 
									
										
										
										
											2009-11-13 04:41:05 +08:00
										 |  |  | axis([0 1000 0 1000]);axis square; |