Difference between revisions of "Introduction 9DoF"

From The Relativty Wiki
(Created page with "== Introduction to 6DoF and 9DoF == Main Alpha Testing page Positional tracking is complex field, full of obtuse terms and complicated mathematics. In a nu...")
(No difference)

Revision as of 11:26, 28 April 2019

Introduction to 6DoF and 9DoF

Main Alpha Testing page

Positional tracking is complex field, full of obtuse terms and complicated mathematics. In a nutshell though, for those of you wondering what this upgrade will give us, it'll fix the main problem that 6DoF trackers have, which is drift.

This is best explained in the two 1 minute videos below, from Sebastian Madgwick - the guy who developed the sensor fusion algorithms that we all use as part of his Ph.D research at the University of Bristol in 2009. Basically, the direction that your 6DoF headset tracker thinks is forwards slowly drifts sideways because of sensor errors, so you have to keep on recalibrating it - but not if you have a 9DoF headset tracker. A 9DoF tracker also measures the earth's magnetic field, alongside the standard 6DoF measurements, & uses a mathematical algorithm to continually compensate for the 6DoF errors.



YouTube: 6Dof Demonstration of Basic Concepts and Drift



YouTube: 9Dof Demonstration of Zero Drift


The hardware has moved on since Sebastian Madgwick was first playing with it, as have the mathematical algorithms. An American called Kris Winer took Madgwick's algorithm and applied them to new Arduino compatible MPU-9250 sensor boards that had recently become available. He released his work to the world as "Beerware" - which means that anyone can do whatever they like with it, but if they ever get the chance, they should buy him a beer. His work is beyond epic, so if you ever meet him, please, buy him as much beer as you can!

However, to those of us who are not so mathematically adept, the algorithms are rather hard to understand. Thankfully, various people have taken them & wrapped them up in nice, approachable Arduino libraries which are pretty straightforward to use. The library that we will be using was created from Kris Winer's code by Hideaki Tai in Japan - however, as is normal in this field, there is a hardware gotcha that you have to be aware of.