| 
									
										
										
										
											2012-06-10 23:26:59 +08:00
										 |  |  | function data = VisualISAMGenerateData(options)
 | 
					
						
							| 
									
										
										
										
											2012-06-10 11:31:09 +08:00
										 |  |  | % VisualISAMGenerateData: create data for viusalSLAM::iSAM examples | 
					
						
							|  |  |  | % Authors: Duy Nguyen Ta and Frank Dellaert | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | %% Generate simulated data | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  | data.points = {}; | 
					
						
							|  |  |  | if options.triangle % Create a triangle target, just 3 points on a plane | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     nPoints = 3; | 
					
						
							|  |  |  |     r = 10; | 
					
						
							|  |  |  |     for j=1:nPoints | 
					
						
							|  |  |  |         theta = (j-1)*2*pi/nPoints; | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |         data.points{j} = gtsamPoint3([r*cos(theta), r*sin(theta), 0]'); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     end | 
					
						
							|  |  |  | else % 3D landmarks as vertices of a cube | 
					
						
							|  |  |  |     nPoints = 8; | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |     data.points = {gtsamPoint3([10 10 10]'),... | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |         gtsamPoint3([-10 10 10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([-10 -10 10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([10 -10 10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([10 10 -10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([-10 10 -10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([-10 -10 -10]'),... | 
					
						
							|  |  |  |         gtsamPoint3([10 -10 -10]')}; | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %% Create camera cameras on a circle around the triangle | 
					
						
							|  |  |  | height = 10; r = 40; | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  | data.K = gtsamCal3_S2(500,500,0,640/2,480/2); | 
					
						
							|  |  |  | data.cameras = {}; | 
					
						
							|  |  |  | for i=1:options.nrCameras | 
					
						
							|  |  |  |     theta = (i-1)*2*pi/options.nrCameras; | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |     t = gtsamPoint3([r*cos(theta), r*sin(theta), height]'); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |     data.cameras{i} = gtsamSimpleCamera_lookat(t, gtsamPoint3, gtsamPoint3([0,0,1]'), data.K); | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %% show images if asked | 
					
						
							| 
									
										
										
										
											2012-06-10 23:26:59 +08:00
										 |  |  | if options.showImages | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |     gui = gcf; | 
					
						
							|  |  |  |     for i=1:options.nrCameras | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |         figure(2+i);clf;hold on | 
					
						
							|  |  |  |         set(2+i,'NumberTitle','off','Name',sprintf('Camera %d',i)); | 
					
						
							|  |  |  |         for j=1:nPoints | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |             zij = data.cameras{i}.project(data.points{j}); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  |             plot(zij.x,zij.y,'*'); | 
					
						
							|  |  |  |             axis([1 640 1 480]); | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  |     figure(gui); | 
					
						
							| 
									
										
										
										
											2012-06-09 04:08:53 +08:00
										 |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-10 12:25:05 +08:00
										 |  |  | %% Calculate odometry between cameras | 
					
						
							|  |  |  | data.odometry = data.cameras{1}.pose.between(data.cameras{2}.pose); |