Hostname: page-component-745bb68f8f-lrblm Total loading time: 0 Render date: 2025-01-21T01:37:28.474Z Has data issue: false hasContentIssue false

A novel online time calibration framework via double-stage EKF for visual-inertial odometry

Published online by Cambridge University Press:  28 October 2024

Shuaiyong Li*
Affiliation:
School of Automation, Chongqing University of Posts and Telecommunications, Chongqing, China
Jiawei Nie
Affiliation:
School of Automation, Chongqing University of Posts and Telecommunications, Chongqing, China
Chengchun Guo
Affiliation:
School of Automation, Chongqing University of Posts and Telecommunications, Chongqing, China
Yang Yang
Affiliation:
School of Automation, Chongqing University of Posts and Telecommunications, Chongqing, China
Lin Mei
Affiliation:
Chongqing Special Equipment Inspection and Research Institute, Chongqing, China
*
Corresponding author: Shuaiyong Li; Email: [email protected]
Rights & Permissions [Opens in a new window]

Abstract

There is an unavoidable time offset between the camera stream and the inertial measurement unit (IMU) data due to the sensor triggering and transmission delays, which will seriously affect the accuracy of visual-inertial odometry (VIO). A novel online time calibration framework via double-stage EKF for VIO is proposed in this paper. First, the first-stage complementary Kalman filter is constructed by adapting the complementary characteristics between the accelerometer and the gyroscope in the IMU, where the rotation result predicted by the gyroscope is corrected through the measurement of the accelerometer so that the IMU can output a more accurate initial pose. Second, the unknown time offset is added to the state vector of the VIO system. The estimated pose of IMU is used as the prediction information, and the reprojection error of multiple cameras on the same feature point is used as the constraint information. During the operation of the VIO system, the time offset is continuously calculated and superimposed on the IMU timestamp to obtain the data synchronized by the IMU and the camera. The Schur complement model is used to marginalize the camera state that carries less information in the system state, avoiding the loss of prior information between images, and improving the accuracy of camera pose estimation. Finally, the effectiveness of proposed algorithm is verified using the EuRoC dataset and the real experimental data.

Type
Research Article
Copyright
© The Author(s), 2024. Published by Cambridge University Press

1. Introduction

The fusion of visual and inertial measurement data has attracted extensive attention due to its small size, low power consumption, and simple mechanical structure [Reference Yang and Shen1Reference Martinelli6], which has been widely used in mobile robots [Reference Jung, Lee and Myung7Reference Liu, Sun, Pu and Yan8], virtual reality, augmented reality [Reference Muñoz-Salinas, Sarmadi, Cazzato and Medina-Carnicer9], and other fields. Existing visual-inertial odometry (VIO) algorithms can be divided into nonlinear optimization frameworks and filter frameworks according to different back-end optimization methods. The nonlinear optimization method obtains the best state estimation by minimizing the residual error generated by the camera and the inertial measurement unit (IMU) measurement, which can achieve higher pose estimation accuracy. However, its iterative optimization processing consumes many computing resources [Reference Qin, Li and Shen10Reference Ling, Bao, Jie, Zhu, Li, Tang, Liu, Liu and Zhang13]. The algorithm based on the filter frameworks has no iterative optimization processing and consumes fewer computing resources than the nonlinear optimization algorithms [Reference Zhang, Dong, Wang and Sun14Reference Li and Mourikis19], but its pose estimation accuracy is equivalent to the algorithm based on nonlinear optimization. The operating mechanism of the VIO system is the complementary nature of image data and IMU data [Reference Sabatelli, Galgani, Fanucci and Rocchi20], which means the IMU measurement can make up for short-term camera tracking failure errors, and the camera constraints can also correct the inaccurate attitude state predicted by IMU. Only by knowing the precise sampling times of camera and IMU can their data be accurately fused. However, the timestamps of the camera and the IMU are affected by triggering and transmission delays, resulting in unknown time offsets between the camera and the IMU [Reference Qin and Shen21], which will affect the accuracy of the VIO. Therefore, it is of great significance to study the online time calibration between the camera and the IMU to improve the accuracy of VIO pose estimation.

In view of the discrepancy of VIO pose estimation caused by time asynchronism during the fusion of camera and IMU, many different time calibration methods have been proposed. Zhang et al. [Reference Zhang, Li and Zhu22] used a delayed sensor to measure the time offset. Then based on the assumption that the time offset is completely known, a visual-assisted inertial navigation method was proposed for VIO pose estimation. Choi et al. [Reference Choi, Choi, Park and Chung23] proposed an improved algorithm to estimate the VIO pose based on the assumption that the time offset is approximately known. However, these algorithms are all based on the assumption that the time offset is known and do not attempt to estimate it. In actual engineering, it is difficult to know the time offset in advance. Furgale et al. [Reference Furgale, Rehder and Siegwart24] proposed a spatiotemporal calibration algorithm, Kalibr, which jointly estimates the time offset and spatial transformation between the camera and the IMU within the maximum likelihood estimation theory framework. Kelly et al. [Reference Kelly and Sukhatme25] first calculated the rotation estimates of the camera and the IMU separately and registered them for time alignment by a variant of the iterative closest point method in the rotation space. However, this method only used the rotation measurement and not all available measurements. The positioning accuracy of the VIO system will decrease. Both of the above two algorithms need to use a calibration board to implement, and they focus on offline calculations, which cannot solve the problem of online time calibration. Qing et al. [Reference Qin and Shen21] proposed an online temporal calibration VIO algorithm based on a projection model, which models and compensates for the considered temporal offset based on the assumption of uniform motion of feature points between adjacent image frames. Liu et al. [Reference Liu and Meng26] proposed an online time calibration algorithm for VIO based on an improved projection model, which improved the assumption of uniform motion of feature points. However, this kind of algorithm based on the projection model has high requirements for extracting and distributing front-end feature points. In practice, due to the illumination, it is difficult to achieve the desired effect. Li et al. [Reference Li and Mourikis19] proposed an online time calibration method based on Extended Kalman Filter (EKF), which does not require high quality of the front-end feature points, is less affected by factors such as illumination and has good computational efficiency. Guo et al. [Reference Guo, Kottas, DuToit, Ahmed, Li and Roumeliotis27] adopted the same algorithm and introduced a ratio variable to account for the pose displacement caused by time offset. However, these algorithms do not consider the large noise in the gyroscope measurement, which makes the deviation between the IMU-predicted pose and the real pose, reducing the pose estimation accuracy of this algorithm.

To solve the problem of significant errors in VIO pose estimation caused by the time offset during the fusion of camera and IMU, this paper proposes a robust VIO method based on double-stage EKF online time calibration to improve the accuracy of mobile robot pose estimation. The algorithm in this paper consists of a complementary Kalman filter and a multistate constrained Kalman filter (MSCKF). The complementary Kalman filter takes accelerometer measurements as observation vectors, corrects for gyroscope bias, and finally outputs a more accurate initial pose for MSCKF. Then, the unknown time offset is added to the state vector of MSCKF and calculates the feature points reprojection error, which is used to update the time offset, IMU state, and camera state. Finally, the Schur complement model is used to marginalize the old camera state, keep the calculation scale small, preserve prior constraint information, and improve VIO accuracy further.

The main contributions of this article are as follows:

1. A novel double-stage EKF VIO is proposed. When the error of visual information is large or even invalid, the complementary Kalman filter corrects the gyroscope deviation, calculates the accurate IMU initial attitude estimation value, and the VIO system obtains more accurate attitude estimation.

2. The time offset is added to the state vector of the VIO system, and the time offset is calibrated online with the constraint of the feature point reprojection error, improving the accuracy of the camera and IMU fusion system.

The rest of this paper is organized as follows. Section II describes the related issues, Section III introduces the overall framework of the proposed time alignment algorithm. Sections IV and V detail the double-stage Kalman filter of the proposed algorithm, Section VI presents the experimental results of EuRoC dataset and real mobile robot localization, and Section VII is the conclusion of this paper. In addition, some main notations used in this article are given in Table I.

