Calibration
The gimbal will work without calibration, but the camera wouldn't be leveled well. For optimal performance the accelerometers within the IMU modules need to be calibrated. Several calibration techniques are existing, and two are implemented in the STorM32 project, namely the "1-point" and "6-point" calibrations.
Unfortunately, it is not absolutely clear which method is the best. The firmware author doesn't have the resources for an extensive research project, which is what would be needed for clarifying this. Hence, the situation is a bit experimental. However, from the experience so far, this rule of thumb seems to provide good advice:
No calibration is a no go, but a simple 1-point calibration is nearly always sufficient.
Comment: One may wonder why the accelerometers need to be calibrated, but not the gyros. In principle, also the gyros should be calibrated for best performance. However, the calibration techniques are so complicated that calibrating the gyros is beyond our reach.
General
Reasons and Goals
It might be helpful to first understand better why a calibration of the accelerometers is done at all. The obvious reason is of course to account for the inaccuracies of the accelerometers, which are individual to each device. The goal is to get data which correctly reflect the actual accelerations. In the case of the camera IMU this e.g. implies that the camera is indeed level. However, there are additional important reasons for doing the calibration, and these are in fact different for the camera IMU and the 2nd IMU.
Camera IMU
The accuracy of the calibration of the camera IMU also strongly influences the "horizon tilt", i.e., the accuracy with which the horizon is held in e.g. quick yaw turns. The horizon tilt is minimal then the accelerometer Z axis is parallel to the gimbal Z axis, which can be realized by calibrating the accelerometer well, and by a square gimbal and square mounting of the accelerometer (similar statements hold for the X and Y axes, but the Z axis is most important). Thus, a main goal of calibrating the camera IMU is to optimize the "horizon tilt" performance.
The alignment of the axes is more important for this than the numerical accuracy of the calibration. Therefore, a simple 1-point calibration often does an excellent job. Unless undertaken carefully, a nominally more precise 6-point calibration can result in a worse alignment of the axes.
Comment: Improperly aligned IMU sensor and gimbal axes is only one of the reasons for horizon tilt (which can be minimized by calibration). A second effect, which is of totally different physical origin, and which cannot be overcome by calibration, are accelerations of the gimbal during e.g. high-g maneuvers. The measured accelerations then do not coincide with the gravity anymore, and the AHRS loses its horizon, leading to a tilt of the camera. Unfortunately, both effects are often confused, but should be clearly distinguished.
Second IMU
The measurement accuracy of the 2nd IMU is by itself not really important. For the operation of the STorM32 gimbal controller it is however important that the data of the 2nd IMU are consistent with the data of the camera IMU, since otherwise the internal math would go wrong, which can lead to all sorts of weird problems. Luckily, some tolerance is acceptable, which however depends also on the number of poles of the motors. For motors with 14 poles or less, the calibration of the 2nd IMU doesn't need to be super accurate, and a quick 1-point calibration usually does it. The higher the pole count of the motors, the better the calibration needs to be.
Rules of Thumb
Calibration Accuracy
A 6-point calibration is meaningful only if it is done very accurately. A poorly undertaken 6-point calibration can easily result in poorer performance than a supposedly less accurate 1-point calibration. The resulting quality factor for the 6-point calibration option can give a good indication as to the results (a value of 80 is very good, 150 average, 250 not so good).
A 1-point calibration is meaningful only if it is done for a level IMU module.
Rules of thumb
- The calibration only needs to be as good as you need it to be. If you are happy with the way your gimbal performs, you don't need to spend time on a (better) calibration.
- It has been found that the Z axis is usually more wrong than the X and Y axes. IMU orientations with the Z axis pointing up or down appear thus to be preferable. Equally good results can be obtained for any orientation. Some of the best videos out there were in fact recorded with the IMU's Z axis in a horizontal orientation. The comment just means that with the Z axis pointing up or down it's more likely that one can get away with a "less precise" calibration for a desired level of performance.
- The calibration of the camera IMU is more important than that for the 2nd IMU, i.e., for the 2nd IMU a "less accurate" calibration usually is sufficient.
- The calibration of the 2nd IMU becomes more important as the motor pole count increases (e.g. 14 pole versus 22 pole). Using 22 pole motors, or higher, will definitely need a good calibration, of both IMUs.
Recommendations
- A 1-point calibration is fairly simple, and is hence the minimum for both the camera and the 2nd IMU.
- When possible choose IMU orientations with the Z axis pointing up or down, but that's not a must as explained before.
- Don't do a 6-point calibration unless you plan to do it very accurately (check out the rcgroups thread).
- If motors with 12 or 14 poles are used, a 1-point calibration of the 2nd IMU is most likely sufficient. Higher-pole motors require more careful 2nd IMU calibrations.
Lastly, some advice:
Save your calibration data to a file!
Ideally save it from within the [GUI:Acc Calibration] dialog window, as this stores the most detailed information. Consider also posting your calibration files in the rcgroups discussion thread, so that the firmware author and others can enhance their knowledge and hopefully develop better calibration schemes.
Calibration Procedure
The calibration consists of two steps. In one step, the calibration constants are determined for the particular NT IMU module under consideration. In another step, the calibration constants are made effective by storing them permanently into the NT IMU module or the STorM32 board.
Comment: For NT IMU modules which are running the original firmware, the calibration constants are stored in the NT IMU module itself. Otherwise the calibration constants are stored in the STorM32 controller.
The [GUI:Calibrate Acc] tab is the central place for all calibration related tasks. It provides the means to select the IMU which shall be calibrated, to enter calibration values, and to store them. The fields holding the calibration constants can be populated in various ways:
- Values can be edited or entered directly into the text fields.
- The values can be set to the default values by hitting the [Reset to Default] button.
- The values currently stored in the NT IMU module/STorM32 board can be read out by hitting the [Read from Board] button.
- The fields can be populated with calibration values stored in a calibration file via the [Load from File] button.
- The fields can be set to the values obtained from a 1-point or 6-point calibration via the [Run 1-Point Calibration] and [Run 6-Point Calibration] buttons.
The calibration constants are send to and permanently stored in the NT IMU module/STorM32 board by hitting the [Store Calibration] button.
It is recommended to restart the STorM32 controller after having changed calibration constants.
The 1-point and 6-point calibration procedures are better explained by videos. The next chapter offers one video, but you can find further ones on the Video Tutorials page.
Tutorial Videos
Rcgroups user mackar made a great videos on how to do a 6-point calibration (see also here and here).
Calibration Tools
bruce356's 3D printed calibration cube:
http://www.rcgroups.com/forums/showpost.php?p=29983118&postcount=2346
stl files: http://www.rcgroups.com/forums/showpost.php?p=29983275&postcount=2351
GekoCH's wooden board calibration tool: http://www.rcgroups.com/forums/showpost.php?p=30034517&postcount=2439
larsm's calibration technique: http://www.rcgroups.com/forums/showpost.php?p=29649741&postcount=1897
OlliW's lego calibration tool: http://www.rcgroups.com/forums/showpost.php?p=29646349&postcount=1890