16 lines
		
	
	
		
			589 B
		
	
	
	
		
			Matlab
		
	
	
			
		
		
	
	
			16 lines
		
	
	
		
			589 B
		
	
	
	
		
			Matlab
		
	
	
%% Initialize graph, initial estimate, and odometry noise
 | 
						|
datafile = findExampleDataFile('w100.graph');
 | 
						|
model = noiseModel.Diagonal.Sigmas([0.05; 0.05; 5*pi/180]);
 | 
						|
[graph,initial] = load2D(datafile, model);
 | 
						|
 | 
						|
%% Add a Gaussian prior on pose x_0
 | 
						|
priorMean = Pose2(0, 0, 0);
 | 
						|
priorNoise = noiseModel.Diagonal.Sigmas([0.01; 0.01; 0.01]);
 | 
						|
graph.add(PriorFactorPose2(0, priorMean, priorNoise));
 | 
						|
 | 
						|
%% Optimize using Levenberg-Marquardt optimization and get marginals
 | 
						|
optimizer = LevenbergMarquardtOptimizer(graph, initial);
 | 
						|
result = optimizer.optimizeSafely;
 | 
						|
marginals = Marginals(graph, result);
 | 
						|
 |