

# AN4682 Application note

LSM6DS33: always-on 3D accelerometer and 3D gyroscope

#### Introduction

This document is intended to provide usage information and application hints related to ST's LSM6DS33 iNEMO inertial module.

The LSM6DS33 is a 3D digital accelerometer and 3D digital gyroscope system-in-package with a digital I<sup>2</sup>C/SPI serial interface standard output, performing at 0.9 mA in combo Normal mode and 1.25 mA (up to 1.6 kHz) in combo High-Performance mode. Thanks to the ultra-low noise performance of both the gyroscope and the accelerometer, the device combines always-on low-power features with superior sensing precision for an optimal motion experience for the consumer. Furthermore, the accelerometer features smart sleep-to-wake-up (Activity) and return-to-sleep (Inactivity) functions that allow advanced power saving.

The device has a dynamic user-selectable full-scale acceleration range of  $\pm 2/\pm 4/\pm 8/\pm 16~g$  and an angular rate range of  $\pm 125/\pm 250/\pm 500/\pm 1000/\pm 2000$  dps.

The LSM6DS33 can be configured to generate interrupt signals by using hardware recognition of free-fall events, 6D orientation, tap and double-tap sensing, activity or inactivity, wake-up events.

The LSM6DS33 is compatible with the requirements of the leading OSs, offering real, virtual and batch-mode sensors. It has been designed to implement in hardware significant motion, tilt, pedometer functions and timestamp.

The LSM6DS33 has an integrated smart first-in first-out (FIFO) buffer of up to 8 kbyte size, allowing dynamic batching of significant data (i.e. sensors, step counter, timestamp and temperature).

The LSM6DS33 is available in a small plastic land grid array package (LGA-16L) and it is guaranteed to operate over an extended temperature range from -40 °C to +85 °C.

The ultra-small size and weight of the SMD package make it an ideal choice for handheld portable applications such as smartphones, IoT connected devices, and wearables or any other application where reduced package size and weight are required.

January 2018 DocID027736 Rev 5 1/96

Contents AN4682

### **Contents**

| 1 | Pin  | descript                  | ion                                                               | 8  |  |  |  |
|---|------|---------------------------|-------------------------------------------------------------------|----|--|--|--|
| 2 | Regi | isters .                  |                                                                   | 10 |  |  |  |
|   | 2.1  | Embed                     | ded functions registers                                           | 14 |  |  |  |
| 3 | Ope  | rating m                  | odes                                                              | 15 |  |  |  |
|   | 3.1  | Power-                    | Down mode                                                         | 17 |  |  |  |
|   | 3.2  | High-P                    | erformance mode                                                   | 17 |  |  |  |
|   | 3.3  | Normal                    | I mode                                                            | 17 |  |  |  |
|   | 3.4  | Low-Po                    | ower mode                                                         | 17 |  |  |  |
|   | 3.5  | Gyrosc                    | cope Sleep mode                                                   | 17 |  |  |  |
|   | 3.6  | Changi                    | ing the power mode in accelerometer-only mode                     | 18 |  |  |  |
|   | 3.7  | Acceler                   | rometer bandwidth                                                 | 20 |  |  |  |
|   |      | 3.7.1                     | Accelerometer slope filter                                        | 25 |  |  |  |
|   | 3.8  | Gyrosc                    | ope bandwidth                                                     | 26 |  |  |  |
|   | 3.9  | Acceler                   | rometer and gyroscope turn-on/off time                            | 28 |  |  |  |
| 4 | Read | ding out                  | put data                                                          | 31 |  |  |  |
|   | 4.1  | Startup                   | ·<br>o sequence                                                   | 31 |  |  |  |
|   | 4.2  |                           | he status register                                                |    |  |  |  |
|   | 4.3  | _                         | he data-ready signal                                              |    |  |  |  |
|   |      | 4.3.1                     | DRDY mask functionality                                           |    |  |  |  |
|   | 4.4  | Using t                   | he block data update (BDU) feature                                | 33 |  |  |  |
|   | 4.5  | Understanding output data |                                                                   |    |  |  |  |
|   |      | 4.5.1                     | Big-little endian selection                                       | 33 |  |  |  |
|   |      | 4.5.2                     | Examples of output data                                           |    |  |  |  |
|   | 4.6  | Roundi                    | ing functions                                                     | 35 |  |  |  |
|   |      | 4.6.1                     | Rounding of FIFO output registers                                 | 35 |  |  |  |
|   |      | 4.6.2                     | Rounding of source registers                                      | 35 |  |  |  |
|   |      | 4.6.3                     | Rounding of sensor output registers                               | 35 |  |  |  |
|   | 4.7  | •                         | cope edge-sensitive/level-sensitive/impulse-sensitive nable (DEN) | 36 |  |  |  |
|   |      | 4.7.1                     | Edge-sensitive trigger                                            |    |  |  |  |



|   |       | 4.7.2      | Level-sensitive trigger stamping                    | 38   |
|---|-------|------------|-----------------------------------------------------|------|
|   |       | 4.7.3      | Impulse-sensitive trigger stamping                  | 38   |
|   | 4.8   | Gyros      | cope axes orientation                               | . 38 |
| 5 | Inter | rupt ge    | neration                                            | . 40 |
|   | 5.1   | Interru    | pt pin configuration                                | . 40 |
|   | 5.2   | Free-fa    | all interrupt                                       | . 42 |
|   | 5.3   | Wake-      | up interrupt                                        | . 44 |
|   | 5.4   | 6D/4D      | orientation detection                               | . 46 |
|   |       | 5.4.1      | 6D orientation detection                            | 46   |
|   |       | 5.4.2      | 4D orientation detection                            | 48   |
|   | 5.5   | Single     | -tap and double-tap recognition                     | . 48 |
|   |       | 5.5.1      | Single tap                                          | 48   |
|   |       | 5.5.2      | Double tap                                          | 49   |
|   |       | 5.5.3      | Single-tap and double-tap recognition configuration | . 50 |
|   |       | 5.5.4      | Single-tap example                                  | 52   |
|   |       | 5.5.5      | Double-tap example                                  | 53   |
|   | 5.6   | Activity   | y/Inactivity recognition                            | . 53 |
|   | 5.7   | Boot s     | tatus                                               | . 55 |
| 6 | And   | roid em    | bedded functions                                    | . 57 |
|   | 6.1   | Pedon      | neter functions: step detector and step counter     | . 57 |
|   | 6.2   | Signifi    | cant motion                                         | . 60 |
|   | 6.3   | Tilt       |                                                     | . 62 |
|   | 6.4   |            | tamp                                                |      |
| 7 | First | :-in first | -out (FIFO) buffer                                  | . 65 |
|   | 7.1   | FIFO r     | registers                                           | . 66 |
|   |       | 7.1.1      | FIFO_CTRL1 (06h)                                    | 66   |
|   |       | 7.1.2      | FIFO_CTRL2 (07h)                                    | 66   |
|   |       | 7.1.3      | FIFO_CTRL3 (08h)                                    | 67   |
|   |       | 7.1.4      | FIFO_CTRL4 (09h)                                    | 68   |
|   |       | 7.1.7      |                                                     |      |
|   |       | 7.1.5      | FIFO_CTRL5 (0Ah)                                    | 68   |
|   |       |            | FIFO_CTRL5 (0Ah)                                    |      |
|   |       | 7.1.5      |                                                     | 70   |

|    |       | 7.1.9    | FIFO_STATUS4 (3Dh)                                | 71 |
|----|-------|----------|---------------------------------------------------|----|
|    |       | 7.1.10   | FIFO_DATA_OUT_L (3Eh)                             | 72 |
|    |       | 7.1.11   | FIFO_DATA_OUT_H (3Fh)                             | 72 |
|    | 7.2   | FIFO n   | modes                                             | 72 |
|    |       | 7.2.1    | Bypass mode                                       | 72 |
|    |       | 7.2.2    | FIFO mode                                         | 73 |
|    |       | 7.2.3    | Continuous mode                                   | 74 |
|    |       | 7.2.4    | Continuous-to-FIFO mode                           | 76 |
|    |       | 7.2.5    | Bypass-to-Continuous mode                         | 78 |
|    | 7.3   | Setting  | the FIFO trigger, FIFO ODR and decimation factors | 80 |
|    |       | 7.3.1    | Procedure for ODR changes when using FIFO         | 81 |
|    | 7.4   | Retriev  | ving data from the FIFO                           | 82 |
|    | 7.5   | FIFO p   | pattern                                           | 82 |
|    |       | 7.5.1    | Example 1                                         | 83 |
|    |       | 7.5.2    | Example 2                                         | 83 |
|    |       | 7.5.3    | Example 3                                         | 84 |
|    | 7.6   | FIFO tl  | hreshold                                          | 85 |
|    | 7.7   | High pa  | art of gyroscope and accelerometer data           | 88 |
|    | 7.8   | Step co  | ounter and timestamp data in FIFO                 | 88 |
|    | 7.9   | Tempe    | erature data in FIFO                              | 89 |
| 8  | Tem   | perature | e sensor                                          | 90 |
|    | 8.1   | Examp    | ole of temperature data calculation               | 91 |
| 9  | Self- | test     |                                                   | 92 |
|    | 9.1   | Accele   | rometer self-test                                 | 92 |
|    | 9.2   | Gyroso   | cope self-test                                    | 92 |
| 10 | Povi  | sion his | etony                                             | 95 |

AN4682 List of tables

## List of tables

| Table 1.  | Pin status                                                                  | 9  |
|-----------|-----------------------------------------------------------------------------|----|
| Table 2.  | Registers                                                                   | 10 |
| Table 3.  | Embedded functions registers                                                | 14 |
| Table 4.  | Accelerometer ODR and power mode selection                                  | 15 |
| Table 5.  | Gyroscope ODR and power mode selection                                      | 16 |
| Table 6.  | Power consumption                                                           |    |
| Table 7.  | Accelerometer anti-aliasing filter bandwidth selection (XL_BW_SCAL_ODR = 1) | 20 |
| Table 8.  | Accelerometer anti-aliasing bandwidth options (High-Performance mode)       |    |
| Table 9.  | Accelerometer LPF1 cutoff frequency                                         |    |
| Table 10. | Accelerometer anti-aliasing + LPF1 overall cutoff frequency                 |    |
| Table 11. | Accelerometer slope and high-pass filter selection and cutoff frequency     |    |
| Table 12. | Accelerometer LPF2 cutoff frequency.                                        |    |
| Table 13. | Gyroscope digital low-pass filter cutoff in Low-Power / Normal mode         |    |
| Table 14. | Gyroscope digital low-pass filter cutoff in High-Performance mode           |    |
| Table 15. | Gyroscope high-pass filter cutoff frequency [Hz]                            |    |
| Table 16. | Accelerometer/gyroscope turn-on/off times                                   |    |
| Table 17. | Accelerometer number of samples to be discarded                             |    |
| Table 18. | Gyroscope number of samples to be discarded                                 |    |
| Table 19. | Output data registers content vs. acceleration (FS_XL = ±2 g)               |    |
| Table 20. | Output data registers content vs. angular rate (FS_G = ±250 dps)            |    |
| Table 21. | Output registers rounding pattern                                           |    |
| Table 22. | DEN configurations                                                          |    |
| Table 23. | ORIENT_CFG_G register                                                       |    |
| Table 24. | Settings for gyroscope axes orientation                                     |    |
| Table 25. | INT1_CTRL register                                                          |    |
| Table 26. | MD1_CFG register                                                            |    |
| Table 27. | INT2_CTRL register                                                          |    |
| Table 28. | MD2_CFG register                                                            |    |
| Table 29. | Free-fall threshold LSB value                                               |    |
| Table 30. | D6D_SRC register                                                            |    |
| Table 31. | Threshold for 4D/6D function                                                |    |
| Table 32. | D6D_SRC register in 6D positions                                            |    |
| Table 33. | TAP_SRC register                                                            |    |
| Table 34. | FIFO_CTRL1 register                                                         |    |
| Table 35. | FIFO_CTRL2 register                                                         |    |
| Table 36. | FIFO_CTRL3 register                                                         |    |
| Table 37. | Gyroscope FIFO decimation setting                                           |    |
| Table 38. | Accelerometer FIFO decimation setting                                       |    |
| Table 39. | FIFO_CTRL4 register                                                         |    |
| Table 40. | 3 <sup>rd</sup> FIFO data set decimation setting                            |    |
| Table 41. | FIFO CTRL5 register                                                         |    |
| Table 42. | FIFO ODR selection setting                                                  |    |
| Table 43. | FIFO mode selection.                                                        |    |
| Table 44. | FIFO STATUS1 register                                                       |    |
| Table 45. | FIFO STATUS2 register                                                       |    |
| Table 46. | FIFO_STATUS2 behavior (case with one sensor in FIFO, STOP_ON_FTH =0)        |    |
| Table 47. | FIFO STATUS3 register                                                       |    |
| Table 48. | FIFO_STATUS4 register                                                       |    |
|           |                                                                             |    |



List of tables AN4682

| Table 49. | FIFO_DATA_OUT_L register                              | . 72 |
|-----------|-------------------------------------------------------|------|
| Table 50. | FIFO_DATA_OUT_H register                              |      |
| Table 51. | Example 1: FIFO_PATTERN_[9:0] bits and next reading   | . 83 |
| Table 52. | Example 2: FIFO_PATTERN_[9:0] bits and next reading   | . 84 |
| Table 53. | Example 3: FIFO_PATTERN_[9:0] bits and next reading   |      |
| Table 54. | High part of gyroscope and accelerometer data in FIFO | . 88 |
| Table 55. | Timestamp and pedometer data in FIFO                  | . 88 |
| Table 56. | Temperature data in FIFO                              | . 89 |
| Table 57. | Output data registers content vs. temperature         | . 91 |
| Table 58. | Document revision history                             | . 95 |

AN4682 List of figures

## List of figures

| igure 1.   | Pin connections                                        | 8  |
|------------|--------------------------------------------------------|----|
| igure 2.   | Switching power modes (no change in ODR)1              | 9  |
| igure 3.   | Switching power modes (with subsequent change in ODR)1 | 9  |
| igure 4.   | Accelerometer sampling chain diagram                   | 0. |
| igure 5.   | Accelerometer composite digital filter                 |    |
| igure 6.   | Accelerometer slope filter                             |    |
| igure 7.   | Gyroscope sampling chain diagram                       |    |
| igure 8.   | Gyroscope high-pass filter reset                       |    |
| igure 9.   | Data-ready signal                                      |    |
| igure 10.  | Data synchronization: edge-sensitive                   |    |
| Figure 11. | Storing synchronized data in FIFO                      |    |
| igure 12.  | Data synchronization: level-sensitive                  |    |
| igure 13.  | Gyroscope axes orientation and sign configuration      |    |
| igure 14.  | Gyroscope axes orientation and sign example            |    |
| igure 15.  | Free-fall interrupt                                    |    |
| igure 16.  | Wake-up interrupt (using the slope filter)             |    |
| igure 17.  | 6D recognized orientations                             |    |
| igure 18.  | Single-tap event recognition                           |    |
| igure 19.  | Double-tap event recognition (LIR bit = 0)             |    |
| igure 20.  | Single and double-tap recognition (LIR bit = 0)5       |    |
| igure 21.  | Activity/Inactivity recognition5                       |    |
| igure 22.  | Pedometer debounce                                     |    |
| igure 23.  | Pedometer minimum threshold5                           |    |
| igure 24.  | Tilt example                                           |    |
| igure 25.  | FIFO mode (STOP_ON_FTH=0)                              |    |
| igure 26.  | Continuous mode                                        |    |
| igure 27.  | Continuous-to-FIFO mode                                |    |
| igure 28.  | Bypass-to-Continuous mode                              |    |
| igure 29.  | FIFO trigger signal selection                          |    |
| igure 30.  | FIFO threshold (STOP_ON_FTH = 0)                       |    |
| igure 31.  | FIFO threshold (STOP_ON_FTH = 1) in FIFO mode          |    |
| igure 32.  | FIFO threshold (STOP_ON_FTH = 1) in Continuous mode    |    |
| igure 33.  | Accelerometer self-test procedure                      |    |
| Figure 34. | Gyroscope self-test procedure                          | 14 |



Pin description AN4682

## 1 Pin description

Figure 1. Pin connections



<sup>1.</sup> Leave pin electrically unconnected and soldered to PCB.

AN4682 Pin description

Table 1. Pin status

| Pin# | Name    | Function                                                                                                                                               | Pin status                                                                                |
|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 1    | VDDIO   | Power supply for I/O pins                                                                                                                              |                                                                                           |
| 2    | SCL     | I <sup>2</sup> C serial clock (SCL)<br>SPI serial port clock (SPC)                                                                                     | Input without pull-up                                                                     |
| 3    | SDA     | I <sup>2</sup> C serial data (SDA) SPI serial data input (SDI) 3-wire interface serial data output (SDO)                                               | Input without pull-up                                                                     |
| 4    | SDO/SA0 | SPI 4-wire interface serial data output (SDO) I <sup>2</sup> C least significant bit of the device address (SA0)                                       | Default: Input without pull-up. Pull-up is enabled if SIM bit =1 (SPI 3-wire) in reg 12h. |
| 5    | CS      | I <sup>2</sup> C/SPI mode selection (1: SPI idle mode / I <sup>2</sup> C communication enabled; 0: SPI communication mode / I <sup>2</sup> C disabled) | Default: Input with pull-up. Pull-up is disabled if I2C_disable bit = 1 in reg 13h.       |
| 6    | INT2    | Programmable interrupt 2 (INT2) /<br>Data enabled (DEN)                                                                                                | Default: Output forced to ground                                                          |
| 7    | INT1    | Programmable interrupt 1                                                                                                                               | Default: Output forced to ground                                                          |
| 8    | RES     | Reserved, connect to GND                                                                                                                               | Internally unconnected                                                                    |
| 9    | RES     | Reserved, connect to GND                                                                                                                               | Internally connected to GND                                                               |
| 10   | RES     | Reserved, connect to GND                                                                                                                               | Internally unconnected                                                                    |
| 11   | RES     | Reserved, connect to GND                                                                                                                               | Input without pull-up                                                                     |
| 12   | GND     | 0 V supply                                                                                                                                             |                                                                                           |
| 13   | GND     | 0 V supply                                                                                                                                             |                                                                                           |
| 14   | NC      | Leave unconnected                                                                                                                                      | Internally unconnected                                                                    |
| 15   | RES     | Reserved, connect to GND                                                                                                                               | Input without pull-up                                                                     |
| 16   | VDD     | Power supply                                                                                                                                           |                                                                                           |

Internal pull-up value is from 30 k $\Omega$  to 50 k $\Omega,$  depending on VDDIO.



## Registers

Table 2. Registers

| Register name   | Address | Bit7                   | Bit6                     | Bit5                         | Bit4                         | Bit3                         | Bit2               | Bit1             | Bit0             |
|-----------------|---------|------------------------|--------------------------|------------------------------|------------------------------|------------------------------|--------------------|------------------|------------------|
| FUNC_CFG_ACCESS | 01h     | FUNC_CFG<br>_EN        | 0                        | 0                            | 0                            | 0                            | 0                  | 0                | 0                |
| FIFO_CTRL1      | 06h     | FTH_7                  | FTH_6                    | FTH_5                        | FTH_4                        | FTH_3                        | FTH_2              | FTH_1            | FTH_0            |
| FIFO_CTRL2      | 07h     | TIMER_PEDO<br>_FIFO_EN | TIMER_PEDO<br>_FIFO_DRDY | 0                            | 0                            | FTH_11                       | FTH_10             | FTH_9            | FTH_8            |
| FIFO_CTRL3      | 08h     | 0                      | 0                        | DEC_FIFO<br>_GYRO2           | DEC_FIFO<br>_GYRO1           | DEC_FIFO<br>_GYRO0           | DEC_FIFO<br>_XL2   | DEC_FIFO<br>_XL1 | DEC_FIFO<br>_XL0 |
| FIFO_CTRL4      | 09h     | 0                      | ONLY_HIGH<br>_DATA       | TIMER_<br>PEDO_<br>DEC_FIFO2 | TIMER_<br>PEDO_<br>DEC_FIFO1 | TIMER_<br>PEDO_<br>DEC_FIFO0 | 0                  | 0                | 0                |
| FIFO_CTRL5      | 0Ah     | 0                      | ODR_FIFO                 | ODR_FIFO<br>_2               | ODR_FIFO<br>_1               | ODR_FIFO<br>_0               | FIFO_MODE<br>_2    | FIFO_MODE<br>_1  | FIFO_MODE<br>_0  |
| ORIENT_CFG_G    | 0Bh     | 0                      | 0                        | SignX_G                      | SignY_G                      | SignZ_G                      | Orient_2           | Orient_1         | Orient_0         |
| INT1_CTRL       | 0Dh     | INT1_STEP<br>_DETECTOR | INT1_SIG<br>_MOT         | INT1_FULL_<br>FLAG           | INT1_FIFO_<br>OVR            | INT1_FTH                     | INT1_BOOT          | INT1_DRDY<br>_G  | INT1_DRDY<br>_XL |
| INT2_CTRL       | 0Eh     | INT2_STEP<br>_DELTA    | INT2_STEP<br>_COUNT_OV   | INT2_FULL_<br>FLAG           | INT2_FIFO_<br>OVR            | INT2_FTH                     | INT2_DRDY<br>_TEMP | INT2_DRDY<br>_G  | INT2_DRDY<br>_XL |
| WHO_AM_I        | 0Fh     | 0                      | 1                        | 1                            | 0                            | 1                            | 0                  | 0                | 1                |
| CTRL1_XL        | 10h     | ODR_XL3                | ODR_XL2                  | ODR_XL1                      | ODR_XL0                      | FS_XL1                       | FS_XL0             | BW_XL1           | BW_XL0           |
| CTRL2_G         | 11h     | ODR_G3                 | ODR_G2                   | ODR_G1                       | ODR_G0                       | FS_G1                        | FS_G0              | FS_125           | 0                |
| CTRL3_C         | 12h     | воот                   | BDU                      | H_LACTIVE                    | PP_OD                        | SIM                          | IF_INC             | BLE              | SW_RESET         |
| CTRL4_C         | 13h     | XL_BW_<br>SCAL_ODR     | SLEEP_G                  | INT2_on<br>_INT1             | FIFO_TEMP<br>_EN             | DRDY<br>_MASK                | I2C_disable        | 0                | STOP_ON<br>_FTH  |
| CTRL5_C         | 14h     | ROUNDING2              | ROUNDING1                | ROUNDING0                    | 0                            | ST1_G                        | ST0_G              | ST1_XL           | ST0_XL           |

DocID027736 Rev 5

| П |  |
|---|--|
| П |  |
| ı |  |
|   |  |
|   |  |
|   |  |
| i |  |
| П |  |
|   |  |

Table 2. Registers (continued)

| Register name | Address | Bit7       | Bit6     | Bit5           | Bit4               | Bit3     | Bit2                | Bit1              | Bit0               |
|---------------|---------|------------|----------|----------------|--------------------|----------|---------------------|-------------------|--------------------|
| CTRL6_C       | 15h     | TRIG_EN    | LVLen    | LVL2_EN        | XL_HM<br>_MODE     | 0        | 0                   | 0                 | 0                  |
| CTRL7_G       | 16h     | G_HM_MODE  | HP_G_EN  | HPCF_G1        | HPCF_G0            | HP_G_RST | ROUNDING<br>_STATUS | 0                 | 0                  |
| CTRL8_XL      | 17h     | LPF2_XL_EN | HPCF_XL1 | HPCF_XL0       | 0                  | 0        | HP_SLOPE_<br>XL_EN  | 0                 | LOW_PASS<br>_ON_6D |
| CTRL9_XL      | 18h     | 0          | 0        | Zen_XL         | Yen_XL             | Xen_XL   | 0                   | 0                 | 0                  |
| CTRL10_C      | 19h     | 0          | 0        | Zen_G          | Yen_G              | Xen_G    | FUNC_EN             | PEDO_RST<br>_STEP | SIGN_MOTI<br>ON_EN |
| WAKE_UP_SRC   | 1Bh     | 0          | 0        | FF_IA          | SLEEP<br>_STATE_IA | WU_IA    | X_WU                | Y_WU              | Z_WU               |
| TAP_SRC       | 1Ch     | 0          | TAP_IA   | SINGLE<br>_TAP | DOUBLE<br>_TAP     | TAP_SIGN | X_TAP               | Y_TAP             | Z_TAP              |
| D6D_SRC       | 1Dh     | 0          | D6D_IA   | ZH             | ZL                 | YH       | YL                  | XH                | XL                 |
| STATUS_REG    | 1Eh     | -          | -        | -              | -                  | -        | TDA                 | GDA               | XLDA               |
| OUT_TEMP_L    | 20h     | Temp7      | Temp6    | Temp5          | Temp4              | Temp3    | Temp2               | Temp1             | Temp0              |
| OUT_TEMP_H    | 21h     | Temp15     | Temp14   | Temp13         | Temp12             | Temp11   | Temp10              | Temp9             | Temp8              |
| OUTX_L_G      | 22h     | D7         | D6       | D5             | D4                 | D3       | D2                  | D1                | D0                 |
| OUTX_H_G      | 23h     | D15        | D14      | D13            | D12                | D11      | D10                 | D9                | D8                 |
| OUTY_L_G      | 24h     | D7         | D6       | D5             | D4                 | D3       | D2                  | D1                | D0                 |
| OUTY_H_G      | 25h     | D15        | D14      | D13            | D12                | D11      | D10                 | D9                | D8                 |
| OUTZ_L_G      | 26h     | D7         | D6       | D5             | D4                 | D3       | D2                  | D1                | D0                 |
| OUTZ_H_G      | 27h     | D15        | D14      | D13            | D12                | D11      | D10                 | D9                | D8                 |
| OUTX_L_XL     | 28h     | D7         | D6       | D5             | D4                 | D3       | D2                  | D1                | D0                 |
| OUTX_H_XL     | 29h     | D15        | D14      | D13            | D12                | D11      | D10                 | D9                | D8                 |
| OUTY_L_XL     | 2Ah     | D7         | D6       | D5             | D4                 | D3       | D2                  | D1                | D0                 |

