Document Number: AN-000266

Revision: 1.0

Date: 01/05/2021



# ICM-42607x and ICM-42670x Accelerometer Low Power Mode Implementation



## **Table of Contents**

| 1 | Introduction |                                                            |    |  |  |  |
|---|--------------|------------------------------------------------------------|----|--|--|--|
| 2 | Acce         | Accelerometer LP mode configurations after reset           |    |  |  |  |
|   | 2.1          | ACCEL_UI_AVG (bank0 register 0x24 bit 6:4)                 | 4  |  |  |  |
|   | 2.2          | ACCEL_odr (bank0 register 0x21 bit 3:0)                    |    |  |  |  |
|   | 2.3          | ACCEL_LP_CLK_sel (bank0 register 0x1F bit 7)               | 5  |  |  |  |
|   | 2.4          | ACCEL_mode (bank0 register 0x1F bit 1:0)                   |    |  |  |  |
| 3 | Char         | nge accel mode from LP to LN when using wake-up oscillator | 7  |  |  |  |
|   | 3.1          | Enable IDLE (bank0 register 0x1F bit 4)                    | 7  |  |  |  |
|   | 3.2          | INT_SOURCEO (bankO register 0x2B bit 7:0)                  |    |  |  |  |
|   | 3.3          | Accel_odr (bank0 register 0x21 bit 3:0)                    | 8  |  |  |  |
|   | 3.4          | accel_mode (bank0 register 0x1f bit 1:0)                   | 8  |  |  |  |
|   | 3.5          | INT SOURCEO (banko register 0x2B bit 7:0)                  |    |  |  |  |
|   | 3.6          | Disable IDLE (bank0 register 0x1F bit 4)                   | 9  |  |  |  |
|   | 3.7          | An example                                                 | 10 |  |  |  |
| 4 | Acce         | elerometer IP mode power consumption and noise level       | 11 |  |  |  |
| 5 |              | sion History                                               |    |  |  |  |



#### 1 INTRODUCTION

In addition to low noise (LN) mode, ICM-42607x and ICM-42670x support low power (LP) mode. The LP mode consumes very little power, which is a useful mode for power sensitive applications, such as always-on wearable devices.

This application note describes how to bring the accel to LP mode, how to switch from LP mode to LN mode, and LP mode performance.



#### 2 ACCELEROMETER LP MODE CONFIGURATIONS AFTER RESET

Accel LP mode operates as duty cycle mode. There are two internal clock sources that can be selected for the Accel LP mode inactive time, Wake-Up oscillator clock (6.4 kHz) and RC oscillator clock (4 MHz).

Before enabling Accel LP mode, ACCEL\_UI\_AVG must be selected for averaging filter setting to create Accelerometer output.

After part softreset, the configuration register settings are listed as below.

#### 2.1 ACCEL\_UI\_AVG (BANKO REGISTER 0X24 BIT 6:4)

The ACCEL\_UI\_AVG cannot be changed when Accel LP mode is selected. It must be set before LP mode is enabled.

The higher the averaging number is, the lower the noise level and the higher the power consumption are.

| Name: ACCEL_CONFIG1 Address: 36 (24h) OTP: 1 Reset value: 1h 00000001b |                  |                                                                                                                                                                                                                                                                   |  |  |
|------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| BIT ACCESS                                                             | NAME             | DESCRIPTION                                                                                                                                                                                                                                                       |  |  |
| [6:4] read-write                                                       | accel_ui_avg_ind | LPM number of averaged ADC samples to generate output sample 0 -: 2 averaged samples 1 -: 4 averaged samples 2 -: 8 averaged samples 3 -: 16 averaged samples 4 -: 32 averaged samples 5 -: 64 averaged samples 6 -: 64 averaged samples 7 -: 64 averaged samples |  |  |

This field cannot be changed when the accel sensor is in LPM



#### 2.2 ACCEL\_ODR (BANKO REGISTER 0X21 BIT 3:0)

The highest ODR for Accel LP mode is 400 Hz.

When using APEX function, the ACCEL\_ODR must be configured to an ODR equal or greater to the DMP\_ODR (Bank0, register 0x26, bit 1:0) for correct device operation.

