-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathInitialize.m
51 lines (46 loc) · 1.98 KB
/
Initialize.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
% -------------------------------------------------------------------------
% KF-GINS-Matlab: An EKF-based GNSS/INS Integrated Navigation System in Matlab
%
% Copyright (C) 2024, i2Nav Group, Wuhan University
%
% Author : Liqiang Wang
% Contact : [email protected]
% Date : 2023.3.3
% -------------------------------------------------------------------------
function [kf, navstate] = Initialize(cfg)
% kalman parameters initialization
kf.RANK = 21;
kf.NOISE_RANK = 18;
kf.P = zeros(kf.RANK, kf.RANK);
kf.Qc = zeros(kf.NOISE_RANK, kf.NOISE_RANK);
kf.x = zeros(kf.RANK, 1);
% Qc
kf.Qc(1:3, 1:3) = power(cfg.accvrw, 2) * eye(3, 3);
kf.Qc(4:6, 4:6) = power(cfg.gyrarw, 2) * eye(3, 3);
kf.Qc(7:9, 7:9) = 2 * power(cfg.gyrbiasstd, 2) / cfg.corrtime * eye(3, 3);
kf.Qc(10:12, 10:12) = 2 * power(cfg.accbiasstd, 2) / cfg.corrtime * eye(3, 3);
kf.Qc(13:15, 13:15) = 2 * power(cfg.gyrscalestd, 2) / cfg.corrtime * eye(3, 3);
kf.Qc(16:18, 16:18) = 2 * power(cfg.accscalestd, 2) / cfg.corrtime * eye(3, 3);
% P0
kf.P(1:3, 1:3) = diag(power(cfg.initposstd, 2));
kf.P(4:6, 4:6) = diag(power(cfg.initvelstd, 2));
kf.P(7:9, 7:9) = diag(power(cfg.initattstd, 2));
kf.P(10:12, 10:12) = diag(power(cfg.initgyrbiasstd, 2));
kf.P(13:15, 13:15) = diag(power(cfg.initaccbiasstd, 2));
kf.P(16:18, 16:18) = diag(power(cfg.initgyrscalestd, 2));
kf.P(19:21, 19:21) = diag(power(cfg.initaccscalestd, 2));
% navigation state initialization
navstate.time = cfg.starttime;
navstate.pos = cfg.initpos;
navstate.vel = cfg.initvel;
navstate.att = cfg.initatt;
navstate.cbn = euler2dcm(cfg.initatt);
navstate.qbn = euler2quat(cfg.initatt);
navstate.gyrbias = cfg.initgyrbias;
navstate.accbias = cfg.initaccbias;
navstate.gyrscale = cfg.initgyrscale;
navstate.accscale = cfg.initaccscale;
param = Param();
[navstate.Rm, navstate.Rn] = getRmRn(cfg.initpos(1), param);
navstate.gravity = getGravity(cfg.initpos);
end