| Register name    | Address | Bit7                   | Bit6                   | Bit5                   | Bit4                   | Bit3                   | Bit2                   | Bit1                   | Bit0                   |
|------------------|---------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|
| OUTY_H_XL        | 2Bh     | D15                    | D14                    | D13                    | D12                    | D11                    | D10                    | D9                     | D8                     |
| OUTZ_L_XL        | 2Ch     | D7                     | D6                     | D5                     | D4                     | D3                     | D2                     | D1                     | D0                     |
| OUTZ_H_XL        | 2Dh     | D15                    | D14                    | D13                    | D12                    | D11                    | D10                    | D9                     | D8                     |
| FIFO_STATUS1     | 3Ah     | DIFF_FIFO<br>_7        | DIFF_FIFO<br>_6        | DIFF_FIFO<br>_5        | DIFF_FIFO<br>_4        | DIFF_FIFO<br>_3        | DIFF_FIFO<br>_2        | DIFF_FIFO<br>_1        | DIFF_FIFO<br>_0        |
| FIFO_STATUS2     | 3Bh     | FTH                    | FIFO_OVER_<br>RUN      | FIFO_FULL              | FIFO<br>_EMPTY         | DIFF_FIFO<br>_11       | DIFF_FIFO<br>_10       | DIFF_FIFO<br>_9        | DIFF_FIFO<br>_8        |
| FIFO_STATUS3     | 3Ch     | FIFO_<br>PATTERN_7     | FIFO_<br>PATTERN_6     | FIFO_<br>PATTERN_5     | FIFO_<br>PATTERN_4     | FIFO_<br>PATTERN_3     | FIFO_<br>PATTERN_2     | FIFO_<br>PATTERN_1     | FIFO_<br>PATTERN_0     |
| FIFO_STATUS4     | 3Dh     | 0                      | 0                      | 0                      | 0                      | 0                      | 0                      | FIFO_<br>PATTERN_9     | FIFO_<br>PATTERN_8     |
| FIFO_DATA_OUT_L  | 3Eh     | DATA_OUT<br>_FIFO_L_7  | DATA_OUT<br>_FIFO_L_6  | DATA_OUT<br>_FIFO_L_5  | DATA_OUT<br>_FIFO_L_4  | DATA_OUT<br>_FIFO_L_3  | DATA_OUT<br>_FIFO_L_2  | DATA_OUT<br>_FIFO_L_1  | DATA_OUT<br>_FIFO_L_0  |
| FIFO_DATA_OUT_H  | 3Fh     | DATA_OUT<br>_FIFO_H_7  | DATA_OUT<br>_FIFO_H_6  | DATA_OUT<br>_FIFO_H_5  | DATA_OUT<br>_FIFO_H_4  | DATA_OUT<br>_FIFO_H_3  | DATA_OUT<br>_FIFO_H_2  | DATA_OUT<br>_FIFO_H_1  | DATA_OUT<br>_FIFO_H_0  |
| TIMESTAMP0_REG   | 40h     | TIMESTAMP<br>0_7       | TIMESTAMP<br>0_6       | TIMESTAMP<br>0_5       | TIMESTAMP<br>0_4       | TIMESTAMP<br>0_3       | TIMESTAMP<br>0_2       | TIMESTAMP<br>0_1       | TIMESTAMP<br>0_0       |
| TIMESTAMP1_REG   | 41h     | TIMESTAMP<br>1_7       | TIMESTAMP<br>1_6       | TIMESTAMP<br>1_5       | TIMESTAMP<br>1_4       | TIMESTAMP<br>1_3       | TIMESTAMP<br>1_2       | TIMESTAMP<br>1_1       | TIMESTAMP<br>1_0       |
| TIMESTAMP2_REG   | 42h     | TIMESTAMP<br>2_7       | TIMESTAMP<br>2_6       | TIMESTAMP<br>2_5       | TIMESTAMP<br>2_4       | TIMESTAMP<br>2_3       | TIMESTAMP<br>2_2       | TIMESTAMP<br>2_1       | TIMESTAMP<br>2_0       |
| STEP_TIMESTAMP_L | 49h     | STEP_TIME<br>STAMP_L_7 | STEP_TIME<br>STAMP_L_6 | STEP_TIME<br>STAMP_L_5 | STEP_TIME<br>STAMP_L_4 | STEP_TIME<br>STAMP_L_3 | STEP_TIME<br>STAMP_L_2 | STEP_TIME<br>STAMP_L_1 | STEP_TIME<br>STAMP_L_0 |
| STEP_TIMESTAMP_H | 4Ah     | STEP_TIME<br>STAMP_H_7 | STEP_TIME<br>STAMP_H_6 | STEP_TIME<br>STAMP_H_5 | STEP_TIME<br>STAMP_H_4 |                        | STEP_TIME<br>STAMP_H_2 | STEP_TIME<br>STAMP_H_1 | STEP_TIME<br>STAMP_H_0 |
| STEP_COUNTER_L   | 4Bh     | STEP_COUN<br>TER_L_7   | STEP_COUNT<br>ER_L_6   | STEP_COUN<br>TER_L_5   | STEP_COU<br>NTER_L_4   | STEP_COU<br>NTER_L_3   | STEP_COU<br>NTER_L_2   | STEP_COU<br>NTER_L_1   | STEP_COU<br>NTER_L_0   |
| STEP_COUNTER_H   | 4Ch     | STEP_COUN<br>TER_H_7   | STEP_COUNT<br>ER_H_6   | STEP_COUN<br>TER_H_5   | STEP_COU<br>NTER_H_4   | STEP_COU<br>NTER_H_3   | STEP_COU<br>NTER_H_2   | STEP_COU<br>NTER_H_1   | STEP_COU<br>NTER_H_0   |





Table 2. Registers (continued)

|               |         |                         |                     | . rtogiotoro ( | ,                 |                     |                |                |                |
|---------------|---------|-------------------------|---------------------|----------------|-------------------|---------------------|----------------|----------------|----------------|
| Register name | Address | Bit7                    | Bit6                | Bit5           | Bit4              | Bit3                | Bit2           | Bit1           | Bit0           |
| FUNC_SRC      | 53h     | STEP_COUN<br>T_DELTA_IA | SIGN_<br>MOTION_IA  | TILT_IA        | STEP_<br>DETECTED | STEP_OVE<br>RFLOW   | 0              | 0              | 0              |
| TAP_CFG       | 58h     | TIMER_EN                | PEDO_EN             | TILT_EN        | SLOPE<br>_FDS     | TAP_X_EN            | TAP_Y_EN       | TAP_Z_EN       | LIR            |
| TAP_THS_6D    | 59h     | D4D_EN                  | SIXD_THS1           | SIXD_THS0      | TAP_THS4          | TAP_THS3            | TAP_THS2       | TAP_THS1       | TAP_THS0       |
| INT_DUR2      | 5Ah     | DUR3                    | DUR2                | DUR1           | DUR0              | QUIET1              | QUIET0         | SHOCK1         | SHOCK0         |
| WAKE_UP_THS   | 5Bh     | SINGLE_DOU<br>BLE_TAP   | INACTIVITY          | WK_THS5        | WK_THS4           | WK_THS3             | WK_THS2        | WK_THS1        | WK_THS0        |
| WAKE_UP_DUR   | 5Ch     | FF_DUR5                 | WAKE<br>_DUR1       | WAKE<br>_DUR0  | TIMER_HR          | SLEEP<br>_DUR3      | SLEEP<br>_DUR2 | SLEEP<br>_DUR1 | SLEEP<br>_DUR0 |
| FREE_FALL     | 5Dh     | FF_DUR4                 | FF_DUR3             | FF_DUR2        | FF_DUR1           | FF_DUR0             | FF_THS2        | FF_THS1        | FF_THS0        |
| MD1_CFG       | 5Eh     | INT1_INACT<br>_STATE    | INT1_SINGLE<br>_TAP | INT1_WU        | INT1_FF           | INT1_DOUB<br>LE_TAP | INT1_6D        | INT1_TILT      | INT1<br>_TIMER |
| MD2_CFG       | 5Fh     | INT2_INACT<br>_STATE    | INT2_SINGLE<br>_TAP | INT2_WU        | INT2_FF           | INT2_DOUB<br>LE_TAP | INT2_6D        | INT2_TILT      | 0              |



#### 2.1 Embedded functions registers

The list of the registers for embedded functions available in the device is given in *Table 3*.

Embedded functions registers are accessible when the FUNC\_CFG\_EN bit is set to '1' in the FUNC\_CFG\_ACCESS register.

Note: All modifications to the content of the embedded functions registers have to be performed with both the accelerometer and the

gyroscope sensor in Power-Down mode.

Table 3. Embedded functions registers

| Register name    | Address | Bit7           | Bit6           | Bit5           | Bit4           | Bit3           | Bit2           | Bit1           | Bit0           |
|------------------|---------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| PEDO_THS_REG     | 0Fh     | PEDO_4G        | -              | -              | THS_MIN_4      | THS_MIN_3      | THS_MIN_2      | THS_MIN_1      | THS_MIN_0      |
| SM_THS           | 13h     | SM_THS_7       | SM_THS_6       | SM_THS_5       | SM_THS_4       | SM_THS_3       | SM_THS_2       | SM_THS_1       | SM_THS_0       |
| PEDO_DEB_REG     | 14h     | DEB<br>_TIME_4 | DEB<br>_TIME_3 | DEB<br>_TIME_2 | DEB<br>_TIME_1 | DEB<br>_TIME_0 | DEB<br>_STEP_2 | DEB<br>_STEP_1 | DEB<br>_STEP_0 |
| STEP_COUNT_DELTA | 15h     | SC_DELTA<br>_7 | SC_DELTA<br>_6 | SC_DELTA<br>_5 | SC_DELTA<br>_4 | SC_DELTA<br>_3 | SC_DELTA<br>_2 | SC_DELTA<br>_1 | SC_DELTA<br>_0 |

#### 3 Operating modes

The LSM6DS33 provides three possible operating configurations:

- only accelerometer active and gyroscope in Power-Down;
- only gyroscope active and accelerometer in Power-Down;
- both accelerometer and gyroscope active with independent ODR.

After the power supply is applied, the LSM6DS33 performs a 20 ms boot procedure to load the trimming parameters. After the boot is completed, both the accelerometer and the gyroscope are automatically configured in Power-Down mode.

The accelerometer and the gyroscope can be independently configured in four different power modes: Power-Down, Low-Power, Normal and High-Performance mode. They are allowed to have different data rates without any limit. The gyroscope sensor can also be set in Sleep mode to reduce its power consumption.

When both the accelerometer and gyroscope are on, the accelerometer is synchronized with the gyroscope and the data rates of the two sensors are integer multiples of each other. If the accelerometer and the gyroscope have been configured with the same output data rate, the gyroscope data-ready signal (DRDY\_G) is always subsequent to the accelerometer data-ready signal (DRDY\_XL); in this case, for synchronous reading of the two sensors, it is convenient to use the gyroscope data-ready signal.

Referring to the LSM6DS33 datasheet, the output data rate (ODR\_XL) bits of CTRL1\_XL register and the High-Performance disable (XL\_HM\_MODE) bit of CTRL6\_C register are used to select the power mode and the output data rate of the accelerometer sensor (*Table 4*).

Note:

When the LSM6DS33 is configured in accelerometer-only mode (the gyroscope is in Power-Down mode) and the accelerometer is set in Low-Power/Normal mode, the FUNC\_EN bit of the CTRL10\_C register must be set to 1.

Table 4. Accelerometer ODR and power mode selection

| ODR_XL [3:0] | ODR [Hz] when XL_HM_MODE = 1 | ODR [Hz] when XL_HM_MODE = 0 |
|--------------|------------------------------|------------------------------|
| 0000         | Power Down                   | Power Down                   |
| 0001         | 12.5 Hz (Low Power)          | 12.5 Hz (High Performance)   |
| 0010         | 26 Hz (Low Power)            | 26 Hz (High Performance)     |
| 0011         | 52 Hz (Low Power)            | 52 Hz (High Performance)     |
| 0100         | 104 Hz (Normal mode)         | 104 Hz (High Performance)    |
| 0101         | 208 Hz (Normal mode)         | 208 Hz (High Performance)    |
| 0110         | 416 Hz (High Performance)    | 416 Hz (High Performance)    |
| 0111         | 833 Hz (High Performance)    | 833 Hz (High Performance)    |
| 1000         | 1.66 kHz (High Performance)  | 1.66 kHz (High Performance)  |
| 1001         | 3.33 kHz (High Performance)  | 3.33 kHz (High Performance)  |
| 1010         | 6.66 kHz (High Performance)  | 6.66 kHz (High Performance)  |

The output data rate (ODR\_G) bits of CTRL2\_G register and the High-Performance disable (G\_HM\_MODE) bit of CTRL7\_G register are used to select the power mode and output data rate of the gyroscope sensor (*Table 5*).

Table 5. Gyroscope ODR and power mode selection

| ODR_G [3:0] | ODR [Hz] when G_HM_MODE = 1 | ODR [Hz] when G_HM_MODE = 0 |
|-------------|-----------------------------|-----------------------------|
| 0000        | Power Down                  | Power Down                  |
| 0001        | 12.5 Hz (Low Power)         | 12.5 Hz (High Performance)  |
| 0010        | 26 Hz (Low Power)           | 26 Hz (High Performance)    |
| 0011        | 52 Hz (Low Power)           | 52 Hz (High Performance)    |
| 0100        | 104 Hz (Normal mode)        | 104 Hz (High Performance)   |
| 0101        | 208 Hz (Normal mode)        | 208 Hz (High Performance)   |
| 0110        | 416 Hz (High Performance)   | 416 Hz (High Performance)   |
| 0111        | 833 Hz (High Performance)   | 833 Hz (High Performance)   |
| 1000        | 1.66 kHz (High Performance) | 1.66 kHz (High Performance) |

Table 6 shows the typical values of power consumption for the different operating modes.

**Table 6. Power consumption** 

| ODR [Hz]              | Accelerometer only<br>(at Vdd = 1.8 V) | Gyroscope only<br>(at Vdd = 1.8 V) | Combo [Acc + Gyro]<br>(at Vdd = 1.8 V) |
|-----------------------|----------------------------------------|------------------------------------|----------------------------------------|
| Power Down            | -                                      | -                                  | 6 μΑ                                   |
| 12.5 Hz (Low Power)   | 24 μΑ                                  | 470 μΑ                             | 425 μΑ                                 |
| 26 Hz (Low Power)     | 31 μΑ                                  | 500 μΑ                             | 450 μΑ                                 |
| 52 Hz (Low Power)     | 45 μΑ                                  | 540 μΑ                             | 500 μΑ                                 |
| 104 Hz (Normal mode)  | 70 μΑ                                  | 625 μΑ                             | 600 μΑ                                 |
| 208 Hz (Normal mode)  | 120 μΑ                                 | 880 μΑ                             | 900 μΑ                                 |
| 12.5 Hz (High Perf.)  | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 26 Hz (High Perf.)    | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 52 Hz (High Perf.)    | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 104 Hz (High Perf.)   | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 208 Hz (High Perf.)   | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 416 Hz (High Perf.)   | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 833 Hz (High Perf.)   | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 1.66 kHz (High Perf.) | 240 μΑ                                 | 1.15 mA                            | 1.25 mA                                |
| 3.33 kHz (High Perf.) | 325 μΑ                                 | N.A.                               | N.A.                                   |
| 6.66 kHz (High Perf.) | 325 μΑ                                 | N.A.                               | N.A.                                   |



#### 3.1 Power-Down mode

When the accelerometer/gyroscope is in Power-Down mode, almost all internal blocks of the device are switched off to minimize power consumption. Digital interfaces (I<sup>2</sup>C and SPI) are still active to allow communication with the device. The content of the configuration registers is preserved and the output data registers are not updated, keeping the last data sampled in memory before going into Power-Down mode.

#### 3.2 High-Performance mode

In High-Performance mode, all accelerometer/gyroscope circuitry is always on and data are generated at the data rate selected through the ODR\_XL/ODR\_G bits.

Data interrupt generation is active.

#### 3.3 Normal mode

While High-Performance mode guarantees the best performance in terms of noise, Normal mode further reduces the current consumption. The accelerometer/gyroscope data reading chain is automatically turned on and off to save power. In the gyroscope device, only the driving circuitry is always on.

Data interrupt generation is active.

Note:

When the LSM6DS33 is configured in accelerometer-only mode (the gyroscope is in Power-Down mode) and the accelerometer is set in Normal mode, the FUNC\_EN bit of the CTRL10\_C register must be set to 1.

#### 3.4 Low-Power mode

Low-Power mode differs from Normal mode in the available output data rates. In Low-Power mode low-speed ODRs are enabled; three low-speed ODRs can be chosen through the ODR\_XL/ODR\_G bits.

Data interrupt generation is active.

Note:

When the LSM6DS33 is configured in accelerometer-only mode (the gyroscope is in Power-Down mode) and the accelerometer is set in Low-Power mode, the FUNC\_EN bit of the CTRL10 C register must be set to 1.

#### 3.5 Gyroscope Sleep mode

While the gyroscope is in Sleep mode the circuitry that drives the oscillation of the gyroscope mass is kept active. Compared to gyroscope Power-Down, turn-on time from Sleep mode to Low-Power/Normal/High-Performance mode is drastically reduced.

If the gyroscope is not configured in Power-Down mode, it enters in Sleep mode when the Sleep mode enable (SLEEP\_G) bit of CTRL4\_C register is set to 1, regardless of the selected gyroscope ODR.

#### 3.6 Changing the power mode in accelerometer-only mode

In the LSM6DS33 different power modes and ODR are implemented. When the power mode is changed from High-Performance mode to Low-Power / Normal mode or vice versa, the internal reading chain needs to be reset in order to guarantee correct behavior of the device in the new selected power mode.

In accelerometer-only mode, a reading chain reset is executed by design when the ODR value is changed or when the Power-Down mode is set. If the power mode is changed without changing the ODR or without passing through Power-Down mode (e.g. when directly passing in accelerometer-only mode from 100 Hz High-Performance mode to 100 Hz Normal mode), the reading chain is not reset and the proper functionality of the device in the new selected power mode cannot be guaranteed.

In this case, there are two possible methods that allow always performing a correct reset of the reading chain during a power mode change:

- 1. If no ODR change is needed, Power-Down mode must be set before the new power mode change (refer to *Figure 2*).
- 2. If an ODR change is needed, the ODR must be changed after the power mode change (refer to *Figure 3*).

Note: No specific power mode procedure has to be applied in Gyroscope-only mode or in Accelerometer/Gyroscope Combo mode.

The following example refers to the first method above (no ODR change needed during power mode change); the procedure in accelerometer-only mode to change the power mode from 100 Hz High-Performance mode to 100 Hz Normal mode is:

```
a. Write CTRL6_C = 00h  // Accelerometer in High-Performance mode (initial configuration)
b. Write CTRL1_XL = 40h  // Accelerometer-only, 100 Hz ODR (initial configuration)
...
n. Write CTRL1_XL = 00h  // Accelerometer in Power-Down mode
n+1. Write CTRL6_C = 10h  // Accelerometer in Normal mode
n+2. Write CTRL1_XL = 40h  // Accelerometer-only, 100 Hz ODR
```

Note: Step n. is mandatory.

The following example refers to the second method above (ODR change needed during power mode change); the procedure in accelerometer-only mode to change the power mode from 100 Hz High-Performance mode to 200 Hz Normal mode is:

```
a. Write CTRL6_C = 00h  // Accelerometer in High-Performance mode (initial configuration)
b. Write CTRL1_XL = 40h  // Accelerometer-only, 100 Hz ODR (initial configuration)
...
n. Write CTRL6_C = 10h  // Accelerometer in Normal mode
n+1. Write CTRL1_XL = 50h  // Accelerometer-only, 200 Hz ODR
```

Note: Steps n. and n+1. cannot be inverted.

477

Power Down

Low-Power / Normal High-Performance mode

Figure 2. Switching power modes (no change in ODR)

Figure 3. Switching power modes (with subsequent change in ODR)



(\*) This procedure has to be performed also when passing from High-Performance mode to Low-Power / Normal mode.

#### 3.7 Accelerometer bandwidth

The accelerometer sampling chain (*Figure 4*) is represented by a cascade of four blocks: an analog low-pass filter, an ADC converter, a digital low-pass filter and the composite group of digital filters described in *Figure 5*.

Figure 4. Accelerometer sampling chain diagram



The analog signal coming from the mechanical parts is filtered by a low-pass anti-aliasing filter before being converted by the ADC. The anti-aliasing filter is enabled in High-Performance mode only.

If the XL\_BW\_SCAL\_ODR bit in CTRL4\_C register is set to 1, the bandwidth of this analog filter is determined by setting the BW\_XL bits of CTRL1\_XL register; relative filter cutoff frequency values are given in *Table 7*. If the XL\_BW\_SCAL\_ODR bit is set to 0, the bandwidth of the analog filter is determined by the ODR\_XL selection (*Table 8*).

Table 7. Accelerometer anti-aliasing filter bandwidth selection (XL\_BW\_SCAL\_ODR = 1)

| BW_XL[1:0] | Bandwidth [Hz] |
|------------|----------------|
| 00         | 400            |
| 01         | 200            |
| 10         | 100            |
| 11         | 50             |

 Table 8. Accelerometer anti-aliasing bandwidth options (High-Performance mode)

| A 1                         | A                         | A                         |
|-----------------------------|---------------------------|---------------------------|
| Accelerometer               | Analog filter cutoff [Hz] | Analog filter cutoff [Hz] |
| ODR [Hz]                    | XL_BW_SCAL_ODR = 0        | XL_BW_SCAL_ODR = 1        |
| 12.5 Hz (High Performance)  | 50                        | BW_XL[1:0]                |
| 26 Hz (High Performance)    | 50                        | BW_XL[1:0]                |
| 52 Hz (High Performance)    | 50                        | BW_XL[1:0]                |
| 104 Hz (High Performance)   | 50                        | BW_XL[1:0]                |
| 208 Hz (High Performance)   | 100                       | BW_XL[1:0]                |
| 416 Hz (High Performance)   | 200                       | BW_XL[1:0]                |
| 833 Hz (High Performance)   | 400                       | BW_XL[1:0]                |
| 1.66 kHz (High Performance) | 400                       | BW_XL[1:0]                |
| 3.33 kHz (High Performance) | FILTER NOT USED           | BW_XL[1:0]                |
| 6.66 kHz (High Performance) | FILTER NOT USED           | BW_XL[1:0]                |

20/96 DocID027736 Rev 5

The digital signal is then filtered by a low-pass digital filter (LPF1) whose cutoff frequency depends on the selected accelerometer ODR, as shown in *Table 9*.

Table 9. Accelerometer LPF1 cutoff frequency

| Accelerometer ODR [Hz]      | LPF1 digital filter cutoff frequency [Hz] |
|-----------------------------|-------------------------------------------|
| 12.5 Hz (Low Power)         | 742                                       |
| 26 Hz (Low Power)           | 742                                       |
| 52 Hz (Low Power)           | 742                                       |
| 104 Hz (Normal mode)        | 742                                       |
| 208 Hz (Normal mode)        | 742                                       |
| 12.5 Hz (High Performance)  | 23                                        |
| 26 Hz (High Performance)    | 46                                        |
| 52 Hz (High Performance)    | 92                                        |
| 104 Hz (High Performance)   | 184                                       |
| 208 Hz (High Performance)   | 369                                       |
| 416 Hz (High Performance)   | 742                                       |
| 833 Hz (High Performance)   | 1517                                      |
| 1.66 kHz (High Performance) | 3320                                      |
| 3.33 kHz (High Performance) | 1517                                      |
| 6.66 kHz (High Performance) | 3320                                      |

The total cutoff frequency resulting from the combination of the anti-aliasing filter and digital LPF1 filter is indicated in *Table 10*: it's basically determined by the lowest cutoff frequency of these two filters.

Table 10. Accelerometer anti-aliasing + LPF1 overall cutoff frequency

| Accelerometer ODR [Hz]                         | Analog filter BW<br>[Hz] | Digital filter BW<br>[Hz] | Total<br>BW [Hz] |
|------------------------------------------------|--------------------------|---------------------------|------------------|
| 12.5 Hz to 208 Hz<br>(Low Power / Normal mode) | -                        | 742                       | 740              |
|                                                | 400                      | 23                        | 23               |
| 12.5 Hz (High Dorformanos)                     | 200                      | 23                        | 23               |
| 12.5 Hz (High Performance)                     | 100                      | 23                        | 22               |
|                                                | 50                       | 23                        | 20               |
|                                                | 400                      | 46                        | 45.5             |
| 26 Hz (High Porformance)                       | 200                      | 46                        | 44.5             |
| 26 Hz (High Performance)                       | 100                      | 46                        | 41               |
|                                                | 50                       | 46                        | 32.5             |

Table 10. Accelerometer anti-aliasing + LPF1 overall cutoff frequency (continued)

| Accelerometer ODR [Hz]       | Analog filter BW<br>[Hz] | Digital filter BW<br>[Hz] | Total<br>BW [Hz] |
|------------------------------|--------------------------|---------------------------|------------------|
|                              | 400                      | 92                        | 89               |
| FO LI- (Lligh Dorformonos)   | 200                      | 92                        | 82               |
| 52 Hz (High Performance)     | 100                      | 92                        | 65               |
|                              | 50                       | 92                        | 43               |
|                              | 400                      | 184                       | 165              |
| 104 Hz (High Performance)    | 200                      | 184                       | 131              |
| 104 FIZ (Flight Feholmance)  | 100                      | 184                       | 86               |
|                              | 50                       | 184                       | 48               |
|                              | 400                      | 369                       | 265              |
| 208 Hz (High Performance)    | 200                      | 369                       | 172              |
| 200 Hz (High Fellolinance)   | 100                      | 369                       | 96               |
|                              | 50                       | 369                       | 49               |
|                              | 400                      | 742                       | 350              |
| 416 Hz (High Performance)    | 200                      | 742                       | 192              |
| 410 HZ (High Performance)    | 100                      | 742                       | 99               |
|                              | 50                       | 742                       | 50               |
|                              | 400                      | 1517                      | 395              |
| 833 Hz (High Performance)    | 200                      | 1517                      | 199              |
| 000 Fiz (Flight Fehormanice) | 100                      | 1517                      | 100              |
|                              | 50                       | 1517                      | 50               |
|                              | 400                      | 3320                      | 400              |
| 1.66 kHz (High Performance)  | 200                      | 3320                      | 200              |
| 1.00 km2 (nigii Periormance) | 100                      | 3320                      | 100              |
|                              | 50                       | 3320                      | 50               |
|                              | -                        | 1517                      | 1500             |
|                              | 400                      | 1517                      | 390              |
| 3.33 kHz (High Performance)  | 200                      | 1517                      | 198              |
|                              | 100                      | 1517                      | 100              |
|                              | 50                       | 1517                      | 50               |
|                              | -                        | 3320                      | 3160             |
|                              | 400                      | 3320                      | 400              |
| 6.66 kHz (High Performance)  | 200                      | 3320                      | 200              |
|                              | 100                      | 3320                      | 100              |
|                              | 50                       | 3320                      | 50               |



> Finally, the digital signal is processed by the composite group of filters composed of a lowpass digital filter (LPF2), a high-pass digital filter and a slope filter. As shown in Figure 5, it is possible to independently apply these filters to the accelerometer output data (and to the FIFO data) and/or to the interrupt generators.

> The enable signal of these high-pass and low-pass digital filters is the logic "OR" of the SLOPE FDS bit of the TAP CFG register and the FUNC EN bit of the CTRL10 C register.

> The SLOPE FDS bit is also used to select the filter (high-pass or slope) used for the wakeup interrupt functionality. For this reason, if the wake-up functionality is implemented using the slope filter and also the LPF2 filter is required, the latter has to be enabled by setting the FUNC EN bit to 1.

> In all other cases, to enable the high-pass and low-pass digital filters it's recommended to set to 1 the SLOPE\_FDS bit and set to 0 the FUNC\_EN bit (if the embedded functions, such as the Android functions, are not used).



Figure 5. Accelerometer composite digital filter

The bits LPF2\_XL\_EN, HP\_SLOPE\_XL\_EN and HPCF\_XL [1:0] of CTRL8\_XL are used to select the filter applied to the accelerometer output data and to the FIFO data:

- if the HP\_SLOPE\_XL\_EN bit is set to 0, no filter is applied, regardless of the LPF2 XL EN bit configuration;
- if both the LPF2\_XL\_EN bit and the HP\_SLOPE\_XL\_EN bit are set to 1, the LP digital filter (LPF2) is applied;
- if the LPF2 XL EN bit is set to 0 and the HP SLOPE XL EN bit is set to 1, the applied filter depends on the configuration of the HPCF XL [1:0] bits, as shown in Table 11.

Table 11. Accelerometer slope and high-pass filter selection and cutoff frequency

| HPCF_XL[1:0] | Applied filter | HP digital filter cutoff frequency [Hz] |
|--------------|----------------|-----------------------------------------|
| 00           | Slope          | ODR_XL / 4                              |
| 01           | High-Pass      | ODR_XL / 100                            |
| 10           | High-Pass      | ODR_XL/9                                |
| 11           | High-Pass      | ODR_XL / 400                            |

The HPCF\_XL [1:0] bits of CTRL8\_XL are also used to select the cutoff frequency of the LPF2 filter, as shown in *Table 12*. This low-pass filter can also be used in the 6D/4D functionality by setting the LOW\_PASS\_ON\_6D bit of CTRL8\_XL register to 1.

Table 12. Accelerometer LPF2 cutoff frequency

| HPCF_XL[1:0] | LPF2 digital filter<br>cutoff frequency [Hz] |
|--------------|----------------------------------------------|
| 00           | ODR_XL / 50                                  |
| 01           | ODR_XL / 100                                 |
| 10           | ODR_XL/9                                     |
| 11           | ODR_XL / 400                                 |

#### 3.7.1 Accelerometer slope filter

As shown in *Figure 5*, the LSM6DS33 device embeds a digital slope filter which is used for single/double-tap features; it can also be used for wake-up detection and for activity/inactivity functionality when the SLOPE\_FDS bit of the TAP\_CFG register is set to 0.

The slope filter output data is computed using the following formula:

$$slope(t_n) = [acc(t_n) - acc(t_{n-1})] / 2$$

An example of a slope data signal is illustrated in Figure 6.

Figure 6. Accelerometer slope filter



#### 3.8 Gyroscope bandwidth

The gyroscope sampling chain is represented by a cascade of four blocks: analog low-pass anti-aliasing filter, ADC converter, digital low-pass filter and a selectable high-pass filter (*Figure 7*).

Figure 7. Gyroscope sampling chain diagram



The analog signal coming from the mechanical parts is filtered by a low-pass anti-aliasing filter (having a constant bandwidth) before being converted by the ADC. The digital signal is then filtered by a low-pass digital filter whose cutoff frequency depends on the selected gyroscope ODR: the cutoff values in Low-Power and Normal mode are shown in *Table 13*; the cutoff values related to High-Performance mode are indicated in *Table 14*.

Table 13. Gyroscope digital low-pass filter cutoff in Low-Power / Normal mode

| Gyroscope ODR [Hz]   | Cutoff [Hz] |
|----------------------|-------------|
| 12.5 Hz (Low Power)  | 3.9         |
| 26 Hz (Low Power)    | 7.9         |
| 52 Hz (Low Power)    | 15.8        |
| 104 Hz (Normal mode) | 31.4        |
| 208 Hz (Normal mode) | 60.2        |

Table 14. Gyroscope digital low-pass filter cutoff in High-Performance mode

| Gyroscope ODR [Hz]    | Cutoff [Hz] |
|-----------------------|-------------|
| 12.5 Hz (High Perf.)  | 4.2         |
| 26 Hz (High Perf.)    | 8.3         |
| 52 Hz (High Perf.)    | 16.6        |
| 104 Hz (High Perf.)   | 33.4        |
| 208 Hz (High Perf.)   | 66.7        |
| 416 Hz (High Perf.)   | 135.9       |
| 833 Hz (High Perf.)   | 295.4       |
| 1.66 kHz (High Perf.) | 1057.0      |

The LSM6DS33 gyroscope provides embedded high-pass filtering capability to easily delete the DC component of the measured angular rate. As shown in *Figure 7*, through the HP\_G\_EN bit of the CTRL7\_G register, it is possible to apply the filter on the gyroscope output data and on FIFO stored data.

Note:

The embedded High-pass filter is available in High-Performance mode only. If the gyroscope is configured in Low-Power / Normal mode, the high-pass filter is bypassed regardless of the configuration of the HP\_G\_EN bit in the CTRL7\_G register.

The bandwidth of the high-pass filter depends on the settings of the HPCF\_G[1:0] bits of the CTRL7\_G register. The high-pass filter cutoff frequencies are shown in *Table 15*.

|         | , , , , | . ,                                    |
|---------|---------|----------------------------------------|
| HPCF_G1 | HPCF_G0 | High-pass filter cutoff frequency [Hz] |
| 0       | 0       | 0.0081                                 |
| 0       | 1       | 0.0324                                 |
| 1       | 0       | 2.07                                   |
| 1       | 1       | 16.32                                  |

Table 15. Gyroscope high-pass filter cutoff frequency [Hz]

The high-pass filter can be reset by setting the HP\_G\_RST bit of the CTRL7\_G register to 1. The reset operation instantly deletes the DC component of the angular rate from the next generated X, Y, Z output value (*Figure 8*).

After the filter resets, the HP\_G\_RST bit is automatically set back to 0.



Figure 8. Gyroscope high-pass filter reset

#### 3.9 Accelerometer and gyroscope turn-on/off time

The accelerometer reading chain contains low-pass filtering to improve signal-to-noise performance and to reduce aliasing effects. For this reason it is needed to take into account the settling time of the filter when the accelerometer / gyroscope power mode is switched or when the accelerometer / gyroscope ODR is changed.

Turn-on/off time has to be considered also for the gyroscope sensor when switching its modes or when the accelerometer / gyroscope ODR is changed.

The list of expected accelerometer / gyroscope turn-on/off times when the operating modes are changed is indicated in *Table 16*; the starting condition must be stable for at least 200 ms.

*Table 17* clarifies how many accelerometer samples have to be discarded in High-Performance mode depending on the internal filter bandwidth and output data rate selection. Bandwidth value selection is described in *Table 8*.

*Table 18* shows how many gyroscope samples have to be discarded when switching from gyroscope Sleep mode to Low-Power / Normal / High-Performance mode or when the accelerometer / gyroscope ODR is changed, depending on the output data rate selection.

Setting the DRDY\_MASK bit of the CTRL4\_C register to 1, the accelerometer and gyroscope data-ready signals are masked until the settling of the sensor filters is completed: this feature allows automatically ignoring the samples to be discarded.

Note:

The DRDY\_MASK bit masks the samples to be discarded only when switching from Power-Down to an active mode, it doesn't mask them on ODR changes.

Table 16. Accelerometer/gyroscope turn-on/off times

| Starting mode                              | Operating mode change                                            | Accelerometer Max turn-on/off time                                                                                              | Gyroscope<br>Max turn-on/off time |
|--------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Acc: Power-Down<br>Gyro: Power-Down        | Acc: Low-Power /<br>Normal mode                                  | First sample correct                                                                                                            | -                                 |
| Acc: Power-Down<br>Gyro: Power-Down        | Acc: High-Performance mode                                       | see Table 17                                                                                                                    | -                                 |
| Acc: Power-Down<br>Gyro: Power-Down        | Gyro: Sleep / Low-<br>Power / Normal / High-<br>Performance mode | -                                                                                                                               | 80 ms                             |
| Acc: LP / NM / HP mode<br>Gyro: Power-Down | Gyro: Sleep / Low-<br>Power / Normal / High-<br>Performance mode | Acc in LP/NM mode:<br>20 ms+1/ODR  Acc in HP mode:<br>max(20 ms+1/ODR,<br>number of sample to<br>be discarded from<br>Table 17) | 80 ms                             |
| Acc: Power-Down<br>Gyro: LP / NM / HP mode | Acc: Low-Power /<br>Normal mode                                  | First sample correct                                                                                                            | see Table 18                      |
| Acc: Power-Down<br>Gyro: LP / NM / HP mode | Acc: High-Performance mode                                       | see Table 17                                                                                                                    | see Table 18                      |

Table 16. Accelerometer/gyroscope turn-on/off times

| Starting mode                                     | Starting mode Operating mode Accelerometer Change Max turn-on/off time                                                 |                                                                                      | Gyroscope<br>Max turn-on/off time  |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|------------------------------------|
| Acc: Power Down<br>Gyro: Sleep mode               | Acc: Low Power /<br>Normal mode                                                                                        | First sample correct                                                                 | No impact on current Sleep mode    |
| Acc: Power Down<br>Gyro: Sleep mode               | Acc: High Performance mode                                                                                             | see Table 17                                                                         | No impact on current<br>Sleep mode |
| Acc: LP / NM / HP mode<br>Gyro: LP / NM / HP mode | Acc: Power Down                                                                                                        | 1us                                                                                  | First sample correct               |
| Acc: LP / NM / HP mode<br>Gyro: Sleep mode        | Acc: Power Down                                                                                                        | 1us                                                                                  | No impact on current<br>Sleep mode |
| Acc: LP / NM / HP mode<br>Gyro: LP / NM / HP mode | Gyro: Power Down /<br>Sleep mode                                                                                       | First sample correct                                                                 | 1us                                |
| Acc: LP / NM / HP mode<br>Gyro: LP / NM / HP mode | Acc. change () )R                                                                                                      |                                                                                      | see Table 18                       |
| Acc: LP / NM / HP mode<br>Gyro: Sleep mode        | Acc: change ODR                                                                                                        | Acc in LP/NM mode:<br>first sample correct<br>Acc in HP mode:<br>see <i>Table 17</i> | No impact on current<br>Sleep mode |
| Acc: LP / NM / HP mode<br>Gyro: Sleep mode        | Normal / High                                                                                                          |                                                                                      | see Table 18                       |
| Acc: LP / NM / HP mode Gyro: LP / NM / HP mode    |                                                                                                                        | Acc in LP/NM mode:<br>first sample correct<br>Acc in HP mode:<br>see <i>Table 17</i> | see Table 18                       |
| Acc: LP / NM / HP mode<br>Gyro: LP / NM / HP mode | Acc: change Analog Anti-aliasing filter BW through BW_XL bits of CTRL1_XL (with XL_BW_SCAL_ODR =1 in CTRL4_C register) | Acc in LP/NM mode:<br>first sample correct<br>Acc in HP mode:<br>see <i>Table 17</i> | First sample correct               |