Table I. Nomenclature.

2. Problem formulation

The VIO system consists of a camera and IMU, and each sensor provides measurement data at a constant frequency. In practice, the timestamps of individual sensors are often affected by triggering and transmission delays, resulting in unknown time offsets $t_{d}$ between different sensors. Figure 1 shows the process of time offsets generated by sensor delays. Among them, the IMU data wait for $t_{b}$ , and the camera data wait for $t_{a}$ to be received. $t_{a}$ is not equal to $t_{b}$ , and both of them are unknown quantities. The time offset between different sensors is defined as $t_{d}=t_{a}-t_{b}$ , and the positive or negative of $t_{d}$ is determined by the relative size of $t_{a}$ and $t_{b}$ . The IMU time stamp is used as the reference time in this paper. As shown in Figure 1, $t_{d}$ is a negative value.

Figure 1. Illustration of time offset due to delays of different sensors. $t_{a}$ represents the delay of camera, and $t_{b}$ represents the delay of IMU. $t_{d}$ is the time offset between camera and IMU.

Due to the negative effect of $t_{d}$ , the IMU preintegration results between each image frame are inconsistent with the actual pose transformation data, and the system will generate wrong state estimations. At the same time, the attitude information in the IMU preintegration is provided by the gyroscope measurement. However, the gyroscope measurement contains significant noise, which will make the IMU preintegration result deviate from the actual value. Therefore, in implementing the VIO system, it is essential to fully consider the measurement noise of the gyroscope and the time offset between the camera and the IMU.

3. System overview

The proposed VIO system is divided into two parts: the first part is the front-end feature point matching and tracking, and the second part is the online time calibration framework. The second part mainly includes two filters, the first-stage complementary Kalman filter and the second-stage MSCKF. The overall system flow is shown in Figure 2.

Figure 2. The flow chart of the VIO system: front end, complementary filter, and multi-state constrained Kalman filter as back end.

In the first part, the feature points are extracted and tracked using the Lucas–Kanade optical flow algorithm from the input image, and the position of the feature points is predicted based on the IMU preintegration results [Reference Baker and Matthews28]. When the number of feature points is less than the set threshold, new feature points are extracted outside the area where the matched feature points reside to ensure that the number of feature points meets the threshold requirements [Reference Rosten and Drummond29Reference Forster, Carlone, Dellaert and Scaranmuzza31]. To improve the system’s robustness, we evenly divide the image to ensure that each sub-region can extract a certain number of feature points.

The second part mainly consists of two Kalman filters. In the first-stage complementary filter, we mainly utilize the complementary characteristics of the accelerometer and gyroscope of IMU. First, the rotation information is estimated by the gyroscope as the state vector and the measurement value of the accelerometer as the observation vector. Second, the error ${\textbf{r}}$ between the acceleration measurement and the gravity is used to update the rotation information. Finally, the updated rotation information is output to the second-stage MSCKF. In the second-stage of MSCKF, the main task is to solve the unknown time offset. We add the time offset and the latest IMU-predicted camera state to the state vector of the VIO system, which is updated by the reprojection errors of the same feature points from multiple camera frames as residuals. The Schur complement model is used to marginalize the old camera states, which can not only keep the fixed size of the sliding window and improve the computational efficiency but also can preserve the prior information in the marginalized image frame and improve the estimation accuracy of the camera pose.

4. Complementary Kalman filter

Define the IMU pose ${\textbf{X}}_{pose}$ as the state vector of the complementary Kalman filter. The details are as follows:

(1) \begin{equation} {\textbf{X}}_{pose}=\left[\begin{array}{l@{\quad}l} {}^{I}\!\!{}_{G}{{\textbf{q}}}{_{}^{T}} & {\textbf{b}}_{g}^{T} \end{array}\right]^{T} \end{equation}

where the ${}^{I}\!\!{}_{G}{{\textbf{q}}}{}=\left[\begin{array}{l@{\quad}l@{\quad}l@{\quad}l} q_{x} & q_{y} & q_{z} & q_{w} \end{array}\right]^{T}$ is the unit quaternion that describes the rotation from the global frame to the IMU frame. ${\textbf{b}}_{g}$ represents the bias of the gyroscope, which is modelled as random walk processes driven by the white Gaussian noise ${\textbf{n}}_{{{{{\unicode{x03C9}}}}} g}$ .

4.1. Process model

The state equation in continuous time form is as follows:

(2) \begin{equation} {}^{I}\!\!{}_{G}{\dot{{\textbf{q}}}}{}=\frac{1}{2}\boldsymbol{\Omega }\left({\unicode{x1D6DA}}\right){}^{I}\!\!{}_{G}{{\textbf{q}}}{} \end{equation}
(3) \begin{equation} \dot{{\textbf{b}}}_{g}={\textbf{n}}_{{{{{\unicode{x03C9}}}}} g} \end{equation}

where ${\unicode{x1D6DA}}={\unicode{x1D6DA}}_{m}-{\textbf{b}}_{g}-{\textbf{n}}_{g}$ is the true value of the angular velocity of the IMU, ${\textbf{n}}_{g}$ is the Gaussian noise of the gyroscope. ${\unicode{x1D6DA}}_{m}=\left[\begin{array}{l@{\quad}l@{\quad}l} {{{{\unicode{x03C9}}}}} _{x} & {{{{\unicode{x03C9}}}}} _{y} & {{{{\unicode{x03C9}}}}} _{z} \end{array}\right]^{T}$ represents the angular velocity measured by the gyroscope. $\boldsymbol{\Omega }({\unicode{x1D6DA}})=\left[\begin{array}{l@{\quad}l} -\lfloor {\unicode{x1D6DA}}\times \rfloor & {\unicode{x1D6DA}}\\[5pt] -{\unicode{x1D6DA}}^{T} & 0 \end{array}\right]$ with $\lfloor {\unicode{x1D6DA}}\times \rfloor$ denotes the skew-symmetric matrix of ${\unicode{x1D6DA}}$ .

The approximate state equation can be obtained as follows by applying the expectation operator in the above formula

(4) \begin{equation} {}^{I}\!\!{}_{G}{\dot{\hat{{\textbf{q}}}}}{}=\frac{1}{2}\boldsymbol{\Omega }\left(\hat{{\unicode{x1D6DA}}}\right){}^{I}\!\!{}_{G}{\hat{{\textbf{q}}}}{} \end{equation}
(5) \begin{equation} \dot{\hat{{\textbf{b}}}}_{g}=\textbf{0}_{3\times 1} \end{equation}

where $\hat{{\unicode{x1D6DA}}}={\unicode{x1D6DA}}_{m}-\hat{{\textbf{b}}}_{g}$ represents the estimated results of actual angular velocity information of the gyroscope. To propagate state uncertainty, the state transition matrix is calculated as follows:

(6) \begin{equation} \boldsymbol{\Phi }_{{k_{q}}}=\exp \left(\int _{t_{k}}^{t_{k+1}}\frac{1}{2}\boldsymbol{\Omega }\left(\hat{{\unicode{x1D6DA}}}\left(\tau \right)\right)d\tau \right)_{4\times 4}\approx \left({\textbf{I}}+\frac{{\Delta} t}{2}\boldsymbol{\Omega }\right) \end{equation}
(7) \begin{equation} \boldsymbol{\Phi }_{{k_{b}}}=\textbf{0}_{3\times 3} \end{equation}

where ${{\Delta}} t$ is the time interval between two IMU data frames. From the above formula, the discrete state transition equation of the system can be obtained as