| Name: ACCEL_CONFIGO Address: 33 (21h) OTP: 0 Reset value: 6h 00000110b |            |           |                                                                                                                                                                                                                                                      |  |
|------------------------------------------------------------------------|------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| BIT                                                                    | ACCESS     | NAME      | DESCRIPTION                                                                                                                                                                                                                                          |  |
| [3:0]                                                                  | read-write | accel_odr | 0: N/A 1-: N/A 2-: N/A 3-: N/A 4-: N/A 5-: 1.6k (LN only) 6-: 800 (default, LN only) 7-: 400 8-: 200 9-: 100 10-: 50 11-: 25 12-: 12.5 13-: 6.25 (LP only) 14-: 3.125 (LP only) This field can be changed on-the-fly when accel sensor is already on |  |

#### 2.3 ACCEL\_LP\_CLK\_SEL (BANKO REGISTER 0X1F BIT 7)

Configure Accel LP mode clock source from Wake-Up oscillator clock or RC oscillator clock. Using Wake-Up oscillator will consume less power than using RC oscillator. But when using Wake-Up oscillator, a special sequence is required to switch the mode from LP to LN. This will be discussed in section 4.

| Addre | Name: PWR_MGMT_0 Address: 31 (1fh) OTP: 1 |                  |                                                                                                                                                                                          |  |  |
|-------|-------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Reset | value: 0h 00000000b                       |                  |                                                                                                                                                                                          |  |  |
| BIT   | ACCESS                                    | NAME             | DESCRIPTION                                                                                                                                                                              |  |  |
| [7]   | read-write                                | accel_lp_clk_sel | O: Accelerometer LP mode uses Wake Up oscillator clock. This is the lowest power consumption mode and it is the recommended setting.  1: Accelerometer LP mode uses RC oscillator clock. |  |  |
|       |                                           |                  | This field can be changed on-the-fly even if accel sensor is already on                                                                                                                  |  |  |



#### 2.4 ACCEL\_MODE (BANKO REGISTER 0X1F BIT 1:0)

Set the ACCEL\_MODE with binary 10 to place the Accel to LP mode.

Name: PWR\_MGMT\_0 Address: 31 (1fh)

| OTP: 1 | OTP: 1            |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|--------|-------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Reset  | value: 0h 0000000 | 0b         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| BIT    | ACCESS            | NAME       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| [1:0]  | read-write        | accel_mode | Accel_mode[1:0] 00: OFF 01: OFF 10: LPM 11: LNM  Notes: - when selecting LP Mode please refer to "accel_lp_clk_sel" setting, bit[7] of this register.                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|        |                   |            | <ul> <li>before entering and during LP Mode the following combinations of ODR and averaging are not permitted:</li> <li>1) ODR=1600 Hz and ODR=800 Hz: any averaging.</li> <li>2) ODR=400 Hz: averaging=16, 32 or 64.</li> <li>3) ODR=200 Hz: averaging=64.</li> <li>when transitioning from OFF to LPM/LNM, do not issue any register writes for 200 μs. For details please see use notes.</li> <li>This field can be changed on-the-fly even if accel sensor is already on</li> </ul> |  |  |  |



## 3 CHANGE ACCEL MODE FROM LP TO LN WHEN USING WAKE-UP OSCILLATOR

If accel is in LP with RCosc, the user can trigger a change toward accel LN mode at anytime. The mode change will take effect on the next ODR.

When accel is in LP mode with WUosc, before changing it to LN mode, it is necessary to change the LP mode clock source from Wuosc to RCosc and wait for 1 ODR period.

ALP+WUosc mode → ALP+RCosc mode → wait for one Accel ODR period → all other power modes

#### 3.1 ENABLE IDLE (BANKO REGISTER 0X1F BIT 4)

Set IDLE bit to 1 and keep the LP mode setting (ACCEL\_MODE=10).