Table 17. Accelerometer number of samples to be discarded

| Accelerometer ODR [Hz] | BW = 400 Hz | BW = 200 Hz | BW = 100 Hz | BW = 50 Hz | No filter |
|------------------------|-------------|-------------|-------------|------------|-----------|
| 12.5 Hz (High Perf.)   | 1           | 1           | 1           | 1          | N.A.      |
| 26 Hz (High Perf.)     | 1           | 1           | 1           | 1          | N.A.      |
| 52 Hz (High Perf.)     | 1           | 1           | 1           | 1          | N.A.      |
| 104 Hz (High Perf.)    | 1           | 1           | 1           | 2          | N.A.      |
| 208 Hz (High Perf.)    | 1           | 1           | 2           | 4          | N.A.      |
| 416 Hz (High Perf.)    | 1           | 2           | 3           | 7          | N.A.      |
| 833 Hz (High Perf.)    | 2           | 4           | 7           | 14         | N.A.      |
| 1.66 kHz (High Perf.)  | 4           | 8           | 14          | 28         | N.A.      |
| 3.33 kHz (High Perf.)  | 8           | 16          | 28          | 56         | 2         |
| 6.66 kHz (High Perf.)  | 16          | 32          | 56          | 112        | 4         |

Table 18. Gyroscope number of samples to be discarded

| Gyroscope ODR [Hz] | Number of samples |
|--------------------|-------------------|
| 12.5 Hz            | 2                 |
| 26 Hz              | 2                 |
| 52 Hz              | 2                 |
| 104 Hz             | 2                 |
| 208 Hz             | 2                 |
| 416 Hz             | 2                 |
| 833 Hz             | 3                 |
| 1.66 kHz           | 4                 |

AN4682 Reading output data

#### 4 Reading output data

#### 4.1 Startup sequence

Once the device is powered up, it automatically downloads the calibration coefficients from the embedded flash to the internal registers. When the boot procedure is completed, i.e. after approximately 20 milliseconds, the accelerometer and gyroscope automatically enter Power-Down mode.

To turn on the accelerometer and gather acceleration data, it is necessary to select one of the operating modes through the CTRL1\_XL register and to enable at least one of the axes through CTRL9\_XL.

The following general-purpose sequence can be used to configure the accelerometer:

```
    Write CTRL9_XL = 38h
    Write CTRL1_XL = 60h
    Write INT1_CTRL = 01h
    Wrote INT1

// Acc = 416Hz (High-Performance mode)
// Acc Data Ready interrupt on INT1
```

To turn on the gyroscope and gather angular rate data, it is necessary to select one of the operating modes through the CTRL2\_G register and to enable at least one of the axes through CTRL10\_C.

The following general-purpose sequence can be used to configure the gyroscope:

```
    Write CTRL10_C = 38h
    Write CTRL2_G = 60h
    Write INT1_CTRL = 02h
    Write INT1_CTRL = 02h
    Write INT1_CTRL = 02h

// Gyro Data Ready interrupt on INT1
```

#### 4.2 Using the status register

The device is provided with a STATUS\_REG register which should be polled to check when a new set of data is available. The XLDA bit is set to 1 when a new set of data is available at accelerometer output; the GDA bit is set to 1 when a new set of data is available at gyroscope output.

For the accelerometer (the gyroscope is similar), the reads should be performed as follows:

- 1 Read STATUS
- 2 If XLDA = 0, then go to 1
- 3 Read OUTX L XL
- 4 Read OUTX\_H\_XL
- 5 Read OUTY\_L\_XL
- 6 Read OUTY H XL
- 7 Read OUTZ\_L\_XL
- 8 Read OUTZ H XL
- 9 Data processing
- 10 Go to 1



Reading output data AN4682

#### 4.3 Using the data-ready signal

The device can be configured to have one HW signal to determine when a new set of measurement data is available for reading.

For the accelerometer sensor, the data-ready signal is represented by the XLDA bit of the STATUS\_REG register. The signal can be driven to the INT1 pin by setting to 1 the INT1\_DRDY\_XL bit of the INT1\_CTRL register and to the INT2 pin by setting to 1 the INT2\_DRDY\_XL bit of the INT2\_CTRL register.

For the gyroscope sensor, the data-ready signal is represented by the GDA bit of the STATUS\_REG register. The signal can be driven to the INT1 pin by setting to 1 the INT1\_DRDY\_G bit of the INT1\_CTRL register and to the INT2 pin by setting to 1 the INT2\_DRDY\_G bit of the INT2\_CTRL register.

The data-ready signal rises to 1 when a new set of data has been generated and it is available for reading. The interrupt is reset when the higher part of one of the enabled channels has been read (29h, 2Bh, 2Dh for the accelerometer; 23h, 25h, 27h for the gyroscope).

Setting the DRDY\_MASK bit of the CTRL4\_C register to 1, the accelerometer and gyroscope data-ready signals are masked until the settling of the sensor filters is completed.



Figure 9. Data-ready signal

#### 4.3.1 DRDY mask functionality

Setting the DRDY\_MASK bit of the CTRL4\_C register to 1, the accelerometer and gyroscope data-ready signals are masked until the settling of the sensor filters is completed.

The DRDY\_MASK bit masks the samples to be discarded only when switching from Power-Down to an active mode, it doesn't mask them on ODR changes. Furthermore, only the data-ready signals are masked, whereas the output registers are continuously updated also during the settling period of the sensor filters.

When FIFO is active and the DRDY\_MASK bit is set to 1, accelerometer invalid samples stored in FIFO are always equal to 7FFFh; gyroscope invalid samples stored in FIFO can be equal to 7FFFh, 7FFEh or 7FFDh. In this way, a tag is applied to the invalid samples stored in the FIFO buffer, so that they can be easily identified and discarded during data post-processing.

32/96 DocID027736 Rev 5

AN4682 Reading output data

#### 4.4 Using the block data update (BDU) feature

If reading the accelerometer/gyroscope data is particularly slow and cannot be synchronized (or it is not required) with either the XLDA/GDA bits in the STATUS\_REG register or with the DRDY signal driven to the INT1/INT2 pins, it is strongly recommended to set the BDU (block data update) bit to 1 in the CTRL3\_C register.

This feature avoids reading values (most significant and least significant parts of output data) related to different samples. In particular, when the BDU is activated, the data registers related to each channel always contain the most recent output data produced by the device, but, in case the read of a given pair (i.e. OUTX\_H\_XL(G) and OUTX\_L\_XL(G), OUTY\_H\_XL(G) and OUTY\_L\_XL(G), OUTZ\_H\_XL(G) and OUTZ\_L\_XL(G)) is initiated, the refresh for that pair is blocked until both MSB and LSB parts of the data are read.

Note:

BDU only guarantees that the LSB part and MSB part have been sampled at the same moment. For example, if the reading speed is too slow, X and Y can be read at T1 and Z sampled at T2.

#### 4.5 Understanding output data

The measured acceleration data are sent to the OUTX\_H\_XL, OUTX\_L\_XL, OUTY\_H\_XL, OUTY\_L\_XL, OUTZ\_H\_XL, and OUTZ\_L\_XL registers. These registers contain, respectively, the most significant part and the least significant part of the acceleration signals acting on the X, Y, and Z axes.

The measured angular rate data are sent to the OUTX\_H\_G, OUTX\_L\_G, OUTY\_H\_G, OUTY\_L\_G, OUTZ\_H\_G, and OUTZ\_L\_G registers. These registers contain, respectively, the most significant part and the least significant part of the angular rate signals acting on the X, Y, and Z axes.

The complete output data for the X, Y, Z channels is given by the concatenation OUTX\_H\_XL(G) & OUTX\_L\_XL(G), OUTY\_H\_XL(G) & OUTY\_L\_XL(G), OUTY\_H\_XL(G) & OUTY\_L\_XL(G), OUTZ\_H\_XL(G) & OUTZ\_L XL(G) and it is expressed as a two's complement number.

Both acceleration data and angular rate data are represented as 16-bit numbers.

#### 4.5.1 Big-little endian selection

The LSM6DS33 allows swapping the content of the lower and the upper part of the output data registers (i.e. OUTX\_H\_XL(G) with OUTX\_L\_XL(G), and OUT\_TEMP\_H with OUT\_TEMP\_L) in order to be compliant with both little-endian and big-endian data representations.

"Little Endian" means that the low-order byte of the number is stored in memory at the lowest address, and the high-order byte at the highest address. This mode corresponds to the BLE bit of the CTRL3 C register set to 0 (default configuration).

On the contrary, "Big Endian" means that the high-order byte of the number is stored in memory at the lowest address, and the low-order byte at the highest address. This mode corresponds to the BLE bit of the CTRL3 C register set to 1.

Reading output data AN4682

#### 4.5.2 Examples of output data

*Table 19* provides a few basic examples of the accelerometer data that is read in the data registers when the device is subject to a given acceleration.

*Table 20* provides a few basic examples of the gyroscope data that is read in the data registers when the device is subject to a given angular rate.

The values listed in the following tables are given under the hypothesis of perfect device calibration (i.e. no offset, no gain error,....) and practically show the effect of the BLE bit.

Table 19. Output data registers content vs. acceleration (FS\_XL =  $\pm 2 g$ )

|                     | BLE = 0            |                    | BLE = 1            |                    |
|---------------------|--------------------|--------------------|--------------------|--------------------|
| Acceleration values | Register address   |                    |                    |                    |
|                     | OUTX_H_XL<br>(29h) | OUTX_L_XL<br>(28h) | OUTX_H_XL<br>(29h) | OUTX_L_XL<br>(28h) |
| 0 g                 | 00h                | 00h                | 00h                | 00h                |
| 350 mg              | 16h                | 69h                | 69h                | 16h                |
| 1 g                 | 40h                | 09h                | 09h                | 40h                |
| -350 m <i>g</i>     | E9h                | 97h                | 97h                | E9h                |
| -1 g                | BFh                | F7h                | F7h                | BFh                |

Table 20. Output data registers content vs. angular rate (FS\_G = ±250 dps)

|                     | BLE = 0                 |     | BLE = 1           |                   |
|---------------------|-------------------------|-----|-------------------|-------------------|
| Angular rate values | Register address        |     |                   |                   |
| -                   | OUTX_H_G OUTX_L_G (23h) |     | OUTX_H_G<br>(23h) | OUTX_L_G<br>(22h) |
| 0 dps               | 00h                     | 00h | 00h               | 00h               |
| 100 dps             | 2Ch                     | A4h | A4h               | 2Ch               |
| 200 dps             | 59h                     | 49h | 49h               | 59h               |
| -100 dps            | D3h                     | 5Ch | 5Ch               | D3h               |
| -200 dps            | A6h                     | B7h | B7h               | A6h               |