(8) \begin{equation} {\textbf{X}}_{pose}\!\left(k+1\right)=\left[\begin{array}{l} {}^{I}\!\!{}_{G}{{\textbf{q}}}{}\!\left(k+1\right)\\[5pt] {\textbf{b}}_{g}\!\left(k+1\right) \end{array}\right]=\left[\begin{array}{l} \boldsymbol{\Phi }_{{k_{q}}}\quad {}^{I}\!\!{}_{G}{{\textbf{q}}}{}\left(k\right)\\[5pt] \boldsymbol{\Phi }_{{k_{b}}}\quad {\textbf{b}}_{g}\!\left(k\right) \end{array}\right]+{\textbf{y}}\!\left(k\right) \end{equation}
(9) \begin{equation} {\textbf{X}}_{pose}\left(k+1\right)\approx {\textbf{H}}_{p}{\textbf{X}}_{pose}\left(k\right)+{\textbf{y}}\left(k\right) \end{equation}

where ${\textbf{H}}_{p}$ represents the state transition matrix of the gyroscope state. The specific values are shown in ref. [Reference Sun, Mohta, Pfrommer, Watterson, Liu, Mulgaonkar, Taylor and Kumar18]. ${\textbf{y}}(k)$ obeys a Gaussian distribution with a mean of 0 and a covariance matrix ${\textbf{Q}}_{k}$ .

(10) \begin{equation} {\textbf{y}}\left(k\right)\sim N\left(0;\;{\textbf{Q}}_{k}\right),{\textbf{Q}}_{k}=\left[\begin{array}{l@{\quad}l} \sigma _{q}^{2}{\textbf{I}}_{4} & \textbf{0}_{4\times 3}\\[5pt] \textbf{0}_{3\times 4} & \sigma _{bg}^{2}{\textbf{I}}_{3} \end{array}\right] \end{equation}

where $\sigma _{q}$ and $\sigma _{bg}$ are constants.

Finally, the propagated covariance of the gyroscope state can be expressed as follows:

(11) \begin{equation} {\textbf{P}}_{pos{e_{k+1|k}}}={\textbf{H}}_{p}{\textbf{P}}_{pos{e_{k|k}}}{\textbf{H}}_{p}^{T}+{\textbf{Q}}_{k} \end{equation}

4.2. Observation model

The actual value of the accelerometer is

(12) \begin{equation} {\boldsymbol{a}}={\boldsymbol{a}}_{{\boldsymbol{m}}}-{\textbf{b}}_{a} \end{equation}

where ${\textbf{{a}}}_{{\textbf{{m}}}}=\left[\begin{array}{l@{\quad}l@{\quad}l} a_{{\textbf{{x}}}} & a_{{\textbf{{y}}}} & a_{{\textbf{{z}}}} \end{array}\right]^{{\textbf{{T}}}}$ represents the acceleration measured by accelerometer, ${\textbf{b}}_{a}$ represents the bias of the accelerometer. According to the attitude information predicted by the gyroscope, we can obtain the $\hat{{\textbf{{a}}}}$

(13) \begin{equation} \hat{{\textbf{{a}}}}={}^{I}\!\!{}_{G}{{\textbf{R}}}{}\left[\begin{array}{c} 0\\[5pt] 0\\[5pt] -{\textbf{g}} \end{array}\right]=-{\textbf{g}}\left[\begin{array}{c} 2q_{{\textbf{{x}}}}q_{{\textbf{{z}}}}+2q_{{\textbf{{y}}}}q_{{\textbf{{w}}}}\\[5pt] 2q_{{\textbf{{y}}}}q_{{\textbf{{z}}}}-2q_{{\textbf{{x}}}}q_{{\textbf{{w}}}}\\[5pt] q_{{\textbf{{w}}}}^{2}-q_{{\textbf{{x}}}}^{2}-q_{{\textbf{{y}}}}^{2}+q_{{\textbf{{z}}}}^{2} \end{array}\right] \end{equation}

where ${\textbf{g}}$ is the gravity vector. The residual of the accelerometer can be expressed as

(14) \begin{equation} {\textbf{r}}={\textbf{{a}}}-\hat{{\textbf{{a}}}}={\textbf{H}}_{{\boldsymbol{g}}}{\textbf{X}}_{{\boldsymbol{pose}}}+{\textbf{{v}}}\!\left({\boldsymbol{k}}\right) \end{equation}

where ${\textbf{H}}_{g}$ represents the Jacobian matrix of the acceleration measurement with respect to the state of the gyroscope, and the specific values are shown in ref. [Reference Sun, Mohta, Pfrommer, Watterson, Liu, Mulgaonkar, Taylor and Kumar18]. ${\textbf{v}}(k)$ obeys a Gaussian distribution with mean 0 and covariance ${\textbf{R}}_{k}$ .

(15) \begin{equation} {\textbf{v}}\left(k\right)\sim N\left(0;\;{\textbf{R}}_{k}\right)\!,{\textbf{R}}_{k}=\sigma _{a}^{2}{\textbf{I}}_{3} \end{equation}

where $\sigma _{a}$ is a constant. Finally, update ${\textbf{X}}_{pose}$ by the residual

