Inertial Measurement Units

From PaparazziUAV
Jump to navigation Jump to search

Paparazzi IMU

Booz IMU v 1.2

  • High quality analog devices sensors
  • 16bit ADC capable of 200 000 samples per second
  • Special attention to clean power with onboard linear supplies
  • Efficient high-speed SPI for minimal microcontroller overhead and ultra-low latency (=better controller performance).
  • Fits on Booz, Lisa AND Tiny/TWOG autopilots.

While designed for booz, the first kalman filters were added to the fixedwing code for the Tiny autopilots.

IMU001.jpg

The hardware description is here.

Available at PPZUAV. The first IMU have been assembled and are being calibrated. Look for updates soon.

YAI v1.0

Why "yet another imu" while there are already so many out there?

Yai assemb.jpg

  • Designed to be completely compatible with original booz IMU and its code
  • Cheaper sensors (lower bias stability)
  • Higher resolution (16bits) and frequency (200ksps) and cleaner onboard power supply, better grounding and shielding than compared with e.g. external sparkfun breakout boards
  • Fast low latency SPI communication (no uart as the tiny/twog miss uarts)
  • The most important part of attitude determination is proper kinematic compensation using for instance GPS, pressure sensors etc etc. When using IMU with external processors there is often less flexibility. Things as timing for instance are as important as the quality of the gyros themselves.

Board, BOM -> [ http://svn.savannah.nongnu.org/viewvc/paparazzi-hardware/trunk/sensors/yai/?root=paparazzi Hardware Repository]

3rd Party IMU

IMU's measure rotation rates, acceleration (6DOF) and some also magnetic fields (9DOF). This data is used by an autopilot to estimate the state of the aircraft. They that can be used with a Paparazzi autopilot based UAS. If you happen to have such a device, we really would love to see that you share your IMU paparazzi autopilot integration projects information on this Wiki.

PPZUAV IMU 9DOF

PPZ 9DOF IMU

I couldn't wait and had my friend design me up this one. At the time SparkFun didn't have all these sensors on one board. I2C out 5v power. Testing now. I'll warn you likely something wrong with it. It's open so anyone can have it now. PCBs will be available for a few dollars. Schematic open, design open but not in Eagle. I can post the gerbers.


SparkFun Razor 6DOF IMU

Razor IMU (top) with the tiny13 autopilot
Razor IMU in the tiny13 autopilot box

Official website

6DOF - Ultra-Thin IMU

Very cheap, currently 62-72 Euro. Shop in Europe


Has been integrated in Paparazzi by Hochschule Bremen, Germany.

Remove the high pass filters of the RazorIMU to get better results.

For the Twog and Tiny 2.2 autopilots you have also remove the resistors to GND of the 5V analog inputs.

Connections and wiring to the tiny13


Cloudcap Crista IMU

Christa IMU

Official website

More infos soon.


3rd Party INS

INS measure rates with their sensors and run algorithms to estimate the state on their own. They give this information the the autopilot (e.g. Euler angles) that can then use it for navigation.

ArduIMU+ V2 (Flat)

ArduIMU

Official website 3 axis Accelerometer + 3 axis Gyroscope.

Very cheap Has been integrated in Paparazzi by ZHAW, Winterthur, Switzerland.

  • A magnetometer has been integrated in the software to compensate drift in yaw.
  • GPS from the Tiny is passed over I2C to the AHRS on the IMU

More info on integration can be found here. Where can I buy ArduIMU?
Sparkfun
DIYDrones Store

Vector-Nav VN-100

Vector-Nav VN-100

Official website

There is a module for this AHRS (ins_vn100.xml for fixedwings).


MicroStrain 3DM-GX2

MicroStrain 3DM-GX2

Official website

More info soon.


Xsens MTi and MTi-G (with GPS)

Xsens MTi
Xsens MTi-G (with GPS)

Official website MTi

Official website MTi-G

More info soon.


The Very Short Essential Introduction To Inertial Attitude Estimation

The only physical entity related to attitude (pitch and roll) is the earth gravity vector (unless you use a multi-antenna phase-measuring GPS... $$$$). Unfortunately, the sensors that measure gravity (=accelerometers) also measure so-called kinematic accelerations or in other words: changes in speed: like centrifugal forces, Coriolis forces, linear accelerations etc... The sum of all these litteraly is "what you feel" and is called "specific force".

so

 accelerometer_value (specific force) = earth_gravity + change in velocity (linear accelerations) + velocity times turn rate (centrifugal etc)

or

 A = B + C + D  

You measure A and want to know B. What all "gyroscopes and accelerometer only" AHRS projects are doing in some way or another is to neglect the last 2 (C and D). In many situations this is not bad: for instance: when testing the AHRS attached to your computer: it can not accelerate for a very long time (at most a few meters: so if you accerate to the left, then you need to accelerate to the right directly after so the average is zero) and can not rotate to much either (or your cable gets strangled). This is why all AHRS videos on youtube look perfect. And on the desk they are perfect: you neglected 2 terms in the equation that in that situation are perfectly neglect-able. Also with a quadrotor that hovers and keeps its nose in the same direction all the time, these neglected terms are small.

Now what about the gyroscopes you might ask. I deliberately keep them only second as gyroscopes (turn rate or rotation speed sensors) do NOT give you attitude but ONLY HELP TO SOLVE SHORT TERM errors in the previous part. If gyroscopes would measure turn-rate perfectly, then they would help more but all MEMS/PIEZZO sensors are more or less sensitive to 1) temperature, 2) turnrate, 3) vibrations, 4) accelerations, 5) radiation, 6) power supply quality 7) non-linearity 8) ADC-quality 9) dynamic range and saturation problems, ... so if you integrate gyroscopes, sooner or later errors build up (drift). I put this list here so you know what to pay attention for: if using gyroscopes: always try to keep the temperature as constant as possible or let the temperature settle, reduce vibrations (dampers), use better ADC (e.g. 10bit ADC with +/- 1200 deg/sec gyros have a resolution of 2.4 degrees/s per ADC tick, so your phi/theta might drift 1.2deg/sec without noticing) and power supply filtering and shielding etc to start with. All of these define for how long (seconds!/minutes?) gyroscope integration is useful.

If you convert the accelerometer directly to attitude and plot it, it will vibrate a lot and will show errors when you accelerate the AHRS on your desk. During a coordinated turn of a fixedwing plane, the force you feel is perpendicular to the plane (not pointing to earth). The accelerometer only clearly is insufficient to know your attitude. One solution is to use gyroscopes that are so good that you can predict for many minutes (then the average acceleration during several turns would still point to earth). But if your gyros can only help for shorter terms (like all MEMS sensors of less than 500euro/each) then extra information is required. E.g: if you add GPS data or airspeed data however, from the flightpath you can quite accurately reconstruct the missing C and D terms. Together with the accelerometer you can know "where the earth is" even when you keep accelerating and turning. Here questions like latency, update rate, noisy derivatives (linear acceleration) are of importance.

Finally there is the heading... GPS ground-track is not the same as nose direction. Gyroscopes measure how much the nose has been turning, so using GPS to correct it induces errors that increase with corsswind. Magnetometers can help here, and become necessary whenever you do not move enough anymore (hovering).