1. Introduction
Calibration of an inertial measurement unit (IMU) is a necessary step in preparing the IMU for operation, that being either inertial navigation or some supplementary task in biomechanics or robotics. The purpose of calibration is to provide formulas and estimate parameters needed to convert the raw accelerometer and gyro readings into the specific force and the angular rate of the unit. The majority of calibration models found in the literature are linear and include scale factors and biases; similar models are used in this paper. The calibration procedure consists of experiments with the IMU and algorithms to process the collected data.
Calibration of an IMU is fairly straightforward if done on a precise turntable with two or three degrees of freedom, measuring rotation angles with high accuracy. The table is usually well-calibrated, and its azimuth angle relative to the North is known, thus the true angular velocity and specific force are also known. In such a case, the calibration procedure usually consists of several steps—different static positions and rotations with prescribed angular velocities. Therefore, the data processing algorithms consist of several respective steps to calibrate biases and scale factors of accelerometers and angular velocity sensors. Mathematical formulas for these steps are often straightforward and can be reduced to linear least squares [
1,
2], or Kalman filtering [
3,
4].
A series of papers considers IMU calibration when a so-called low-grade turntable [
5] is used. Such a turntable delivers rotation, but either it does not provide information about rotation rate or angles, or this information is inaccurate. Thus, the only information available is the data taken from the IMU sensors. In such settings, IMU calibration cannot be done step-by-step, and dynamic equations of motion must be taken into account. In Refs. [
3,
5], an algorithm for calibration on a low-grade turntable based on the extended Kalman filter was suggested, with very good results, including applications for calibrating both low-cost and tactical grade IMUs. The Kalman filter algorithm is optimal under the well-known more or less reasonable assumptions, and is easy to implement. Unfortunately, in practice, to converge, it requires a fairly good initial guess on the IMU orientation and scale factors. Another difficulty arises from the necessity to know the IMU sensors noises to obtain the optimal results.
When we consider calibrating low-cost micromechanical IMUs, which are now broadly used, in, for instance, biomechanics, robotics or pedestrian dead reckoning (see earlier work [
6], later [
7,
8], or recent [
9,
10,
11]), the calibration procedure should be straightforward and reliable. In most practical cases, using a precise turntable is impossible. A lot of approaches to calibration of micromechanical IMUs without special equipment such as a turntable are known, see, for example, earlier work [
12], or more recent [
13,
14,
15]. For calibrating accelerometers, the IMU is put to several (about eighteen) static positions. For calibrating gyros, the IMU is rotated from one such position to another by hand. With collected data, the calibration problem is set as a maximum likelihood optimization problem, which is usually solved by numerical optimization. Note that there is one drawback of IMU calibration without putting it on a turntable: it is difficult to produce consistent regular rotations by hand; thus, the angular velocity sensors scale factors and misalignments can be estimated inaccurately. Another drawback lies with numerical optimization: it requires an initial guess and can diverge if such a guess is not good.
Having in mind the argument above, we think that using some turntable for calibration, preferably the simplest one, is advisable. In a recent paper [
16], a thorough procedure to calibrate a low-cost IMU on a rotation bench is proposed, with excellent experimental verification. The procedure allows to estimate not just linear, but also a nonlinear calibration model. It should be noted, however, that the algorithms are based on numerical optimization of the cost function and thus require an initial guess on some parameters.
This paper proposes an approach to calibration of a micromechanical IMU using either a low-grade turntable, or just a common home tool such as an electric screwdriver. Such a screwdriver often allows two speeds of rotation and reverse rotation. The proposed calibration experiment is as follows. The screwdriver is rigidly mounted on a workbench with the rotation axis approximately horizontal. The IMU is fixed in some position to the screwdriver shaft and is rotated for several tens of revolutions. Then, the position of the IMU on the shaft is changed, and revolutions are repeated, and so on. The number of positions must not be less than three, the positions must differ from one another by turns around axes approximately perpendicular to the shaft. The screwdriver orientation, angular velocity or the number of revolutions are not measured otherwise but by the IMU sensors. The screwdriver rotation can be nonuniform due to imperfections of the motor or gearbox, but must be monotonic with approximately constant duration of one revolution.
The proposed data processing algorithm first applies FFT (fast Fourier transform) to obtain the Fourier transform of the sensor data. The next step is to localize the frequencies corresponding to the peaks of the spectrum, and to calculate the amplitudes and phases of the spectrum at the peaks. The peaks are at zero frequency, at screwdriver revolution frequency, and maybe at some higher frequencies due to imperfections of the screwdriver gearbox. The frequencies, amplitude and phase data are collected in a small data array. The subsequent steps of the algorithm work with this data array, and are purely algebraic.
First, the accelerometers are calibrated. We apply here the well-known idea of fitting the raw accelerometer data with an ellipsoid [
17]. The only difference from [
17] is that, here, the ellipsoid lies in the space of spectral coefficients, not in the physical space of accelerometer readings. Since the ellipsoid-fitting algorithm is purely algebraic, it does not require any initial guess, and the convergence issues do not arise. Along with calibrating the accelerometers, the algorithm selects the instrument coordinate frame and computes the angular velocities of rotation in the instrument frame. Provided that the instrument frame is selected, the mean angular velocity of revolutions is computed and the accelerometers are calibrated, the angular rate sensor calibration is reduced to a straightforward linear algebraic problem.
We have not found many papers about IMU calibration by applying the Fourier technique to the turntable experiment. One such paper is Ref. [
18]. The calibration model in Ref. [
18] is the same as ours. However, the big difference is that in Ref. [
18], the true angular velocity and the true specific force are assumed known from the turntable data. With this assumption, the equations are completely linear and can be solved without iterations both in the time domain and in the spectral domain. In our case where the true sensors readings are unknown, the initial equations are nonlinear, thus, as far as we know, non-iterative algorithms in the time domain do not exist, which leaves the spectral approach we propose the only non-iterative one. Some preliminary results were published by us in Ref. [
19].
The paper is organized as follows. First, we state the problem. Next, the necessary mathematical formulas are derived and analyzed. Further on, we present results of simulation and experiments with a micromechanical IMU that support our reasoning. The bold letters such as denote column vectors in the three-dimensional space, the bold capital letters such as denote column vectors in the three-dimensional space of Fourier transforms. When the coordinate frame the column vectors are written in is of importance, we write them as , where are the coordinate frame axes.
2. Calibration Problem Statement
2.1. Calibration Model
The IMU measures the angular rate of the sensor relative to the inertial frame and the specific force acting on the proof mass M of the accelerometer. In some cases, especially for IMU operating in the environment with high angular rates, it is necessary to assume several proof masses. However, here, we assume just one proof mass. Both the angular rate and the specific force are given by the column vectors of their coordinates and in the so-called instrument frame . The origin of this frame is at the proof mass, its axes are rigidly connected with the instrument body.
Under the linear calibration model, the raw accelerometer data
and the raw gyro data
are connected with the true specific force
and angular velocity
written in the instrument frame
by the calibration formulas [
3,
7]:
where
are the unmodeled measurement errors. The goal of calibration is to estimate the
matrices
and the
column vectors
. Many calibration procedures can be found in the literature; some are mentioned in the introduction section. In this paper, we consider the following calibration procedure settings.
The IMU is mounted on the shaft of a turntable or a screwdriver in several positions and, in each position, it is rotated for several tens of revolutions using the screwdriver motor. These rotations are called “experiments”. The screwdriver body does not move relative to the Earth during all the experiments.
We use the following coordinate frames (
Figure 1). The navigation frame
is connected with the Earth, its axis
points up, the axis
is the projection of the shaft rotation axis on the horizon. The axes origin
O lies on the shaft rotation axis. The azimuth angle between
and the East direction is denoted as
. The frame
is rigidly tied to the body of the screwdriver, its
axis is directed along the shaft, the angle
of this axis with the horizon is constant. The axis
lies in the vertical plane, the axis
lies in the horizontal plane. The frame
is rigidly tied to the shaft: the axis
points along the shaft, the axes
rotate in the plane perpendicular to the shaft during experiments. The IMU instrument frame
is rigidly tied to the shaft in each experiment but changes its orientation relative to the shaft from experiment to experiment. The proof mass
M of the accelerometer can lie out of the shaft rotation axis: the centrifugal forces induced by the shaft rotation are accounted for by the algorithm.
2.2. Experiments and Data Models
Let
P be the number of experiments (different rotations) numbered by
: in each experiment, the shaft axes
rotate around the axis
, the angle of the axis
relative to the stand axis
is denoted by
:
Here,
is the duration of the experiment,
is the angular velocity of the shaft,
is the phase shift,
is the disturbance due to imperfection of the turntable. For brevity, we set
to zero in the theoretical section of this paper (influence of this term can be compensated for by analyzing the higher frequency spectrum of the sensors). Let us complement experiments—rotations with static experiments were the IMU stands still at different positions, denoting these experiments with numbers
:
Let
and
be the gravity and the Earth angular velocity vectors,
g and
u be their absolute values. In the navigation frame, these vectors are written as
where
is the latitude,
is the azimuth angle of the screwdriver shaft. In the screwdriver frame
, these vectors can be written as
Here, we use the notation
Note that
are unknown before calibration, thus the constants in (7) are also unknown. In the shaft frame, the gravity
and the Earth angular velocity
during the
p-th experiment can be written as
Now, we remember that the sensor angular velocity and the specific force acting on the proof mass in the
p-th experiment can be written as
where
is the vector of displacement of the proof mass relative to the shaft. In the instrument frame in the
p-th experiment, the above vectors can be written as
Here,
are the components of
along the
axes. Writing down the centrifugal force, we have neglected its component due to the Earth rotation.
Turning , appropriately in the plane perpendicular to the shaft, we can assume without loss of generality that , in (3), (4). Thus, we can write , .
For the static experiments (4), where the screwdriver motor is switched off, the IMU measurements can be written as
Equations (10)–(13) were written in the invariant vector form. Further on, we assume that they are written as column vectors in the instrument frame: , etc. However, since the instrument frame is the only frame used below, we omit the superscript . Note that the column vectors and written in the instrument frame are constant during each experiment but change from experiment to experiment.
The calibration task is to estimate from (10), (12), and from (11), (13) for calibration models (1), (2). The required mathematical formulas are discussed in the next section.
3. Calibration Algorithm
This section covers mathematical foundations of the proposed algorithm; some technical details of implementation are discussed in the results section.
3.1. Fourier Transform for Accelerometer Calibration Formulas
In this section, we neglect imperfections of the motor, setting , thus setting . Note that these imperfections do not influence the gyro calibration due to their high-frequency spectrum, but can cause a bias in accelerometer calibration due to the centrifugal force bias. However, these biases can be calculated by analyzing the oscillations in the angular velocity measurements. We do not pursue this matter further here.
Let us apply the Fourier transform [
20] in (1), (10) and denote the Fourier images as
, etc.:
The Fourier transform in (1) for both rotations and static experiments takes the form
where
is the delta-function. The Fourier transform in (10) takes the form
We have used the following well-known Fourier transform formulas [
20]:
Comparing (17), (18) and (15), (16), we see that the Fourier transform
has delta-function-type peaks at
, while the Fourier transform
has delta-function-type peaks at
. Let us denote the amplitudes of these peaks as
The Fourier transforms
,
take the form
Note that
here can be calculated as the position of a peak of
in the interval
, if the rotation was clockwise, or in the interval
, if the rotation was counter-clockwise. Equations (15) and (16) can now be rewritten as
Collecting coefficients at delta-functions in the equation above and in (17), (18), we obtain
Equation (23) are the base for calibrating the accelerometers. They can be resolved in the unknowns in several ways. We take the simplest way here, not claiming it to be the most accurate one.
Let us exclude the unknown constants
from (23) by algebraic manipulations:
Equation (24) can be resolved to find
. Note that the choice of the sensor frame is arbitrary provided it is fixed in the instrument body; thus,
includes only six independent variables [
3]. For a given number
of experiments, we have
equations. It looks like that to calculate 6 + 3 = 9 calibration parameters, it suffices to set
. However, a more careful look shows that we must take
, see below.
3.2. Fitting Accelerometer Data to an Ellipsoid
Equation (24) is quadratic. To reduce these to linear equations, we use the well-known trick [
17]: introduce the symmetric positive matrix
M, the vector
m, and the constant
m0 as
Equation (24) can then be rewritten as
Equation (26) defines an ellipsoid in the three-dimensional space. To obtain its parameters, let us divide the first equation in (26) with
, and use the notation
Note that if
, and the column vectors
are linearly independent, then the system (28) allows the false trivial solution
which will follow with the estimate of the scaling matrix as
. Thus, for reliable calibration, we must set
.
Expanding coefficients for
to a vector as
and expanding the unknowns to the vector
we obtain the system of linear equations in
xThe overdetermined system (32) can be solved in the mean square sense to obtain
x, then
,
from (31), and further on
Finally, the calibration parameters for the accelerometers
,
, are obtained by factorizing
M in upper triangular, lower triangular or symmetric form, depending on the situation:
Knowing the calibration parameters, we can find
g1,
g2, α from (23) as:
Next, we calculate the orts
,
,
as column vectors in the instrument frame as:
Now, we have to discuss one question. If the directions of rotation are known beforehand, then the signs of are also known, and the formulas (36) are quite correct. Now suppose that we do not know these signs, and have taken the wrong sign of some . Then, the sign of will be wrong; consequently, the signs of , will be also wrong. To find the correct sign, let us multiply the second equation in (23) with taken from (36): we get . We know that the value g1 = g sin α is positive; thus, the scalar product on the right must be also positive. If it is negative, we must change the sign of and change the signs of , before proceeding to calibrate the gyros.
Note that the vectors , , cannot be explicitly calculated from the above equations. However, if the experiments were done in such a way that each q-th static experiment precedes to or follows after some p-th rotation experiment without dismounting the IMU from the screwdriver shaft, then we can set = . However, we cannot do the same with , , because the rotation angle of these unit vectors around the shaft can be different from the rotation angles of , .
3.3. Calibration of Angular Rate Sensors
When calibrating accelerometers, we have obtained the axes of the shaft frame in the sensor frame. We have also obtained the rotation angular rates as frequencies of the peaks of the Fourier transform of the accelerometer data.
To calculate the gyros calibration parameters, let us perform the Fourier transform in (11), (13):
,
, to obtain
Here,
As earlier mentioned, introducing the peak values of the angular velocity spectrum
we can write
When we collect factors before the delta-functions in (37), (38), we obtain the system of
equations
We have 21 unknowns here: besides the twelve calibration parameters , we do not know nine more: , . Further on, we can select one of two ways.
If we are calibrating a low-accuracy IMU, we can neglect the Earth angular velocity, and get the system of
linear equations in the twelve unknowns:
If , these equations allow us to calculate the elements of .
If we are calibrating a high-accuracy IMU, then we must take into account the Earth angular velocity. To get rid of the unknown vectors
, we multiply (41) with
to get the system of equations
This is a system of
linear equations, with additional unknowns
, 18 unknowns in total. If
, which is the minimal number of experiments for calibrating the accelerometers, we get 31 equations—more than enough. Note that we need to know only the absolute value of the Earth angular velocity here—no need to know the azimuth angle or even the latitude.
5. Discussion
The paper presented an approach for calibration of a micro-mechanical IMU using a simple turntable, such as a domestic screwdriver, with a calibration algorithm based on the Fourier transform of the data. Verification of our calibration algorithm was done in two ways. First, we used the simulation data and showed that when the duration of experimental rotations was taken more than 40 s (80 revolutions at two rotations per second), the calibration accuracy became sufficient for any purpose. When duration of rotations was below 10 s (20 revolutions at two rotations per second), calibration results were inaccurate. The latter can be explained by the effect of “spectrum leakage” when using FFT on a short time interval.
Second, we performed experiments with the micromechanical inertial measurement unit called x-IMU [
21] and compared the results of calibration using our algorithm to the x-IMU factory calibration data, which had proved to be very accurate in our experiments in pedestrian navigation [
10]. The differences in the scale factors were around 0.2%, the errors in estimating directions of sensitivity axes were around 0.06 degrees. However, the calibration accuracy was not as high as was expected from simulations. We see the reason for this in that, in our experiments, the rotation angular velocity drifted considerably due to instability of screwdriver RPM. We expect the results to be much better when we use a better turntable than our screwdriver. Another way to increase accuracy is to use reverse rotations, which we did not do.
Some rough estimates not included here show that the accuracy of our algorithm is considerably lower than that of the well-known Kalman filter approach to calibration on a rotating turntable [
3], which can be seen to be asymptotically optimal under the assumption of the sensor errors being Gaussian white noise. Nevertheless, a big advantage of our algorithm, which comes from purely algebraic formulas used, is its guaranteed convergence without any need for an initial guess. Without such a guess, the Kalman filter algorithm often diverges. The results of calibration with our algorithm can be used as an initial guess for the Kalman filter algorithm. Joining together the Fourier approach and the Kalman filter approach, with an initial guess provided by the former, is an aim of our future work.
Our algorithm has two versions—for high-grade and low-grade IMU. For the case of low-grade IMU, which is discussed in this paper in more detail, we do not account for the Earth angular velocity, and the algorithm becomes much simpler. Note that when rotation rates become about one turn per second, the Earth angular velocity influence on estimating the gyro scaling matrices is negligible since the rotation rates are several orders of magnitude higher than the Earth rotation rate of 13 degrees per hour. We think that the high-grade IMU version of our algorithm should be used only when a turntable with fairly constant rotation rate is used.
One of the popular micromechanical IMU calibration methods is the so-called calibration without external equipment [
13,
14], etc., which we have used a lot in our experiments in pedestrian navigation [
9]. We have found (the results are not included here) that the new algorithm performs considerably better when it comes to the angular rate calibration of the sensors because their scale factors are estimated better with relatively fast and lengthy rotations, which are impossible to perform by hand. Moreover, contrary to our algorithm, the rotation-by-hand angular rate calibration requires an initial guess on the parameters. Accuracy of accelerometer calibration for the two approaches is comparable. We note also a general advantage of the spectral approach which is that the spectrum provides additional information about the IMU, helping to find out certain effects such as proof mass separation the initial mathematical calibration model has not accounted for.
As already mentioned in the Introduction, we have found just one paper [
18] about IMU calibration by applying the Fourier technique which is in relation to ours. The big difference is that in Ref. [
18], the true angular velocity and the true specific force are assumed known from the turntable data; thus, the equations are completely linear and can be solved without iterations both in the time domain and in the spectral domain. In our case where the true sensor readings are unknown, the initial equations are nonlinear, which makes the spectral approach we propose look special from the point of view of guaranteed convergence.