| Addres | Name: PWR_MGMT_0 Address: 31 (1fh) OTP: 1 |            |                                                                                                                                                                                                                                                            |  |  |
|--------|-------------------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Reset  | value: 0h 00000000b                       |            |                                                                                                                                                                                                                                                            |  |  |
| BIT    | ACCESS                                    | NAME       | DESCRIPTION                                                                                                                                                                                                                                                |  |  |
| [4]    | read-write                                | idle       | If this bit is set to 1, the RC oscillator is powered on even if Accel and Gyro are powered off.  Nominally this bit is set to 0, so when Accel and Gyro are powered off, the chip will go to OFF state, since the RC oscillator will also be powered off. |  |  |
|        |                                           |            | This field can be changed on-the-fly even if a sensor is already on                                                                                                                                                                                        |  |  |
| [1:0]  | read-write                                | accel_mode | Accel mode[1:0] 00: OFF 01: OFF 10: LPM 11: LNM When transitioning from OFF to LPM/LNM, do not issue any register writes for 200 μs. For details please see use notes.                                                                                     |  |  |
|        |                                           |            | This field can be changed on-the-fly even if accel sensor is all                                                                                                                                                                                           |  |  |

#### 3.2 INT\_SOURCEO (BANKO REGISTER 0X2B BIT 7:0)

Disable all interrupt sources. Set 0x00 to the INT\_SOURCEO register.

| Name  | Name: INT_SOURCE0                                                          |                        |                                                                   |  |  |  |  |
|-------|----------------------------------------------------------------------------|------------------------|-------------------------------------------------------------------|--|--|--|--|
| Addr  | Address: 43 (2bh)                                                          |                        |                                                                   |  |  |  |  |
| OTP:  | OTP: 1                                                                     |                        |                                                                   |  |  |  |  |
| Reset | Reset value: 10h 00010000b                                                 |                        |                                                                   |  |  |  |  |
| BIT   | ACCESS                                                                     | NAME                   | DESCRIPTION                                                       |  |  |  |  |
| [7]   | read-write                                                                 | int_st_done_int1_en    | Self-Test Done interrupt source enable – Interrupt output 1       |  |  |  |  |
|       |                                                                            |                        | 0 : Disabled                                                      |  |  |  |  |
|       |                                                                            |                        | 1 : Enabled                                                       |  |  |  |  |
| [6]   | [6] read-write int_fsync_int1_en UI FSYNC Interrupt source enable for int1 |                        |                                                                   |  |  |  |  |
| [5]   | 5] read-write int_pll_rdy_int1_en PLL RDY Interrupt source enable for int1 |                        |                                                                   |  |  |  |  |
| [4]   | read-write                                                                 | int_reset_done_int1_en | RESET DONE Interrupt source enable for int1                       |  |  |  |  |
| [3]   | read-write                                                                 | int_drdy_int1_en       | UI DRDY Interrupt source enable for int1                          |  |  |  |  |
| [2]   | read-write                                                                 | int_fifo_ths_int1_en   | FIFO THS Interrupt source enable for int1                         |  |  |  |  |
| [1]   | read-write                                                                 | int_fifo_full_int1_en  | FIFO FULL Interrupt source enable for int1                        |  |  |  |  |
|       |                                                                            |                        | To avoid FIFO interrupts while reading FIFO, this bit needs to be |  |  |  |  |
|       |                                                                            |                        | disabled while reading FIFO. Please see use notes for details     |  |  |  |  |
| [0]   | read-write                                                                 | int_agc_rdy_int1_en    | AGC RDY Interrupt source enable for int1                          |  |  |  |  |



#### 3.3 ACCEL\_ODR (BANKO REGISTER 0X21 BIT 3:0)

Change ACCEL\_ODR for LN mode ODR based on customer application.

Name: ACCEL\_CONFIG0 Address: 33 (21h) OTP: 0 Reset value: 6h 00000110b **ACCESS** NAME **DESCRIPTION** [3:0] 0 -: N/A read-write accel odr 1 -: N/A 2 -: N/A 3 -: N/A 4 -: N/A 5 -: 1.6k (LN only) 6 -: 800 (default, LN only) 7 -: 400 8 -: 200 9 -: 100 10 -: 50

> 11 -: 25 12 -: 12.5

13 -: 6.25 (LP only) 14 -: 3.125 (LP only) 15 -: 1.5625 (LP only)

This field can be changed on-the-fly when accel sensor is already on

#### 3.4 ACCEL\_MODE (BANKO REGISTER 0X1F BIT 1:0)

Set ACCEL\_MODE=11 (LN mode) and keep IDLE bit to 1.

