forked from Huan2018/Matlab-Graph-Optimization
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSecondExample_VINS_visual.m
103 lines (78 loc) · 3.26 KB
/
SecondExample_VINS_visual.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
clc
clear
addpath('./g2o_files/');
addpath('./auxilliary/')
addpath('./Math/');
addpath('./Factor/');
addpath('./VINS_DataGenerator/');
load VINS_cubic3.mat
[ Graph ] = InitializeGraph;
%%% add Prior
M_initial.value = RobotState{1, 1}.pose;
M_initial.inf=100*eye(6);
[ Graph ] = AddUnaryEdge( Graph, 'PriorPose3_Factor', 'Pose3', 'pose0', M_initial );
Graph.Nodes.Pose3.Values.pose0 = RobotState{1, 1}.pose;
Measurement.value.vel = RobotState{1, 1}.velocity ;
Measurement.value.bias = [RobotState{1, 1}.ba; RobotState{1, 1}.bw];
Measurement.inf=100*eye(9);
NodeArray=cell(2,2);
NodeArray{1,1}='Velocity3'; NodeArray{1,2}='v0';
NodeArray{2,1}='IMUbias'; NodeArray{2,2}='b0';
[ Graph ]= AddComplexEdge(Graph, 'PriorVelAndbias_Factor', NodeArray, Measurement);
Graph.Nodes.Velocity3.Values.v0 = RobotState{1, 1}.velocity;
Graph.Nodes.IMUbias.Values.b0 = Measurement.value.bias;
%
Measure_translation.inf=10000*eye(6);
T0= RobotState{1, 1}.pose; R0=T0(1:3,1:3); p0=T0(1:3,4);
T1= RobotState{1, 2}.pose; R1=T1(1:3,1:3); p1=T1(1:3,4);
Measure_translation.value=[R0'*R1 R0'*(p1-p0) ];
[ Graph ] = AddNormalEdge( Graph, 'RelativePose3_Factor', 'Pose3', 'pose0', 'Pose3', 'pose1', Measure_translation );
%
%%% add IMU measurement
num_poses =10;
for i = 0: num_poses-1
% %%%%%%%% IMU part
% NodeArray{1,1}='Pose3'; NodeArray{1,2}=['pose' num2str(i)];
% NodeArray{2,1}='Velocity3'; NodeArray{2,2}=['v' num2str(i)];
% NodeArray{3,1}='IMUbias'; NodeArray{3,2}=['b' num2str(i)];
% NodeArray{4,1}='Pose3'; NodeArray{4,2}=['pose' num2str(i+1)];
% NodeArray{5,1}='Velocity3'; NodeArray{5,2}=['v' num2str(i+1)];
% NodeArray{6,1}='IMUbias'; NodeArray{6,2}=['b' num2str(i+1)];
% Measurement_IMU_i = Measurement_IMU{i+1};
% [ Graph ]= AddComplexEdge(Graph, 'IMU_Factor', NodeArray, Measurement_IMU_i);
%
%
% NodeArray_bias{1,1}='IMUbias'; NodeArray_bias{1,2}=['b' num2str(i)];
% NodeArray_bias{2,1}='IMUbias'; NodeArray_bias{2,2}=['b' num2str(i+1)];
% Measurement_IMU_change.value = [];
% Measurement_IMU_change.inf = IMUbiasWalk_inf;
% [ Graph ]= AddComplexEdge(Graph, 'IMUbias_Factor', NodeArray_bias, Measurement_IMU_change);
%
% if 1
Graph.Nodes.Pose3.Values.(NodeArray{1,2})=RobotState{i+1}.pose;
% Graph.Nodes.Pose3.Values.(NodeArray{4,2})=RobotState{i+2}.pose;
% Graph.Nodes.Velocity3.Values.(NodeArray{2,2})= RobotState{i+1}.velocity;
% Graph.Nodes.Velocity3.Values.(NodeArray{5,2})= RobotState{i+2}.velocity;
% Graph.Nodes.IMUbias.Values.(NodeArray{3,2})= [RobotState{i+1}.ba;RobotState{i+1}.bw];
% Graph.Nodes.IMUbias.Values.(NodeArray{6,2})= [RobotState{i+2}.ba;RobotState{i+2}.bw];
% end
%[ Graph ] = PerformGO( Graph ); % To get odometry
for j=1:50
landmark_id =['landmark' num2str(j)];
pose_id = ['pose' num2str(i)];
Measurement.value= (Measurement_Vision( j+ 50*i ,3:4))' ;
depth_rough = norm(RGBD_data(j+ 50*i,3:5))*(1+randn*0.1);
%Measurement.inf= eye(2)*(1/depth_rough^2)*(1^2) ;
Measurement.inf= eye(3) ;
NodeArrayA{1,1}='Pose3'; NodeArrayA{1,2}=pose_id;
NodeArrayA{2,1}='Landmark3'; NodeArrayA{2,2}=landmark_id;
[ Graph ]= AddComplexEdge(Graph, 'VisionTest_Factor', NodeArrayA, Measurement);
if i <=2
Graph.Nodes.Landmark3.Values.(landmark_id )= Landmarks.(landmark_id)+randn(3,1)*0.3;
end
end
% if i >2
% [ Graph ] = PerformGO( Graph );
% end
end
[ Graph ] = PerformGO_DL( Graph );