(16) \begin{equation} \left\{\begin{array}{l} {\textbf{X}}_{pos{e_{k+1|k+1}}}={\textbf{X}}_{pos{e_{k+1|k}}}+\textbf{Kr}\\[5pt] \textbf{K}={\textbf{P}}_{pos{e_{k+1|k}}}{\textbf{H}}_{g}^{T}\left({\textbf{H}}_{g}{\textbf{P}}_{pos{e_{k+1|k}}}{\textbf{H}}_{g}^{T}+{\textbf{R}}_{k}\right)^{-1}\\[5pt] {\textbf{P}}_{pos{e_{k+1|k+1}}}=\left({\textbf{I}}-\textbf{K}{\textbf{H}}_{g}\right){\textbf{P}}_{pos{e_{k+1|k}}} \end{array}\right. \end{equation}

where $\textbf{K}$ is the Kalman gain, ${\textbf{X}}_{pos{e_{k+1|k+1}}}$ and ${\textbf{P}}_{pos{e_{k+1|k+1}}}$ are the state vectors and covariance matrices estimated at time $k+1$ , respectively. By fusing the measured values of the accelerometer, we can calculate the precise IMU pose ${}^{I}\!\!{}_{G}{{\textbf{q}}}{}$ and gyroscope bias ${\textbf{b}}_{g}$ for state vector of the IMU in the second-stage filter.

5. The principle of MSCKF

The state vector of the IMU in the second-stage filter MSCKF is as follows:

(17) \begin{equation} {\textbf{X}}_{I}=\left[\begin{array}{l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l} {}^{I}\!\!{}_{G}{{\textbf{q}}}{_{}^{T}} & {\textbf{b}}_{g}^{T} & {}^{G}{{\textbf{v}}}{_{I}^{T}} & {\textbf{b}}_{a}^{T} & {}^{G}{{\textbf{p}}}{_{I}^{T}} & {}_{I}^{C}{{\textbf{q}}}{_{}^{T}} & {}^{I}{{\textbf{p}}}{_{C}^{T}} & t_{d} \end{array}\right]^{T} \end{equation}

where the unit quaternion ${}^{I}\!\!{}_{G}{{\textbf{q}}}{}$ and the vector ${\textbf{b}}_{g}$ are the optimal estimates from the first-stage complementary Kalman filter. The vectors ${}^{G}{{\textbf{v}}}{_{I}^{}}$ and ${}^{G}{{\textbf{p}}}{_{I}^{}}$ represent the velocity and position of the IMU frame, respectively. The vector ${\textbf{b}}_{a}$ represents the linear acceleration deviation of the accelerometer. ${}^{I}\!\!{}_{C}{{\textbf{q}}}{}$ and ${}^{I}{{\textbf{p}}}{_{C}^{}}$ describe the relative transformation between the camera and the IMU.

Use the standard additive error to define the position, velocity, bias, and time offsets (e.g. ${}^{G}{\tilde{{\textbf{p}}}}{_{I}^{}}={}^{G}{{\textbf{p}}}{_{I}^{}}-{}^{G}{\hat{{\textbf{p}}}}{_{I}^{}}$ ). Whereas the minimal 3D orientation error representation is used, that is,

(18) \begin{equation} {\textbf{q}}=\delta {\textbf{q}}\otimes \hat{{\textbf{q}}},\delta {\textbf{q}}\approx \left[\begin{array}{l@{\quad}l} \dfrac{1}{2}\tilde{\boldsymbol{\theta }}^{T} & 1 \end{array}\right]^{T} \end{equation}

where $\tilde{\boldsymbol{\theta }}\in \mathrm{\mathbb{R}}^{3}$ represents a small angle rotation. According to the above error definition, the IMU error state vector $\tilde{{\textbf{X}}}_{I}$ is given:

(19) \begin{equation} \tilde{{\textbf{X}}}_{I}=\left[\begin{array}{l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l@{\quad}l} {}^{I}\!\!{}_{G}{\tilde{\boldsymbol{\theta }}}{_{}^{T}} & \tilde{{\textbf{b}}}_{g}^{T} & {}^{G}{\tilde{{\textbf{v}}}}{_{I}^{T}} & \tilde{{\textbf{b}}}_{a}^{T} & {}^{G}{\tilde{{\textbf{p}}}}{_{I}^{T}} & {}^{I}\!\!{}_{C}{\tilde{\boldsymbol{\theta }}}{_{}^{T}} & {}^{I}{\tilde{{\textbf{p}}}}{_{C}^{T}} & \tilde{t}_{d} \end{array}\right]^{T} \end{equation}

The IMU state and N camera states are both added to the VIO system state vector, and the entire error of state vector in VIO system is

(20) \begin{equation} \tilde{{\textbf{X}}}=\left[\begin{array}{l@{\quad}l@{\quad}l@{\quad}l} \tilde{{\textbf{X}}}_{I}^{T} & \tilde{{\textbf{X}}}_{C_{1}}^{T} & \cdots & \tilde{{\textbf{X}}}_{C_{N}}^{T} \end{array}\right]^{T} \end{equation}

The error vector for each camera state is

(21) \begin{equation} \tilde{{\textbf{X}}}_{{C_{i}}}=\left[\begin{array}{l@{\quad}l} {}^{Ci}\!\!{}_{G}{\tilde{\boldsymbol{\theta }}}{_{}^{T}} & {}^{G}{\tilde{{\textbf{p}}}}{_{Ci}^{T}} \end{array}\right]^{T} \end{equation}

5.1. Process model

The state equation of the IMU in continuous time form is

\begin{equation*} \begin{array}{l@{\quad}l} {}^{I}\!\!{}_{G}{\dot{{\textbf{q}}}}{}=\dfrac{1}{2}\boldsymbol{\Omega }\!\left({\unicode{x1D6DA}}_{m}-{\textbf{b}}_{g}-{\textbf{n}}_{g}\right){}^{I}\!\!{}_{G}{{\textbf{q}}}{},\, & \dot{{\textbf{b}}}_{g}={\textbf{n}}_{{{{{\unicode{x03C9}}}}} g} \end{array} \end{equation*}
\begin{equation*} {}^{G}{\dot{{\textbf{v}}}}{}={\textbf{C}}\!\left({}^{I}\!\!{}_{G}{{\textbf{q}}}{}\right)^{{\textbf{{T}}}}\left({\textbf{{a}}}_{{\textbf{{m}}}}-{\textbf{b}}_{a}-{\textbf{n}}_{a}\right)+{}^{G}{{\textbf{g}}}{} \end{equation*}
\begin{equation*} \begin{array}{l@{\quad}l} \dot{{\textbf{b}}}_{a}={\textbf{n}}_{{{{{\unicode{x03C9}}}}} a},\, & {}^{G}{\dot{{\textbf{p}}}}{_{I}^{}}={}^{G}{{\textbf{v}}}{} \end{array}_{I} \end{equation*}
(22) \begin{equation} \begin{array}{l@{\quad}l} {}_{C}^{I}\dot{{\textbf{q}}}=0,\, & \begin{array}{l@{\quad}l} {}^{I}{\dot{{\textbf{p}}}}{_{C}^{}}=0,\, & \dot{t}_{d} \end{array}=0 \end{array} \end{equation}

where $C(\!\cdot\!)$ is the function that converts the quaternion into the rotation matrix. We can get the propagation model of the IMU state through the linear continuous kinematics model of the IMU error state, and it is shown as follows:

(23) \begin{equation} \dot{\tilde{{\textbf{X}}}}_{I}={\textbf{F}}\tilde{{\textbf{X}}}_{I}+{\textbf{G}}{\textbf{n}}_{I} \end{equation}

where ${\textbf{n}}_{I}=\left(\begin{array}{l@{\quad}l@{\quad}l@{\quad}l} {\textbf{n}}_{g}^{T} & {\textbf{n}}_{{{{{\unicode{x03C9}}}}} g}^{T} & {\textbf{n}}_{a}^{T} & {\textbf{n}}_{{{{{\unicode{x03C9}}}}} a}^{T} \end{array}\right)^{T}$ . The vectors ${\textbf{n}}_{g}$ and ${\textbf{n}}_{a}$ are the Gaussian noise of the gyroscope and accelerometer measurements. ${\textbf{n}}_{{{{{\unicode{x03C9}}}}} g}$ and ${\textbf{n}}_{{{{{\unicode{x03C9}}}}} a}$ are the random walk rates of the gyroscope and accelerometer measurement bias. The details of ${\textbf{F}}$ and ${\textbf{G}}$ are shown in ref. [Reference Sun, Mohta, Pfrommer, Watterson, Liu, Mulgaonkar, Taylor and Kumar18]. A fourth-order Runge–Kutta numerical integration is used to estimate the state of the IMU The discrete-time state transition matrix $\boldsymbol{\Phi }_{k}$ and the discrete-time noise covariance matrix ${\textbf{Q}}_{k}$ are shown as follows:

(24) \begin{equation} \boldsymbol{\Phi }_{k}=\exp \left(\int _{t_{k}}^{t_{k+1}}{\textbf{F}}d\tau \right) \end{equation}
(25) \begin{equation} {\textbf{Q}}_{k}=\int _{t_{k}}^{t_{k+1}}\boldsymbol{\Phi }_{k}{\textbf{G}}{\textbf{n}}_{I}{\textbf{G}}^{T}\boldsymbol{\Phi }_{k}^{T}d\tau \end{equation}

The covariance prediction matrix of the VIO system at time $k$ can be described as

(26) \begin{equation} {\textbf{P}}_{k+1|k}=\left[\begin{array}{c@{\quad}c} \boldsymbol{\Phi }_{k}{\textbf{P}}_{I{I_{k|k}}}\boldsymbol{\Phi }_{k}^{T}+{\textbf{Q}}_{k} & \boldsymbol{\Phi }_{k}{\textbf{P}}_{I{C_{k|k}}}\\[5pt] {\textbf{P}}_{IC_{k|k}}^{T}\boldsymbol{\Phi }_{k}^{T} & {\textbf{P}}_{C{C_{k|k}}} \end{array}\right] \end{equation}

The pose of the newly added camera state ${\textbf{x}}_{{C_{i}}}$ in the state vector can be calculated according to the IMU pre-integration result and the relative position between the camera and the IMU.

(27) \begin{equation} {}_{G}^{C_{i}}{{\textbf{q}}}{}={}_{I}^{C}{{\textbf{q}}}{}\otimes {}^{I}\!\!{}_{G}{{\textbf{q}}}{},{}^{G}{{\textbf{p}}}{_{Ci}^{}}={}^{G}{{\textbf{p}}}{_{I}^{}}+C\left({}^{I}\!\!{}_{G}{{\textbf{q}}}{}\right)^{T}{}^{I}{\hat{{\textbf{p}}}}{_{C}^{}} \end{equation}

The augmented covariance matrix is as follows:

(28) \begin{equation} {\textbf{P}}_{k|k}=\left[\begin{array}{c} {\textbf{I}}_{22+6N}\\[5pt] \textbf{J} \end{array}\right]{\textbf{P}}_{k|k}\left[\begin{array}{c} {\textbf{I}}_{22+6N}\\[5pt] \textbf{J} \end{array}\right]^{T} \end{equation}

where $\textbf{J}$ is shown in ref. [Reference Sun, Mohta, Pfrommer, Watterson, Liu, Mulgaonkar, Taylor and Kumar18].

5.2. Measurement model

The image data are used to correct the state of IMU. At time $t$ , there is a time offset $t_{d}$ between the camera and IMU. Assuming that the left and right cameras can track the same feature point $f_{i}$ at the same time, where the pose of the left camera is $\left[\begin{array}{l@{\quad}l} {}_{G}^{C1}{{\textbf{q}}}{}(t+t_{d}) & {}^{G}{{\textbf{p}}}{_{C1}^{}}(t+t_{d}) \end{array}\right]$ and the pose of the right camera is $\left[\begin{array}{l@{\quad}l} {}_{G}^{C2}{{\textbf{q}}}{}(t+t_{d}) & {}^{G}{{\textbf{p}}}{_{C2}^{}}(t+t_{d}) \end{array}\right]$ . The observation of the stereo camera is

(29) \begin{equation} \textbf{z}_{i}\!\left(t\right)=\left[\begin{array}{l} u_{1}^{i}\!\left(t\right)\\[5pt] v_{1}^{i}\!\left(t\right)\\[5pt] u_{2}^{i}\!\left(t\right)\\[5pt] v_{2}^{i}\!\left(t\right) \end{array}\right]=\left[\begin{array}{c@{\quad}c} \dfrac{1}{{}^{C1}{z}{_{i}^{}}\!\left(t+t_{d}\right)} & \textbf{0}_{2\times 2}\\[5pt] \textbf{0}_{2\times 2} & \dfrac{1}{{}^{C2}{z}{_{i}^{}}\!\left(t+t_{d}\right)} \end{array}\right]\times \left[\begin{array}{l} {}^{C1}{x}{_{i}^{}}\!\left(t+t_{d}\right)\\[5pt] {}^{C1}{y}{_{i}^{}}\!\left(t+t_{d}\right)\\[5pt] {}^{C2}{x}{_{i}^{}}\!\left(t+t_{d}\right)\\[5pt] {}^{C2}{y}{_{i}^{}}\!\left(t+t_{d}\right) \end{array}\right] \end{equation}

where $\left[\begin{array}{l@{\quad}l@{\quad}l} {}^{Ck}{x}{_{i}^{}}(t+t_{d}) & {}^{Ck}{y}{_{i}^{}}(t+t_{d}) & {}^{Ck}{z}{_{i}^{}}(t+t_{d}) \end{array}\right]^{T},k=1,2$ represents the position of the feature point in the left and right images and is shown as follows:

(30) \begin{equation} {}^{C_{k}}{{\textbf{p}}}{_{fi}^{}}\left(t+t_{d}\right)=\left[\begin{array}{l} {}^{Ck}{x}{_{i}^{}}\left(t+t_{d}\right)\\[5pt] {}^{Ck}{y}{_{i}^{}}\left(t+t_{d}\right)\\[5pt] {}^{Ck}{z}{_{i}^{}}\left(t+t_{d}\right) \end{array}\right]=C\left({}_{G}^{Ck}{{\textbf{q}}}{}\left(t+t_{d}\right)\right)\left({}^{G}{{\textbf{p}}}{_{fi}^{}}-{}^{G}{{\textbf{p}}}{_{I}^{}}\left(t+t_{d}\right)\right)+{}^{G}{{\textbf{p}}}{_{I}^{}} \end{equation}

where ${}^{G}{{\textbf{p}}}{_{fi}^{}}$ is the 3D point position of the feature point $f_{i}$ in the global frame, which can be calculated through the least square method of multiple feature points. After obtaining the ${}^{G}{{\textbf{p}}}{_{fi}^{}}$ , we can calculate the reprojection error of the feature point observed in the current frame, and it is shown as follows:

(31) \begin{equation} {\textbf{r}}_{i,t}=\textbf{z}_{i}\!\left(t\right)-\hat{\textbf{z}}_{{f_{i}}}\left(t+t_{d}\right)\approx {\textbf{H}}_{X,t}^{i}\tilde{{\textbf{X}}}\left(t+t_{d}\right)+{\textbf{H}}_{{f_{i}},t}{}^{G}{\tilde{{\textbf{p}}}}{_{fi}^{}}\left(t+t_{d}\right)+{\textbf{n}}_{{f_{i}}} \end{equation}

where ${\textbf{n}}_{{f_{i}}}$ is the measurement noise. The measurement Jacobian matrices ${\textbf{H}}_{C}^{i}$ and ${\textbf{H}}_{{f_{i}}}$ are shown in ref. [Reference Sun, Mohta, Pfrommer, Watterson, Liu, Mulgaonkar, Taylor and Kumar18].

The above is the observation residual of a feature point in a camera frame, and the residual block obtained by superimposing multiple observations of the feature point $f_{i}$ is shown as follows:

(32) \begin{equation} {\textbf{r}}_{i}={\textbf{H}}_{X}^{i}\tilde{{\textbf{X}}}+{\textbf{H}}_{{f_{i}}}{}^{G}{\tilde{{\textbf{p}}}}{_{fi}^{}}+{\textbf{n}}_{{f_{i}}} \end{equation}

Since ${}^{G}{\tilde{{\textbf{p}}}}{_{fi}^{}}$ is computed using the camera pose, its uncertainty is related to the camera pose in that state. To ensure that the uncertainty of ${}^{G}{\tilde{{\textbf{p}}}}{_{fi}^{}}$ will not affect the residual, the residual in Eq, (36) ${\textbf{r}}_{i}$ is projected onto the left null space of ${\textbf{H}}_{{f_{i}}}$

(33) \begin{equation} {\textbf{r}}_{0}^{i}=\textbf{A}^{T}{\textbf{r}}_{i}\approx \textbf{A}^{T}{\textbf{H}}_{X}^{i}\tilde{{\textbf{X}}}+\textbf{A}^{T}{\textbf{n}}_{{f_{i}}}={\textbf{H}}_{X,0}^{i}\tilde{{\textbf{X}}}+{\textbf{n}}_{0}^{i} \end{equation}

$\textbf{A}$ represents a unitary matrix composed of column vectors of ${\textbf{H}}_{{f_{i}}}$ . The state of the IMU is updated through the gyroscope and accelerometer measurements. Then, the new camera state is estimated according to the IMU preintegration result and then added to the state vector of VIO system to calculate the augmented covariance matrix. Finally, the VIO system state is updated using the reprojection errors of the multi-constrained feature points.

(34) \begin{equation} \left\{\begin{array}{l} {\textbf{X}}_{k+1|k+1}={\textbf{X}}_{k+1|k}+\textbf{K}'{\textbf{r}}'\\[5pt] \textbf{K}'={\textbf{P}}_{k+1|k}{\textbf{H}}^{T}\left({\textbf{H}}{\textbf{P}}_{k+1|k}{\textbf{H}}^{T}+{\textbf{R}}'\right)^{-1}\\[5pt] {\textbf{P}}_{k+1|k+1}={\textbf{P}}_{k+1|k}-\textbf{K}'{\textbf{H}}{\textbf{P}}_{k+1|k} \end{array}\right. \end{equation}

where ${\textbf{r}}'$ is the reprojection error of all points in the current frame, composed of different ${\textbf{r}}_{0}^{i}$ . ${\textbf{H}}$ is the observation matrix, composed of different ${\textbf{H}}_{X,0}^{i}$ .

5.3. Schur complement marginalization

With the continuous operation of the VIO system, the number of newly added camera states grows, and the matrix’s dimension becomes larger, which increases the computational cost of camera pose estimation. To meet the real-time requirements, it is necessary for us to marginalize some camera states with just a small amount of information. If such a camera state is deleted directly, it will cause the prior information of some camera states to be lost. The Schur complement model is utilized to marginalize old camera states to reduce the computational cost and preserve the prior information of this kind of camera state.

Figure 3. The marginalization process. The change process of the covariance matrix when the marginalized state ${\textbf{C}}_{1}$ and added state ${\textbf{C}}_{7}$ .

Figure 3 shows the process of adding new states and deleting old states in the sliding window where ${\textbf{X}}_{I}$ is the IMU state, ${\textbf{C}}_{1}$ is the old camera state that needs to be deleted, and ${\textbf{C}}_{7}$ is the new camera state that needs to be added to the sliding window. First, the state of ${\textbf{C}}_{7}$ is added to the system state vector. At the same time, the cross-covariance part between ${\textbf{C}}_{7}$ and ${\textbf{C}}_{6}$ , and ${\textbf{X}}_{I}$ is added to the system covariance matrix. Then, the state ${\textbf{C}}_{1}$ needs to be deleted, but ${\textbf{C}}_{1}$ is connected to ${\textbf{C}}_{0}$ and ${\textbf{C}}_{2}$ . Deleting it directly will cause the loss of prior information, so the marginalization is performed through the Schur complement model.

(35) \begin{equation} {\textbf{P}}_{AA}^{new}={\textbf{P}}_{AA}-{\textbf{P}}_{AB}{\textbf{P}}_{BB}^{-1}{\textbf{P}}_{AB}^{T} \end{equation}

where ${\textbf{P}}_{BB}$ is the covariance matrix of state ${\textbf{C}}_{1}, {\textbf{P}}_{AA}$ is the covariance matrix of the state to be preserved, and ${\textbf{P}}_{AB}$ is the covariance matrix between state ${\textbf{C}}_{1}$ and the state to be preserved. In the process of marginalization, state ${\textbf{C}}_{1}$ is first moved to the top of the covariance matrix and then the covariance matrices ${\textbf{P}}_{AB}$ and ${\textbf{P}}_{AB}^{T}$ are obtained. Finally, a new covariance matrix named ${\textbf{P}}_{AA}^{new}$ was obtained through the Schur complement model, preserving prior information between ${\textbf{C}}_{1}$ and ${\textbf{C}}_{0}$ , and ${\textbf{C}}_{2}$ , and adding new constraints between ${\textbf{C}}_{0}$ and ${\textbf{C}}_{2}$ .

The algorithm flow of this paper is shown in Algorithm 1.

Algorithm 1 Overview system process

6. Experiments

In this section, the performance of the proposed online time calibration algorithm is verified by the following two groups of experiments. The first experiment is on the EuRoC dataset, with the original MSCKF [Reference Liu and Meng26], the algorithm C-MSCKF with complementary Kalman filter [Reference Cen, Jiang, Tan, Su and Xue32], optimization-based VINS- Mono without loop closure detection mode [Reference Li and Mourikis19] and OPEN-VINS algorithm [Reference Geneva, Eckenhoff, Lee, Yang and Huang5] based on Kalman filter for comparison. The root mean square error (RMSE) is used to analyze the performance of our proposed method. The second experiment is a real experiment. First, on a circle with a fixed radius of 2.5 m, experiments using the VINS-MONO and OPEN-VINS algorithms with online time calibration were performed to evaluate the performance of the algorithms by comparing the estimated trajectories with the real trajectories. Second, it is compared with the MSCKF algorithm in a closed indoor environment, and the performance improvement of the algorithm is detected by judging the loopback accuracy. All algorithms are run on a laptop configured with i5-8250U (quad-core 1.6 GHz) CPU and 8G RAM.

6.1. EuRoC data set

The EuRoC dataset is collected by an unmanned aerial vehicle containing stereo image pairs at 20 Hz and IMU measurements at 200 Hz. In the original dataset [Reference Burri, Nikolic, Gohl, Schneider, Rehder, Omari, Achtelik and Siegwart33], due to the high-precision cameras and IMUs, the image stream and the IMU data sequence are fully time-synchronized. In order to verify the performance of our proposed method in this article, the time stamp of the image stream is uniformly modified. The open-source toolbox provided in ref. [Reference Zhang and Scaramuzza34] is used to evaluate the VIO performance quantitatively. The RMSE of the absolute trajectory error is selected as the evaluation standard of the algorithm performance. All algorithms run 10 Monte Carlo experiments on the custom EuRoC dataset.

Figure 4. The estimation process of the time offset of the algorithm in (a) V1_01, (b) V2_01, (c) MH_04, and (d) MH_05 four sequences, the time offsets are 10 ms.

Figure 4 shows the time offset estimation results for the Proposed, OPEN-VINS, and VINS-MONO on four sequences (V1_01, V2_01, MH_04, and MH_05) with a time offset of 10 ms. From the results in Figure 4, it can be observed that our proposed method achieves the highest precision in time offset estimation. VINS-MONO relying on minimizing the reprojection error of feature points, depends on high-quality image features, leading to inaccurate estimation results. On the other hand, OPEN-VINS employs a Kalman filter framework to predict the time offset, but it fails to sufficiently consider the impact of imprecise gyroscope attitudes on system accuracy, resulting in inaccurate estimation as well. Calculate the average time offset estimated by each algorithm and compare it with the preset time offset to evaluate the time estimation performance of each algorithm. Combining the information from Figure 4 and Table 2, it is evident that our proposed method online time calibration accurately predicts the specified time offset with estimation errors within 0.5 ms. By incorporating the time offset into sensor timestamps and achieving synchronization between sensors through software implementation, the effectiveness of our propoed method has been demonstrated.

Figure 5 shows the trajectory estimation accuracy comparison of our proposed method, MSCKF, C-MSCKF, VINS-MONO, and OPEN-VINS on the EuRoC dataset with 20 ms time offset. The gray dotted line represents the groundtruth. Figure 5(a), (b), (c), and (d) are the XY plane projection diagrams of the trajectories of the five algorithms on the four sequences of the custom EuRoC dataset V1_01, V2_01, MH_04, and MH_05, respectively. Table 2 shows the time offset estimation results of our proposed method and the trajectory RMSE of the five algorithms in the four sequences V1_01, V2_01, MH_04, and MH_05, It can be seen from Table 2 and Figure 5 that our proposed method has higher algorithm accuracy. The possible reasons for the advantage of our proposed method over the other method are mainly manifested in two points: first, the inclusion of the first-stage complementary Kalman filter, which corrects the position estimation results of the gyroscope by using accelerometer measurements, enables the IMU to output a more accurate position and provides good position estimation results for the VIO system, which is a part that other methods fail to achieve. Second, the problem that the time offsets between different sensors lead to the time unsynchronization between the estimated and observed states of the Kalman filter is fully considered, and a one-dimensional time offset is added to the state vector of the VIO, which is continuously updated using the camera observation, so as to achieve the smallest error between the estimated state of the IMU and the observed state of the camera, thus improving the positioning accuracy of the system.

Figure 6 shows the average running time of the back end for the four algorithms. The running times of our proposed method, MSCKF, OPEN-VINS, and VINS-MONO algorithms are 8.72 ms, 7.73 ms, 18.14 ms, and 29.9 ms, respectively. It can be seen from the figure that the optimization-based algorithm VINS-MONO has the highest time complexity, more than three times that of our proposed method, mainly because VINS-MONO jointly optimizes all the state vectors that can be optimized. When new images arrive, the data size will grow, thus increasing the time complexity of the algorithm. The complexity of the OPEN-VINS algorithm based on EKF is also relatively high because it combines a variety of modules that can improve the accuracy of the algorithm, resulting in an increase in overall performance and complexity. Compared with the MSCKF algorithm, our proposed method has a first-order complementary Kalman filter structure, and the time offset is added to the VIO system state vector. Therefore, the problem size is slightly larger than the original MSCKF algorithm, and the running time is slightly higher than the MSCKF algorithm, but our proposed method is more accurate than MSCKF. The positioning accuracy of VIO is significantly higher than that of MSCKF algorithm.

Table II. Time offset calibration results on euRoC datasets.

Figure 5. The trajectories of MSCKF, C-MSCKF, VINS-MONO, OPEN-VINS, and proposed on EuRoC datasets V1_01, V2_01, MH_04, and MH_05 sequences with 20 ms time offset.

Figure 6. The average back-end processing time of the three algorithms on the EuRoC dataset.

6.2. Experimental verfication of real scenes

In real experiment, the camera is fixed on a mobile robot platform to make the robot move in a circular motion. Meanwhile, select the VICON motion capture system to record the robot’s 3D position as ground truth. The experimental environment is shown in Figure 7. The ZED2 Stereo camera is used in real experiment. This sensor contains two global shutter cameras with the field of vision of $120^{\circ}\times 110^{\circ}\times 70^{\circ}$ (diagonal, horizontal, and vertical, respectively) and a six-axis IMU. The camera frequency is set to be 20 Hz, the image resolution is set to be 1280 × 720, and the IMU frequency is 200 Hz.

Figure 7. Area where the real-world motion experiment took place. A VICON motion capture system is used to record the real 3D position as ground truth.

In Figure 8(a), the gray dotted line represents the ground truth, and the blue, green, and red lines represent VINS-MONO (no loop), OPEN-VINS, and our proposed method, respectively. Figure 8(b) shows the unstable temporal offset estimated by our proposed method during motion. It can be seen from Figure 8(a) that the trajectory accuracy of our proposed method is higher and closer to the ground truth. This shows that our proposed method uses the accelerometer to dynamically correct the gyroscope bias, which improves the initial attitude and trajectory accuracy of the VIO system. At the same time, this paper defines the time offset in different sensor fusion processes as an unknown variable and uses a MSCKF for dynamic estimation, which further improves the trajectory accuracy of the VIO system.

Figure 8. Trajectory comparisons of the real-world motion experiment. (a) Trajectories of ground truth, OPEN-VINS, VINS-MONO, and proposed algorithms. (b) Unstable time offset estimated by proposed.

In Figure 9, we compare the final trajectories of our proposed method and MSCKF in a closed environment. Figure 9(a) is the indoor experimental scene, Figure 9(b) is our proposed method and MSCKF trajectory, where the blue line belongs to the MSCKF algorithm, the red line belongs to our proposed method, and Figure 9(c) is the unstable time offset calculated by our proposed method. From Figure 9(b), it can be seen that due to the IMU rotation, there is a large deviation in the start and end points of the MSCKF algorithm trajectory estimation. Our proposed method corrects the rotation obtained by the gyroscope through the accelerometer. Fully consider the unstable time offset in the fusion process, so that the IMU rotation data are more stable, the image constraints are more accurate, and the starting point and the ending point coincide. The above experiments fully prove that the VIO algorithm based on the two-stage EKF proposed in this paper has higher positioning accuracy under the condition of increasing a small amount of calculation cost.

Figure 9. Trajectory of a moving vehicle in an enclosed space. (a) Experimental environment. (b) Trajectories of MSCKF and proposed. (c) Proposed estimated unstable time offset.

7. Conclusion

This paper proposes a new online time calibration framework based on double-stage EKF for the VIO system. It solves the problem of inaccurate time offset caused by trigger delay and IMU noise during camera and IMU fusion. The algorithm in this paper can estimate the accurate time offset, and the RMSE of the trajectory is better than the current best VINS-MONO algorithm based on optimization and the best filter-based MSCKF algorithm. The work content is as follows:

1. The algorithm in this paper adds an unknown time offset to the VIO system state vector, estimates the time offset between the camera and the IMU online through camera observation constraints, and adds a complementary filter to improve the accuracy of the algorithm. Finally, compared with the same type of excellent online calibration algorithms, the proposed method has higher accuracy and robustness.

2. Compared with the current best VIO algorithm, the algorithm in this paper has obvious advantages in time complexity. The time complexity is about 30% of the optimization-based VINS-MONO algorithm and about 48% of the EKF-based OPEN-VINS algorithm, so it is easier to apply to low-cost computing platforms.

During the operation of the VIO system, many factors will have an impact on the estimation results, such as lighting conditions, equipment movement speed, and long corridor problems will affect the process of image feature point extraction and matching, leading to inaccurate observation information of Kalman filtering and affecting the system accuracy. The accuracy of each sensor and the severe time offset between sensors can also affect the system positioning accuracy. In the future, we will continue to carry out research on this problem.

If you need the dataset and related documentation, please contact the author.

Author contributions

S.L. and J.N. designed the study, conducted data gathering, and performed statistical analyzes, J.N., C.G., and Y.Y. wrote the article. L.M. provided critical revisions to the manuscript.

Financial support

This work was supported by Chongqing Natural Science Foundation Joint Fund for Innovation and Development (No. CSTB2024NSCQ-LZX0035), Science and Technology Research Project of Chongqing Municipal Education Commission (No. KJZD-M202300605), Young Talent Project of Nanning Municipal "Yongjiang Program" (RC20230107), Chongqing Municipal General Project for Scientific and Technological Innovation and Applied Development Special Project ( CSTB2022TIAD-GPX0028), and the Natural Science Foundation of Chongqing Municipality (CSTB2022NSCQ-MSX0230).

Competing interests

The authors declare that they have no competing interests.

Ethical approval

None.

References

Yang, Z. and Shen, S., “Monocular visual-inertial state estimation with online initialisation and camera-IMU extrinsic calibration,” IEEE Trans Automat Sci Eng 14(1), 3951 (2017).CrossRefGoogle Scholar
Mur-Artal, R. and Tardós, J. D., “Visual-inertial monocular SLAM with map reuse,” IEEE Robot Automat Lett 2(2), 796803 (2017).CrossRefGoogle Scholar
Jones, E. S. and Soatto, S., “Visual-inertial navigation, mapping and localisation: A scalable real-time causal approach,” Int J Robot Res 30(4), 407430 (2011).CrossRefGoogle Scholar
Shkurti, F., Rekleitis, I., Scaccia, M. and Dudek, G., “State Estimation of an Underwater Robot Using Visual and Inertial Information,” In: Proceedinngs IEEE/RSJ International Conference on Intelligent Robots and Systems, (2011) pp. 50545060.Google Scholar
Geneva, P., Eckenhoff, K., Lee, W., Yang, Y. and Huang, G., “Openvins: A Research Platform for Visual-Inertial Estimation,” In: International Conference on Robotics and Automation, (2020) pp. 46664672.Google Scholar
Martinelli, A., “Vision and IMU data fusion: Closed-form solutions for attitude, speed, absolute scale, and bias determination,” IEEE Trans Robot 28(1), 4460 (2012).CrossRefGoogle Scholar
Jung, J., Lee, S.-M and Myung, H., “Indoor mobile robot localization and mapping based on ambient magnetic fields and aiding radio sources,” IEEE Trans Instrum Meas 64(7), 19221934 (2015).CrossRefGoogle Scholar
Liu, J., Sun, L., Pu, J. and Yan, Y., “Hybrid cooperative localisation based on robot-sensor networks,” Singal Process 188, 108242 (2021).CrossRefGoogle Scholar
Muñoz-Salinas, R., Sarmadi, H., Cazzato, D. and Medina-Carnicer, R., “Flexible body scanning without template models,” Signal Process 154, 350362 (2019).CrossRefGoogle Scholar
Qin, T., Li, P. and Shen, S., “VINS-mono: A robust and versatile monocular visual-inertial state estimator,” IEEE Trans Robot 34(4), 10041020 (2018).CrossRefGoogle Scholar
Leutenegger, S., Lynen, S., Bosse, M., Siegwart, R. and Furgale, P., “Keyframe-based visual-inertial odometry using nonlinear optimisation,” Int J Rob Res 34(3), 314334 (2015).CrossRefGoogle Scholar
Wei, H., Zhang, T. and Zhu, Y., “An iterative-optimization-based calibration framework for VIO with limited prior conditions,” IEEE Sens J 21(21), 2469424708 (2021).CrossRefGoogle Scholar
Ling, Y., Bao, L., Jie, Z., Zhu, F., Li, Z., Tang, S., Liu, Y., Liu, W. and Zhang, T., “Modeling Varying Camera-IMU Time Offset in Optimisation-Based Visual-Inertial Odometry,” In: Proc European Conference on Computer Vision, (2018) pp. 484500.Google Scholar
Zhang, Z., Dong, P., Wang, J. and Sun, Y., “Improving S-MSCKF with variational bayesian adaptive nonlinear filter,” IEEE Sens J 20(16), 94379448 (2020).CrossRefGoogle Scholar
Chang, L., Hu, B. and Li, K., “Iterated multiplicative extended Kalman filter for attitude estimation using vector observations,” IEEE Trans Aerosp Electron Syst 52(4), 20532060 (2016).CrossRefGoogle Scholar
Rehder, J., Siegwart, R. and Furgale, P., “A general approach to spatiotemporal calibration in multisensor systems,” IEEE Trans Robot 32(2), 383398 (2016).CrossRefGoogle Scholar
Mourikis, A. I. and Roumeliotis, S. I., “A Multi-State Constraint Kalman Filter for Vision-aided Inertial Navigation,” In: Proceedings IEEE International Conference on Robotics and Automation, (2007) pp. 35653572.Google Scholar
Sun, K., Mohta, K., Pfrommer, B., Watterson, M., Liu, S., Mulgaonkar, Y., Taylor, C. J. and Kumar, V., “Robust stereo visual inertial odometry for fast autonomous flight,” IEEE Robot Autom Lett 3(2), 965972 (2018).CrossRefGoogle Scholar
Li, M. and Mourikis, A. I., “Online temporal calibration for camera-IMU systems: Theory and algorithms,” Int J Robot Res 33(7), 947964 (2014).CrossRefGoogle Scholar
Sabatelli, S., Galgani, M., Fanucci, L. and Rocchi, A., “A double-stage Kalman filter for orientation tracking with an integrated processor in 9-d imu,” IEEE Trans Instrum Meas 62(3), 590598 (2012).CrossRefGoogle Scholar
Qin, T. and Shen, S., “Online Temporal Calibration for Monocular Visual-Inertial System,” In: Proceedings IEEE/RSJ International Conference Intelligent Robots Systems, (2018) pp. 36623669.Google Scholar
Zhang, K., Li, X. R. and Zhu, Y., “Optimal update with out-of-sequence measurements,”IEEE,” IEEE Trans Signal Process 53(6), 19922004 (2005).CrossRefGoogle Scholar
Choi, M., Choi, J., Park, J. and Chung, W. K., “State Estimation with Delayed Measurements Considering Uncertainty of Time Delay,” In: IEEE International Conference on Robotics and Automation, (2009) pp. 39873992.Google Scholar
Furgale, P., Rehder, J. and Siegwart, R., “Unified Temporal And Spatial Calibration For Multi-Sensor Systems,” In: IEEE/RSJ International Conference on Intelligent Robots and Systems, (2013) pp. 12801286.Google Scholar
Kelly, J. and Sukhatme, G. S., “A General Framework for Temporal Calibration of Multiple Proprioceptive and Exteroceptive Sensors,” In: Experimental Robotics (Springer Tracts in Advanced Robotics), vol. 79 (Springer, Berlin, Germany, (2014) pp. 195209.Google Scholar
Liu, Y. and Meng, Z., “Online temporal calibration based on modified projection model for visual-inertial odometry,” IEEE Trans Instrum Meas 69(7), 51975207 (2020).CrossRefGoogle Scholar
Guo, C., Kottas, D., DuToit, R., Ahmed, A., Li, R. and Roumeliotis, S., “Efficient Visual-Inertial Navigation using a Rolling-Shutter Camera with Inaccurate Timestamps,” In: Proc. Robotics Science and Systems, (2014) pp. 19.Google Scholar
Baker, S. and Matthews, I., “Lucas-kanade 20 years on: A unifying framework,” Int J Comput Vis 56(3), 221255 (2004).CrossRefGoogle Scholar
Rosten, E. and Drummond, T., “Machine Learning for High-Speed Corner Detection,” In: European Conference on Computer Vision, (2006) pp. 430443.Google Scholar
Li, M. and Mourikis, A. I., “3-D Motion Estimation and Online Temporal Calibration for Camera-Imu Systems,” In: Proceedings IEEE International Conference on Robotics and Automation, (2013) pp. 57095716.Google Scholar
Forster, C., Carlone, L., Dellaert, F. and Scaranmuzza, D., “On-manifold pre-integration for real-time visual-inertial odometry,” IEEE Trans Robot 33(1), 121 (2017).CrossRefGoogle Scholar
Cen, R., Jiang, T., Tan, Y., Su, X. and Xue, F., “A low-cost visual inertial odometry for mobile vehicle based on double stage Kalman filter,” Signal Process 197, 108537 (2022).CrossRefGoogle Scholar
Burri, M., Nikolic, J., Gohl, P., Schneider, T., Rehder, J., Omari, S., Achtelik, M. W. and Siegwart, R., “The EuRoC micro aerial vehicle datasets,” Int J Robot Res 35(10), 11571163 (2016).CrossRefGoogle Scholar
Zhang, Z. and Scaramuzza, D., “A Tutorial on Quantitative Trajectory Evaluation for Visual(-Inertial) Odometry,” In: Proceedings IEEE/RSJ International Conference on Intelligent Robots and Systems, (2018) pp. 72447251.Google Scholar
Figure 0

Table I. Nomenclature.

Figure 1

Figure 1. Illustration of time offset due to delays of different sensors.$t_{a}$represents the delay of camera, and$t_{b}$represents the delay of IMU.$t_{d}$is the time offset between camera and IMU.

Figure 2

Figure 2. The flow chart of the VIO system: front end, complementary filter, and multi-state constrained Kalman filter as back end.

Figure 3

Figure 3. The marginalization process. The change process of the covariance matrix when the marginalized state${\textbf{C}}_{1}$and added state${\textbf{C}}_{7}$.

Figure 4

Algorithm 1 Overview system process

Figure 5

Figure 4. The estimation process of the time offset of the algorithm in (a) V1_01, (b) V2_01, (c) MH_04, and (d) MH_05 four sequences, the time offsets are 10 ms.

Figure 6

Table II. Time offset calibration results on euRoC datasets.

Figure 7

Figure 5. The trajectories of MSCKF, C-MSCKF, VINS-MONO, OPEN-VINS, and proposed on EuRoC datasets V1_01, V2_01, MH_04, and MH_05 sequences with 20 ms time offset.

Figure 8

Figure 6. The average back-end processing time of the three algorithms on the EuRoC dataset.

Figure 9

Figure 7. Area where the real-world motion experiment took place. A VICON motion capture system is used to record the real 3D position as ground truth.

Figure 10

Figure 8. Trajectory comparisons of the real-world motion experiment. (a) Trajectories of ground truth, OPEN-VINS, VINS-MONO, and proposed algorithms. (b) Unstable time offset estimated by proposed.

Figure 11

Figure 9. Trajectory of a moving vehicle in an enclosed space. (a) Experimental environment. (b) Trajectories of MSCKF and proposed. (c) Proposed estimated unstable time offset.