AN4682 Reading output data

#### 4.6 Rounding functions

The rounding function can be used to auto address the LSM6DS33 registers for a circular burst-mode read. Basically, with a multiple read operation the address of the register that is being read goes automatically from the first register to the last register of the pattern and then goes back to the first one.

#### 4.6.1 Rounding of FIFO output registers

The rounding function is automatically enabled when performing a multiple read operation of the FIFO output registers FIFO DATA OUT L (3Eh) and FIFO DATA OUT H (3Fh).

#### 4.6.2 Rounding of source registers

It's possible to apply the rounding function also to the source registers of the LSM6DS33 device, in order to verify with one multiple read whether new data was generated or a new interrupt event was detected.

The rounding function on the source registers can be enabled by setting to 1 the ROUNDING\_STATUS bit of the CTRL7\_G register: when this function is enabled, with a multiple read operation the address of the register that is being read goes automatically from STATUS REG (1Eh) to FUNC SRC (53h) and goes back to WAKE UP SRC (1Bh).

#### 4.6.3 Rounding of sensor output registers

The rounding function can also be enabled for the following groups of output registers:

- Gyroscope output registers, from OUTX\_L\_G (22h) to OUTZ\_H\_G (27h);
- Accelerometer output registers, from OUTX\_L\_XL (28h) to OUTZ\_H\_XL (2Dh);

The output registers rounding pattern can be configured using the bits ROUNDING[2:0] of the CTRL5\_C register, as indicated in *Table 21*.

| ROUNDING[2:0] | Rounding pattern          |  |
|---------------|---------------------------|--|
| 000           | No rounding               |  |
| 001           | Accelerometer only        |  |
| 010           | Gyroscope only            |  |
| 011           | Gyroscope + Accelerometer |  |

Table 21. Output registers rounding pattern

Reading output data AN4682

## 4.7 Gyroscope edge-sensitive/level-sensitive/impulse-sensitive data enable (DEN)

The LSM6DS33 allows external trigger level recognition by configuring the TRIG\_EN, LVLen and LVL2\_EN bits of the CTRL6\_C register (*Table 22*). The default value for these three bits is 0 (external trigger is disabled). Three different trigger modes can be used: edge-, level-, or impulse-sensitive trigger; the Data Enable (DEN) input signal is driven on the INT2 pin, which is configured as an input pin when one of the gyroscope trigger modes is enabled.

| TRIG_EN | LVLen | LVL2_EN | Function          |  |  |
|---------|-------|---------|-------------------|--|--|
| 1       | 0     | 0       | Edge-sensitive    |  |  |
| 0       | 1     | 0       | Level-sensitive   |  |  |
| 0       | 1     | 1       | Impulse-sensitive |  |  |

Table 22. DEN configurations

Edge-sensitive and impulse-sensitive triggers need both accelerometer and gyroscope sensors to be active (not in Power-Down mode) and configured with the same output data rate value. The level-sensitive trigger can also work with only the gyroscope in active mode, regardless of the selected gyroscope ODR.

#### 4.7.1 Edge-sensitive trigger

The edge-sensitive trigger is enabled when the TRIG\_EN bit of CTRL6\_C register is set to 1 and the LVLen and LVL2\_EN bits are set to 0. If the FIFO is not used, both accelerometer and gyroscope sensors have to be in active mode and configured with the same ODR value.

Once enabled, the gyroscope output registers are updated with the next generated X, Y, Z gyroscope data at the rising edge of the DEN (INT2 pin) input signal. If no rising edge occurs, the gyroscope output registers are not updated.



Figure 10. Data synchronization: edge-sensitive

57

If both the edge-sensitive trigger and FIFO (see Section 7: First-in first-out (FIFO) buffer) are enabled, the DEN (INT2 pin) signal works as a trigger signal for writing data in the FIFO buffer: FIFO patterns are stored in the FIFO on the rising edge of the DEN signal. In order to have this feature enabled, both the DATA\_VALID\_SEL\_FIFO bit of the MASTER\_CONFIG register and the TIMER\_PEDO\_FIFO\_DRDY bit of the FIFO\_CTRL2 register have to be set to 0. Furthermore, both accelerometer and gyroscope sensors have to be in active mode and the accelerometer ODR value has to be half of the gyroscope ODR value.

Note:

Each pattern is stored in FIFO buffer twice, so the second stored pattern has to be discarded.

This features allows, for example, the synchronization of the camera frames with the samples coming from the gyroscope for Electrical Image Stabilization (EIS) applications. The synchronization signal from the camera module must be connected to the INT2 pin.

In the example shown in *Figure 11* the FIFO has been configured to store in the FIFO buffer both the gyroscope data and the timestamp data; when the DEN signal toggles, the data are written to FIFO twice on the rising edge. The second set of data must be discarded.



Figure 11. Storing synchronized data in FIFO

The settings required for this example are as follows:

```
1 Write 08h into FIFO CTRL3
                                  // Enable gyroscope data in FIFO (no decimation)
2 Write 80h into FIFO_CTRL2
                                  // Enable step counter and timestamp data as 4th FIFO data set
3 Write 08h into FIFO CTRL4
                                  // Enable step counter and timestamp in FIFO (no decimation)
   Write 26h into FIFO_CTRL5
                                  // Set FIFO in Continuous mode, FIFO ODR = 104 Hz
                                  // Enable the edge-sensitive trigger
   Write 80h into CTRL6 G
                                  // INT2 pin is switched to input mode (DEN signal)
   Write 30h into CTRL1 XL
                                  // Turn on the accelerometer: ODR_XL = 52Hz, FS_XL = \pm 2 g
                                  // Turn on the gyroscope
   Write 4Ch into CTRL2 G
                                  // ODR_G = 104 Hz, FS_G = ±2000 dps
  Write 80h into TAP CFG
                                  // Enable timestamp counter
```

Reading output data AN4682

#### 4.7.2 Level-sensitive trigger stamping

The level-sensitive trigger is enabled when the LVLen bit of the CTRL6 C register is set to 1 and the TRIG EN and LVL2 EN bits are set to 0.

Once enabled, the LSB of the generated gyroscope X, Y, Z output data is replaced with the current DEN (INT2 pin) level. This replacement applies also to the data stored in FIFO.

LSB = 0**LSB = 1** LSB = 0Gyroscope samples DEN (INT2 pin)

Figure 12. Data synchronization: level-sensitive

#### 4.7.3 Impulse-sensitive trigger stamping

The impulse-sensitive trigger is enabled when the LVLen and LVL2 EN bits of the CTRL6 C register are set to 1 and the TRIG EN bit is set to 0. Furthermore, both accelerometer and gyroscope sensors have to be in active mode and configured with the same ODR value.

The impulse-sensitive trigger is similar to the level-sensitive trigger and has to be used if the duration of the DEN positive pulse is shorter than the selected gyroscope ODR. Once enabled, the LSB bit of the gyroscope X, Y, Z output data generated after the pulse is set to 1. If no pulse occurs, the LSB bit of the next generated gyroscope X, Y, Z output data is set to 0. If the pulse occurs during the update of the data, it could happen that two consecutive gyroscope data are tagged instead of just the first one, and it's also possible that the tag of the LSB bit to 1 is not applied to all three axes of each X, Y, Z output data: in this case, one of the two consecutively tagged data has to be discarded at sw level.

#### 4.8 Gyroscope axes orientation

Axes orientation and sign of the gyroscope sensor can be changed by software using the ORIENT CFG G register, as illustrated in Figure 13.



Figure 13. Gyroscope axes orientation and sign configuration

The Orient\_[2:0] bits of the ORIENT\_CFG\_G register allow driving the pitch, roll and yaw physical axes to the X, Y and Z output registers as indicated in Table 24.

Table 23. ORIENT\_CFG\_G register

| b7 | b6 | b5      | b4      | b3      | b2       | b1       | b0       |
|----|----|---------|---------|---------|----------|----------|----------|
| 0  | 0  | SignX_G | SignY_G | SignZ_G | Orient_2 | Orient_1 | Orient_0 |

Table 24. Settings for gyroscope axes orientation

| Orient_[2:0] | Pitch | Roll | Yaw |
|--------------|-------|------|-----|
| 000          | X     | Y    | Z   |
| 001          | X     | Z    | Y   |
| 010          | Y     | Х    | Z   |
| 011          | Y     | Z    | Х   |
| 100          | Z     | Х    | Y   |
| 101          | Z     | Y    | Х   |

The SignX\_G, SignY\_G and SignZ\_G bits of the ORIENT\_CFG\_G register allow respectively changing (setting the bit to 1) the sign of the X, Y and Z output registers data.

Case (a) of the example in Figure 14 corresponds to the default case for axes orientation and sign, with all Orient\_[2:0], SignX\_G, SignY\_G and SignZ\_G bits of the ORIENT\_CFG\_G register set to 0.

In case (b) the Orient [2:0] bits have been set to 010b, driving Pitch and Roll data on different axes than the default case; furthermore the sign on X and Z data has been changed by setting the SignX\_G and SignZ\_G bits to 1.

Figure 14. Gyroscope axes orientation and sign example



# 5 Interrupt generation

In the LSM6DS33 device the interrupt generation is based on accelerometer data only, so, for interrupt generation purposes, the accelerometer sensor has to be set in an active operating mode (not in Power-Down); the gyroscope sensor can be configured in Power-Down mode since it's not involved in interrupt generation.

The interrupt generator can be configured to detect:

- Free-fall;
- Wake-up;
- 6D/4D orientation detection;
- Single-tap and double-tap sensing;
- Activity/Inactivity recognition.

In addition, the LSM6DS33 can efficiently run the sensor-related features specified in Android, saving power and enabling faster reaction time. In particular, it has been designed to implement in hardware:

- Significant motion;
- Tilt;
- Pedometer functions;
- Timestamp.

All these interrupt signals, together with FIFO interrupt signals, can be independently driven to the INT1 and INT2 interrupt pins or checked by reading the dedicated source register bits.

The H\_LACTIVE bit of the CTRL3\_C register must be used to select the polarity of the interrupt pins. If this bit is set to 0 (default value), the interrupt pins are active high and they change from low to high level when the related interrupt condition is verified. Otherwise, if the H\_LACTIVE bit is set to 1 (active low), the interrupt pins are normally at high level and they change from high to low when an interrupt condition is reached.

The PP\_OD bit of CTR3\_C allows changing the behavior of the interrupt pins from push-pull to open drain. If the PP\_OD bit is set to 0, the interrupt pins are in push-pull configuration (low-impedance output for both high and low level). When the PP\_OD bit is set to 1, only the interrupt active state is a low-impedance output.

The LIR bit of TAP\_CFG allows applying the latched mode to the interrupt signals. When the LIR bit is set to 1, once the interrupt pin is asserted, it must be reset by reading the related interrupt source register. If the LIR bit is set to 0, the interrupt signal is automatically reset when the interrupt condition is no longer verified or after a certain amount of time.

# 5.1 Interrupt pin configuration

The device is provided with two pins that can be activated to generate either Data Ready or interrupt signals. The functionality of these pins is selected through the MD1\_CFG and INT1\_CTRL registers for the INT1 pin, and through the MD2\_CFG and INT2\_CTRL registers for the INT2 pin.

A brief description of these interrupt control registers is given in the following summary; the default value of their bits is equal to 0, which corresponds to 'disable'. In order to enable the routing of a specific interrupt signal on the pin, the related bit has to be set to 1.

40/96 DocID027736 Rev 5



| <b>Table</b> | 25. | INT1 | <b>CTRL</b> | register |
|--------------|-----|------|-------------|----------|
|--------------|-----|------|-------------|----------|

| b7 b6      |          | b5        | b5 b4    |       | b2    | b1     | b0      |
|------------|----------|-----------|----------|-------|-------|--------|---------|
| INT1_STEP_ | INT1_    | INT1_     | INT1_    | INT1_ | INT1_ | INT1_  | INT1_   |
| DETECTOR   | SIGN_MOT | FULL_FLAG | FIFO_OVR | FTH   | BOOT  | DRDY_G | DRDY_XL |

- INT1\_STEP\_DETECTOR: Pedometer step recognition interrupt on INT1.
- INT1 SIGN MOT: Significant motion interrupt on INT1.
- INT1\_FULL\_FLAG: FIFO full flag interrupt on INT1.
- INT1\_FIFO\_OVR: FIFO overrun flag interrupt on INT1.
- INT1 FTH: FIFO threshold interrupt on INT1.
- INT1\_BOOT: Boot interrupt on INT1.
- INT1\_DRDY\_G: Gyroscope Data-Ready on INT1.
- INT1 DRDY XL: Accelerometer Data-Ready on INT1.

### Table 26. MD1\_CFG register

| b7                       | b6                      | b5          | b4          | b3                      | b2          | b1            | b0             |
|--------------------------|-------------------------|-------------|-------------|-------------------------|-------------|---------------|----------------|
| INT1_<br>INACT_<br>STATE | INT1_<br>SINGLE_<br>TAP | INT1_<br>WU | INT1_<br>FF | INT1_<br>DOUBLE_<br>TAP | INT1_<br>6D | INT1_<br>TILT | INT1_<br>TIMER |

- INT1\_INACT\_STATE: Inactivity interrupt on INT1.
- INT1\_SINGLE\_TAP: Single-tap interrupt on INT1.
- INT1\_WU: Wake-up interrupt on INT1.
- INT1 FF: Free-fall interrupt on INT1.
- INT1\_DOUBLE\_TAP: Double-tap interrupt on INT1.
- INT1 6D: 6D detection interrupt on INT1.
- INT1\_TILT: Tilt interrupt on INT1.
- INT1\_TIMER: Timer interrupt on INT1.

### Table 27. INT2\_CTRL register

| b7                  | b6                     | b5 | b4 | b3           | b2                 | b1 | b0               |
|---------------------|------------------------|----|----|--------------|--------------------|----|------------------|
| INT2_STEP_<br>DELTA | INT2_STEP_<br>COUNT_OV |    |    | INT2_<br>FTH | INT2_DRD<br>Y_TEMP | _  | INT2_<br>DRDY_XL |

- INT2 STEP DELTA: Pedometer step recognition on delta time interrupt on INT2.
- INT2\_STEP\_COUNT\_OV: Step counter overflow interrupt on INT2.
- INT2\_FULL\_FLAG: FIFO full flag interrupt on INT2.
- INT2 FIFO OVR: FIFO overrun flag interrupt on INT2.
- INT2\_FTH: FIFO threshold interrupt on INT2.
- INT2\_DRDY\_TEMP: Temperature Data-Ready on INT2.
- INT2\_DRDY\_G: Gyroscope Data-Ready on INT2.
- INT2 DRDY XL: Accelerometer Data-Ready on INT2.



|                          |                         |             | 10 20: 11:152 | _0. 0 .0g.              | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |               |    |
|--------------------------|-------------------------|-------------|---------------|-------------------------|-----------------------------------------|---------------|----|
| b7                       | b6                      | b5          | b4            | b3                      | b2                                      | b1            | b0 |
| INT2_<br>INACT_<br>STATE | INT2_<br>SINGLE_<br>TAP | INT2_<br>WU | INT2_<br>FF   | INT2_<br>DOUBLE_<br>TAP | INT2_<br>6D                             | INT2_<br>TILT | 0  |

Table 28 MD2 CFG register

- INT2 INACT STATE: Inactivity interrupt on INT2.
- INT2 SINGLE TAP: Single-tap interrupt on INT2.
- INT2 WU: Wake-up interrupt on INT2.
- INT2 FF: Free-fall interrupt on INT2.
- INT2 DOUBLE TAP: Double-tap interrupt on INT2.
- INT2 6D: 6D detection interrupt on INT2.
- INT2 TILT: Tilt interrupt on INT2.

If multiple interrupt signals are routed on the same pin (INTx), the logic level of this pin is the "OR" combination of the selected interrupt signals. In order to know which event has generated the interrupt condition, the related source registers have to be read: WAKE UP SRC, D6D SRC, TAP SRC and FUNC SRC.

The INT2 on INT1 pin of CTRL4 C register allows driving all the enabled interrupt signals in logic "OR" on the INT1 pin (by setting this bit to 1). When this bit is set to 0, the interrupt signals are divided between the INT1 and INT2 pins.

#### 5.2 Free-fall interrupt

Free-fall detection refers to a specific register configuration that allows recognizing when the device is in free-fall: the acceleration measured along all the axes goes to zero. In a real case a "free-fall zone" is defined around the zero-g level where all the accelerations are small enough to generate the interrupt. Configurable threshold and duration parameters are associated to free-fall event detection: the threshold parameter defines the free-fall zone amplitude; the duration parameter defines the minimum duration of the free-fall interrupt event to be recognized (Figure 15).



Figure 15. Free-fall interrupt

The free-fall interrupt signal can be driven to the two interrupt pins by setting to 1 the INT1\_FF bit of the MD1\_CFG register or the INT2\_FF bit of the MD2\_CFG register; it can also be checked by reading the FF\_IA bit of the WAKE\_UP\_SRC register.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal is automatically reset when the free-fall condition is no longer verified. If latch mode is enabled and the free-fall interrupt signal is driven to the interrupt pins, once a free-fall event has occurred and the interrupt pin is asserted, it must be reset by reading the WAKE\_UP\_SRC register. If the latch mode is enabled, but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect.

The register used to configure the threshold parameter is named FREE\_FALL; the unsigned threshold value is related to the value of the FF\_THS[2:0] field value as indicated in *Table 29*. The values given in this table are valid for each accelerometer full-scale value.

| FREE_FALL - FF_THS[2:0] | Threshold LSB value [mg] |
|-------------------------|--------------------------|
| 000                     | 156                      |
| 001                     | 219                      |
| 010                     | 250                      |
| 011                     | 312                      |
| 100                     | 344                      |
| 101                     | 406                      |
| 110                     | 469                      |
| 111                     | 500                      |

Table 29. Free-fall threshold LSB value

Duration time is measured in N/ODR\_XL, where N is the content of the FF\_DUR[5:0] field of the FREE\_FALL / WAKE\_UP\_DUR registers and ODR\_XL is the accelerometer data rate.

A basic SW routine for the free-fall event recognition is given below.

The sample code exploits a threshold set to 312 mg for free-fall recognition and the event is notified by hardware through the INT1 pin. The FF\_DUR[5:0] field of the FREE\_FALL / WAKE\_UP\_DUR registers is configured like this to ignore events that are shorter than 6/ODR XL = 6/412 Hz  $\sim$ = 15 msec in order to avoid false detections.



# 5.3 Wake-up interrupt

In the LSM6DS33 device the wake-up feature can be implemented using either the slope filter (see *Section 3.7.1* for more details) or the high-pass digital filter, as illustrated in *Figure 5*. The filter to be applied can be selected using the SLOPE\_FDS bit of the TAP\_CFG register: if this bit is set to 0 (default value), the slope filter is used; if it's set to 1, the high-pass digital filter is used.

The wake-up interrupt signal is generated if a certain number of consecutive filtered data exceed the configured threshold (*Figure 16*).

The unsigned threshold value is defined using the WK\_THS[5:0] bits of the WAKE\_UP\_THS register; the value of 1 LSB of these 6 bits depends on the selected accelerometer full scale:  $1 LSB = (FS_XL)/(2^6)$ . The threshold is applied to both positive and negative data: for a wake-up interrupt generation, the module of the filtered data must be bigger than the threshold.

The duration parameter defines the minimum duration of the wake-up event to be recognized; its value is set using the WAKE\_DUR[1:0] bits of the WAKE\_UP\_DUR register: 1 LSB corresponds to 1/ODR\_XL time, where ODR\_XL is the accelerometer output data rate. It is important to appropriately define the duration parameter to avoid unwanted wake-up interrupts due to spurious spikes of the input signal.

This interrupt signal can be driven to the two interrupt pins setting to 1 the INT1\_WU bit of the MD1\_CFG register or the INT2\_WU bit of the MD2\_CFG register; it can also be checked by reading the WU\_IA bit of the WAKE\_UP\_SRC register. The X\_WU, Y\_WU, Z\_WU bits of the WAKE\_UP\_SRC register indicate which axis has triggered the wake-up event.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal is automatically reset when the filtered data falls below the threshold. If latch mode is enabled and the wake-up interrupt signal is driven to the interrupt pins, once a wake-up event has occurred and the interrupt pin is asserted, it must be reset by reading the WAKE\_UP\_SRC register. If the latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect.



Figure 16. Wake-up interrupt (using the slope filter)

57

The example code which implements the SW routine for the wake-up event recognition using the high-pass digital filter is given below.

```
// Turn on the accelerometer
1
    Write 60h into CTRL1 XL
                                      // ODR XL = 416 Hz, FS XL = \pm 2 q
2
    Write 10h into TAP CFG
                                      // Apply high-pass digital filter; latch mode disabled
3
    Write 00h into WAKE UP DUR
                                      // No duration
4
    Write 02h into WAKE_UP_THS
                                      // Set wake-up threshold
5
    Write 20h into MD1 CFG
                                      // Wake-up interrupt driven to INT1 pin
```

Since the duration time is set to zero, the wake-up interrupt signal is generated for each X,Y,Z filtered data exceeding the configured threshold. The WK\_THS field of the WAKE\_UP\_THS register is set to 000010b, therefore the wake-up threshold is 62.5 mg (=  $2 * FS \times L / 2^6$ ).

Since the wake-up functionality is implemented using the slope/high-pass digital filter, it's necessary to consider the settling time of the filter just after this functionality is enabled. For example, when using the slope filter (but a similar consideration can be done for the high-pass digital filter usage) the wake-up functionality is based on the comparison of the threshold value with half of the difference of the acceleration of the current (x,y,z) sample and the previous one (refer to Section 3.7.1: Accelerometer slope filter).

At the very first sample, the slope filter output is calculated as half of the difference of the current sample [e.g. (x,y,z) = (0,0,1g)] with the previous one which is (x,y,z)=(0,0,0) since it doesn't exist. For this reason, on the z-axis the first output value of the slope filter is (1g - 0)/2 = 500 mg and it could be higher than the threshold value in which case a spurious interrupt event is generated. The interrupt signal is kept high for 1 ODR, then it goes low.

In order to avoid this spurious interrupt generation multiple solutions are possible. Hereafter three alternative solutions (for slope filter case):

- a) Ignore the first generated wake-up signal;
- b) Add a wait time higher than 1 ODR before driving the interrupt signal to the INT1/2 pin;
- c) Initially set a higher ODR (833 Hz) so the first 2 samples are generated in a shorter period of time, reducing the slope filter latency time, then set the desired ODR (e.g. 12.5 Hz) and drive the interrupt signal on the pin as indicated in the following procedure:

```
1
    Write 00h into WAKE_UP_DUR
                                      // No duration
2
    Write 02h into WAKE UP THS
                                      // Set wake-up threshold
3
    Write 00h into TAP_CFG
                                      // Apply slope filter; latch mode disabled
                                      // Turn on the accelerometer
4
    Write 70h into CTRL1 XL
                                      // ODR XL = 833 Hz, FS XL = \pm 2 g
5
    Wait 4 ms
                                      // Insert (reduced) wait time
6
    Write 10h into CTRL1 XL
                                      // ODR XL = 12.5 Hz
    Write 20h into MD1 CFG
                                      // Wake-up interrupt driven to INT1 pin
```



## 5.4 6D/4D orientation detection

The LSM6DS33 device provides the capability to detect the orientation of the device in space, enabling easy implementation of energy-saving procedures and automatic image rotation for mobile devices.

### 5.4.1 6D orientation detection

Six orientations of the device in space can be detected; the interrupt signal is asserted when the device switches from one orientation to another. The interrupt is not reasserted as long as the position is maintained.

6D interrupt is generated when, for two consecutive samples, only one axis exceeds a selected threshold and the acceleration values measured from the other two axes are lower than the threshold: the ZH, ZL, YH, YL, XH, XL bits of the D6D\_SRC (1Dh) register indicate which axis has triggered the 6D event.

In more detail:

Table 30. D6D\_SRC register

| b7 | b6     | b5 | b4 | b3 | b2 | b1 | b0 |
|----|--------|----|----|----|----|----|----|
| 0  | D6D_IA | ZH | ZL | YH | YL | XH | XL |

- D6D IA is set high when the device switches from one orientation to another.
- ZH (YH, XH) is set high when the face perpendicular to the Z(Y,X) axis is almost flat
  and the acceleration measured on the Z(Y,X) axis is positive and in the module bigger
  than the threshold.
- ZL (YL, XL) is set high when the face perpendicular to the Z(Y,X) axis is almost flat and the acceleration measured on the Z(Y,X) axis is negative and in the module bigger than the threshold.

The SIXD\_THS[1:0] bits of the TAP\_THS\_6D register are used to select the threshold value used to detect the change in device orientation. The threshold values given in *Table 31* are valid for each accelerometer full-scale value.

 SIXD\_THS[1:0]
 Threshold value [degrees]

 00
 80

 01
 70

 10
 60

 11
 50

