State Estimation Tutorial

Table of contents

  1. 0 - Introduction to Robotic State Estimation (Presentation) ๐Ÿ“บ
    1. 0.1 - IMU State Space Model ๐Ÿ‡ฆ๐Ÿ‡ง
    2. 0.2 - Quick Introduction to IMU Noise Parameters ใ€ฐ๏ธ
    3. 0.3 - Quick Introduction to GraphMSF ๐Ÿงฎ
  2. 1.0 - Sensor Fusion (Interactive Session) ๐Ÿค”
    1. 1.1 - Pure IMU Integration ๐Ÿ“ˆ
    2. 1.2 - Adding Wheel Odometry ๐Ÿšด
    3. 1.3 - Adding LiDAR Mapping ๐Ÿšจ
  3. 2.0 - Biased Accelerometer (Interactive Session) ๐Ÿค”
    1. 2.1 - Non-tuned Configuration โŒ
    2. 2.2 - Tuning the Bias Behavior ๐ŸŽ›๏ธ -> โœ…
  4. 3.0 - Correct Handling of Coordinate Frames (OPTIONAL, Interactive Session) ๐Ÿค”
    1. 3.1 - Without Optimizing T_M_W โŒ
    2. 3.2 - With Optimizing T_M_W โœ…

Before starting the tutorial, follow the Preparation Instructions and compile the required code.

The first part of this tutorial - Section 0 - will be given as a presentation. The second part - Sections 1-3 - will then be more interactive.

0 - Introduction to Robotic State Estimation (Presentation) ๐Ÿ“บ

As a first part of this tutorial, we will look at IMUs and its characteristics in more detail.

0.1 - IMU State Space Model ๐Ÿ‡ฆ๐Ÿ‡ง

Starting off, we look at the equations and the most common model used for IMUs. All together.

0.2 - Quick Introduction to IMU Noise Parameters ใ€ฐ๏ธ

In a second step, we will look at the IMU noise parameters, and how they can be computed. All together.

0.3 - Quick Introduction to GraphMSF ๐Ÿงฎ

As a third part, a quick overview of the GraphMSF software framework is given. All together.

1.0 - Sensor Fusion (Interactive Session) ๐Ÿค”

In this part, we will now investigate the sensor fusion performance using various inputs. The whole tutorial will be guided on the projector, with short breaks to run the code on the PCs.

1.1 - Pure IMU Integration ๐Ÿ“ˆ

In a first step, pure IMU integration and its limitations are investigated.

Question 1

  • What do you expect to observe?
  • Is IMU alone enough for estimating the full robot state?

For this, run the following launch file on your computer and make sure that everything runs without an issue.

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_1.launch

In this terminal, it will also ask you for an experiment name for logging of the data. Simply enter 1.1. Next, play the first 30s of the attached rosbag.

# In Terminal 2
$ rosbag play <path_to_bagfile>/outdoor_2023-06-16-11-39-50_smb263.bag --clock -u 30 

Question 2

  • What can you observe qualitatively?

The corresponding plots are then saved on your computer in smb_msf_graph/tutorial/rss_plots. Inspect them.

Question 3

  • What do you observe quantitaively for position and velocity?
  • In particular, pay attention to the lateral robot velocity after 30s. Does this makes sense?

1.2 - Adding Wheel Odometry ๐Ÿšด

In a next step, we will add wheel odometry to the estimation.


Task 1

  • Go to the config file smb_msf_graph/tutorial/config/1_smb_graph_params.yaml
  • Enable the wheel odometry where you can see the # TODO: Change here.

Same as before, the scripts can be started by doing:

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_1.launch

Enter the name 1.2. This time we play the entire bag, hence remove the -u 30:

# In Terminal 2
$ rosbag play <path_to_bagfile>/outdoor_2023-06-16-11-39-50_smb263.bag --clock 

Question 4

  • What do you observe this time?
  • How does it compare to wheel odometry alone? This can be seen by the red arrow, and in the corresponding plot.

1.3 - Adding LiDAR Mapping ๐Ÿšจ

In a next step, we will add LiDAR mapping.


Task 2

  • Again go to smb_msf_graph/tutorial/config/1_smb_graph_params.yaml.
  • Enable the LiDAR mapping and disable the wheel odometry again.

Then run

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_1.launch

Enter the name 1.3.

# In Terminal 2
$ rosbag play <path_to_bagfile>/outdoor_2023-06-16-11-39-50_smb263.bag --clock 

Question 5

  • How is the performance with respect to Wheel Odometry?
  • How does the trajectoryโ€™s smoothness relate to the LiDAR Mapping path?

2.0 - Biased Accelerometer (Interactive Session) ๐Ÿค”

In the second task, we will now look at the scenario of a biased accelerometer. The bias is in the form of a sine wave with period time of 20s, and an amplitude of 0.1m/s^2.

2.1 - Non-tuned Configuration โŒ

In the first step, we will run the non-tuned configuration. For this, run the following and inspect the behavior:

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_2.launch

Enter the name 2.1. Then play the first 30s of the bag:

# In Terminal 2
$ rosbag play <path_to_bagfile>/outdoor_2023-06-16-11-39-50_smb263.bag --clock -u 30

Question 6

  • Look at the plots. What can you observe?
  • How does the trajectory in z direction look like?

2.2 - Tuning the Bias Behavior ๐ŸŽ›๏ธ -> โœ…

In a next step, we tune the IMU bias estimation.


Task 3

  • Go to smb_msf_graph/tutorial/config/2_core_graph_params.yaml.
  • Tune the acceleration random walk.
  • Think about whether it should be larger or smaller, and increase/decrease it by a factor of 10 and 100.

Then run

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_2.launch

Enter the name 2.2. Then play the first 30s of the bag:

# In Terminal 2
$ rosbag play <path_to_bagfile>/outdoor_2023-06-16-11-39-50_smb263.bag --clock -u 30

Question 7

  • How does the trajectory in the z direction look now?
  • How does the bias estimate capture the true bias?

3.0 - Correct Handling of Coordinate Frames (OPTIONAL, Interactive Session) ๐Ÿค”

In this task, we will investigate the importance of optimizing over T_M_W. For this, we provide another dataset where the map (M) and gravity-aligned world (W) frames are strongly misaligned.

3.1 - Without Optimizing T_M_W โŒ

Run the following script, which will not optimize over this frame displacement.

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_3.launch

Enter the name 3.1. Then play the first 30s of the NEW bag:

# In Terminal 2
$ rosbag play <path_to_bagfile>/indoor_tilted_2023-06-29-17-32-42_smb.bag --clock -u 30

Question 8

  • What can you observe here?
  • How does the z position and z bias behave?
  • How does the estimated velocity look like?

3.2 - With Optimizing T_M_W โœ…

We now enable the alignemnt of the extrinsic frames.


Task 4

  • Go to smb_msf_graph/tutorial/config/3_core_graph_params.yaml.
  • Enable the frame optimization.

Then run the same again:

# In Terminal 1
$ roslaunch smb_msf_graph tutorial_3.launch

Enter the name 3.2. Then play the first 30s of this bag:

# In Terminal 2
$ rosbag play <path_to_bagfile>/indoor_tilted_2023-06-29-17-32-42_smb.bag --clock -u 30

Question 9

  • Why do you think is the situation now becoming better, and the overall estimate smoother?