I am trying to fuse a u-blox M8 with a MicroStrain IMU via a loosely coupled architecture.
I was wondering if there are any suggestions or insights based on the results that I am getting.
I based most of my code off of Paul Grove’s 2nd edition book. I did a six-point tumble test to calibrate my IMU to get the accelerometer fixed bias, the accelerometer scale factor and the accelerometer misalignment. I also got gyroscope fixed bias. I don’t have a rate table so I can’t get the gyroscope scale factor and misalignment yet.
The filter is not currently estimating any calibration information.
I ran a test of the code for about 6 hours and 40 minutes.
I have a couple of questions about the procedure.
My main difficulty is that I am not sure what I should be expecting from the hardware/integration architecture that I am using. What would you expect after a test of 6 hours with a loosely coupled architecture?
I am also having difficulty deciding on how to tune the filter. Are there any papers/procedures that you recommend for deciding what should go into Q and R Matrices? I tried propagating the IMU standalone to see how quickly it diverged from it’s initial position. I also took gps data to see how it diverged from it’s initial position. I am wondering If the tuning would be a function of my update interval, as well as how long it takes the two systems to diverge to a specified distance.
For my R matrix, I am taking the uncertainty posted by the GPS. For my Q matrix, I am using the power spectral density. I do have some difficulty understanding the reasoning behind this.
Finally, I am wondering how much you think that estimating calibration information in my filter would help with a long term solution.
Please ignore the xlabel for the figures. It says time in seconds was about 28 days. But the test lasted for just 6 hrs and 40 minutes.