Table 31. Threshold for 4D/6D function

The low-pass filter LPF2 can also be used in 6D functionality by setting the LOW\_PASS\_ON\_6D bit of the CTRL8\_XL register to 1. The LPF2 filter has to be enabled as described in *Section 3.7*.

This interrupt signal can be driven to the two interrupt pins by setting to 1 the INT1\_6D bit of the MD1\_CFG register or the INT2\_6D bit of the MD2\_CFG register; it can also be checked by reading the D6D\_IA bit of the D6D\_SRC register.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal is active only for 1/ODR\_XL[s] then it is automatically deasserted (ODR\_XL is the accelerometer output data rate). If latch mode is enabled and the 6D interrupt signal is driven to the interrupt pins, once an orientation change has occurred and the interrupt pin is asserted, a reading of the D6D\_SRC register clears the request and the device is ready to recognize a different orientation. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect.

Referring to the six possible cases illustrated in *Figure 17*, the content of the D6D\_SRC register for each position is shown in *Table 32*.



Figure 17. 6D recognized orientations

Table 32. D6D\_SRC register in 6D positions

| Case | D6D_IA | ZH | ZH | YH | YL | хн | XL |
|------|--------|----|----|----|----|----|----|
| (a)  | 1      | 0  | 0  | 0  | 0  | 0  | 1  |
| (b)  | 1      | 0  | 0  | 0  | 1  | 0  | 0  |
| (c)  | 1      | 0  | 0  | 1  | 0  | 0  | 0  |
| (d)  | 1      | 0  | 0  | 0  | 0  | 1  | 0  |
| (e)  | 1      | 1  | 0  | 0  | 0  | 0  | 0  |
| (f)  | 1      | 0  | 1  | 0  | 0  | 0  | 0  |

Hereafter an example which implements the SW routine for 6D orientation detection.

```
    Write 60h into CTRL1_XL  // Turn on the accelerometer  // ODR_XL = 416 Hz, FS_XL = ±2 g
    Write 40h into TAP_THS_6D  // Set 6D threshold (SIXD_THS[1:0] = 10b = 60 degrees)
    Write 10h into TAP_CFG  // Enable LPF2 filter
    Write 01h into CTRL8_XL  // Apply LPF2 filter to 6D functionality
    Write 04h into MD1 CFG  // 6D interrupt driven to INT1 pin
```

### 5.4.2 4D orientation detection

The 4D direction function is a subset of the 6D function especially defined to be implemented in mobile devices for portrait and landscape computation. It can be enabled by setting the D4D\_EN bit of the TAP\_THS\_6D register to 1. In this configuration, the Z-axis position detection is disabled, therefore reducing position recognition to cases (a), (b), (c), and (d) of *Table 32*.

# 5.5 Single-tap and double-tap recognition

The single-tap and double-tap recognition functions featured in the LSM6DS33 help to create a man-machine interface with little software loading. The device can be configured to output an interrupt signal on a dedicated pin when tapped in any direction.

If the sensor is exposed to a single input stimulus, it generates an interrupt request on the inertial interrupt pin INT1 and/or INT2. A more advanced feature allows the generation of an interrupt request when a double input stimulus with programmable time between the two events is recognized, enabling a mouse button-like function.

In the LSM6DS33 device the single-tap and double-tap recognition functions use the slope between two consecutive acceleration samples to detect the tap events; the slope data is computed using the following formula:

$$slope(t_n) = [acc(t_n) - acc(t_{n-1})] / 2$$

This function can be fully programmed by the user in terms of expected amplitude and timing of the slope data by means of a dedicated set of registers.

Single and double-tap recognition work independently of the selected output data rate. Recommended accelerometer ODRs for these functions are 416 Hz and 833 Hz.

### 5.5.1 Single tap

If the device is configured for single-tap event detection, an interrupt is generated when the slope data of the selected channel exceeds the programmed threshold and returns below it within the Shock time window.

In the single-tap case, if the LIR bit of the TAP\_CFG register is set to 0, the interrupt is kept high for the duration of the Quiet window.

In order to enable the latch feature on the single-tap interrupt signal, both the LIR bit and the INT1\_DOUBLE\_TAP (or INT2\_DOUBLE\_TAP) bit of MD1\_CFG (MD2\_CFG) have to be set to 1: the interrupt is kept high until the TAP\_SRC register is read.

48/96 DocID027736 Rev 5



The SINGLE\_DOUBLE\_TAP bit of WAKE\_UP\_THS has to be set to 0 in order to enable single-tap recognition only.

In case (a) of *Figure 18* the single-tap event has been recognized, while in case (b) the tap has not been recognized because the slope data falls below the threshold after the Shock time window has expired.



Figure 18. Single-tap event recognition

# 5.5.2 Double tap

If the device is configured for double-tap event detection, an interrupt is generated when, after a first tap, a second tap is recognized. The recognition of the second tap occurs only if the event satisfies the rules defined by the Shock, the Latency and the Duration time windows.

In particular, after the first tap has been recognized, the second tap detection procedure is delayed for an interval defined by the Quiet time. This means that after the first tap has been recognized, the second tap detection procedure starts only if the slope data exceeds the threshold after the Quiet window but before the Duration window has expired. In case (a) of *Figure 19*, a double-tap event has been correctly recognized, while in case (b) the interrupt has not been generated because the slope data exceeds the threshold after the window interval has expired.

Once the second tap detection procedure is initiated, the second tap is recognized with the same rule as the first: the slope data must return below the threshold before the Shock window has expired.

It is important to appropriately define the Quiet window to avoid unwanted taps due to spurious bouncing of the input signal.

In the double-tap case, if the LIR bit of the TAP\_CFG register is set to 0, the interrupt is kept high for the duration of the Quiet window. If the LIR bit is set to 1, the interrupt is kept high until the TAP\_SRC register is read.



Figure 19. Double-tap event recognition (LIR bit = 0)

# 5.5.3 Single-tap and double-tap recognition configuration

The LSM6DS33 device can be configured to output an interrupt signal when tapped (once or twice) in any direction: the TAP\_X\_EN, TAP\_Y\_EN and TAP\_Z\_EN bits of the TAP\_CFG register must be set to 1 to enable the tap recognition on X, Y, Z directions, respectively.

Configurable parameters for tap recognition functionality are the tap threshold and the Shock, Quiet and Duration time windows.

The TAP\_THS[4:0] bits of the TAP\_THS\_6D register are used to select the unsigned threshold value used to detect the tap event. The value of 1 LSB of these 5 bits depends on the selected accelerometer full scale:  $1 LSB = (FS_XL)/(2^5)$ . The unsigned threshold is applied to both positive and negative slope data.

The Shock time window defines the maximum duration of the overthreshold event: the acceleration must return below the threshold before the Shock window has expired, otherwise the tap event is not detected. The SHOCK[1:0] bits of the INT\_DUR2 register are used to set the Shock time window value: the default value of these bits is 00b and corresponds to 4/ODR\_XL time, where ODR\_XL is the accelerometer output data rate. If the SHOCK[1:0] bits are set to a different value, 1 LSB corresponds to 8/ODR\_XL time.

In the double-tap case, the Quiet time window defines the time after the first tap recognition in which there must not be any overthreshold. When the latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the Quiet time also defines the length of the interrupt pulse (in both single and double-tap case). The QUIET[1:0] bits of the INT\_DUR2 register are used to set the Quiet time window value: the default value of these bits is 00b and corresponds to

50/96 DocID027736 Rev 5

2/ODR\_XL time, where ODR\_XL is the accelerometer output data rate. If the QUIET[1:0] bits are set to a different value, 1 LSB corresponds to 4/ODR XL time.

In the double-tap case, the Duration time window defines the maximum time between two consecutive detected taps. The Duration time period starts just after the completion of the Quiet time of the first tap. The DUR[3:0] bits of the INT\_DUR2 register are used to set the Duration time window value: the default value of these bits is 0000b and corresponds to 16/ODR\_XL time, where ODR\_XL is the accelerometer output data rate. If the DUR[3:0] bits are set to a different value, 1 LSB corresponds to 32/ODR XL time.

Figure 20 illustrates a single-tap event (a) and a double-tap event (b). These interrupt signals can be driven to the two interrupt pins by setting to 1 the INT1\_SINGLE\_TAP bit of the MD1\_CFG register or the INT2\_SINGLE\_TAP bit of the MD2\_CFG register for the single-tap case, and setting to 1 the INT1\_DOUBLE\_TAP bit of the MD1\_CFG register or the INT2\_DOUBLE\_TAP bit of the MD2\_CFG register for the double-tap case.

No single/double tap interrupt is generated if the accelerometer is in Inactivity status (see *Section 5.6* for more details).



Tap interrupt signals can also be checked by reading the TAP\_SRC (1Ch) register, described in *Table 33*.

| b7 | b6     | b5            | b4            | b3       | b2    | b1    | b0    |  |  |
|----|--------|---------------|---------------|----------|-------|-------|-------|--|--|
| 0  | TAP_IA | SINGLE<br>TAP | DOUBLE<br>TAP | TAP_SIGN | X_TAP | Y_TAP | Z_TAP |  |  |

Table 33. TAP\_SRC register

- TAP\_IA is set high when a single-tap or double-tap event has been detected.
- SINGLE TAP is set high when a single tap has been detected.
- DOUBLE TAP is set high when a double tap has been detected.
- TAP\_SIGN indicates the acceleration sign when the tap event is detected. It is set low in case of positive sign and it is set high in case of negative sign.
- X\_TAP (Y\_TAP, Z\_TAP) is set high when the tap event has been detected on the X (Y, Z) axis

Single and double-tap recognition works independently. Setting the SINGLE\_DOUBLE\_TAP bit of WAKE\_UP\_THS to 0, only the single-tap recognition is enabled: double-tap recognition is disabled and cannot be detected. When the SINGLE\_DOUBLE\_TAP is set to 1, both single and double-tap recognition are enabled.

If the latch mode is enabled and the interrupt signal is driven to the interrupt pins, the value assigned to SINGLE\_DOUBLE\_TAP also affects the behavior of the interrupt signal: when it is set to 0, the latch mode is applied to the single-tap interrupt signal; when it is set to 1, the latch mode is applied to the double-tap interrupt signal only. The latched interrupt signal is kept high until the TAP\_SRC register is read. If the latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the latch feature does not take effect.

# 5.5.4 Single-tap example

A basic SW routine for single-tap detection is given below.

```
// Turn on the accelerometer
1
    Write 60h into CTRL1_XL
                                     // ODR XL = 416 Hz, FS XL = \pm 2 g
2
    Write 0Eh into TAP_CFG
                                    // Enable tap detection on X, Y, Z axis
    Write 09h into TAP_THS_6D
3
                                    // Set tap threshold
    Write 06h into INT DUR2
                                    // Set Quiet and Shock time windows
4
                                    // Only single tap enabled (SINGLE_DOUBLE_TAP = 0)
    Write 00h into WAKE UP THS
5
    Write 40h into MD1 CFG
                                    // Single tap interrupt driven to INT1 pin
```

In this example the TAP\_THS field of the TAP\_THS\_6D register is set to 01001b, therefore the tap threshold is 562.5 mg (=  $9 * FS_XL / 2^5$ ).

The SHOCK field of the INT\_DUR2 register is set to 10b: an interrupt is generated when the slope data exceeds the programmed threshold, and returns below it within 38.5 ms (= 2 \* 8 / ODR\_XL) corresponding to the Shock time window.

The QUIET field of the INT\_DUR2 register is set to 01b: since the latch mode is disabled, the interrupt is kept high for the duration of the Quiet window, therefore 9.6 ms (= 1 \* 8 / ODR\_XL.)

52/96 DocID027736 Rev 5

# 5.5.5 Double-tap example

A basic SW routine for double-tap detection is given below.

```
// Turn on the accelerometer
1
    Write 60h into CTRL1 XL
                                     // ODR XL = 416 Hz, FS XL = \pm 2 q
2
    Write 0Eh into TAP_CFG
                                     // Enable tap detection on X, Y, Z axis
    Write 0Ch into TAP THS 6D
3
                                     // Set tap threshold
    Write 7Fh into INT DUR2
                                     // Set Duration, Quiet and Shock time windows
4
5
    Write 80h into WAKE UP THS
                                    // Single & Double tap enabled (SINGLE DOUBLE TAP = 1)
    Write 08h into MD1 CFG
                                     // Double tap interrupt driven to INT1 pin
6
```

In this example the TAP\_THS field of the TAP\_THS\_6D register is set to 01100b, therefore the tap threshold is 750 mg (= 12 \* FS XL /  $2^5$ ).

For interrupt generation, during the first and the second tap the slope data must return below the threshold before the Shock window has expired. The SHOCK field of the INT DUR2 register is set to 11b, therefore the Shock time is 57.7 ms (= 3 \* 8 / ODR XL).

For interrupt generation, after the first tap recognition there must not be any slope data overthreshold during the Quiet time window. Furthermore, since the latch mode is disabled, the interrupt is kept high for the duration of the Quiet window. The QUIET field of the INT DUR2 register is set to 11b, therefore the Quiet time is 28.8 ms (= 3 \* 4/ ODR XL).

For the maximum time between two consecutive detected taps, the DUR field of the  $INT\_DUR2$  register is set to 0111b, therefore the Duration time is 538.5 ms (= 7 \* 32 / ODR XL).

# 5.6 Activity/Inactivity recognition

The Activity/Inactivity recognition function allows reducing system power consumption and developing new smart applications.

When the Activity/Inactivity recognition function is activated, the LSM6DS33 device is able to automatically decrease the accelerometer sampling rate to 12.5 Hz, increasing the accelerometer ODR and bandwidth as soon as the wake-up interrupt event has been detected. This feature is applied to the accelerometer sensor only, regardless of the selected gyroscope power mode and ODR. The maximum allowed accelerometer ODR (configurable through the ODR\_XL [3:0] bits of the CTRL1\_XL register) for using the Activity/Inactivity feature is 833 Hz.

With this feature the system may be efficiently switched from low-power consumption to full performance and vice-versa depending on user-selectable acceleration events, thus ensuring power saving and flexibility.

The Activity/Inactivity recognition function is enabled by setting to 1 the INACTIVITY bit of the WAKE\_UP\_THS register.

In the LSM6DS33 device the Activity/Inactivity recognition function can be implemented using either the slope filter (see *Section 3.7.1* for more details) or the high-pass digital filter, as illustrated in *Figure 5*. The filter to be applied can be selected using the SLOPE\_FDS bit



of the TAP\_CFG register: if this bit is set to 0 (default value), the slope filter is used; if it's set to 1, the high-pass digital filter is used.

This function can be fully programmed by the user in terms of expected amplitude and timing of the slope data by means of a dedicated set of registers (*Figure 21*).

The unsigned threshold value is defined using the WK\_THS[5:0] bits of a dedicated set of registers WAKE\_UP\_THS register; the value of 1 LSB of these 6 bits depends on the selected accelerometer full scale: 1 LSB =  $(FS_XL)/(2^6)$ . The threshold is applied to both positive and negative filtered data.

When a certain number of consecutive X,Y,Z slope data is smaller than the configured threshold, the ODR\_XL [3:0] bits of the CTRL1\_XL register are bypassed (Inactivity) and the accelerometer is internally set to 12.5 Hz although the content of CTRL1\_XL is left untouched. The duration of the Inactivity status to be recognized is defined by the SLEEP\_DUR[3:0] bits of the WAKE\_UP\_DUR register: 1 LSB corresponds to 512/ODR\_XL time, where ODR\_XL is the accelerometer output data rate.

When the Inactivity status is detected, the interrupt is set high for 1/ODR\_XL[s] period then it is automatically deasserted.

When a single sample of X,Y,Z filtered data on one axis becomes bigger than the threshold, the CTRL1\_XL register settings are immediately restored (Activity).

When the Activity status is detected, the interrupt is set high for 1/ODR\_XL[s] period then it is automatically deasserted.

Once the Activity/Inactivity detection function is enabled, the status can be driven to the two interrupt pins by setting to 1 the INT1\_INACT\_STATE bit of the MD1\_CFG register or the INT1\_INACT\_STATE bit of the MD2\_CFG register; it can also be checked by reading the SLEEP STATE IA bit of the WAKE UP SRC register.



Figure 21. Activity/Inactivity recognition

The code provided below is a basic routine for Activity/Inactivity detection implementation.

```
    Write 50h into CTRL1_XL // Turn on the accelerometer // ODR_XL = 208 Hz, FS_XL = ±2 g
    Write 02h into WAKE_UP_DUR // Set duration for Inactivity detection
    Write 42h into WAKE_UP_THS // Enable Activity/Inactivity threshold // Enable Activity/Inactivity detection
    Write 80h into MD1 CFG // Activity/Inactivity interrupt driven to INT1 pin
```

In this example the WK\_THS field of the WAKE\_UP\_THS register is set to 000010b, therefore the Activity/Inactivity threshold is 62.5 mg (=  $2 * FS \times L / 2^6$ ).

Before Inactivity detection, the X,Y,Z slope data must be smaller than the configured threshold for a period of time defined by the SLEEP\_DUR field of the WAKE\_UP\_DUR register: this field is set to 0010b, corresponding to 4.92 s (= 2 \* 512 / ODR\_XL). After this period of time has elapsed, the accelerometer ODR is internally set to 12.5 Hz.

The Activity status is detected and the CTRL1\_XL register settings immediately restored if the slope data of (at least) one axis are bigger than the threshold.

### 5.7 Boot status

After the device is powered up, the LSM6DS33 performs a 20 ms boot procedure to load the trimming parameters. After the boot is completed, both the accelerometer and the gyroscope are automatically configured in Power-Down mode. During boot time the registers are not accessible.

After power-up, the trimming parameters can be re-loaded by setting to 1 the BOOT bit of the CTRL3\_C register.

No toggle of the device power lines is required and the content of the device control registers is not modified, so the device operating mode doesn't change after boot. If the reset to the default value of the control registers is required, it can be performed by setting to 1 the SW\_RESET bit of the CTRL3\_C register. The SW\_RESET procedure can take 50  $\mu$ s; the status of reset is signaled by the status of the SW\_RESET bit of the CTRL3\_C register: once the reset is completed, this bit is automatically set low.

The boot status signal is driven to the INT1 interrupt pin by setting to 1 the INT1\_BOOT bit of the INT1\_CTRL register: this signal is set high while the boot is running and it is set low again at the end of the boot procedure.

The reboot flow is as follows:

- 1. Set the Gyroscope in Power-Down mode;
- 2. Set the Accelerometer in High-Performance mode;
- Set to 1 the BOOT bit of the CTRL3\_C register; wait 20 ms.

The reset flow is as follows:

- 1. Set the gyroscope in Power-Down mode;
- 2. Set the accelerometer in High-Performance mode;
- 3. Set to 1 the SW\_RESET bit of the CTRL3\_C register;
- 4. Wait 50 μs (or wait until the SW\_RESET bit of the CTRL3\_C register returns to 0).

In order to avoid conflicts, the reboot and the sw reset must not be executed at the same time (do not set to 1 at the same time both BOOT bit and SW\_RESET bit of CTRL3\_C register). The above flows must be performed serially.

# 6 Android embedded functions

The LSM6DS33 device implements in hardware the sensor-related functions specified in Android L; specific IP blocks with negligible power consumption and high-level performance implement the following functions using only the accelerometer:

- Pedometer functions (step detector and step counter);
- Significant motion;
- Tilt;
- Timestamp.

All these functions work at 26 Hz, so the accelerometer ODR must be set at 26 Hz or higher values.

# 6.1 Pedometer functions: step detector and step counter

A specific IP block of the LSM6DS33 device is dedicated to pedometer functions: the step detector and the step counter.

Pedometer functions work at 26 Hz, so the accelerometer ODR must be set at 26 Hz or higher values.

In order to enable the pedometer functions it is necessary to set to 1 both the FUNC\_EN bit of the CTRL10\_C register and the PEDO\_EN bit of the TAP\_CFG register.

The step counter indicates the number of steps detected by the step detector algorithm after the pedometer function has been enabled. The step count is given by the concatenation of the STEP\_COUNTER\_H and STEP\_COUNTER\_L registers and it is represented as a 16-bit unsigned number.

The step count is not reset to zero when the accelerometer is configured in Power-Down or the pedometer is disabled; it can be reset to zero by setting the PEDO\_RST\_STEP bit of the CTRL10\_C register to 1. After the counter resets, the PEDO\_RST\_STEP bit is not automatically set back to 0.

The step detector functionality generates an interrupt every time a step is recognized. In case of interspersed step sessions, 7 consecutive steps (debounce steps) have to be detected before the first interrupt generation (debounce functionality) in order to avoid false step detections.

The number of debounce steps can be modified through the DEB\_STEP field of the PEDO\_DEB\_REG register: basically, it corresponds to the minimum number of steps to be detected before the first step counter increment. 1 LSB of this field corresponds to 1 step, the default value is 6 steps.

The debounce functionality restarts after around 1 second of device inactivity. This period of time (debounce time) can be modified through the DEB\_TIME field of the PEDO\_DEB\_REG register. 1 LSB corresponds to 80 ms, default value is 13 (13 \*80 ms = 1040 ms). This value must be greater than 0.

The example in *Figure 22* explains how the step counter behavior changes by changing the debounce time. In this example, the pedometer algorithm detects 7 steps close to each other and then two more isolated steps after a certain period of time; assuming that the value of the DEB\_STEP field of the PEDO\_DEB\_REG register is set to 6 LSB (=6 debounce



steps, default value) and the initial step counter value in STEP\_COUNTER\_H/L registers is zero (no steps previously detected):

- a) in case (a), the step count starts increasing after the seventh step and after the first eight detected steps the value of STEP\_COUNTER\_H/L registers will be 8. Since the debounce time set in the DEB\_TIME field of the PEDO\_DEB\_REG register is greater than the period of time between step #8 and step #9, also steps #9 and #10 will cause the step counter to increase: the final step count value in STEP\_COUNTER\_H/L registers will be 10.
- b) also in case (b) the step count starts increasing after the seventh step and after the first eight detected steps the value of STEP\_COUNTER\_H/L registers will be 8, but since the debounce time set in the DEB\_TIME field of the PEDO\_DEB\_REG register is lower than the period of time between step #8 and step #9, steps #9 and #10 will not cause the step counter to increase: the final step count value in the STEP\_COUNTER\_H/L registers will be 8. Furthermore, if between step #10 and the following step elapses a period of time greater than the debounce time, the detected steps #9 and #10 will be definitively discarded and no longer considered.



Figure 22. Pedometer debounce

By default, the step counter works at  $\pm 2~g$  full scale, independently of the configured device full scale, but it can be configured to work at  $\pm 4~g$  full scale which can help to avoid acceleration saturation (e.g. in fast walk). In order to set the  $\pm 4~g$  full scale for the step counter the PEDO\_4G bit of the PEDO\_THS\_REG register has to be set to 1 and the accelerometer full scale configured in CTRL1\_XL register must be  $\geq \pm 4~g$ .

It is also possible to set the "Minimum Threshold", that is the value at which the threshold for step recognition asymptotically tends if no steps are detected and below which it cannot descend (see *Figure 23*). This configuration is available in the THS\_MIN field of the PEDO\_THS\_REG register. The value of 1 LSB of these 6 bits depends on the selected step counter full scale: 1 LSB = 16 mg if the PEDO\_4G bit is 0; 1 LSB = 32 mg if the PEDO\_4G bit is 1.

**577** 



Figure 23. Pedometer minimum threshold

The step detector interrupt signal can be driven to the INT1 interrupt pin by setting to 1 the INT1\_STEP\_DETECTOR bit of the INT1\_CTRL register; it can also be checked by reading the STEP\_DETECTED bit of the FUNC\_SRC register.

Instead of generating an interrupt every time a step is recognized, it is possible to generate it if at least one step is detected within a certain time period. This time period is defined by setting a value higher than 00h in the STEP\_COUNT\_DELTA register. It is necessary to set the TIMER\_EN bit of the TAP\_CFG register to 1 (to enable the timer) and the TIMER\_HR bit of the WAKE\_UP\_DUR register to 0 when using this feature: in this case, 1 LSB of the value of the STEP\_COUNT\_DELTA register corresponds to 1.6384 seconds. This interrupt signal can be driven to the INT2 interrupt pin by setting to 1 the INT2\_STEP\_DELTA bit of the INT2\_CTRL register; it can also be checked by reading the STEP\_COUNT\_DELTA\_IA bit of the FUNC\_SRC register.

The Step Counter overflow signal can be driven to the INT2 interrupt pin by setting to 1 the INT2\_STEP\_COUNT\_OV bit of the INT2\_CTRL register: in this case, when the step count reaches the 2<sup>16</sup> value, an interrupt signal is generated on the INT2 pin and the step count is automatically reset to zero, no need to reset it by setting to 1 the PEDO\_RST\_STEP bit.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal generated by the pedometer functions is pulsed: the duration of the pulse observed on the interrupt pins is about 60  $\mu$ s; the duration of the pulse observed on the bits STEP\_COUNT\_DELTA\_IA, STEP\_DETECTED\_IA and STEP\_OVERFLOW of the FUNC\_SRC register is 1/26 Hz.

