AN3182 Application note Tilt measurement using a low-g 3-axis accelerometer Introduction This application note describes the methods and techniques for measuring tilt angles from a low-g 3-axis accelerometer. The LIS331DLH 3-axis digital accelerometer is used as an example in this document. Other 3-axis analog or digital accelerometers may also be applied to the tilt angle measurement procedures described here, depending on their respective specifications. The ultra-low power LIS331DLH digital accelerometer is housed in a 3 x 3 x 1 mm LGA-16 package. It has an I2C / SPI digital serial interface for 3-axis acceleration outputs, so no external ADC chip is required. It also features a dynamically user-selectable full-scale measurement range of ±2 g / ±4 g / ±8 g, with output data rates from 0.5 Hz to 1 kHz. Section 1 of this application note introduces the terminology and parameters related to the accelerometer, while Section 2 presents the accelerometer calibration techniques. Section 3 describes the tilt sensing theory and the methods of determining tilt angle measurement. April 2010 Doc ID 17289 Rev 1 1/18 www.st.com Contents AN3182 Contents 1 Terminology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.1 Accelerometer datasheet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 1.2 Understanding the parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.3 Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2 Calibrating the accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 3 Calculating tilt angles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 3.1 Theory of operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 3.2 Tilt sensing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.2.1 Single-axis tilt sensing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.2.2 Dual-axis tilt sensing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 3.2.3 Tri-axis tilt sensing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Appendix A Least square method. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 2/18 Doc ID 17289 Rev 1 AN3182 List of figures List of figures Figure 1. Figure 2. Figure 3. Figure 4. Figure 5. Figure 6. Figure 7. Figure 8. Figure 9. Accelerometer inside a handheld device . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 Pitch definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Roll definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 Tilt measurement using a single axis of the accelerometer . . . . . . . . . . . . . . . . . . . . . . . . 10 360° rotation of a single axis of the accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Plot of 360° rotation of a single axis of the accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . 11 Tilt sensitivity of a dual-axis accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Tilt angles from a tri-axis accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Tilt sensitivity of a tri-axis accelerometer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 Doc ID 17289 Rev 1 3/18 Terminology 1 AN3182 Terminology Low-g MEMS accelerometers are widely used for tilt sensing in consumer electronics and industrial applications, such as screen rotation and automobile security alert systems. Another popular application for low-g accelerometers is tilt compensated electronic compasses for map rotation and personal navigation devices. This application note describes how to obtain accurate tilt measurements with respect to local Earth horizontal plane, by compensating for a few non idealities that may cause angular tilt calculation error. In this document, the 3-axis digital accelerometer LIS331DLH is used as an example. For detailed information and device specifications, refer to the LIS331DLH datasheet available at http://www.st.com. Other 3-axis analog or digital accelerometers may also be used, in accordance with their respective specifications. 1.1 Accelerometer datasheet When designing a tilt sensing system, the first step is to examine the accelerometer specifications and understand the meaning of each parameter that affects tilt sensing accuracy. Table 1 shows the main parameters of the LIS331DLH 3-axis digital accelerometer when a full-scale of ±2 g is selected, which is optimum for tilt sensing applications. Note that higher full-scale ranges can also be selected for tilt sensing, but accuracy is affected by the resulting lower sensitivity. Table 1. Main parameters for the LIS331DLH @ Vdd = 2.5 V, T = 25 °C Symbol Parameter Vdd Power supply Idd Current consumption in normal mode ODR Output data rate in normal mode BW System bandwidth Ton Turn-on time Top Operating temperature range FS Full-scale measurement rage FS bit set to 00 So Sensitivity FS bit set to 00 12-bit representation TCSo Sensitivity change vs. temperature FS bit set to 00 ±0.01 %/°C TyOff Typical zero-g level offset accuracy FS bit set to 00 ±20 mg TCOff Zero-g level change vs. temperature Max delta from 25 °C ±0.1 mg/°C An Acceleration noise density FS bit set to 00 218 ( μg ) ⁄ ( Hz ) 4/18 Test conditions Min. Typ. Max. Unit 2.16 2.5 3.6 V Selectable by DR bits in CTRL_REG1 ODR = 100 Hz 250 µA 50/100/400/ 1000 Hz ODR/2 Hz 1/ODR + 1 ms -40 Doc ID 17289 Rev 1 +85 ±2.0 0.9 1 °C g 1.1 mg/LSB AN3182 1.2 Terminology Understanding the parameters ● Vdd - Power supply: This parameter defines the accelerometer operating DC power supply range between +2.16 V and +3.6 V (typical +2.5 V). Correct operation of the accelerometer using a power supply voltage outside of this range is not guaranteed. The parameters in Table 1 are provided by the accelerometer manufacturer under Vdd = +2.5 V at a room temperature of T = 25 °C. It is recommended to keep the Vdd clean, with minimum ripple. One possible way to do this is to use an ultra low-noise lowdropout regulator to power the accelerometer. ● Idd - Current consumption in normal mode: In the case of the LIS331DLH, lower ODR corresponds to lower current consumption. ● ODR - Output data rate in normal mode: This parameter shows the possible output data rates in normal mode. The user can select different ODR by setting the DR bits in the CTRL_REG1 register. ● BW - System bandwidth: This parameter defines the bandwidth of the system. When ODR = 100 Hz, BW is typically 50 Hz with built-in low pass filter. The system recognizes any motion below 50 Hz. If the system has dynamic motion higher than 50 Hz, then ODR needs to be increased to a higher setting in order to cover all useful system signals. ● Ton - Turn-on time: This parameter defines the time required before the accelerometer is ready to output measured acceleration data after exiting power-down mode. For example, at ODR = 100 Hz, the user should wait for a minimum of 1/100 + 1 = 11 ms after exiting from power-down mode before sampling the accelerometer data. ● Top - operating temperature range: This parameter defines the operating temperature range. When the device is operated inside the specified range, proper behavior of the sensor is guaranteed. ● FS - Full-scale measurement range: For tilt sensing applications, a ±2.0 g range is sufficient because the Earth’s gravity is ±1 g only. If the application requires measurement of higher g acceleration, the user can set the LIS331DLH to a higher fullscale range of ±4.0 g or ±8.0 g, which results in lower sensitivity. ● So - Sensitivity: This parameter defines the value of 1LSB with respect to mg in the digital representation. For example, at ±2.0 g full-scale range, the sensitivity is typically about 1 mg/LSB at 12-bit representation. Therefore, when the sensor is stable on a horizontal surface, the Z axis output is around 1000LSB. ● TCSo - Sensitivity change vs. temperature: This parameter defines how sensitivity changes with temperature. For example, at a ±2.0 g full-scale range, the sensitivity changes within ±0.01%/°C. Therefore, if the environmental temperature changes 40 °C, from 25 °C to 65 °C, then the sensitivity changes within the range of ±0.01% * 40 = ±0.4%, which means the sensitivity change over 40 °C is within 0.996 mg/LSB and 1.004 mg/LSB, which shows that the sensitivity is very stable versus temperature change. Thus, temperature compensation for sensitivity can be ignored. ● TyOff - Typical zero-g level offset accuracy: This parameter defines the zero-g accuracy at a room temperature of 25 °C. For example, at a ±2.0 g full-scale range, the zero-g accuracy of ±20 mg means that the zero-g output varies typically in the range of ±20 mg around the expected ideal value. ● TCOff - Zero-g level change vs. temperature: This parameter defines how much the zero-g level is affected by temperature variations. For example, at ±2.0 g full-scale range, the zero-g level changes typically within ±0.1 mg/°C. This means that if the environmental temperature changes 40 °C, from 25 °C to 65 °C, then the zero-g level changes within the range of ±0.1 mg * 40 = ±4 mg, which shows that the zero-g level is Doc ID 17289 Rev 1 5/18 Terminology AN3182 very stable versus temperature change. So temperature compensation for the zero-g level can be ignored. ● An - Acceleration noise density: This parameter defines the standard resolution the user can obtain from the accelerometer (once the desired BW is selected). 1 σ resolution = An ( μg ⁄ Hz ) ⋅ BW ( Hz ) . The higher BW leads to lower resolution. 1.3 ● NL - Non linearity: This parameter defines the maximum error between the outputs and the best fit straight line. For example, at ±2.0 g full-scale range, the non linearity of 0.5% of FS means the largest error is 0.5% * 4000 mg = 2 mg, which corresponds to 0.1°. When the application requires measurements of around the 0 g condition (as with tilt measurement), the non-linearity effect is negligible and can be ignored. ● CrossAx - Cross-axis sensitivity: The cross-axis effect arises due to natural misalignment of die positioning on the package substrate. Even if negligible in most applications, for very accurate tilt measurement the cross-axis sensitivity effect can be easily compensated for by following the procedure in Section 2: Calibrating the accelerometer. Moreover, when the device is placed on the final application board, the accelerometer calibration compensates both the device cross-axis sensitivity, and the misalignment between the accelerometer sensing axes and the board axes. Definitions Assume that the LIS331DLH accelerometer is installed in a handheld device, such as a cell phone, a PDA or simply on a PCB board as shown in Figure 1. Figure 1. Accelerometer inside a handheld device ;E 5ROO =$ /,6'/+ ;$ 3LWFK <$ <E +DQGKHOGGHYLFH =E !-V Xb, Yb and Zb are the handheld device body axes with a forward-right-down configuration. XA, YA and ZA are the accelerometer sensing axes, respectively. Note that the sign of YA and ZA from the sensor measurements need to be reversed to have the sensing axes in the same direction as the device body axes. Pitch and roll angles are referenced to the local horizontal plane, which is perpendicular to the Earth's gravity. ● 6/18 Pitch (α) is defined as the angle between the Xb axis and the horizontal plane. Assume that the pitch angle resolution is 0.1°, then it goes from 0° to +179.9° when rotating around the Yb axis with the Xb axis moving upwards from a flat level, and then keeps moving from a vertical position (+90°) back to a flat level again. The pitch angle goes from 0° to -180° when the Xb axis is moving downwards from a flat level, and then Doc ID 17289 Rev 1 AN3182 Terminology keeps moving from a vertical position (-90°) back to a flat level again. For example, in Figure 2, Yb is fixed, Xb is rotating from Pitch = 0° to +30°, +90°, +150° and +179.9° for a positive direction. ● Roll (β) is defined as the angle between the Yb axis and the horizontal plane. Assume that the roll angle resolution is 0.1°, then it goes from 0° to +179.9° when rotating around the Xb axis with the Yb axis moving downwards from a flat level, and then keeps moving from a vertical position (+90°) back to a flat level again. The roll angle goes from 0° to -180° when the Yb axis is moving upwards from a flat level, and then keeps moving from a vertical position (-90°) back to a flat level again. For example, in Figure 3, Xb is fixed, Yb is rotating from roll = 0° to +30°, +90°, +150° and +179.9° for a positive direction. Figure 2. Pitch definition 3LWFK ;E 3LWFK 3LWFK 3LWFK <E 3LWFK 3LWFK 3LWFK Figure 3. 3LWFK !-V Roll definition 5ROO 3LWFK ;E 5ROO 5ROO <E 5ROO 5ROO 5ROO 3LWFK 5ROO !-V Assume Ax, Ay, Az is the accelerometer raw measurement in the format of LSBs. Table 2 shows the sign definition of the raw sensor data at 6 stationary positions with respect to the known Earth gravity vector. For example, in Figure 1, Xb and Yb are level and Zb is pointing down. Therefore, Ax = Ay = 0, Az = +1 g. Doc ID 17289 Rev 1 7/18 Terminology AN3182 Table 2. Sign definition of LIS331DLH sensor raw measurements Accelerometer (signed integer) Stationary position 8/18 Ax Ay Az Zb down 0 0 +1 g Zb up 0 0 -1 g Yb down 0 +1 g 0 Yb up 0 -1 g 0 Xb down +1 g 0 0 Xb up -1 g 0 0 Doc ID 17289 Rev 1 AN3182 2 Calibrating the accelerometer Calibrating the accelerometer Section 1 describes the accelerometer parameters and the definition of the pitch and roll tilt angles. The next step is to calibrate the accelerometer before tilt calculation can take place. Please note that all accelerometers from ST, including the LIS331DLH, have been factorycalibrated. For most applications, such as screen portrait/landscape rotation and laptop lid open/close detection, accelerometer calibration is not necessary. This means that users can use the zero-g level and sensitivity parameters from the datasheet directly to convert raw measurements Ax, Ay and Az to normalized measurements Ax1, Ay1 and Az1. For applications that require better than 1° tilt-measurement accuracy, such as automobile alert systems, tilt-compensated electronic compasses and level monitoring systems, accelerometer calibration is suggested. The relationship between the normalized Ax1, Ay1 and Az1 and the accelerometer raw measurements Ax, Ay and Az can be expressed as, Equation 1 0 0 ⎡1/ A _ SC x ⎤ ⎡A x − A _ OS x ⎤ ⎡ A x1 ⎤ ⎥ ⎢ ⎥ ⎢ ⎢ ⎥ [ ] A A _ m 0 1 / A _ SC 0 = y 1 y 3 x 3 ⎢ ⎥ ⋅ ⎢A y − A _ OS y ⎥ ⎢ ⎥ ⎢ ⎢⎣ ⎥ ⎢⎣ A z1 ⎥⎦ 0 0 1/ A _ SC z ⎦ ⎣ A z − A _ OS z ⎥⎦ ⎡ ACC11 ACC12 ACC13 ⎤ ⎡A x ⎤ ⎡ ACC10 ⎤ ⎥ ⎢ ⎥ ⎢ ⎥ ⎢ = ⎢ACC 21 ACC 22 ACC 23 ⎥ ⋅ ⎢A y ⎥ + ⎢ACC 20 ⎥ ⎢⎣ACC 31 ACC 32 ACC 33 ⎥⎦ ⎢⎣ A z ⎥⎦ ⎢⎣ACC 30 ⎥⎦ where [A_m] is the 3 x 3 misalignment matrix between the accelerometer sensing axes and the device body axes, A_SCi (i = x, y, z) is the sensitivity (or scale factor) and A_OSi is the zero-g level (or offset). The goal of accelerometer calibration is to determine 12 parameters from ACC10 to ACC33, so that with any given raw measurements at arbitrary positions, the normalized values Ax1, Ay1 and Az1 can be obtained, resulting in: Equation 2 A = A 2x1 + A 2y1 + A 2z1 = 1 Calibration can be performed at 6 stationary positions as shown in Table 2. Collect 5 to 10 seconds of accelerometer raw data with ODR = 100 Hz at each position with known Ax1, Ay1 and Az1. Then apply the least square method to obtain the 12 accelerometer calibration parameters. Refer to Appendix A for additional details. Doc ID 17289 Rev 1 9/18 Calculating tilt angles AN3182 3 Calculating tilt angles 3.1 Theory of operation Figure 4 shows the single sensing axis of the accelerometer for tilt measurement. Figure 4. Tilt measurement using a single axis of the accelerometer 6HQVLQJ$[LVRIWKHDFFHOHURPHWHU Į $ J Į Į +RUL]RQWDOSODQH !-V The accelerometer measures the projection of the gravity vector on the sensing axis. The amplitude of the sensed acceleration changes as the sin of the angle α between the sensitive axis and the horizontal plane. Equation 3 A = g × sin(α) Using Equation 3, it is possible to estimate the tilt angle, Equation 4 A α = arcsin( ) g where: ● A = acceleration measured ● g = Earth gravity vector A single axis of the accelerometer with 360° rotation is shown in Figure 5 and 6. 10/18 Doc ID 17289 Rev 1 AN3182 Calculating tilt angles Figure 5. 360° rotation of a single axis of the accelerometer J D[ J ; Į D[ D[ J !-V Figure 6. Plot of 360° rotation of a single axis of the accelerometer $FFHOHUDWLRQ>J@ $QJOH>@ !-V 3.2 Tilt sensing 3.2.1 Single-axis tilt sensing From Figure 5 and 6, it can be observed that the sensor is most responsive to changes in tilt angle when the sensing axis is perpendicular to the force of gravity. In this case, the sensitivity is approximately 17.45 mg/° [= sin(1°) - sin(0°)]. Due to the derivate function of the sin function, the sensor has lower sensitivity (less responsive to tilt angle changes) when the sensing axis is close to its +1 g or -1 g position. In this case, sensitivity is only 0.15 mg/° [= sin(90°) - sin(89°)]. Table 3 shows the sensitivity at different tilt angles. In other words, the sin function has good linearity at [0° 45°], [135° 225°] and [315° 36°] as shown in Figure 6. Table 3. Tilt sensitivity of single axis accelerometer Tilt [°] Acceleration [g] Δg /° [mg/°] 0 0.000 17.452 15 0.259 16.818 30 0.500 15.038 45 0.707 12.233 Doc ID 17289 Rev 1 11/18 Calculating tilt angles Table 3. 3.2.2 AN3182 Tilt sensitivity of single axis accelerometer (continued) Tilt [°] Acceleration [g] Δg /° [mg/°] 60 0.866 8.594 75 0.966 4.37 90 1.000 0.152 Dual-axis tilt sensing When a dual-axis tilt sensing approach is used, the user should be aware of two different situations in which this approach could limit overall accuracy or even inhibit tilt calculation. ● Figure 7, Example A: Rotate the accelerometer counter-clockwise around the dotted arrow with β angle. When β is less than 45°, the X axis has higher sensitivity, while the Y axis has lower sensitivity. And when β is greater than 45°, the X axis has lower sensitivity while the Y axis has higher sensitivity. Therefore, when the two-axis approach is used, it is always recommended to calculate the angle based on the orthogonal axis to a ±1 g condition. ● Figure 7, Example B: At this position, both the X and Y axes have high sensitivity. However, without the help of a third axis (for example the Z axis), it is impossible to distinguish a tilt angle of 30° from one of 150° because the X axis has the same outputs at these two tilt angles. Figure 7. Tilt sensitivity of a dual-axis accelerometer %XAMPLE " %XAMPLE ! ȕ 6\PJ ȕ! 6\!PJ < J J ȕ ; ; < !-V 3.2.3 Tri-axis tilt sensing With a 3-axis accelerometer, the user can use the Z axis to combine with the X and Y axes for tilt sensing, to improve tilt sensitivity and accuracy (see Figure 8). There are two ways to calculate 3 tilt angles in Figure 8. The first is use basic trigonometric Equation 5, 6 and 7, where Ax1, Ay1 and Az1 are the values obtained after applying accelerometer calibration on raw measurement data (Ax, Ay, Az), as described in Section 2. Equation 5 ⎛A ⎞ α = arcsin⎜⎜ x1 ⎟⎟ ⎝ g ⎠ 12/18 Doc ID 17289 Rev 1 AN3182 Calculating tilt angles Equation 6 ⎛ A y1 ⎞ ⎟ β = arcsin⎜⎜ ⎟ ⎝ g ⎠ Equation 7 ⎛A ⎞ γ = arccos⎜⎜ z1 ⎟⎟ ⎝ g ⎠ Figure 8. Tilt angles from a tri-axis accelerometer Į ; ȕ Ȗ < = !-V The second way is to use trigonometric Equation 8 and 9 to calculate pitch and roll tilt angle, which produces constant sensitivity over 360° of rotation, as shown in Figure 9. Equation 8 ⎛ ⎜ Pitch = α = arctan⎜ ⎜ ⎝ A x1 (A y1 )2 + (A z1 )2 ⎞ ⎟ ⎟ ⎟ ⎠ Equation 9 ⎛ ⎜ Roll = β = arctan⎜ ⎜ ⎝ Figure 9. A y1 (A x1 )2 + (A z1 )2 ⎞ ⎟ ⎟ ⎟ ⎠ Tilt sensitivity of a tri-axis accelerometer $UFVLQ ; $UFFRV = $UFWDQ ;= 7LOWVHQVLWLYLW\>PJ@ 7LOWLQJ>@ Doc ID 17289 Rev 1 !-V 13/18 Least square method Appendix A AN3182 Least square method Let's consider accelerometer calibration at the 6 stationary positions shown in Table 2. Equation 1 can be rewritten as: Equation 10 [A x1 ] [ A y1 A z1 = A x Ay Az ⎡ ACC11 ⎢ ACC12 1⋅⎢ ⎢ACC13 ⎢ ⎣ACC10 ] ACC 21 ACC 22 ACC 23 ACC 20 ACC 31 ⎤ ⎥ ACC 32 ⎥ ACC 33 ⎥ ⎥ ACC 30 ⎦ Or Equation 11 Y = w⋅X where: ● Matrix X is the 12 calibration parameters that need to be determined ● Matrix w is sensor raw data LSBs collected at 6 stationary positions ● Matrix Y is the known normalized Earth gravity vector For example, ● At Zb down position (P1 position), [A x1 A y1 A z1] = [0 0 1] , and assume that at Zb down position, n1 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, Equation 12 Y1 = [0 0 1]n1x 3 [ ] w1 = A xP1 A yP1 A zP1 1 n1x 4 where: Matrix Y1 has the same row of [0 0 1]. Matrix w1 contains raw data in the format of LSBs. ● At Zb up position (P2 position), [A x1 A y1 A z1] = [0 0 − 1] , and assume that at Zb up position, n2 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, Equation 13 Y2 = [0 0 − 1]n2 x 3 [ w 2 = A xP2 ● At Yb down position (P3 position), [A x1 A yP2 ] A zP2 1 n2 x 4 ] A y1 A z1 = [0 1 0] , and assume that at Yb down position, n3 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, 14/18 Doc ID 17289 Rev 1 AN3182 Least square method Equation 14 Y3 = [0 1 0]n3 x 3 [ w 3 = A xP3 ● Y4 = [0 − 1 0]n4 x 3 [ w 4 = A xP4 A yP4 ] A zP4 1 n4 x 4 At Xb down position (P5 position), [A x1 A y1 A z1] = [1 0 0] , and assume that at Xb down position, n5 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, Equation 16 Y5 = [1 0 0]n5 x 3 [ w 5 = A xP5 ● A zP3 1 n3 x 4 At Yb up position (P4 position), [A x1 A y1 A z1] = [0 − 1 0] , and assume that at Yb up position, n4 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, Equation 15 ● ] A yP3 At Xb up position (P6 position), [A x1 ] A yP5 A zP5 1 n5 x 4 ] A y1 A z1 = [− 1 0 0] , and assume that at Xb up position, n6 sets of accelerometer raw data Ax, Ay and Az have been collected. Then, Equation 17 Y6 = [− 1 0 0]n6 x 3 [ w 6 = A xP6 A yP6 ] A zP6 1 n6 x 4 Combine Equation 12 to 17 and let n = n1 + n2 + n3 + n4 + n5 + n6, then Equation 11 becomes: Equation 18 Ynx 3 = w nx 4 ⋅ X 4 x 3 where: Equation 19 ⎡Y1 ⎤ ⎢ ⎥ ⎢Y2 ⎥ ⎢Y3 ⎥ Y=⎢ ⎥ ⎢Y4 ⎥ ⎢Y ⎥ ⎢ 5⎥ ⎢⎣Y6 ⎥⎦ nx 3 ⎡w1 ⎤ ⎢ ⎥ ⎢w 2 ⎥ ⎢w 3 ⎥ w=⎢ ⎥ ⎢w 4 ⎥ ⎢w ⎥ ⎢ 5⎥ ⎢⎣w 6 ⎥⎦ nx 4 Doc ID 17289 Rev 1 15/18 Least square method AN3182 Therefore, the calibration parameter matrix X can be determined by the least square method as: Equation 20 [ X = wT ⋅ w ] −1 ⋅ wT ⋅ Y where: Equation 21 w T means matrix transpose [w 16/18 T ⋅w ] −1 means matrix inverse Doc ID 17289 Rev 1 AN3182 Revision history Revision history Table 4. Document revision history Date Revision 21-Apr-2010 1 Changes Initial release. Doc ID 17289 Rev 1 17/18 AN3182 Please Read Carefully: Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries (“ST”) reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice. All ST products are sold pursuant to ST’s terms and conditions of sale. Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein. UNLESS OTHERWISE SET FORTH IN ST’S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER’S OWN RISK. Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST. ST and the ST logo are trademarks or registered trademarks of ST in various countries. Information in this document supersedes and replaces all information previously supplied. The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners. © 2010 STMicroelectronics - All rights reserved STMicroelectronics group of companies Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan Malaysia - Malta - Morocco - Philippines - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com 18/18 Doc ID 17289 Rev 1