Name: PWR\_MGMT\_0 Address: 31 (1fh) OTP: 1 Reset value: 0h 00000000b NAME DESCRIPTION **ACCESS** If this bit is set to 1, the RC oscillator is powered on even if Accel and read-write idle [4] Gyro are powered off. Nominally this bit is set to 0, so when Accel and Gyro are powered off, the chip will go to OFF state, since the RC oscillator will also be powered off. This field can be changed on-the-fly even if a sensor is already on [1:0] read-write accel mode Accel mode[1:0] 00: OFF 01: OFF 10: LPM 11: LNM When transitioning from OFF to LPM/LNM, do not issue any register writes for 200 µs. For details please see use notes. This field can be changed on-the-fly even if accel sensor is already on



#### 3.5 INT\_SOURCEO (BANKO REGISTER 0X2B BIT 7:0)

Enable interrupt source based on customer application.

Name: INT SOURCE0 Address: 43 (2bh) OTP: 1 Reset value: 10h 00010000b BIT ACCESS NAME **DESCRIPTION** [7] Self Test Done interrupt source enable - Interrupt output 1 read-write int\_st\_done\_int1\_en 0: Disabled 1: Enabled read-write int\_fsync\_int1\_en UI FSYNC Interrupt source enable for int1 [6] read-write PLL RDY Interrupt source enable for int1 [5] int\_pll\_rdy\_int1\_en [4] read-write int\_reset\_done\_int1\_en RESET DONE Interrupt source enable for int1 [3] read-write int\_drdy\_int1\_en UI DRDY Interrupt source enable for int1 [2] int\_fifo\_ths\_int1\_en FIFO THS Interrupt source enable for int1 read-write read-write int\_fifo\_full\_int1\_en FIFO FULL Interrupt source enable for int1 To avoid fifo full interrupts while reading FIFO, this bit needs to be disabled while reading FIFO. Please see use notes for details AGC RDY Interrupt source enable for int1 [0] read-write int\_agc\_rdy\_int1\_en

#### 3.6 DISABLE IDLE (BANKO REGISTER 0X1F BIT 4)

Set IDLE bit to 0 and keep the LN mode setting (ACCEL MODE=11).

|        | Name: PWR_MGMT_0    |            |                                                                                                                                                                                                                                                            |  |  |  |  |
|--------|---------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        | Address: 31 (1fh)   |            |                                                                                                                                                                                                                                                            |  |  |  |  |
| OTP: 1 |                     |            |                                                                                                                                                                                                                                                            |  |  |  |  |
| Reset  | value: 0h 00000000b |            |                                                                                                                                                                                                                                                            |  |  |  |  |
| BIT    | ACCESS              | NAME       | DESCRIPTION                                                                                                                                                                                                                                                |  |  |  |  |
| [4]    | read-write          | idle       | If this bit is set to 1, the RC oscillator is powered on even if Accel and Gyro are powered off.  Nominally this bit is set to 0, so when Accel and Gyro are powered off, the chip will go to OFF state, since the RC oscillator will also be powered off. |  |  |  |  |
|        |                     |            | This field can be changed on-the-fly even if a sensor is already on                                                                                                                                                                                        |  |  |  |  |
| [1:0]  | read-write          | accel_mode | Accel_mode[1:0]  00: OFF  01: OFF  10: LPM  11: LNM  When transitioning from OFF to LPM/LNM, do not issue any register writes for 200 μs. For details please see use notes.                                                                                |  |  |  |  |
|        |                     |            | This field can be changed on-the-fly even if accel sensor is already on                                                                                                                                                                                    |  |  |  |  |



#### 3.7 AN EXAMPLE

```
1. SIGNAL_PATH_RESET (0x02) <- 0x10 (SIGNAL_PATH_RESET=1)
2. ACCEL_CONFIG1 (0x24) <- 0x01 (ACCCEL_UI_AVG=2x, ACCEL_UI_FILT_BW=180Hz)
3. ACCEL_CONFIG0 (0x21) <- 0x4E (ACCEL_UI_FS_SEL=4g, ACCEL_ODR=3.125Hz)
4. INT_SOURCE0 (0x2B) <- 0x08 (DRDY_INT1_EN=1)
5. PWR_MGMT0 (0x1F) <- 0x02 (ACCEL_MODE=LP)
6. <Wait for 3 sec>
7. PWR_MGMT0 (0x1F) <- 0x12 (ACCEL_MODE=LP, IDLE=1)
8. INT_SOURCE0 (0x2B) <- 0x00 (All interrupt source off)
9. ACCEL_CONFIG0 (0x21) <- 0x46 (ACCEL_UI_FS_SEL=4g, ACCEL_ODR=800Hz)
10. PWR_MGMT0 (0x1F) <- 0x13 (ACEL_MODE=LN, IDLE=1)
11. INT_SOURCE0 (0x2B) <- 0x08 (DRDY_INT1_EN=1)
12. PWR MGMT0 (0x1F) <- 0x03 (ACEL_MODE=LN)
```