If latch mode is enabled (LIR bit of TAP\_CFG is set to 1) and the interrupt signal is driven to the interrupt pins, once a step has occurred, a reading of the FUNC\_SRC register clears the request on both the pins and the STEP\_COUNT\_DELTA\_IA, STEP\_DETECTED\_IA and STEP\_OVERFLOW bits of the FUNC\_SRC register, and the device is ready to recognize the next step. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the interrupt signal observed on the bits of the FUNC\_SRC register is pulsed, with a fixed duration of 1/26 Hz.

Step counter timestamp information is available in the STEP\_TIMESTAMP\_H and STEP\_TIMESTAMP\_L registers: when a step is detected, the value of the



TIMESTAMP\_REG2 register is copied in STEP\_TIMESTAMP\_H, and the value of the TIMESTAMP\_REG1 register is copied in STEP\_TIMESTAMP\_L, providing the timestamp information of this step. For more details about LSM6DS33 timestamp counter and TIMESTAMP\_REG2/TIMESTAMP\_REG1, see Section 6.4.

The step counter timestamp resolution depends on the value of the TIMER\_HR bit of the WAKE\_UP\_DUR register: when this bit is set to 0, 1 LSB of the time step count corresponds to 1638.4 ms; when this bit is set to 1, 1 LSB of the time step count corresponds to 6.4 ms.

Step counter data can be stored in FIFO as a third data set along with timestamp data (see *Section 7.8* for more details).

Hereafter a basic SW routine which shows how to enable the pedometer functions:

```
    Write 20h into CTRL1_XL // Turn on the accelerometer // ODR_XL = 26 Hz, FS_XL = ±2 g
    Write 3Ch into CTRL10_C // Enable embedded functions
    Write 40h into TAP_CFG // Enable pedometer algorithm
    Write 80h into INT1_CTRL // Step Detector interrupt driven to INT1 pin
```

The interrupt signal is generated when a step is recognized and the step count is available by reading the STEP\_COUNTER\_H / STEP\_COUNTER\_L registers.

# 6.2 Significant motion

The Significant Motion function generates an interrupt when a 'significant motion', that could be due to a change in user location, is detected: in the LSM6DS33 device this function has been implemented in hardware using only the accelerometer.

The Significant Motion functionality can be used in location-based applications in order to receive a notification indicating when the user is changing location.

The Significant Motion function works at 26 Hz, so the accelerometer ODR must be set at a value of 26 Hz or higher.

In order to enable Significant Motion detection it is necessary to set to 1 both the FUNC\_EN bit and the SIGN\_MOTION\_EN bit of the CTRL10\_C register.

Note: In order to ensure that the Significant Motion function works properly, the step detector/step counter has to be on.

The Significant Motion interrupt signal is driven to the INT1 interrupt pin by setting to 1 both the INT1\_SIGN\_MOTION bit and the INT1\_STEP\_DETECTOR bit of the INT1\_CTRL register; it can also be checked by reading the SIGN\_MOTION\_IA bit of the FUNC\_SRC register.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal generated by the Significant Motion function is pulsed: the duration of the pulse observed on the interrupt pins is about 60  $\mu$ s; the duration of the pulse observed on the SIGN\_MOTION\_IA bit of the FUNC\_SRC register is 1/26 Hz.

If latch mode is enabled (LIR bit of TAP\_CFG is set to 1) and the interrupt signal is driven to the interrupt pins, once a 'significant motion' is detected, a reading of the FUNC\_SRC register clears the request on both the pins and the SIGN MOTION IA bit of the

57

60/96 DocID027736 Rev 5

FUNC\_SRC register, and the device is ready to recognize the next event. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the interrupt signal observed on the SIGN\_MOTION\_IA bit of the FUNC\_SRC register is pulsed, with a fixed duration of 1/26 Hz.

The embedded function register (accessible by setting to 1 the FUNC\_CFG\_EN bit of FUNC\_CFG\_ACCESS) used to configure the Significant Motion threshold parameter is the SM\_THS register. The SM\_THS\_[7:0] bits of this register define the threshold value: it corresponds to the number of steps to be performed by the user upon a change of location before the Significant Motion interrupt is generated. It is expressed as an 8-bit unsigned value: the default value of this field is equal to 6 (= 00000110b).

When the debounce functionality of the Pedometer is active (see *Section 6.1* for details), the Significant Motion threshold is effective only if its value, corresponding to the value of the SM\_THS\_[7:0] bits of the SM\_THS register, is equal to or greater than the pedometer debounce threshold (corresponding to the value of the DEB\_STEP[2:0] bits of the PEDO\_DEB\_REG (2Bh) register).

Basically, three different scenarios are possible for the Significant Motion threshold value:

- a) If the pedometer debounce functionality is not active, the Significant Motion threshold value is defined by the SM THS [7:0] bits;
- b) if the pedometer debounce functionality is active and the Significant Motion threshold value is equal to or greater than the pedometer debounce value, the effective Significant Motion threshold value is defined by the SM THS [7:0] bits;
- c) if the pedometer debounce functionality is active and the Significant Motion threshold value is lower than the pedometer debounce value, the effective Significant Motion threshold value is defined by the DEB STEP[2:0] bits.

Note:

In case c), if the desired Significant Motion threshold is lower than the default value, the value of the DEB\_STEP[2:0] bits of the PEDO\_DEB\_REG (2Bh) register has to be decreased accordingly. Note that an excessive reduction of the pedometer debounce threshold can cause the Pedometer to report false step detections!

Hereafter a basic SW routine which shows how to enable the significant motion detection function:

```
1
    Write 80h into FUNC CFG ADDRESS
                                               // Enable access to embedded functions registers
    Write 08h into SM_THS
2
                                               // Set Significant Motion threshold
3
    Write 00h into FUNC CFG ADDRESS
                                               // Disable access to embedded functions registers
                                               // Turn-on the accelerometer
4
    Write 20h into CTRL1_XL
                                               // ODR XL = 26 Hz, FS_XL = \pm 2 g
    Write 00h into TAP CFG
                                               // Disable pedometer
                                               // Enable embedded functions
6
    Write 3Dh into CTRL10 C
                                               // Enable Significant Motion detection
7
    Write 40h into TAP CFG
                                               // Enable pedometer algorithm
8
    Write C0h into INT1 CTRL
                                               // Significant motion interrupt driven to INT1 pin
```

In this example the SM\_THS\_[7:0] bits of the SM\_THS register are set to 00001000b, therefore the Significant Motion threshold is equal to 8.



#### 6.3 Tilt

The Tilt function allows detecting when an activity change occurs (e.g. when a phone is in a front pocket and the user goes from sitting to standing or standing to sitting): in the LSM6DS33 device it has been implemented in hardware using only the accelerometer.

In order to enable the tilt detector it is necessary to set to 1 both the FUNC EN bit of the CTRL10 C register and the TILT EN bit of the TAP CFG register.

If the device is configured for tilt event detection, an interrupt is generated when the device is tilted by an angle greater than 35 degrees from the start position. The start position is defined as the position of the device when the tilt detection is enabled or the position of the device when the last Tilt interrupt was generated.

After this function is enabled, for the generation of the first Tilt interrupt the device should be continuously tilted by an angle greater than 35 degrees since start position for a period of time of 2 seconds. After the first Tilt interrupt is generated, the Tilt interrupt signal is set high as soon as the device is tilted by an angle greater than 35 degrees from the position of the device corresponding to the last interrupt detection (no need to wait 2 seconds).

In the example shown in Figure 24, Tilt detection is enabled when the device orientation corresponds to "start position #0": first interrupt is generated if the device is rotated by an angle greater than 35 degrees from the start position and remains in the blue zone for a period of time of at least 2 seconds. After the first Tilt detection interrupt is generated, the new start position (#1) corresponds to the position of the device when the previous interrupt was generated (final position #0), and the next interrupt signal will be generated as soon as the device is tilted by an angle greater than 35 degrees, entering the blue zone surrounding the start position #1.



Figure 24. Tilt example

This interrupt signal can be driven to the two interrupt pins by setting to 1 the INT1\_TILT bit of the MD1\_CFG register or the INT2\_TILT bit of the MD2\_CFG register; it can also be checked by reading the TILT IA bit of the FUNC SRC register.

If latch mode is disabled (LIR bit of TAP\_CFG is set to 0), the interrupt signal generated by the Tilt function is pulsed: the duration of the pulse observed on the interrupt pins is about

62/96 DocID027736 Rev 5



 $60 \mu s$ ; the duration of the pulse observed on the TILT\_IA bit of FUNC\_SRC register is  $1/26 \ Hz$ .

If latch mode is enabled (LIR bit of TAP\_CFG is set to 1) and the interrupt signal is driven to the interrupt pins, once a tilt is detected, a reading of the FUNC\_SRC register clears the request on both the pins and the TILT\_IA bit of FUNC\_SRC register, and the device is ready to recognize the next tilt event. If latch mode is enabled but the interrupt signal is not driven to the interrupt pins, the interrupt signal observed on the TILT\_IA bit of the FUNC\_SRC register is pulsed, with a fixed duration of 1/26 Hz.

The tilt function works at 26 Hz, so the accelerometer ODR must be set at 26 Hz or higher values.

Hereafter a basic SW routine which shows how to enable the tilt detection function:

```
    Write 20h into CTRL1_XL // Turn on the accelerometer // ODR_XL = 26 Hz, FS_XL = ±2 g
    Write 3Ch into CTRL10_C // Enable embedded functions
    Write 20h into TAP_CFG // Enable tilt detection
    Write 02h into MD1_CFG // Tilt detector interrupt driven to INT1 pin
```



# 6.4 Timestamp

Together with sensor data the LSM6DS33 device can provide timestamp information.

If both the accelerometer and the gyroscope are in Power-Down mode, the timestamp counter doesn't work.

To enable this functionality the TIMER\_EN bit of the TAP\_CFG register has to be set to 1: the time step count is given by the concatenation of the TIMESTAMP\_REG2 & TIMESTAMP\_REG1 & TIMESTAMP\_REG0 registers and is represented as a 24-bit unsigned number.

The timestamp resolution can be configured using the TIMER\_HR bit of the WAKE\_UP\_DUR register: when this bit is set to 0, 1 LSB of time step count corresponds to 6.4 ms (low-resolution mode); when this bit is set to 1, 1 LSB of time step count corresponds to 25  $\mu$ s (high-resolution mode).

When the maximum value 16777215 LSB (corresponding to FFFFFFh) is reached and low resolution (TIMER\_HR = 0) is used, the counter is automatically reset to 000000h and continues to count. When the maximum value is reached and high resolution (TIMER\_HR = 1) is used, the counter is not automatically reset to 0 and freezes at FFFFFh. In any case, the timer count can be reset to zero at any time by writing the reset value AAh in the TIMESTAMP\_REG2 register.

An interrupt is generated around 1.638 seconds before timer saturation in both high-resolution mode (when the timer step count reaches the value FF0000h) and low-resolution mode (when the timer step count reaches the value FFF00h). This interrupt signal can be driven to the INT1 pin by setting to 1 the INT1\_TIMER bit of the MD1\_CFG register. Once the interrupt pin is asserted, it must be reset to zero by writing AAh in the TIMESTAMP\_REG2 register (the timer step count will be reset also).

The timestamp count can be stored in FIFO as a third data set along with the step counter data (see *Section 7.8* for details).

The timestamp resolution has to be set before enabling the timestamp functionality; a basic SW routine is as follows:

```
1 Write 50h into CTRL1_XL // Turn on the accelerometer // ODR_XL = 208 Hz, FS_XL = \pm 2 g
2 Write 10h into WAKE_UP_DUR // Timestamp resolution = 25 μs
3 Write 80h into TAP_CFG // Enable timestamp count
4 Write 01h into MD1_CFG // End counter interrupt driven to INT1 pin
```

When switching from a low timestamp resolution to a high resolution the timer count must be reset, as indicated in the example below:

```
    Write 50h into CTRL1_XL  // Turn on the accelerometer  // ODR_XL = 208 Hz, FS_XL = ±2 g
    Write 00h into WAKE_UP_DUR  // Timestamp resolution = 6.4 ms
    Write 80h into TAP_CFG  // Enable timestamp count  ...
    Write 10h into WAKE_UP_DUR  // Timestamp resolution = 25 μs
    Write AAh into TIMESTAMP_REG2  // Reset timer counter
```

64/96 DocID027736 Rev 5

# 7 First-in first-out (FIFO) buffer

In order to limit intervention by the host processor and facilitate post-processing data for event recognition, the LSM6DS33 embeds an 8 kbyte first-in first-out buffer (FIFO).

The FIFO can be configured to store the following data:

- gyroscope sensor data;
- accelerometer sensor data;
- step counter and timestamp data;
- temperature sensor data.

Saving data in the FIFO buffer is based on three 'FIFO data set' consisting of 6 bytes each:

- The 1<sup>st</sup> FIFO data set is reserved for gyroscope data;
- The 2<sup>nd</sup> FIFO data set is reserved for accelerometer data;
- The 3<sup>rd</sup> FIFO data set can be alternately associated to the step counter and timestamp info, or to the temperature sensor data.

All these data sets can be stored in FIFO at different ODRs, by setting the decimation factors in the FIFO\_CTRL3 and FIFO\_CTRL4 registers. Decimation factors are also used to select which FIFO data sets have to be stored in FIFO.

Five different FIFO operating modes can be chosen through the FIFO\_MODE\_[2:0] bits of the FIFO\_CTRL5 register:

- · Bypass mode;
- FIFO mode:
- · Continuous mode;
- Continuous-to-FIFO mode;
- Bypass-to-Continuous mode.

Note: When the FIFO is used, the IF\_INC bit of the CTRL3\_C register must be equal to 1.

Data are retrieved from the FIFO through two dedicated registers: FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H. In this way, data can be read either from the FIFO (at a slower ODR) or from the device output registers (at the normal ODR).

To monitor the FIFO status (full, empty, number of sample stored, etc), four dedicated registers are available: FIFO\_STATUS1, FIFO\_STATUS2, FIFO\_STATUS3, FIFO\_STATUS4.

Programmable FIFO thresholds can be set in FIFO\_CTRL1 and FIFO\_CTRL2 using the FTH [11:0] bits.

FIFO full, FIFO threshold and FIFO overrun events can be enabled to generate dedicated interrupts on the two interrupt pins (INT1 and INT2) through the INT1\_FULL\_FLAG, INT1\_FTH and INT1\_OVR bits of the INT1\_CTRL register, and through the INT2\_FULL\_FLAG, INT2\_FTH and INT2\_OVR bits of the INT2\_CTRL register.

In order to increase the number of samples which can be stored in the FIFO, it is also possible to store (as 1<sup>st</sup> FIFO data set) only the 8 most significant bits of the accelerometer and gyroscope data by setting the bit ONLY\_HIGH\_DATA in the FIFO\_CTRL4 register.

When the TIMER\_PEDO\_FIFO\_DRDY bit of the FIFO\_CTRL2 register is set to 0, writing data in the FIFO is triggered by the accelerometer/gyroscope data-ready. If the



TIMER\_PEDO\_FIFO\_DRDY bit is set to 1, the data are stored in FIFO every time a step is detected.

# 7.1 FIFO registers

The FIFO buffer is managed by:

- five control registers (from FIFO CTRL1 to FIFO CTRL5);
- four status registers (from FIFO\_STATUS1 to FIFO\_STATUS4);
- two data output registers (FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H);
- some additional bits to enable threshold usage (STOP\_ON\_FTH) and route FIFO full, threshold or overrun events to the two interrupt lines (bits: INT1\_FULL\_FLAG, INT2\_FULL\_FLAG, INT1\_FTH, INT2\_FTH, INT1\_FIFO\_OVR, INT2\_FIFO\_OVR).

### 7.1.1 FIFO\_CTRL1 (06h)

The FIFO\_CTRL1 register contains the lower part of the 12-bit FIFO threshold level. For the complete threshold level configuration, consider also the FTH\_[11:8] bits of the FIFO\_CTRL2 register. The value of the FIFO threshold level is referred to data having 16-bit format.

The FIFO watermark flag (FTH bit in FIFO\_STATUS2 register) rises when the number of bytes stored in the FIFO is equal to or higher than the threshold level.

In order to limit the FIFO depth to the watermark level, the STOP\_ON\_FTH bit must be set to 1 in the CTRL4 C register.

Table 34. FIFO\_CTRL1 register

| b7    | b6    | b5    | b4    | b3    | b2    | b1    | b0    |
|-------|-------|-------|-------|-------|-------|-------|-------|
| FTH_7 | FTH_6 | FTH_5 | FTH_4 | FTH_3 | FTH_2 | FTH_1 | FTH_0 |

## 7.1.2 FIFO\_CTRL2 (07h)

Table 35. FIFO\_CTRL2 register

| b7                         | b6                           | b5 | b4 | b3     | b2     | b1    | b0    |
|----------------------------|------------------------------|----|----|--------|--------|-------|-------|
| TIMER_PE<br>DO_FIFO_<br>EN | TIMER_PE<br>DO_FIFO_<br>DRDY | 0  | 0  | FTH_11 | FTH_10 | FTH_9 | FTH_8 |

- TIMER\_PEDO\_FIFO\_EN enables step counter and timestamp data to be stored as the 3<sup>rd</sup> FIFO data set. The content of the 6 bytes stored in the FIFO when this bit is set to 1 is described in *Section 7.8*.
- TIMER\_PEDO\_FIFO\_DRDY. When this bit is set to 1, all the data are stored in the FIFO every time a new step has been detected by the step counter. See Section 7.3 for details.
- FTH\_[11:8] contains the upper part of the FIFO threshold level. For the complete threshold level configuration, consider also the FTH\_[7:0] bits in the FIFO\_CTRL1 register.



# 7.1.3 FIFO\_CTRL3 (08h)

The FIFO\_CTRL3 register contains the accelerometer and gyroscope FIFO decimation factors, used to choose if the data of these sensors have to be stored in the FIFO and at which rate they are stored.

When the DEC\_FIFO\_GYRO[2:0] bits are set to 000b, the 1<sup>st</sup> FIFO data set (reserved for gyroscope data) is not stored in the FIFO. When the DEC\_FIFO\_XL[2:0] bits are set to 000b, the 2<sup>nd</sup> FIFO data set (reserved for accelerometer data) is not stored in the FIFO.

Note: It's required to set at least one of the three decimation factors to 1 (no decimation).

Table 36. FIFO\_CTRL3 register

| b7 | b6 | b5                 | b4                 | b3 | b2               | b1               | b0               |
|----|----|--------------------|--------------------|----|------------------|------------------|------------------|
| 0  | 0  | DEC_FIFO<br>_GYRO2 | DEC_FIFO<br>_GYRO1 | _  | DEC_FIFO<br>_XL2 | DEC_FIFO<br>_XL1 | DEC_FIFO<br>_XL0 |

Table 37. Gyroscope FIFO decimation setting

| DEC_FIFO_GYRO [2:0] | Configuration                |
|---------------------|------------------------------|
| 000                 | Gyroscope sensor not in FIFO |
| 001                 | No decimation                |
| 010                 | Decimation with factor 2     |
| 011                 | Decimation with factor 3     |
| 100                 | Decimation with factor 4     |
| 101                 | Decimation with factor 8     |
| 110                 | Decimation with factor 16    |
| 111                 | Decimation with factor 32    |

Table 38. Accelerometer FIFO decimation setting

| DEC_FIFO_XL [2:0] | Configuration                    |
|-------------------|----------------------------------|
| 000               | Accelerometer sensor not in FIFO |
| 001               | No decimation                    |
| 010               | Decimation with factor 2         |
| 011               | Decimation with factor 3         |
| 100               | Decimation with factor 4         |
| 101               | Decimation with factor 8         |
| 110               | Decimation with factor 16        |
| 111               | Decimation with factor 32        |



## 7.1.4 FIFO CTRL4 (09h)

The FIFO\_CTRL4 register contains the decimation factors used to define at which data rate the data associated to the 3<sup>rd</sup> FIFO data set are stored in the FIFO.

When the TIMER\_PEDO\_DEC\_FIFO[2:0] bits are set to 000b, the 3<sup>rd</sup> FIFO data set is not stored in the FIFO.

Note: It's required to set at least one of the three decimation factors to 1 (no decimation).

The FIFO\_CTRL4 register also contains the bit ONLY\_HIGH\_DATA, which allows storing in the FIFO only the upper part (Most Significant Byte) of accelerometer and gyroscope data, in order to increase the maximum number of accelerometer and gyroscope samples in the FIFO. See *Section 7.7* for more details about this functionality.

b7 b6 b5 b4 b0 h3 b2 b1 TIME PE TIME PE TIME PE ONLY HIGH 0 DO DEC DO DEC DO DEC 0 0 0 DATA FIFO2 FIFO1 FIFO0

Table 39. FIFO\_CTRL4 register

Table 40. 3<sup>rd</sup> FIFO data set decimation setting

| TIMER_PEDO_DEC_FIFO [2:0] | Configuration                             |
|---------------------------|-------------------------------------------|
| 000                       | 3 <sup>rd</sup> FIFO data set not in FIFO |
| 001                       | No decimation                             |
| 010                       | Decimation with factor 2                  |
| 011                       | Decimation with factor 3                  |
| 100                       | Decimation with factor 4                  |
| 101                       | Decimation with factor 8                  |
| 110                       | Decimation with factor 16                 |
| 111                       | Decimation with factor 32                 |

## 7.1.5 FIFO\_CTRL5 (0Ah)

Note:

The FIFO\_CTRL5 register contains the FIFO operating mode bits (FIFO\_MODE\_[2:0]) and the FIFO output data rate bits (ODR\_FIFO\_[3:0]).

FIFO operating modes (Table 43) are described in Section 7.2.

When the internal trigger (accelerometer/gyroscope data-ready) is used, the ODR\_FIFO\_[3:0] bits define the maximum data rate at which data are stored in FIFO. Data can be stored in FIFO at a lower data rate using the FIFO decimation factors.

For more information on how to configure the FIFO trigger and the FIFO ODR see *Section 7.3*.

When the FIFO is used, the IF INC bit of the CTRL3 C register must be equal to 1.

57

# Table 41. FIFO\_CTRL5 register

| b7 | b6      | b5      | b4      | b3      | b2      | b1      | b0      |
|----|---------|---------|---------|---------|---------|---------|---------|
| 0  | ODR     | ODR     | ODR     | ODR     | FIFO    | FIFO    | FIFO    |
|    | _FIFO_3 | _FIFO_2 | _FIFO_1 | _FIFO_0 | _MODE_2 | _MODE_1 | _MODE_0 |

## Table 42. FIFO ODR selection setting

| ODR_FIFO [3:0] | Configuration               |
|----------------|-----------------------------|
| 0000           | FIFO disabled               |
| 0001           | FIFO ODR is set to 12.5 Hz  |
| 0010           | FIFO ODR is set to 26 Hz    |
| 0011           | FIFO ODR is set to 52 Hz    |
| 0100           | FIFO ODR is set to 104 Hz   |
| 0101           | FIFO ODR is set to 208 Hz   |
| 0110           | FIFO ODR is set to 416 Hz   |
| 0111           | FIFO ODR is set to 833 Hz   |
| 1000           | FIFO ODR is set to 1.66 kHz |
| 1001           | FIFO ODR is set to 3.33 kHz |
| 1010           | FIFO ODR is set to 6.66 kHz |

## Table 43. FIFO mode selection

| FIFO_MODE [2:0] | Configuration                                                                  |
|-----------------|--------------------------------------------------------------------------------|
| 000             | Bypass mode. FIFO disabled.                                                    |
| 001             | FIFO mode. Stops collecting data when FIFO is full.                            |
| 010             | Reserved                                                                       |
| 011             | Continuous mode until trigger is deasserted, then FIFO mode.                   |
| 100             | Bypass mode until trigger is deasserted, then Continuous mode.                 |
| 101             | Reserved                                                                       |
| 110             | Continuous mode. If the FIFO is full, the new sample overwrites the older one. |
| 111             | Reserved                                                                       |

47/

#### 7.1.6 FIFO STATUS1 (3Ah)

The FIFO STATUS1 register, together with the FIFO STATUS2 register, provides information about the number of samples stored in the FIFO. Each sample is represented as 16-bit data.

Table 44. FIFO\_STATUS1 register

| b7     | b6     | b5     | b4     | b3     | b2     | b1     | b0     |
|--------|--------|--------|--------|--------|--------|--------|--------|
| DIFF_  |
| FIFO_7 | FIFO_6 | FIFO_5 | FIFO_4 | FIFO_3 | FIFO_2 | FIFO_1 | FIFO_0 |

#### 7.1.7 FIFO STATUS2 (3Bh)

The FIFO STATUS2 register, together with the FIFO STATUS1 register, provides information about the number of samples stored in the FIFO and about the current status (threshold, overrun, full, empty) of the FIFO buffer.

Table 45. FIFO\_STATUS2 register

| b7  | b6                | b5            | b4             | b3               | b2               | b1              | b0              |
|-----|-------------------|---------------|----------------|------------------|------------------|-----------------|-----------------|
| FTH | FIFO_<br>OVER_RUN | FIFO_<br>FULL | FIFO_<br>EMPTY | DIFF_<br>FIFO_11 | DIFF_<br>FIFO_10 | DIFF_<br>FIFO_9 | DIFF_<br>FIFO_8 |

- FTH represents the watermark status. This bit is set high when the number of bytes already stored in the FIFO is equal to or higher than the watermark level (each sample is represented as 16-bit data). The watermark status can be driven to the two interrupt pins by setting to 1 the INT1 FTH bit of the INT1 CTRL register or the INT2 FTH bit of the INT2 CTRL register.
- FIFO OVER RUN is set high when the FIFO is completely filled and at least one sample has already been overwritten to store the new data. This signal can be driven to the two interrupt pins by setting to 1 the INT1 FIFO OVR bit of the INT1 CTRL register or the INT2 FIFO OVR bit of the INT2 CTRL register.
- FIFO FULL is set high when the next set of data that will be stored in FIFO will make the FIFO full. This signal can be driven to the two interrupt pins by setting to 1 the INT1 FULL FLAG bit of the INT1 CTRL register or the INT2 FULL FLAG bit of the INT2 CTRL register.
- FIFO EMPTY is set high when the FIFO is empty.
- DIFF FIFO [11:8] contains the upper part of the number of unread words (16-bit data) stored in the FIFO. The lower part is represented by the DIFF FIFO [7:0] bits in FIFO\_STATUS1. The value of the DIFF\_FIFO\_[11:0] field corresponds to the number of samples in the FIFO (each sample is represented as 16-bit data). When a FIFO overrun event occurs (FIFO OVER RUN bit is set high), the value of the DIFF FIFO [11:0] field is set to 0.

Register content is updated synchronously to the FIFO write and read operation, as illustrated in Table 46.

70/96 DocID027736 Rev 5



**FIFO** DIFF\_FIFO\_ FIFO OVER **Number of FIFO** FIFO\_FULL FIFO\_EMPTY trigger RUN samples [11:0] timing 0 0 0 1 0 t0 0 0 0 3 3 t1 0 0 0 6 6 t2 ... ... ... ... ... 0 0 0 t\_full - 2 4092 4092 0 1 0 4095 4095 t full - 1 4096 0 1 1 0 t\_full (old sample overwritten)

Table 46. FIFO\_STATUS2 behavior (case with one sensor in FIFO, STOP\_ON\_FTH =0)

#### 7.1.8 FIFO\_STATUS3 (3Ch)

The FIFO STATUS3 register, together with FIFO STATUS4 register, specifies which axis of which sensor data will be read at the next reading. For more information on how to retrieve data from the FIFO see Section 7.5.

Table 47. FIFO\_STATUS3 register

| D/      | DO      | มอ      | D4      | DS      | D2      | DI      | DU      |
|---------|---------|---------|---------|---------|---------|---------|---------|
| FIFO_   |
| PATTERN |
| _7      | _6      | _5      | _4      | _3      | _2      | _1      | _0      |

#### 7.1.9 FIFO\_STATUS4 (3Dh)

The FIFO STATUS4 register, together with the FIFO STATUS3 register, specifies which axis of which sensor data will be read at the next reading. For more information on how to retrieve data from the FIFO see Section 7.5.

Table 48. FIFO\_STATUS4 register

| b7 | b6 | b5 | b4 | b3 | b2 | b1                     | b0                     |
|----|----|----|----|----|----|------------------------|------------------------|
| 0  | 0  | 0  | 0  | 0  | 0  | FIFO_<br>PATTERN<br>_9 | FIFO_<br>PATTERN<br>_8 |

# 7.1.10 FIFO\_DATA\_OUT\_L (3Eh)

The FIFO\_DATA\_OUT\_L register is the least significant byte of the FIFO output data. The most significant byte is stored in the FIFO\_DATA\_OUT\_H register. For more information on how to retrieve data from the FIFO, see Section 7.4.

Table 49. FIFO\_DATA\_OUT\_L register

| b7       | b6       | b5       | b4       | b3       | b2       | b1       | b0       |  |  |  |
|----------|----------|----------|----------|----------|----------|----------|----------|--|--|--|
| DATA_    |  |  |  |
| OUT_FIFO |  |  |  |
| _L_7     | _L_6     | _L_5     | _L_4     | _L_3     | _L_2     | _L_1     | _L_0     |  |  |  |

# 7.1.11 FIFO\_DATA\_OUT\_H (3Fh)

The FIFO\_DATA\_OUT\_H register is the most significant byte of the FIFO output data. The least significant byte is stored in the FIFO\_DATA\_OUT\_L register. For more information on how to retrieve data from the FIFO, see Section 7.4.

Table 50. FIFO\_DATA\_OUT\_H register

| b7       | b6       | b5       | b4       | b3       | b2       | b1       | b0       |
|----------|----------|----------|----------|----------|----------|----------|----------|
| DATA_    |
| OUT_FIFO |
| _H_7     | _H_6     | _H_5     | _H_4     | _H_3     | _H_2     | _H_1     | _H_0     |

## 7.2 FIFO modes

The LSM6DS33 FIFO buffer can be configured to operate in five different modes selectable through the FIFO\_MODE\_[2:0] field of the FIFO\_CTRL5 register. The available configurations ensure a high level of flexibility and extend the number of functions usable in application development.

Bypass, FIFO, Continuous, Continuous-to-FIFO and Bypass-to-Continuous modes are described in the following paragraphs.

Note: When the FIFO is used the IF\_INC bit of the CTRL3\_C register must be equal to 1.

### 7.2.1 Bypass mode

When Bypass mode is enabled, the FIFO is not used, the buffer content is cleared, and it remains empty until another mode is selected.

Bypass mode is selected when the FIFO\_MODE\_[2:0] bits are set to 000b. When this mode is enabled, the FIFO\_STATUS2 register contains the value 10h (FIFO empty).

Bypass mode must be used in order to stop and reset the FIFO buffer when a different mode is operating. Note that placing the FIFO buffer in Bypass mode, the whole buffer content is cleared.

After Bypass mode is set, it's necessary to wait at least 30 µs before setting a different FIFO operating mode.

57

#### 7.2.2 FIFO mode

In FIFO mode, the buffer continues filling until it becomes full. Then it stops collecting data and the FIFO content remains unchanged until a different mode is selected.

Follow these steps for FIFO mode configuration (if accelerometer/gyroscope data-ready is used as FIFO trigger):

- Choose the decimation factor for each sensor through the decimation bits in the FIFO\_CTRL3 and FIFO\_CTRL4 registers (see Section 7.3 for details);
- 2. Choose the FIFO ODR through the ODR\_FIFO\_[3:0] bits in the FIFO\_CTRL5 register;
- Set the FIFO\_MODE\_[2:0] bits in the FIFO\_CTRL5 register to 001b to enable the FIFO mode.

When this mode is selected, the FIFO starts collecting data. The FIFO\_STATUS1 and FIFO\_STATUS2 registers are updated according to the number of samples stored.

When the next stored set of data will make the FIFO full, the FIFO\_FULL bit of the FIFO\_STATUS2 register is set to 1 and no more data are stored in the FIFO buffer. Data can be retrieved after the FIFO\_FULL event, by reading the FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H registers for the number of times specified by the DIFF\_FIFO\_[11:0] bits of the FIFO\_STATUS1 and FIFO\_STATUS2 registers.

Using the FTH bit of the FIFO\_STATUS2 register, data can also be retrieved when a threshold level (FTH\_[11:0] in FIFO\_CTRL1 and FIFO\_CTRL2 registers) is reached, if the application requires a lower number of samples in the FIFO.

If the STOP\_ON\_FTH bit of the CTRL4\_C register is set to 1, the FIFO size is limited to the value of the FTH\_[11:0] bits in the FIFO\_CTRL1 and FIFO\_CTRL2 registers: in this case, the FIFO\_FULL bit of the FIFO\_STATUS2 register is set high when the number of samples in FIFO will reach or exceed the FTH [11:0] value on the next FIFO write operation.

In case FIFO is read before the FIFO\_FULL event, it must not be completely emptied in order to avoid the misalignment of the data read from it. At least one complete FIFO pattern has to be left in the FIFO buffer (do not read it); it will be the first data read in the next read operation.

In case FIFO gets emptied after the FIFO\_OUT registers are read, a FIFO reset (through the Bypass mode setting) is needed.

Communication speed is not very important in FIFO mode because the data collection is stopped and there is no risk of overwriting data already acquired. Before restarting the FIFO mode, it is necessary to set to Bypass mode first, in order to completely clear the FIFO content.

Figure 25 shows an example of FIFO mode usage. In the example X-Y-Z data (green cells indicate the sample number) from just one sensor are stored in the FIFO. In these conditions, the number of samples that can be stored in the FIFO buffer is 4095: when the FIFO buffer is completely filled the FIFO\_FULL bit of the FIFO\_STATUS2 register is set high.





Figure 25. FIFO mode (STOP\_ON\_FTH=0)

#### 7.2.3 Continuous mode

In Continuous mode, the FIFO continues filling. When the buffer is full, the FIFO index restarts from the beginning, and older data are replaced by the new data. The oldest values continue to be overwritten until a read operation frees FIFO slots. The host processor's reading speed is important in order to free slots faster than new data is made available. To stop this configuration, Bypass mode must be selected.

Follow these steps for Continuous mode configuration (if accelerometer/gyroscope data-ready is used as FIFO trigger):

- Choose the decimation factor for each sensor through the decimation bits in the FIFO\_CTRL3 and FIFO\_CTRL4 registers (see Section 7.3 for details);
- 2. Choose the FIFO ODR through the ODR FIFO [3:0] bits in the FIFO CTRL5 register;
- Set the FIFO\_MODE\_[2:0] bits in the FIFO\_CTRL5 register to 110b to enable FIFO Continuous mode.

When this mode is selected, the FIFO collects data continuously. The FIFO\_STATUS1 and FIFO\_STATUS2 registers are updated according to the number of samples stored.

When the next stored set of data will make the FIFO full, the FIFO\_FULL bit of the FIFO\_STATUS2 register is set to 1. The FIFO\_OVER\_RUN bit in the FIFO\_STATUS2 register indicates when at least one sample has been overwritten to store the new data.

Data can be retrieved after the FIFO\_FULL event, by reading the FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H registers for a number of times specified by the DIFF\_FIFO\_[11:0] bits in the FIFO\_STATUS1 and FIFO\_STATUS2 registers.

Using the FTH bit of the FIFO\_STATUS2 register, data can also be retrieved when a threshold level (FTH\_[11:0] in FIFO\_CTRL1 and FIFO\_CTRL2 registers) is reached.

If the STOP\_ON\_FTH bit of CTRL4\_C register is set to 1, the FIFO size is limited to the value of the FTH\_[11:0] bits in the FIFO\_CTRL1 and FIFO\_CTRL2 registers: in this case,

74/96 DocID027736 Rev 5



the FIFO\_FULL bit of the FIFO\_STATUS2 register is set high when the number of samples in FIFO will reach the FTH\_[11:0] value on the next FIFO write operation.

In case FIFO is read before the FIFO\_FULL event, it must not be completely emptied in order to avoid the misalignment of the data read from it. At least one complete FIFO pattern has to be left in the FIFO buffer (do not read it); it will be the first data read in the next read operation.

In case FIFO gets emptied after the FIFO\_OUT registers are read, a FIFO reset (through the Bypass mode setting) is needed.

It is recommended to read faster than 1\*ODR at least three times the number of the enabled FIFO data set, in order to free FIFO slots for the new data: this allows avoiding loss of data.

Figure 26 shows an example of the Continuous mode usage. In the example, X-Y-Z data (green cells indicate the sample number) from just one sensor are stored in the FIFO and the FIFO samples are read faster than 1 \* ODR, so that no data is lost. In these conditions, the number of samples stored is 4095.



Figure 26. Continuous mode

#### 7.2.4 Continuous-to-FIFO mode

This mode is a combination of the Continuous and FIFO modes previously described. In Continuous-to-FIFO mode, the FIFO buffer starts operating in Continuous mode and switches to FIFO mode when an event condition occurs.

The event condition can be one of the following:

- Significant Motion: event detection has to be configured and the INT1\_SIG\_MOT bit of the INT1\_CTRL register has to be set to 1;
- Tilt: event detection has to be configured and the INT2\_TILT bit of the MD2\_CFG register has to be set to 1;
- Step detection: event detection has to be configured and the INT1\_STEP\_DETECTOR bit of the INT1\_CTRL register has to be set to 1;
- Single tap: event detection has to be configured and the INT2\_SINGLE\_TAP bit of the MD2\_CFG register has to be set to 1;
- Double tap: event detection has to be configured and the INT2\_DOUBLE\_TAP bit of the MD2\_CFG register has to be set to 1;
- Free-fall: event detection has to be configured and the INT2\_FF bit of the MD2\_CFG register has to be set to 1;
- Wake-up: event detection has to be configured and the INT2\_WU bit of the MD2\_CFG register has to be set to 1;
- 6D: event detection has to be configured and the INT2\_6D bit of the MD2\_CFG register has to be set to 1.

Continuous-to-FIFO mode is sensitive to the level of the interrupt signal and not to the edge, which means that if Continuous-to-FIFO is in FIFO mode and the interrupt condition disappears, the FIFO buffer returns to Continuous mode. It is recommended to latch the interrupt signal used as the FIFO event in order to avoid losing interrupt events (the interrupt signal has to be driven to the interrupt pin so that the latch function takes effect).

In case FIFO is read before the FIFO\_FULL event, it must not be completely emptied in order to avoid the misalignment of the data read from it. At least one complete FIFO pattern has to be left in the FIFO buffer (do not read it); it will be the first data read in the next read operation.

In case FIFO gets emptied after the FIFO\_OUT registers are read, a FIFO reset (through the Bypass mode setting) is needed.





Figure 27. Continuous-to-FIFO mode

Follow these steps for Continuous-to-FIFO mode configuration (if the accelerometer/gyroscope data-ready is used as the FIFO trigger):

- Configure one of the events as previously described;
- 2. Choose the decimation factor for each sensor through the decimation bits in the FIFO\_CTRL3 and FIFO\_CTRL4 registers (see Section 7.3 for details);
- 3. Choose the FIFO ODR through the ODR\_FIFO\_[3:0] bits in the FIFO\_CTRL5 register;
- Set the FIFO\_MODE\_[2:0] bits in the FIFO\_CTRL5 register to 011b to enable FIFO
  Continuous-to-FIFO mode.

In Continuous-to-FIFO mode the FIFO buffer continues filling; when the next stored set of data will make the FIFO full, the FIFO\_FULL bit is set high.

If the STOP\_ON\_FTH bit of the CTRL4\_C register is set to 1, the FIFO size is limited to the value of the FTH\_[11:0] bits in the FIFO\_CTRL1 and FIFO\_CTRL2 registers: in this case, the FIFO\_FULL bit of the FIFO\_STATUS2 register is set high when the number of samples in FIFO will reach or exceed the FTH\_[11:0] value on the next FIFO write operation.

When the trigger event occurs, two different cases can be observed:

- 1. If the FIFO buffer is already full (FIFO\_FULL = 1), it stops collecting data at the first sample after the event trigger. The FIFO content is composed of the samples collected before the event.
- 2. If FIFO buffer is not full yet (initial transient), it continues filling until it becomes full (FIFO FULL = 1) and then, if the trigger is still present, it stops collecting data.

Continuous-to-FIFO can be used in order to analyze the history of the samples which have generated an interrupt; the standard operation is to read the FIFO content when the FIFO mode is triggered and the FIFO buffer is full and stopped.

### 7.2.5 Bypass-to-Continuous mode

This mode is a combination of the Bypass and Continuous modes previously described. In Bypass-to-Continuous mode, the FIFO buffer starts operating in Bypass mode and switches to Continuous mode when a trigger condition occurs.

The event condition can be one of the following:

- Significant Motion: event detection has to be configured and the INT1\_SIG\_MOT bit of the INT1\_CTRL register has to be set to 1;
- Tilt: event detection has to be configured and the INT2\_TILT bit of the MD2\_CFG register has to be set to 1;
- Step detection: event detection has to be configured and the INT1\_STEP\_DETECTOR bit of the INT1\_CTRL register has to be set to 1;
- Single tap: event detection has to be configured and the INT2\_SINGLE\_TAP bit of MD2\_CFG register has to be set to 1;
- Double tap: event detection has to be configured and the INT2\_DOUBLE\_TAP bit of the MD2\_CFG register has to be set to 1;
- Free-fall: event detection has to be configured and the INT2\_FF bit of the MD2\_CFG register has to be set to 1;
- Wake-up: event detection has to be configured and the INT2\_WU bit of the MD2\_CFG register has to be set to 1;
- 6D: event detection has to be configured and the INT2\_6D bit of the MD2\_CFG register has to be set to 1.

Bypass-to-Continuous mode is sensitive to the level of the interrupt signal and not to the edge, which means that if Bypass-to-Continuous is in Continuous mode and the interrupt condition disappears, the FIFO buffer returns to Bypass mode. It is recommended to latch the interrupt signal used as the FIFO event in order to avoid losing data (the interrupt signal has to be driven to the interrupt pin so that the latch function takes effect).

Follow these steps for Bypass-to-Continuous mode configuration (if the accelerometer / gyroscope data-ready is used as the FIFO trigger):

- 1. Configure one of the events as previously described;
- 2. Choose the decimation factor for each sensor through the decimation bits in the FIFO CTRL3 and FIFO CTRL4 registers (see Section 7.3 for details);
- 3. Choose the FIFO ODR through the ODR\_FIFO\_[3:0] bits in the FIFO\_CTRL5 register.
- Set the FIFO\_MODE\_[2:0] bits in the FIFO\_CTRL5 register to 100b to enable FIFO Bypass-to-Continuous mode.





Figure 28. Bypass-to-Continuous mode

Once the trigger condition appears and the buffer switches to Continuous mode, the FIFO buffer continues filling. When the next stored set of data will make the FIFO full, the FIFO\_FULL bit is set high.

In case FIFO is read before the FIFO\_FULL event, it must not be completely emptied in order to avoid the misalignment of the data read from it. At least one complete FIFO pattern has to be left in the FIFO buffer (do not read it); it will be the first data read in the next read operation.

In case FIFO gets emptied after the FIFO\_OUT registers are read, a FIFO reset (through the Bypass mode setting) is needed.

Bypass-to-Continuous can be used in order to start the acquisition when the configured interrupt is generated.



# 7.3 Setting the FIFO trigger, FIFO ODR and decimation factors

Writing data in the FIFO can be configured to be triggered by two different sources.

F(odr) = min ( MAX(ODR\_XL, ODR\_G), ODR\_FIFO ) ODR XL 1st FIFO DATA SET DECIMATOR ODR G F(odr) TIMER PEDO FIFO DRDY = 0 ODR FIFO DEC FIFO GYRO[2:0] FIFO RIGGE 2<sup>nd</sup> FIFO SIGNAL **FIFO** DATA SET DECIMATOR DEC\_FIFO\_XL[2:0] STEP DETECTED TIMER\_PEDO\_FIFO\_DRDY = 3rd FIFO DATA SET DECIMATOR TIME PEDO DEC\_FIFO[2:0]

Figure 29. FIFO trigger signal selection

As described in *Figure 29*, the TIMER\_PEDO\_FIFO\_DRDY bit of the FIFO\_CTRL2 register is used for this purpose:

- if the TIMER\_PEDO\_FIFO\_DRDY bit is set to 0, writing data in the FIFO is triggered by the accelerometer/gyroscope data-ready. The ODR\_FIFO\_[3:0] bits of FIFO\_CTRL5 define the maximum data rate at which data are stored in FIFO; the latter is limited to the maximum value between the accelerometer ODR (defined by the ODR\_XL[3:0] bits of the CTRL1\_XL register) and the gyroscope ODR (defined by the ODR\_G[3:0] bits of the CTRL2\_G register);
- if the TIMER\_PEDO\_FIFO\_DRDY bit is set to 1, writing data in the FIFO is triggered by step detection (corresponding to the behavior of the STEP\_DETECTED bit of the FUNC\_SRC register): the data are stored in FIFO every time a step is detected.

Using the FIFO decimation factors, data can be stored in FIFO at a rate lower than the rate of the FIFO trigger signal. Three decimation factors can be configured, one for each FIFO data set:

- the DEC\_FIFO\_G[2:0] bits of the FIFO\_CTRL3 register define if the gyroscope data (associated to the 1<sup>st</sup> FIFO data set) are stored in FIFO and the relative rate;
- the DEC\_FIFO\_XL[2:0] bits of the FIFO\_CTRL3 register define if the accelerometer data (associated to the 2<sup>nd</sup> FIFO data set) are stored in FIFO and the relative rate;
- the TIMER\_PEDO\_DEC\_FIFO[2:0] bits of the FIFO\_CTRL4 register define if the data associated to the 3<sup>rd</sup> FIFO data set are stored in FIFO and the relative rate.

Note: It's required to set at least one of the three decimation factors to 1 (no decimation).

80/96 DocID027736 Rev 5



When using the internal trigger (accelerometer/gyroscope data-ready), the recommended procedure to configure the FIFO trigger is the following:

- 1. Set the ODR\_FIFO bits of the FIFO\_CTRL5 register to the value corresponding to the maximum ODR between the gyroscope and accelerometer;
- Set to 1 the decimation factor of the FIFO data set associated to the sensor having the maximum ODR.

#### 7.3.1 Procedure for ODR changes when using FIFO

In combo mode configuration and if the application under development expects to store the data of at least one sensor (accelerometer, gyroscope or both) in the FIFO buffer and to modify the accelerometer/gyroscope output data rate (including Power-Down), the following rules have to be respected:

- 1. Both the accelerometer data and the gyroscope data must be stored in the FIFO;
- 2. Set the ODR\_FIFO bits of the FIFO\_CTRL5 register to 1010b (FIFO ODR is set to 6.66 kHz);
- 3. Apply the following procedure when an accelerometer/gyroscope ODR change has to be performed:
  - a) read all the data stored in the FIFO to empty it (see Section 7.4 for details);
  - set the FIFO in Bypass mode (set the FIFO\_MODE bits of the FIFO\_CTRL5 register to 000b);
  - Set the target ODR for the accelerometer and gyroscope through the ODR\_XL bits
    of the CTRL1\_XL register and the ODR\_G bits of the CTRL2\_G register
    respectively;
  - d) Set the gyroscope decimation factor in the DEC\_FIFO\_G[2:0] bits of the FIFO\_CTRL3 register and the accelerometer decimation factor in the DEC\_FIFO\_XL[2:0] bits of the FIFO\_CTRL3 register as follows:
  - Accelerometer decimation factor = max(ODR\_XL[Hz], ODR\_G[Hz])/ODR\_XL[Hz]
  - Gyroscope decimation factor = max(ODR\_XL[Hz], ODR\_G[Hz])/ODR\_G[Hz]
     See *Table 37* and *Table 38* for the values to be set in the DEC\_FIFO\_G[2:0] bits and the DEC\_FIFO\_XL[2:0] bits of the FIFO\_CTRL3. One of the two decimation factors will be equal to 1, as required.
  - e) Set the desired FIFO operating mode (see Section 7.3 for details).

If ODR\_XL and ODR\_G are always equal to each other and the ODR\_FIFO setting is always constant, no need to follow the above rules.



### 7.4 Retrieving data from the FIFO

Note:

When data are stored in the FIFO, the configuration must not be changed in order to be able to retrieve data correctly.

When FIFO is enabled and the mode is different from Bypass, reading the FIFO output registers (FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H) returns the oldest FIFO sample set. Whenever these registers are read, their content is moved to the SPI/I<sup>2</sup>C output buffer. FIFO slots are ideally shifted up one level in order to release room for a new sample, and the FIFO output registers load the current oldest value stored in the FIFO buffer.

The recommended way to retrieve data from the FIFO is the following:

- Read the FIFO\_STATUS1 and FIFO\_STATUS2 registers to check how many words (16-bit data) are stored in the FIFO. This information is contained in the DIFF\_FIFO\_[11:0] bits.
- 2. Read the FIFO\_STATUS3 and FIFO\_STATUS4 registers. The FIFO\_PATTERN\_[9:0] bits allows understanding which sensor and which couple of bytes is being read (see *Section 7.5* for more details).
- 3. Read the FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H registers to retrieve the oldest sample (16-bits format) in the FIFO. They are respectively the lower and the upper part of the oldest sample.

The entire FIFO content is retrieved by performing a certain number of read operations from the FIFO output registers until the buffer becomes empty (FIFO\_EMPTY bit of FIFO\_STATUS2 register is set high). Once the FIFO is empty, every other read operation returns the same value (the latest sample).

It is recommended to read faster than 1\*ODR at least three times the number of the enabled FIFO data set, in order to free FIFO slots for the new data: this allows avoiding loss of data.

The rounding function (see *Section 4.6* for details) is automatically enabled when applying a multiple read operation to the FIFO output registers FIFO\_DATA\_OUT\_L and FIFO\_DATA\_OUT\_H.