# 4 ACCELEROMETER LP MODE POWER CONSUMPTION AND NOISE LEVEL

The table below shows Accel LP mode setting and performance. The power consumption value is derived from validation or characterization of parts with ACCEL\_LP\_CLK\_SEL set to 0.

|           | ACCEL_UI_AVG   | 000  | 001  | 010         | 011             | 100  | 101   |
|-----------|----------------|------|------|-------------|-----------------|------|-------|
|           | Averages       | 2    | 4    | 8           | 16              | 32   | 64    |
|           | Noise (mg-rms) | 6.2  | 4.4  | 3.1         | 2.2             | 1.56 | 1.1   |
| ACCEL_ODR | ODR (Hz)       |      | Po   | ower consum | ption, Idd (uA) |      |       |
| 1111      | 1.5625         | 4.4  | 4.4  | 4.5         | 4.7             | 5.2  | 6.1   |
| 1110      | 3.125          | 4.8  | 4.9  | 5.1         | 5.5             | 6.4  | 8.2   |
| 1101      | 6.25           | 5.5  | 5.7  | 6.1         | 7               | 8.8  | 12.5  |
| 1100      | 12.5           | 6.9  | 7.4  | 8.3         | 10.1            | 13.7 | 20.9  |
| 1011      | 25             | 9.8  | 10.7 | 12.5        | 16.1            | 23.3 | 37.8  |
| 1010      | 50             | 15.6 | 17.4 | 21          | 28.2            | 42.7 | 71.6  |
| 1001      | 100            | 27.2 | 30.8 | 38          | 52.5            | 81.3 | 139.1 |
| 1000      | 200            | 50.5 | 58   | 72          | 101             | 159  | NA    |
| 0111      | 400            | 97   | 111  | 140         | NA              | NA   | NA    |



### 5 REVISION HISTORY

| REVISION DATE | REVISION | DESCRIPTION     |
|---------------|----------|-----------------|
| 01/05/2021    | 1.0      | Initial Release |



This information furnished by InvenSense or its affiliates ("TDK InvenSense") is believed to be accurate and reliable. However, no responsibility is assumed by TDK InvenSense for its use, or for any infringements of patents or other rights of third parties that may result from its use. Specifications are subject to change without notice. TDK InvenSense reserves the right to make changes to this product, including its circuits and software, in order to improve its design and/or performance, without prior notice. TDK InvenSense makes no warranties, neither expressed nor implied, regarding the information and specifications contained in this document. TDK InvenSense assumes no responsibility for any claims or damages arising from information contained in this document, or from the use of products and services detailed therein. This includes, but is not limited to, claims or damages based on the infringement of patents, copyrights, mask work and/or other intellectual property rights.

Certain intellectual property owned by InvenSense and described in this document is patent protected. No license is granted by implication or otherwise under any patent or patent rights of InvenSense. This publication supersedes and replaces all information previously supplied. Trademarks that are registered trademarks are the property of their respective companies. TDK InvenSense sensors should not be used or sold in the development, storage, production or utilization of any conventional or mass-destructive weapons or for any other weapons or life threatening applications, as well as in any other life critical applications such as medical equipment, transportation, aerospace and nuclear instruments, undersea equipment, power plant equipment, disaster prevention and crime prevention equipment.

© 2021 InvenSense. All rights reserved. InvenSense, MotionTracking, MotionProcessing, MotionProcessor, MotionFusion, MotionApps, DMP, AAR, and the InvenSense logo are trademarks of InvenSense, Inc. The TDK logo is a trademark of TDK Corporation. Other company and product names may be trademarks of the respective companies with which they are associated.



©2021 InvenSense. All rights reserved.