# 7.5 FIFO pattern

Data are stored in the FIFO without any tag in order to maximize the number of samples stored. To understand which couple of data and which FIFO data set is going to be read, it is necessary to check the content of the FIFO\_PATTERN\_[9:0] bits in the FIFO\_STATUS3 and FIFO\_STATUS4 registers.

Data are written to the FIFO with a specific pattern (for example GyroX, GyroY, GyroZ, AccX, AccY, AccZ). This pattern changes depending on the ODRs and decimation factors assigned to the three FIFO data sets. The FIFO\_PATTERN\_[9:0] bits contain a number from 0 to the index of the last sample of the pattern, then the pattern is repeated in all FIFO content.

The first sequence of data stored in FIFO buffer contains the data of all the enabled FIFO data sets, from the first one to the third one. Then, data are repeated depending on the value of the decimation factor set for each FIFO data set.

The examples in the next sections explain how to use the information contained in the FIFO PATTERN [9:0] bits.



## 7.5.1 Example 1

Supposing the FIFO is storing data from the gyroscope and accelerometer at the same ODR:

Gyroscope ODR = 104 Hz, Accelerometer ODR = 104 Hz.

If the internal trigger (accelerometer/gyroscope data-ready) is used, it's recommended to set the ODR\_FIFO\_[3:0] bits of the FIFO\_CTRL5 register to 0100b in order to set the FIFO trigger ODR to 104 Hz.

Both the DEC\_FIFO\_GYRO[2:0] and the DEC\_FIFO\_XL[2:0] fields of the FIFO\_CTRL3 register have to be set to 001b (no decimation).

The following data pattern is repeated every 6 samples (each sample is represented as 16-bit data):

Gx Gy Gz XLx XLy XLz (Gyroscope and Accelerometer data)

The FIFO\_PATTERN\_[9:0] bits will contain a number from 0 to 5, as shown in *Table 51*.

| Time | FIFO_PATTERN_[9:0] | Next reading from FIFO output registers |
|------|--------------------|-----------------------------------------|
| t0   | 0                  | Gx                                      |
| t0   | 1                  | Gy                                      |
| t0   | 2                  | Gz                                      |
| t0   | 3                  | XLx                                     |
| t0   | 4                  | XLy                                     |
| t0   | 5                  | XLz                                     |

Table 51. Example 1: FIFO\_PATTERN\_[9:0] bits and next reading

### 7.5.2 Example 2

Supposing the FIFO is storing data from the gyroscope and accelerometer at different ODRs:

• Gyroscope ODR = 208 Hz, Accelerometer ODR = 104 Hz.

If the internal trigger (accelerometer/gyroscope data-ready) is used, it's recommended to set the ODR\_FIFO\_[3:0] bits of the FIFO\_CTRL5 register to 0101b in order to set the FIFO trigger ODR to 208 Hz.

The DEC\_FIFO\_GYRO[2:0] field of the FIFO\_CTRL3 register has to be set to 001b (no decimation applied to gyroscope data) and the DEC\_FIFO\_XL[2:0] field has to be set to 010b (decimation with factor 2 applied to accelerometer data).

Since the gyroscope ODR is twice the accelerometer ODR, the following data pattern is repeated every 9 samples (each sample is represented as 16-bit data):

• Gx Gy Gz XLx XLy XLz Gx Gy Gz

The FIFO\_PATTERN\_[9:0] bits will contain a number from 0 to 8, as shown in *Table 52*.



**Next reading from FIFO** Time FIFO PATTERN [9:0] output registers t0 0 Gx 1 t0 Gy t0 2 Gz t0 3 XLx t0 4 XLy 5 t0 XLz t1 6 Gx 7 t1 Gy t1 8 Gz

Table 52. Example 2: FIFO\_PATTERN\_[9:0] bits and next reading

#### 7.5.3 **Example 3**

Supposing the FIFO is storing data from the gyroscope, accelerometer and timestamp/step count at different ODRs:

 Gyroscope ODR = 104 Hz, Accelerometer ODR = 208 Hz, Timestamp/Step Count ODR = 52 Hz.

If the internal trigger (accelerometer/gyroscope data-ready) is used, it's recommended to set the ODR\_FIFO\_[3:0] bits of the FIFO\_CTRL5 register to 0101b in order to set the FIFO trigger ODR to 208 Hz.

The DEC\_FIFO\_GYRO[2:0] field of FIFO\_CTRL3 register has to be set to 010b (decimation with factor 2 applied to gyroscope data) and the DEC\_FIFO\_XL[2:0] field has to be set to 001b (no decimation applied to accelerometer data). Assuming that the timestamp/step count is associated to the 3<sup>rd</sup> FIFO data set, the TIMER\_PEDO\_DEC\_FIFO[2:0] field of the FIFO\_CTRL4 register has to be set to 100b (decimation with factor 4 applied to timestamp/step count data).

The following data pattern is repeated every 21 samples:

- Gx Gy Gz XLx XLy XLz S0 S1 S2 (gyroscope, accelerometer, timestamp/step count data - 9 samples)
- XLx XLy XLz (accelerometer data 3 samples)
- Gx Gy Gz XLx XLy XLz (gyroscope and accelerometer data 6 samples)
- XLx XLy XLz (accelerometer data 3 samples)

The FIFO PATTERN [9:0] bits will contain a number from 0 to 20, as shown in Table 53.

Time FIFO\_PATTERN\_[9:0] Next reading from FIFO output registers t0 0 Gx 1 t0 Gy t0 2 Gz t0 3 XLx 4 t0 XLy t0 5 XLz t0 6 S0 7 t0 S1 t0 8 S2 9 XLx t1 10 XLy t1 t1 11 XLz t2 12 Gx t2 13 Gy t2 14 Gz t2 15 XLxt2 16 XLy t2 17 XLz t3 18 XLx t3 19 XLy t3 20 XLz

Table 53. Example 3: FIFO\_PATTERN\_[9:0] bits and next reading

#### 7.6 FIFO threshold

The FIFO threshold is a functionality of the LSM6DS33 FIFO which can be used to check when the number of samples in the FIFO reaches a defined threshold level.

The bits FTH\_[11:0] in the FIFO\_CTRL1 and FIFO\_CTRL2 registers contain the threshold level. The resolution of the FTH\_[11:0] field is two bytes (1 LSB = 2 Bytes, each sample is represented as 16-bit data). So, the user can select the desired level in a range between 0 and 4095.

The bit FTH in the FIFO\_STATUS2 register represents the watermark status. This bit is set high if the number of samples in the FIFO reaches or exceeds the watermark level (each sample is represented as 16-bit data).

FIFO size can be limited to the threshold level by setting the STOP\_ON\_FTH bit in the CTRL4\_C register to 1.





Figure 30. FIFO threshold (STOP\_ON\_FTH = 0)

Figure 30 shows an example of FIFO threshold level usage when just accelerometer (or gyroscope) data are stored. The STOP\_ON\_FTH bit set to 0 in the CTRL4\_C register. The threshold level is set to 21 through the FTH[11:0] bits. The FTH bit of the FIFO\_STATUS2 register rises after the level 21 has been reached (21 samples in the FIFO). Since, the STOP\_ON\_FTH bit is set to 0, the FIFO will not stop at the 21<sup>st</sup> sample, but will keep storing data until the FIFO\_FULL flag is set high.



Figure 31. FIFO threshold (STOP\_ON\_FTH = 1) in FIFO mode

57

Figure 31 shows an example of FIFO threshold level usage in FIFO mode with the STOP\_ON\_FTH bit set to 1 in the CTRL4\_C register; just accelerometer (or gyroscope) data are stored in this example. The threshold level is set to 21 through the FTH[11:0] bits and defines the current FIFO size. In FIFO mode, data are stored in the FIFO buffer until the FIFO\_FULL signal rises; the FIFO\_FULL bit of the FIFO\_STATUS2 register rises when the next data stored in the FIFO will make the FIFO full, so in this example it rises after the first 18 data (16-bit each) are stored in FIFO. The FTH bit of the FIFO\_STATUS2 register cannot go to 1 since the FTH threshold level is never reached (data are no longer stored in FIFO after FIFO is full).



Figure 32. FIFO threshold (STOP\_ON\_FTH = 1) in Continuous mode

Figure 32 shows an example of FIFO threshold level usage in Continuous mode with the STOP\_ON\_FTH bit set to 1 in the CTRL4\_C register; just accelerometer (or gyroscope) data are stored in this example. The threshold level is set to 21 through the FTH[11:0] bits. The FIFO\_FULL bit of the FIFO\_STATUS2 register rises when the next data stored in the FIFO will make the FIFO full, so in this example it rises after the first 18 data (16-bit each) are stored in FIFO. The FTH bit of the FIFO\_STATUS2 register rises after the level 21 has been reached (21 samples in the FIFO).



## 7.7 High part of gyroscope and accelerometer data

It is possible to increase the number of samples stored in the FIFO by storing just the high part (8 bits) of gyroscope and accelerometer data.

To the enable this feature, the bit ONLY\_HIGH\_DATA must be set to 1 in the FIFO\_CTRL4 register. Gyroscope and accelerometer data will be written in the FIFO at the same ODR, in the order shown in *Table 54*.

Table 54. High part of gyroscope and accelerometer data in FIFO

| Byte 1    | Byte 2   | Byte 3    | Byte 4   | Byte 5    | Byte 6   |
|-----------|----------|-----------|----------|-----------|----------|
| Accel_X_H | Gyro_X_H | Accel_Y_H | Gyro_Y_H | Accel_Z_H | Gyro_Z_H |

When this feature is enabled, the 6 bytes containing the high part (8 bits) of gyroscope and accelerometer data are associated to the 1<sup>st</sup> FIFO data set and the 2<sup>nd</sup> FIFO data set is not used.

The DEC\_FIFO\_G[2:0] field of the FIFO\_CTRL3 register has to be set to a value different from 000b (1st FIFO data set stored in FIFO).

The DEC\_FIFO\_XL[2:0] field of FIFO\_CTRL3 register has to be set to 000b (2<sup>nd</sup> FIFO data set not in FIFO).

# 7.8 Step counter and timestamp data in FIFO

It is possible to store timestamp and step counter data in the FIFO. These data are stored as a 3<sup>rd</sup> FIFO data set in the 6-byte data format shown in *Table 55*:

- 3 bytes for the timestamp;
- 1 byte is not used;
- 2 bytes for the number of steps.

Table 55. Timestamp and pedometer data in FIFO

| Byte 1    | Byte 2    | Byte 3 | Byte 4    | Byte 5 | Byte 6 |
|-----------|-----------|--------|-----------|--------|--------|
| TIMESTAMP | TIMESTAMP |        | TIMESTAMP | STEPS  | STEPS  |
| [15:8]    | [23:16]   | -      | [7:0]     | [7:0]  | [15:8] |

To enable this feature, the bit TIMER\_PEDO\_FIFO\_EN must be set to 1 in the FIFO\_CTRL2 register.

When this feature is enabled, the 6 bytes containing the timestamp and step counter data are associated to the 3<sup>rd</sup> FIFO data set: the TIMER\_PEDO\_DEC\_FIFO[2:0] field of FIFO CTRL4 register has to be used to define the decimation factor.

When this feature is enabled, data can be stored in the FIFO in two ways, depending on the configuration of the TIMER PEDO FIFO DRDY bit in FIFO CTRL2:

- When the TIMER\_PEDO\_FIFO\_DRDY bit is set to 0, data are written to the FIFO at the ODR\_FIFO rate set in the FIFO\_CTRL5 register.
- When the TIMER\_PEDO\_FIFO\_DRDY bit is set to 1, data are stored in the FIFO every time a new step is detected.



88/96 DocID027736 Rev 5

Follow these steps to store timestamp and pedometer data in the FIFO using either the internal trigger (accelerometer/gyroscope data ready) or the 'step detected' method:

- 1. Turn on the accelerometer;
- 2. Enable the timestamp and pedometer (see Section 6.1 and Section 6.4);
- 3. Choose the decimation factor for the 3<sup>rd</sup> FIFO data set through the TIMER\_PEDO\_DEC\_FIFO[2:0] bits of the FIFO\_CTRL4 register;
- 4. Set to 1 the TIMER\_PEDO\_FIFO\_EN bit in the FIFO\_CTRL2 register;
- 5. Configure the bit TIMER\_PEDO\_FIFO\_DRDY in the FIFO\_CTRL2 register, in order to choose the method of storing data in the FIFO (internal trigger or every step detected);
- If an internal trigger is used, choose the FIFO ODR through the ODR\_FIFO\_[3:0] bits of the FIFO\_CTRL5 register. If the 'step detected' trigger is used, no need to set the ODR\_FIFO\_[3:0] bits;
- 7. Configure the FIFO operating mode through the FIFO\_MODE\_[2:0] field of the FIFO\_CTRL5 register.

## 7.9 Temperature data in FIFO

It is possible to store only temperature data as the 3<sup>rd</sup> FIFO data set.

To enable this feature:

- the bit TIMER\_PEDO\_FIFO\_EN of the FIFO\_CTRL2 register has to be set to 0;
- the bit FIFO\_TEMP\_EN of the CTRL4\_C register has to be set to 1.

Temperature samples (16-bit) are stored in FIFO in the 6-byte data format shown in *Table 56*.

Table 56. Temperature data in FIFO

| Byte 1 | Byte 2 | Byte 3     | Byte 4      | Byte 5 | Byte 6 |
|--------|--------|------------|-------------|--------|--------|
| -      | -      | TEMP [7:0] | TEMP [15:8] | -      | -      |

Follow these steps to store 16-bit temperature data in the FIFO using the internal trigger (accelerometer/gyroscope data ready):

- Turn on the accelerometer or the gyroscope;
- 2. Choose the decimation factor (different from 000b) for the 3<sup>rd</sup> FIFO data set through the TIMER PEDO DEC FIFO[2:0] bits in the FIFO CTRL4 register;
- 3. Set to 1 the FIFO\_TEMP\_EN bit in the CTRL4\_C register and to 0 the bit TIMER\_PEDO\_FIFO\_EN of the FIFO\_CTRL2 register;
- 4. Choose the FIFO ODR through the ODR\_FIFO\_[3:0] bits of the FIFO\_CTRL5 register;
- 5. Configure the FIFO operating mode through the FIFO\_MODE\_[2:0] field of the FIFO\_CTRL5 register.



Temperature sensor AN4682

# 8 Temperature sensor

The LSM6DS33 is provided with an internal temperature sensor that is suitable for ambient temperature measurement.

If both the accelerometer and the gyroscope sensors are in Power-Down mode, the temperature sensor is off.

The maximum output data rate of temperature sensor is 52 Hz and its value depends on how the accelerometer and gyroscope sensors are configured:

- If the gyroscope is in Power-Down mode:
  - the temperature data rate is equal to 12.5 Hz if the accelerometer ODR is equal to 12.5 HzHz (in both Low-Power and High-Performance mode);
  - the temperature data rate is equal to 26 Hz if the accelerometer configuration is 26 Hz Low-Power mode;
  - the temperature data rate is equal to 52H z for all other accelerometer configurations.
- If the accelerometer is in Power-Down mode:
  - the temperature data rate is equal to 12.5 Hz if the gyroscope configuration is 12.5 Hz Low-Power mode;
  - the temperature data rate is equal to 26 Hz if the gyroscope configuration is 26 Hz Low-Power mode;
  - the temperature data rate is equal to 52 Hz for all other gyroscope configurations.
- In combo mode:
  - if the gyroscope is configured in High-Performance mode, the temperature data rate is equal to 52 Hz regardless of the gyroscope ODR and the accelerometer configuration;
  - if the gyroscope is configured in Low-Power / Normal mode, the temperature data rate is equal to the maximum value between the accelerometer ODR and gyroscope ODR, while remaining below the 52 Hz value.

For the temperature sensor, the data-ready signal is represented by the TDA bit of the STATUS\_REG register. The signal can be driven to the INT2 pin by setting to 1 the INT2 DRDY TEMP bit of the INT2 CTRL register.

The temperature data is given by the concatenation of the OUT\_TEMP\_H and OUT\_TEMP\_L registers and it is represented as a number of 16 bits in two's complement format, with a sensitivity of +16 LSB/°C. The output zero level corresponds to 25 °C.

The LSM6DS33 allows swapping, by setting the BLE bit of the CTRL3\_C register set to 1, the content of the lower and the upper part of the temperature output data registers (i.e. OUT\_TEMP\_H with OUT\_TEMP\_L).

Temperature sensor data can also be stored in FIFO with a configurable decimation factor (see *Section 7.9* for details).

90/96 DocID027736 Rev 5

AN4682 Temperature sensor

# 8.1 Example of temperature data calculation

*Table 57* provides a few basic examples of the data that is read in the temperature data registers at different ambient temperature values. The values listed in this table are given under the hypothesis of perfect device calibration (i.e. no offset, no gain error,....).

Table 57. Output data registers content vs. temperature

|                    | BLE = 0             |                     | BLE = 1             |                     |
|--------------------|---------------------|---------------------|---------------------|---------------------|
| Temperature values | Register address    |                     |                     |                     |
|                    | OUT_TEMP_H<br>(21h) | OUT_TEMP_L<br>(20h) | OUT_TEMP_H<br>(21h) | OUT_TEMP_L<br>(20h) |
| 0°C                | FEh                 | 70h                 | 70h                 | FEh                 |
| 25°C               | 00h                 | 00h                 | 00h                 | 00h                 |
| 50°C               | 01h                 | 90h                 | 90h                 | 01h                 |

Self-test AN4682

# 9 Self-test

The embedded self-test functions allows checking the device functionality without moving it.

#### 9.1 Accelerometer self-test

When the accelerometer self-test is enabled, an actuation force is applied to the sensor, simulating a definite input acceleration. In this case the sensor outputs exhibit a change in their DC levels which are related to the selected full scale through the sensitivity value.

The accelerometer self-test function is off when the ST\_XL[1:0] bits of the CTRL5\_C register are programmed to 00b; it is enabled when the ST\_XL bits are set to 01b (positive sign self-test) or 10b (negative sign self-test).

When the accelerometer self-test is activated, the sensor output level is given by the algebraic sum of the signals produced by the acceleration acting on the sensor and by the electrostatic test-force. The complete accelerometer self-test procedure is indicated in *Figure 33*.

# 9.2 Gyroscope self-test

The gyroscope self-test allows testing of the mechanical and electrical part of the gyroscope sensor: when it is activated, an actuation force is applied to the sensor, emulating a definite Coriolis force, and the seismic mass is moved by means of this electrostatic test-force. In this case the sensor output exhibits an output change.

The gyroscope self-test function is off when the ST\_G[1:0] bits of the CTRL5\_C register are programmed to 00b; it is enabled when the ST\_G bits are set to 01b (positive sign self-test) or 11b (negative sign self-test).

When the gyroscope self-test is active, the sensor output level is given by the algebraic sum of the signals produced by the velocity acting on the sensor and by the electrostatic test-force. The complete gyroscope self-test procedure is indicated in *Figure 34*.



3

### Figure 33. Accelerometer self-test procedure

#### Note: Keep the device still during the self-test procedure

Write 30h to CTRL1 XL (10h) Write 00h to CTRL2 G (11h) Write 44h to CTRL3 C (12h) Write 00h to CTRL4 C (13h) Write 00h to CTRL5 C (14h) Write 00h to CTRL6 G (15h) Write 00h to CTRL7 G (16h) Write 00h to CTRL8 XL (17h) Write 38h to CTRL9 XL(18h) Write 00h to CTRL10 C(19h) → Initialize Sensor, turn on sensor, enable X/Y/Z axes. → Set BDU=1. FS=2G. ODR = 52Hz Power up, wait for 200ms for stable output Check XLDA in STATUS REG (1Eh) - Acc Data Ready Bit → Reading OUTX XL/OUTY XL/OUTZ XL clears XLDA, Wait for the first sample Read OUTX XL(28h/29h), OUTY XL (2Ah/2Bh), OUTZ XL (2Ch/2Dh) → Discard data Read the output registers after checking XLDA bit \*5 times Read OUTX\_XL\_L (28h), OUTX\_XL\_H (29h): Store data in OUTX NOST Read OUTY XL L (2Ah), OUTY XL H (2Bh): Store data in OUTY NOST Read OUTZ XL L (2Ch), OUTZ XL H (2Dh): Store data in OUTZ NOST The 16 bit data is expressed in two's complement. Average the stored data on each axis. Write 01h to CTRL5 C (14h) → Enable Acc Self Test Wait for 200ms for stable output

Check XLDA in STATUS REG (1Eh) - Acc Data Ready Bit → Reading OUTX XL/OUTY XL/OUTZ XL clears XLDA. Wait for the first sample Read OUTX XL(28h/29h), OUTY XL (2Ah/2Bh), OUTZ XL (2Ch/2Dh) → Discard data Read the output registers after checking XLDA bit \* 5 times Read OUTX XL L (28h), OUTX XL H (29h): Store data in OUTX ST Read OUTY XL L (2Ah), OUTY XL H (2Bh): Store data in OUTY ST Read OUTZ\_XL\_L (2Ch), OUTZ\_XL\_H (2Dh): Store data in OUTZ\_ST The 16 bit data is expressed in two's complement. Average the stored data on each axis |Min(ST\_X)| <=|OUTX\_ST-OUTX\_NOST| <= |Max(ST\_X)| AND |Min(ST\_Y)<=|OUTY\_ST-OUTY\_NOST| <= |Max(ST\_Y)| AND  $|Min(ST_Z)| \le |OUTZ_ST-OUTZ_NOST| \le |MAX(ST_Z)|$ YES (PASS) NO (FAIL) Write 00h to CTRL1 XL (10h): Disable sensor Write 00h to CTRL5 C (14h): Disable self test



Figure 34. Gyroscope self-test procedure

#### Note: Keep the device still during the self-test procedure



Write 04h to CTRL5 C (14h) → Enable Gyro Self Test Wait for 60 ms Check GDA in STATUS REG (1Eh) - Gyro Data Ready Bit → Reading OUTX/OUTY/OUTZ clears GDA, Wait for the first sample Read OUTX G(22h/23h), OUTY G(24h/25h), OUTZ G(26h/27h) →Discard data Read the output registers after checking GDA bit \* 5 times Read OUTX G L(22h), OUTX G H(23h): Store data in OUTX ST Read OUTY\_G\_L(24h), OUTY\_G\_H(25h): Store data in OUTY ST Read OUTZ G L(26h), OUTZ G H(27h): Store data in OUTZ ST The 16 bit data is expressed in two's complement. Average the stored data on each axis |Min(ST\_X)| <= |OUTX\_ST-OUTX\_NOST| <= |Max(ST\_X)| AND |Min(ST\_Y)<=|OUTY\_ST-OUTY\_NOST| <= |Max(ST\_Y)| **AND**  $|Min(ST_Z)| \le |OUTZ_ST-OUTZ_NOST| \le |MAX(ST_Z)|$ YES (PASS) NO (FAIL) Write 00h to CTRL2\_G (11h): Disable sensor

Write 00h to CTRL5 C (14h): Disable self test

AN4682 Revision history

# 10 Revision history

Table 58. Document revision history

| Date        | Revision | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 04-Aug-2015 | 1        | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 10-Feb-2016 | 2        | Updated Embedded functions registers Added Table 10: Accelerometer anti-aliasing + LPF1 overall cutoff frequency Added Section 3.9: Accelerometer and gyroscope turn-on/off time Updated Section 5.3: Wake-up interrupt Updated Section 5.6: Activity/Inactivity recognition and Section 5.7: Boot status Updated Section 6.1: Pedometer functions: step detector and step counter, Section 6.2: Significant motion, Section 6.3: Tilt, and Section 6.4: Timestamp Added Section 7.3.1: Procedure for ODR changes when using FIFO Updated Table 54: High part of gyroscope and accelerometer data in FIFO Updated Figure 5, 14, 17 and 32 |  |  |
| 14-Oct-2016 | 3        | Updated Introduction Updated Table 2: Registers Added Section 1: Pin description Added Section 3.6: Changing the power mode in accelerometer-only mode Updated Section 5.7: Boot status Updated Section 6.4: Timestamp Updated Section 7.3.1: Procedure for ODR changes when using FIFO Minor textual updates                                                                                                                                                                                                                                                                                                                             |  |  |
| 06-Mar-2017 | 4        | Updated Section 3.3: Normal mode and Section 3.4: Low-Power mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 23-Jan-2018 | 5        | Updated Note in Section 3: Operating modes and Section 3.3: Normal mode Updated Section 5.3: Wake-up interrupt, Section 5.5.3: Single-tap and double- tap recognition configuration, Section 5.6: Activity/Inactivity recognition and Figure 21: Activity/Inactivity recognition                                                                                                                                                                                                                                                                                                                                                          |  |  |

### IMPORTANT NOTICE - PLEASE READ CAREFULLY

STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST's terms and conditions of sale in place at the time of order acknowledgement.

Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers' products.

No license, express or implied, to any intellectual property right is granted by ST herein.

Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product.

ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners.

Information in this document supersedes and replaces information previously supplied in any prior versions of this document.

© 2018 STMicroelectronics – All rights reserved

