

Click here to ask an associate for production status of specific part numbers.

### Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

### **General Description**

The MAX86174A/MAX86174B are ultra-low-power optical data acquisition systems with both transmit and receive channels. On the transmitter side, the MAX86174A/MAX86174B have four LED driver output pins. Each pin is programmable from two, high-current, 8-bit LED drivers. On the receiver side, the MAX86174A consists of two optical readout channels that can operate simultaneously while the MAX86174B has a single optical readout channel. The devices have low-noise, charge-integrating analog front-end, 20-bit ADC, and best-in-class ambient-light cancellation (ALC) circuits.

Due to the low power consumption, compact size, ease and flexibility of use, the MAX86174A/MAX86174B are ideal for a wide variety of optical sensing applications such as pulse oximetry and heart-rate detection.

The MAX86174A/MAX86174B operate on a 1.8V main supply voltage and a 2.7V to 5.5V LED driver supply voltage. The devices support both I<sup>2</sup>C- and SPI-compatible interfaces in a fully autonomous way. The devices have a large 256-word built-in FIFO. The MAX86174A/MAX86174B are available in a compact 16-WLP package.

#### **Applications**

- Wearable Devices for Fitness, Wellness and Medical Applications
- Clinical Accuracy
- · Suitable for Wrist, Finger, Ear, and Other Locations
- Optimized Performance to Detect
  - Optical Heart Rate
  - Heart-Rate Variability
  - Oxygen Saturation (SpO<sub>2</sub>)
  - Body Hydration
  - Muscle and Tissue Oxygen Saturation (SmO<sub>2</sub> and StO<sub>2</sub>)
  - Maximum Oxygen Consumption (VO2 Max)

### **Benefits and Features**

- Complete Optical Data Acquisition System
- Ultra-Low-Power Operation for Body Wearable Devices
  - Low-Power-Operation, Optical Readout Channel < 11μA (typ) at 25fps
  - Exposure Integration Period Ranging from 14.6µs to 117.1µs
  - Low Shutdown Current < 1µA (typ)</li>
- Excellent Top-End Dynamic Range > 93dB in White Card Loop-Back Test (Nyquist Sample-to-Sample Variance)
- Extended Dynamic Range up to 111dB (Averaging and Off-Chip Filtering) to Enable SpO<sub>2</sub> on Wrist/Chest for Low Perfusion Cases
- Support Frame Rates from 1fps to 2048fps
- High-Resolution 20-Bit Charge-Integrating ADCs
- Support Both Burst Averaging and Decimation Averaging Modes
- On-Chip 12Hz Low-Pass Filter for Improved SNR and Reduced Power for Continuous Heart-Rate Measurement
- Supports Two PD Inputs for Multi-Parameter Measurements
- Supports Four LED Driver Output Pins Generated from Two 8-Bit LED Current Drivers
- Low Dark-Current Noise of < 50pA<sub>RMS</sub> (Sample-to-Sample Variance in 117.1µs Integration Time)
- Excellent Ambient Range and Rejection Capability
  - 200µA Ambient Photodiode Current
  - > 70dB Ambient Rejection at 120Hz (Burst Average > 2)
- Miniature 1.67mm x 1.78mm, 0.4mm Ball Pitch, 4 x 4 WLP Package
- -40°C to +85°C Operating Temperature Range

### **Simplified Block Diagram**

#### MAX86174A



#### **MAX86174B**



### **TABLE OF CONTENTS**

| General Description                                  |    |
|------------------------------------------------------|----|
| Applications                                         |    |
| Benefits and Features                                |    |
| Simplified Block Diagram                             |    |
| Absolute Maximum Ratings                             |    |
| Package Information                                  |    |
| 16 WLP                                               | 7  |
| Electrical Characteristics                           |    |
| Typical Operating Characteristics                    |    |
| Pin Configuration                                    |    |
| MAX86174A/MAX86174B                                  |    |
| Pin Description                                      |    |
| Detailed Description                                 |    |
| Optical Transmitter Overview                         |    |
| Optical Receiver Overview                            |    |
| Photodiode Biasing                                   |    |
| Measurement Configuration and Timing                 | 20 |
| Ambient-Light Cancellation                           | 21 |
| Frame and Frame Rate                                 | 22 |
| On-Chip Averaging                                    | 23 |
| Burst Average                                        | 24 |
| Decimation Average                                   | 24 |
| On-Chip Filtering                                    |    |
| ADC Decimation Filter                                |    |
| Digital Low-Pass Filter                              |    |
| AFE Exposure Control and SNR                         | 26 |
| Threshold Detect Function                            |    |
| Automatic Proximity Detect Mode                      | 28 |
| Synchronization Modes                                | 29 |
| Internal Frame Oscillator and Divider Mode           | 29 |
| External Frame Trigger Input Mode                    |    |
| External Frame Clock Input Mode                      | 29 |
| FIFO Description                                     | 29 |
| Digital Interface                                    |    |
| SPI/I <sup>2</sup> C Selection for Serial Interface  |    |
| SPI Interface                                        |    |
| Single Word SPI Register Read and Write Transactions |    |
| SPI Burst Mode Read Transaction                      |    |
| I <sup>2</sup> C-/SMBus-Compatible Serial Interface  |    |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

## TABLE OF CONTENTS (CONTINUED)

| Bit Transfer                       | 36 |
|------------------------------------|----|
| START and STOP Conditions          | 36 |
| Acknowledge Bit                    | 37 |
| I <sup>2</sup> C Write Data Format | 38 |
| I <sup>2</sup> C Read Data Format  | 39 |
| I <sup>2</sup> C Broadcast         | 40 |
| Layout Guidelines                  | 41 |
| Register Map                       | 43 |
| User Register Map                  | 43 |
| Register Details                   | 46 |
| Typical Application Circuits       | 85 |
| MAX86174A/MAX86174B                | 85 |
| Ordering Information               | 85 |
| Revision History                   | 86 |
|                                    |    |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

### LIST OF FIGURES

| Figure 1. LED Drivers                                                  |    |
|------------------------------------------------------------------------|----|
| Figure 2. On-Chip Mux for the PD1_IN and PD2_IN pins                   |    |
| Figure 3. Measurement with One LED On                                  |    |
| Figure 4. Central Difference Method (CDM)                              |    |
| Figure 5. Forward Difference Method (FDM)                              | 22 |
| Figure 6. Frame with One Measurement                                   | 23 |
| Figure 7. Frame with Six Measurements                                  | 23 |
| Figure 8. Frame with Measurement Burst Averaging                       |    |
| Figure 9. Illustration of Measurement with Burst Averaging             |    |
| Figure 10. Frames with Decimation Average of 2                         |    |
| Figure 11. Signal Transfer Function of Decimation Filters              |    |
| Figure 12. Threshold limits with LEVEL_HYST                            | 28 |
| Figure 13. Detailed SPI Timing Diagram                                 |    |
| Figure 14. SPI Write Transaction                                       |    |
| Figure 15. SPI Read Transaction                                        |    |
| Figure 16. SPI FIFO Burst Mode Read Transaction                        |    |
| Figure 17. Detailed I <sup>2</sup> C Timing Diagram                    |    |
| Figure 18. I <sup>2</sup> C START, STOP, and REPEATED START Conditions |    |
| Figure 19. I <sup>2</sup> C Acknowledge Bit                            |    |
| Figure 20. I <sup>2</sup> C Single Byte Write Transaction              |    |
| Figure 21. I <sup>2</sup> C Multi-Byte Write Transaction               |    |
| Figure 22. I <sup>2</sup> C Single Byte Read Transaction               | 40 |
| Figure 23. I <sup>2</sup> C Multi-Byte Read Transaction                |    |
| Figure 24. Top Layer—AFE Layer                                         |    |
| Figure 25. Layer 5—Pseudo PD_GND Shields PD_IN                         |    |
| Figure 26. Bottom Laver—Optics Laver                                   | 42 |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

# LIST OF TABLES

| Table 1. LED Driver and LED Mux Configuration       |    |
|-----------------------------------------------------|----|
| Table 2. LED Driver Full-Scale Range Trade-Off      | 18 |
| Table 3. Configuration for ADC Decimation Filter    | 25 |
| Table 4. Typical SNR Benefit Of Various Parameters  | 26 |
| Table 5. Clock Sources in Each Synchronization Mode | 29 |
| Table 6. FIFO Tags                                  | 30 |
| Table 7. Slave Addresses for I <sup>2</sup> C Mode  | 33 |
|                                                     |    |

Analog Devices | 6 www.analog.com

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFF for Wearable Health

### **Absolute Maximum Ratings**

| V <sub>DD</sub> to GND              | 0.3V to +2.2V                     |
|-------------------------------------|-----------------------------------|
| V <sub>I FD</sub> to PGND           | 0.3V to +6.0V                     |
| PGND to GND                         | 0.3V to +0.3V                     |
| VREF to GND                         | 0.3V to +2.2V                     |
| LEDn_DRV (n = 1 to 4), TRIG to PGND | 0.3V to (V <sub>LED</sub> + 0.3V) |
| PDm_IN to GND (m = 1, 2)            | 0.3V to +2.2V                     |
| SDO/ADDR to GND                     | 0.3V to (V <sub>DD</sub> + 0.3V)  |

| SDI/SDA, SCLK/SCL, CSB/I2C_SEL, INTB to GND0.3V            | ' to |
|------------------------------------------------------------|------|
| +(                                                         | 6V   |
| Output Short-Circuit DurationContinuo                      | us   |
| Continuous Input Current into Any Pin (except LEDn_DRV Pir | ns,  |
| n = 1 to 4)±50n                                            | nΑ   |
| Operating Temperature Range40°C to +85                     | °C   |
| Storage Temperature Range40°C to +150                      | °C   |
| Soldering Temperature (reflow)+260                         | °C   |
|                                                            |      |

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### **Package Information**

#### **16 WLP**

| Package Code                           | N161B1+1                       |
|----------------------------------------|--------------------------------|
| Outline Number                         | <u>21-100454</u>               |
| Land Pattern Number                    | Refer to Application Note 1891 |
| THERMAL RESISTANCE, FOUR-LAYER BOARD   |                                |
| Junction to Ambient (θ <sub>JA</sub> ) | 57.93°C/W                      |

For the latest package outline information and land patterns (footprints), go to <a href="https://www.maximintegrated.com/packages">www.maximintegrated.com/packages</a>. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.

Package thermal resistances were obtained using the method described in JEDEC specification JESD51-7, using a four-layer board. For detailed information on package thermal considerations, refer to <a href="https://www.maximintegrated.com/thermal-tutorial">www.maximintegrated.com/thermal-tutorial</a>.

#### **Electrical Characteristics**

 $(V_{DD}$  = 1.8V,  $V_{LED}$  = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16 $\mu$ A, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6 $\mu$ s, MEASx\_LED\_SETLNG = 6 $\mu$ s, MEASx\_LED\_RGE = 128 $\mu$ A, C<sub>PD</sub> = 65 $\mu$ F, T<sub>A</sub> = +25°C, min/max are from T<sub>A</sub> = -40°C to +85°C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER            | SYMBOL           | CONDITIONS                | MIN | TYP | MAX | UNITS |
|----------------------|------------------|---------------------------|-----|-----|-----|-------|
| POWER SUPPLY         |                  |                           |     |     |     |       |
| Power-Supply Voltage | V <sub>DD</sub>  | Verified during PSRR Test | 1.7 | 1.8 | 2.0 | V     |
| LED-Supply Voltage   | V <sub>LED</sub> | Verified during PSRR Test | 2.7 |     | 5.5 | V     |

## **Electrical Characteristics (continued)**

( $V_{DD}$  = 1.8V,  $V_{LED}$  = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16µA, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6µs, MEASx\_LED\_SETLNG = 6µs, MEASx\_LED\_RGE = 128mA,  $C_{PD}$  = 65pF,  $T_A$  = +25°C, min/max are from  $T_A$  = -40°C to +85°C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER                                  | SYMBOL                                           | COND                                                     | ITIONS                 | MIN                    | TYP  | MAX | UNITS      |    |
|--------------------------------------------|--------------------------------------------------|----------------------------------------------------------|------------------------|------------------------|------|-----|------------|----|
|                                            |                                                  | Single channel,                                          | FR = 512fps            |                        | 95   | 150 |            |    |
|                                            |                                                  | one Measure/                                             | FR = 64fps             |                        | 17   |     | μΑ         |    |
|                                            |                                                  | Frame (Note 5a)                                          | FR = 8fps              |                        | 3.5  |     |            |    |
|                                            |                                                  | Single channel,                                          | FR = 512fps            |                        | 300  | 420 |            |    |
|                                            |                                                  | four Measures/                                           | FR = 64fps             |                        | 40   |     |            |    |
| Average V <sub>DD</sub> Supply             |                                                  | Frame (Note 5a)                                          | FR = 8fps              |                        | 6.5  |     | μA         |    |
| Current                                    | I <sub>DD</sub>                                  | Dual channel, one                                        | FR = 512fps            |                        | 150  | 210 |            |    |
|                                            |                                                  | Measure/Frame                                            | FR = 64fps             |                        | 24   |     |            |    |
|                                            |                                                  | (Note 5b)                                                | FR = 8fps              |                        | 4.5  |     | ] <b>,</b> |    |
|                                            |                                                  | Dual channel, four                                       | FR = 512fps            |                        | 480  | 650 | μA         |    |
| 1                                          |                                                  | Measures/Frame                                           | FR = 64fps             |                        | 60   |     | -          |    |
|                                            |                                                  | (Note 5b)                                                | FR = 8fps              |                        | 9.5  |     |            |    |
|                                            |                                                  | Single Channel,                                          | FR = 512fps            |                        | 870  |     |            |    |
| Average V <sub>LED</sub> Supply<br>Current | I <sub>LED</sub>                                 | one LED/Frame,<br>MEASx_LED_SET                          | FR = 64fps             |                        | 98   |     | μA         |    |
| Current                                    |                                                  | LNG = 1 (Note 5a)                                        | FR = 8fps              |                        | 12.5 |     |            |    |
| V <sub>DD</sub> Current in<br>Shutdown     | I <sub>DD_SHDN</sub>                             | T <sub>A</sub> = +25°C                                   | , , ,                  |                        | 1.0  | 3   | μА         |    |
| V <sub>LED</sub> Current in<br>Shutdown    | I <sub>LED_SHDN</sub>                            | T <sub>A</sub> = +25°C                                   |                        |                        |      | 0.5 | μА         |    |
| LED DRIVER                                 |                                                  |                                                          |                        |                        |      |     |            |    |
| LED Current Resolution                     |                                                  |                                                          |                        |                        | 8    |     | bits       |    |
| Driver DNL                                 | DNL <sub>TX</sub>                                | MEASx_LED_RGE :                                          | = 0x3                  | -1                     |      | +1  | LSB        |    |
| Driver INL                                 | INL <sub>TX</sub>                                | MEASx_LED_RGE :                                          | = 0x3                  |                        | 1    |     | LSB        |    |
|                                            |                                                  |                                                          | MEASx_LED_RGE<br>= 0x0 |                        | 32   |     |            |    |
| Full Cools I FD Current                    | LED Current I <sub>LED</sub> MEASx_DRVy_P = 0xFF | MFASx DRVv PA                                            | MEASx_LED_RGE<br>= 0x1 |                        | 64   |     | 1          |    |
| ruii-Scale LED Current                     |                                                  |                                                          | = 0xFF                 | MEASx_LED_RGE<br>= 0x2 |      | 96  |            | mA |
|                                            |                                                  |                                                          | MEASx_LED_RGE<br>= 0x3 | 120                    | 128  | 136 |            |    |
| LED Driver Rise Time                       |                                                  | MEASx_DRVy_PA = 0xFF, 10% to 90%, all LED range settings |                        |                        |      | 3   | μs         |    |
| LED Driver Fall Time                       |                                                  | MEASx_DRVy_PA = all LED range setting                    |                        |                        |      | 3   | μs         |    |

## **Electrical Characteristics (continued)**

( $V_{DD}$  = 1.8V,  $V_{LED}$  = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16µA, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6µs, MEASx\_LED\_SETLNG = 6µs, MEASx\_LED\_RGE = 128mA,  $C_{PD}$  = 65pF,  $T_A$  = +25°C, min/max are from  $T_A$  = -40°C to +85°C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER                          | SYMBOL                                                                     | COND                                                                        | ITIONS                 | MIN           | TYP   | MAX           | UNITS |  |
|------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------|---------------|-------|---------------|-------|--|
|                                    |                                                                            |                                                                             | MEASx_LED_RGE<br>= 0x0 |               | 135   |               |       |  |
| Minimum Output                     |                                                                            | MEASx_DRVy_PA<br>= 0xFF, < 1%                                               | MEASx_LED_RGE<br>= 0x1 |               | 260   |               | mV    |  |
| Voltage                            | V <sub>OL</sub>                                                            | change in LED current                                                       | MEASx_LED_RGE<br>= 0x2 |               | 380   |               |       |  |
|                                    |                                                                            |                                                                             | MEASx_LED_RGE<br>= 0x3 |               | 500   | 800           |       |  |
|                                    |                                                                            |                                                                             | MEASx_LED_RGE<br>= 0x0 |               | ±5    |               | μA/V  |  |
| LED Driver DC V <sub>LED</sub>     |                                                                            | MEASx_DRVy_PA<br>= 0xFF, V <sub>DD</sub> =                                  | MEASx_LED_RGE<br>= 0x1 |               | ±5    |               |       |  |
| PSR                                |                                                                            | 1.8V, V <sub>LEDn_DRV</sub> = -<br>1.2V, V <sub>LED</sub> = 3.1V<br>to 5.5V | MEASx_LED_RGE<br>= 0x2 |               | ±5    |               | μA/V  |  |
|                                    |                                                                            |                                                                             | MEASx_LED_RGE<br>= 0x3 | -150          |       | +150          |       |  |
|                                    |                                                                            | MEASx_LED_RGE :                                                             | = 0x0                  | 120           | 148   | 180           | mV    |  |
| LED Driver Compliance              |                                                                            | MEASx_LED_RGE :                                                             | = 0x1                  | 260           | 287   | 320           |       |  |
| Interrupt Threshold                |                                                                            | MEASx_LED_RGE :                                                             | = 0x2                  | 395           | 425   | 460           |       |  |
|                                    |                                                                            | MEASx_LED_RGE :                                                             | = 0x3                  | 530           | 560   | 600           | 1     |  |
| READOUT CHANNEL                    |                                                                            |                                                                             |                        |               |       |               |       |  |
| ADC Resolution                     |                                                                            |                                                                             |                        |               | 20    |               | bits  |  |
| INL                                | INL <sub>RX</sub>                                                          | MEASx_TINT = 117                                                            | .1µs                   |               | ±10   |               | LSB   |  |
| IINL                               | INCRX                                                                      | MEASx_TINT = 14.6                                                           | βμs                    |               | ±40   |               | LOD   |  |
| DNL                                | DNL <sub>RX</sub>                                                          | MEASx_TINT = 117                                                            | .1µs                   |               | ±3    |               | LSB   |  |
| DIVL                               | DNLRX                                                                      | MEASx_TINT = 14.6                                                           | βμs                    |               | ±10   |               | LOD   |  |
|                                    |                                                                            | MEASx_PPGy_ADC                                                              | _RGE = 0x0             |               | 4.0   |               |       |  |
| ADC Full-Scale Input               | I <sub>FS</sub>                                                            | MEASx_PPGy_ADC                                                              | _RGE = 0x1             |               | 8.0   |               | μA    |  |
| Current                            | 'F5<br>                                                                    | MEASx_PPGy_ADC                                                              |                        |               | 16.0  |               | μΛ    |  |
|                                    |                                                                            | MEASx_PPGy_ADC                                                              | _RGE = 0x3             |               | 32.0  |               |       |  |
|                                    |                                                                            | MEASx_TINT = 0x0                                                            |                        |               | 14.6  |               |       |  |
| ADC Integration Time               | Time $t_{INT} = \frac{\text{MEASx\_TINT} = 0x1}{\text{MEASx\_TINT} = 0x2}$ |                                                                             |                        | 29.2          |       | μs            |       |  |
| 7.50 megration rime                |                                                                            | MEASx_TINT = 0x2                                                            |                        |               | 58.6  |               | μο    |  |
|                                    |                                                                            | MEASx_TINT = 0x3                                                            |                        |               | 117.1 |               |       |  |
| Minimum Free-Running<br>Frame Rate |                                                                            |                                                                             |                        |               | 1     |               | fps   |  |
| Maximum Free-Running Frame Rate    |                                                                            |                                                                             |                        |               | 2048  |               | fps   |  |
| Internal Frame-Rate<br>Clock       | fFRAME_CLK                                                                 |                                                                             |                        | -2% of<br>typ | 32768 | +2% of<br>typ | Hz    |  |

## **Electrical Characteristics (continued)**

( $V_{DD}$  = 1.8V,  $V_{LED}$  = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16µA, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6µs, MEASx\_LED\_SETLNG = 6µs, MEASx\_LED\_RGE = 128mA,  $C_{PD}$  = 65pF,  $T_A$  = +25°C, min/max are from  $T_A$  = -40°C to +85°C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER                               | SYMBOL             | COND                                                              | ITIONS                           | MIN                   | TYP  | MAX   | UNITS             |
|-----------------------------------------|--------------------|-------------------------------------------------------------------|----------------------------------|-----------------------|------|-------|-------------------|
| TRIG External Frame-<br>Clock Frequency | fTRIG_EXT_CL<br>K  |                                                                   |                                  |                       |      | 34000 | Hz                |
| TRIG Pulse Width                        | t <sub>TRIG</sub>  |                                                                   |                                  | 1                     |      |       | μs                |
| Internal Power-Up Time                  |                    |                                                                   |                                  |                       | 200  |       | μs                |
| ADC Clock Frequency                     | CLK                |                                                                   |                                  | 9.75                  | 10.0 | 10.25 | MHz               |
| Maximum DC-Ambient-<br>Light Rejection  | ALR                | ALC_OVF = 1                                                       |                                  |                       | 200  |       | μА                |
| Dynamic Ambient-Light Rejection         |                    | I <sub>EXPOSURE</sub> = 1μA, I<br>with ±0.4μA <sub>P-P</sub> 120F | AMBIENT = 1µA DC<br>Iz sine wave |                       | 80   |       | dB                |
| DC Ambient-Light<br>Rejection           |                    | I <sub>EXPOSURE</sub> = 1μA, I<br>30μA                            | AMBIENT = 1µA and                |                       | 0.5  |       | nA                |
| Dark-Current Offset                     | DC_O               | PDm_BIAS = 0x1, t <sub>II</sub>                                   | NT = 117.1µs                     |                       | ±1   |       | Counts            |
|                                         |                    | MEASx_TINT = 14.6                                                 | iµs                              |                       | 212  |       |                   |
| Dark-Current Input-                     |                    | MEASx_TINT = 29.2                                                 | 2µs                              |                       | 150  |       | pA <sub>RMS</sub> |
| Referred Noise                          |                    | MEASx_TINT = 58.6                                                 | βμs                              |                       | 106  |       |                   |
|                                         |                    | MEASx_TINT = 117                                                  | .1µs                             |                       | 75   |       | pA <sub>RMS</sub> |
|                                         |                    |                                                                   | t <sub>INT</sub> = 14.6μs        |                       | 1100 |       | - LSB/V           |
| V                                       |                    | I <sub>EXPOSURE</sub> = 1μA,                                      | t <sub>INT</sub> = 29.2µs        |                       | 750  |       |                   |
| V <sub>DD</sub> DC PSR                  |                    | $V_{DD} = 1.7V \text{ to } 2.0V$                                  | t <sub>INT</sub> = 58.6µs        |                       | 530  |       |                   |
|                                         |                    |                                                                   | t <sub>INT</sub> = 117.1μs       |                       | 410  | 800   |                   |
| DIGITAL I/O CHARACTE                    | RISTICS            |                                                                   | •                                | •                     |      |       | •                 |
| Input-Voltage Low                       | V <sub>IL</sub>    | SDI/SDA, SCLK/SCI<br>I2C_SEL                                      | L, TRIG, CSB/                    |                       |      | 0.4   | V                 |
| Input-Voltage High                      | V <sub>IH</sub>    | SDI/SDA, SCLK/SCI<br>I2C_SEL                                      | L, TRIG, CSB/                    | 1.4                   |      |       | V                 |
| Input Hysteresis                        | V <sub>HYS</sub>   | SDI/SDA, SCLK/SCI<br>I2C_SEL                                      | L, TRIG, CSB/                    |                       | 430  |       | mV                |
| Input Capacitance                       | C <sub>IN</sub>    | SDI/SDA, SCLK/SCI<br>I2C_SEL                                      | L, TRIG, CSB/                    |                       | 10   |       | pF                |
| Input-Leakage Current                   | I <sub>IN</sub>    | SDI/SDA, SCLK/SCI<br>I2C_SEL. T <sub>A</sub> = +25°               |                                  | -1                    | 0.01 | +1    | μA                |
| Output-Low Voltage                      | V <sub>OL</sub>    | SDO, INTB, SDI/SD/<br>I <sub>SINK</sub> = 4mA                     | A (in I <sup>2</sup> C mode ),   |                       |      | 0.4   | V                 |
| Output-High Voltage                     | V <sub>OH</sub>    | SDO, INTB, I <sub>SOURCE</sub> = 4mA                              |                                  | V <sub>DD</sub> - 0.4 |      |       | V                 |
| Open-Drain Output-Low<br>Voltage        | V <sub>OL_OD</sub> | INTB_OCFG = 0x0, I <sub>SINK</sub> = 4mA                          |                                  |                       |      | 0.4   | V                 |
| SPI TIMING CHARACTE                     | RISTICS (Note 4    | )                                                                 |                                  | •                     |      |       | •                 |
| SCLK Frequency                          | f <sub>SCLK</sub>  |                                                                   |                                  |                       |      | 24    | MHz               |
| SCLK Period                             | t <sub>CP</sub>    |                                                                   |                                  | 41.7                  |      |       | ns                |
| SCLK Pulse-Width High                   | t <sub>CH</sub>    |                                                                   |                                  | 18                    |      |       | ns                |

## **Electrical Characteristics (continued)**

( $V_{DD}$  = 1.8V,  $V_{LED}$  = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16µA, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6µs, MEASx\_LED\_SETLNG = 6µs, MEASx\_LED\_RGE = 128mA,  $C_{PD}$  = 65pF,  $T_A$  = +25°C, min/max are from  $T_A$  = -40°C to +85°C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER                                             | SYMBOL              | CONDITIONS                                                                  | MIN | TYP | MAX | UNITS |
|-------------------------------------------------------|---------------------|-----------------------------------------------------------------------------|-----|-----|-----|-------|
| SCLK Pulse-Width Low                                  | t <sub>CL</sub>     |                                                                             | 18  |     | ns  |       |
| CSB Fall to SCLK Rise<br>Setup Time                   | t <sub>CSS0</sub>   | Applies to 1st SCLK rising edge after CSB goes low                          | 20  |     |     | ns    |
| CSB Fall to SCLK Rise<br>Hold Time                    | t <sub>CSH0</sub>   | Applies to inactive rising edge preceding 1st rising edge                   | 5   |     |     | ns    |
| Last SCLK Rise to CSB<br>Rise                         | t <sub>CSH1</sub>   | Applies to last SCLK rising edge in a transaction                           | 20  |     |     | ns    |
| Last SCLK Rise to next<br>CSB Fall                    | t <sub>CSF</sub>    | Applies to last SCLK rising edge to next CSB falling edge (new transaction) | 60  |     |     | ns    |
| CSB Pulse-Width High                                  | t <sub>CSPW</sub>   |                                                                             | 40  |     |     | ns    |
| SDI to SCLK Rise Setup<br>Time                        | $t_{DS}$            |                                                                             | 5   |     |     | ns    |
| SDI to SCLK Rise Hold<br>Time                         | t <sub>DH</sub>     |                                                                             | 5   |     |     | ns    |
| SCLK Fall to SDO<br>Transition                        | t <sub>DOT</sub>    | C <sub>LOAD</sub> = 30pF                                                    |     |     | 15  | ns    |
| CSB Fall to SDO<br>Enabled                            | t <sub>DOE</sub>    | C <sub>LOAD</sub> = 0pF                                                     | 20  |     |     | ns    |
| CSB Rise to SDO Hi-Z                                  | t <sub>DOZ</sub>    | Disable Time                                                                |     |     | 5   | ns    |
| I <sup>2</sup> C TIMING CHARACTER                     | RISTICS (Note 4     | l)                                                                          |     |     |     |       |
| I <sup>2</sup> C Write Address                        |                     | ADDR = 0                                                                    |     | D4  |     | Hex   |
| 1 6 Wille Address                                     |                     | ADDR = 1                                                                    |     | D6  |     | TICX  |
| I <sup>2</sup> C Read Address                         |                     | ADDR = 0                                                                    |     | D5  |     | Hex   |
| 1 O Nead Address                                      |                     | ADDR = 1                                                                    |     | D7  |     | TICX  |
| Serial Clock Frequency                                | f <sub>SCL</sub>    |                                                                             | 0   |     | 400 | kHz   |
| Bus-Free Time Between<br>STOP and START<br>Conditions | t <sub>BUF</sub>    |                                                                             | 1.3 |     |     | μs    |
| Hold Time START and<br>Repeat START<br>Condition      | <sup>t</sup> HD,STA |                                                                             | 0.6 |     |     | μs    |
| SCL Pulse-Width Low                                   | t <sub>LOW</sub>    |                                                                             | 1.3 |     |     | μs    |
| SCL Pulse-Width High                                  | <sup>t</sup> HIGH   |                                                                             | 0.6 |     |     | μs    |
| Setup Time for a<br>Repeated START<br>Condition       | tsu,sta             |                                                                             | 0.6 |     |     | μs    |
| Data Hold Time                                        | t <sub>HD,DAT</sub> |                                                                             | 0   |     | 900 | ns    |
| Data Setup Time                                       | t <sub>SU,DAT</sub> |                                                                             | 100 |     |     | ns    |
| Setup Time for STOP<br>Condition                      | tsu,sto             |                                                                             | 0.6 |     |     | μs    |
| Pulse-Width of<br>Suppressed Spike                    | t <sub>SP</sub>     |                                                                             | 0   |     | 50  | ns    |

#### **Electrical Characteristics (continued)**

(V<sub>DD</sub> = 1.8V, V<sub>LED</sub> = 5.0V, MEASx\_PPGy\_ADC\_RGE = 16μA, FR\_CLK\_DIV = 32 (f<sub>FRAME</sub> = 1024fps), MEASx\_TINT = 14.6μs, MEASx\_LED\_SETLNG =  $6\mu$ s, MEASx\_LED\_RGE = 128mA,  $C_{PD}$  = 65pF,  $T_A$  =  $+25^{\circ}$ C, min/max are from  $T_A$  =  $-40^{\circ}$ C to  $+85^{\circ}$ C, unless otherwise noted.) (Note 1, 2, 3)

| PARAMETER                          | SYMBOL          | CONDITIONS | MIN                       | TYP | MAX | UNITS |
|------------------------------------|-----------------|------------|---------------------------|-----|-----|-------|
| Bus Capacitance                    | C <sub>B</sub>  |            |                           |     | 400 | pF    |
| SDA and SCL Receiving<br>Rise Time | t <sub>R</sub>  |            | 20 +<br>0.1C <sub>B</sub> |     | 300 | ns    |
| SDA and SCL Receiving Fall Time    | t <sub>F</sub>  |            | 20 +<br>0.1C <sub>B</sub> |     | 300 | ns    |
| SDA Transmitting Fall Time         | t <sub>TF</sub> |            | 20 +<br>0.1C <sub>B</sub> |     | 300 | ns    |

Note 1: All devices are 100% production tested at T<sub>A</sub> = +25°C. Specifications over temperature limits are guaranteed by Maxim Integrated's bench or proprietary automated test equipment (ATE) characterization.

Note 2: All other register settings are assumed to be POR defaults, unless otherwise noted.

Note 3: Definitions of terms:

- Frame = All measurements made during a particular wake-up interval.
- Sample = Ambient-light-corrected exposure measurement where both LED exposure and ambient-light ADC conversions

#### Register nomenclature:

- ADC\_RGE = Measurement of full-scale range as defined in the MEASx\_PPGy\_ADC\_RGE registers (x = 1 to 6, y = 1, 2). TINT = ADC integration time as defined in the MEASx\_TINT registers (x = 1 to 6).
- PDm BIAS = Photodiode bias setting register (m = 1 to 2).
- LED\_RGE = Measurement of full-scale range of the LED driver in the MEASx\_LED\_RGE register (x = 1 to 6). DRVy\_PA = Measurement of the LED driver DAC code in the MEASx\_DRVy\_PA register (x = 1 to 6, y = A, B, C). LED\_SETLNG = Measurement of the LED settling time in the MEASx\_LED\_SETLNG registers (x = 1 to 6).
- Note 4: For design guidance only. Not production tested.

#### Note 5: FR = PPG Frame Rate

- MEASx\_TINT = 14.6µs, MEASx\_LED\_RGE = 128mA, MEASx\_DRVy\_PA = 0x7F, PPG1\_PWRDN = 0, PPG2\_PWRDN =
- MEASx\_TINT = 14.6µs, MEASx\_LED\_RGE = 128mA, MEASx\_DRVy\_PA = 0x7F, PPG1\_PWRDN = 0, PPG2\_PWRDN =

Analog Devices | 12 www.analog.com

### **Typical Operating Characteristics**

(V<sub>DD</sub> = 1.8V, V<sub>LED</sub> = 5.0V, GND = PGND = 0V, T<sub>A</sub> = +25°C, COI2 filter disabled, unless otherwise noted.)



### **Typical Operating Characteristics (continued)**

(V<sub>DD</sub> = 1.8V, V<sub>LED</sub> = 5.0V, GND = PGND = 0V, T<sub>A</sub> = +25°C, COI2 filter disabled, unless otherwise noted.)



















### **Typical Operating Characteristics (continued)**

(V<sub>DD</sub> = 1.8V, V<sub>LED</sub> = 5.0V, GND = PGND = 0V, T<sub>A</sub> = +25°C, COI2 filter disabled, unless otherwise noted.)







### **Pin Configuration**

#### MAX86174A/MAX86174B



# **Pin Description**

| PIN          | NAME             | FUNCTION                                                                                                                                                                                                                                |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| POWER        |                  |                                                                                                                                                                                                                                         |
| A2           | V <sub>DD</sub>  | Power Supply. Connect to an externally regulated supply. Bypass with a 0.1µF capacitor as close as possible to the bump and a 10µF capacitor to GND.                                                                                    |
| A1           | GND              | Main Power Supply Return. Connect to PCB Ground. Refer to the <u>Layout Guidelines</u> section for more information.                                                                                                                    |
| В3           | V <sub>LED</sub> | LED Power Supply Input. In a configuration with more than one LED supply, connect V <sub>LED</sub> to the highest LED supply voltage. Bypass with a 10µF capacitor to PGND.                                                             |
| C3           | PGND             | LED Power Return. Connect to PCB Ground. Refer to the <u>Layout Guidelines</u> section for more information.                                                                                                                            |
| CONTROL INT  | ERFACE           |                                                                                                                                                                                                                                         |
| D4           | SCLK/SCL         | SPI Clock/I <sup>2</sup> C Clock                                                                                                                                                                                                        |
| C4           | SDO/ADDR         | SPI Data Output. In I <sup>2</sup> C mode, this pin selects the I <sup>2</sup> C device address.                                                                                                                                        |
| D3           | SDI/SDA          | SPI Data Input/I <sup>2</sup> C Data                                                                                                                                                                                                    |
| B4           | CSB/<br>I2C_SEL  | SPI Chip Select Input. The state of this pin sets the serial interface to typical levels. Low = SPI and High = $I^2C$ .                                                                                                                 |
| C2           | TRIG             | External Clock or Start of Conversion Trigger Input. Do not leave unconnected. Tie to GND or V <sub>DD</sub> when it is not used.                                                                                                       |
| B2           | INTB             | Interrupt Output. When INTB is not used, it can be left unconnected.                                                                                                                                                                    |
| OPTICAL PINS | 5                |                                                                                                                                                                                                                                         |
| A4           | PD1_IN           | Photodiode Cathode Input 1. Tie to GND when this pin is not used.                                                                                                                                                                       |
| A3           | PD2_IN           | Photodiode Cathode Input 2. Tie to GND when this pin is not used.                                                                                                                                                                       |
| C1           | LED1_DRV         | LED Output 1. Driven when MEASx_DRVy = 0 ( $x = 1$ to 6, $y = A$ , B). Connect the LED cathode to LED1_DRV and its anode to the V <sub>LED</sub> supply. This pin can be left unconnected when not used.                                |
| D1           | LED2_DRV         | LED Output 2. Driven when MEASx_DRVy = 1 ( $x = 1$ to 6, $y = A$ , B). Connect the LED cathode to LED2_DRV and its anode to the V <sub>LED</sub> supply. This pin can be left unconnected when not used.                                |
| D2           | LED3_DRV         | LED Output 3. Driven when MEASx_DRVy = 2 ( $x = 1$ to 6, $y = A$ , B). Connect the LED cathode to LED3_DRV and its anode to the V <sub>LED</sub> supply. This pin can be left unconnected when not used.                                |
| C2           | LED4_DRV         | LED Output 4. Driven when MEASx_DRVy = 3 (x = 1 to 6, y = A, B). Connect the LED cathode to LED4_DRV and its anode to the $V_{LED}$ supply. Do not leave unconnected when this pin is not used. When not used, tie to GND or $V_{DD}$ . |
| REFERENCE    |                  |                                                                                                                                                                                                                                         |
| B1           | VREF             | ADC Reference Buffer Output. Bypass to GND with a 1µF X5R ceramic capacitor.                                                                                                                                                            |

#### **Detailed Description**

The MAX86174A/MAX86174B are complete integrated optical data acquisition systems, ideal for various applications including optical pulse-oximetry and heart-rate detection applications. The devices are designed for the demanding requirements of wearable devices and require minimal external hardware components for integration into a wearable device.

The MAX86174A includes dual optical-readout channels operating simultaneously and the MAX86174B has a single optical-readout channel. Both devices incorporate robust ambient light cancellation and two high-current LED drivers to form a complete optical-readout signal chain. The two LED drivers support up to 4 LED drive output pins through two on-chip 4x1 multiplexers and control logic. Both devices support 2 PD input pins.

The MAX86174A/MAX86174B are fully adjustable through software registers and the digital output data is stored in a 256-word FIFO. The FIFO allows the MAX86174A/MAX86174B to be connected to a microcontroller or processor on a shared bus, I<sup>2</sup>C or SPI depending on the hardware selection on I2C\_SEL pin, on which the data is not being read continuously from the MAX86174A/MAX86174B registers. Both operate in fully autonomous mode for low-power battery applications.

The MAX86174A/MAX86174B operate on a 1.8V main supply voltage, with a separate 2.7V to 5.5V LED driver-supply voltage (supplied at  $V_{LED}$ ). Both devices have flexible exposure, timing and shutdown configurations as well as control of individual blocks to optimize measurements with minimum power consumption and a high level of accuracy. The MAX86174A/MAX86174B operate in a dynamic power-down mode, always powering down between frames; thus, minimizing power consumption. For more details on the power consumption at various frame rates, refer to the <u>Electrical Characteristics</u> table.

Keeping the ripple on the  $V_{LED}$  line as low as possible ensures the highest SNR is achieved. If a regulated supply is not available, the switching frequency on  $V_{LED}$  should be kept between 100kHz and 3MHz. By ensuring the switching frequency stays within the recommended range, along with a good load transient response, high SNR can be maintained at the heaviest loads (high LED drive-current applications).

The  $\underline{MAX20345}$  or the smaller  $\underline{MAX20343}$  are recommended solutions for a buck-boost supplying V<sub>LED</sub>. Both offer highly efficient buck-boost regulators with a very small load ripple, fast load transient responses, and have load pulse consistencies that provide more than 93dB SNR in a white card DC SNR test.

The various blocks and features in the PPG system are discussed in detail in the following sections.

#### **Optical Transmitter Overview**

The MAX86174A/MAX86174B have two independent precision LED current drivers that are connected to four LED-driver pins through two 4x1 muxes. Two LED current DACs modulate LED pulses for a variety of optical measurements. The two LED current DACs have 8-bit dynamic range with four programmable full-scale range settings of 32mA, 64mA, 96mA, and 128mA (typ). The configuration of the LED drivers can be uniquely set for each measurement. The PPG MEASx Setup (x = 1 to 6) register blocks (0x20 to 0x4E) define how each LED driver is connected for that particular measurement. Each measurement can drive one or both LED drivers.

Table 1. LED Driver and LED Mux Configuration

| MEASx_DRVy<br>(x = 1 to 6, y = A, B) | LEDn_DRV PIN CONNECTED TO LED DRIVER (n = 1 to 4) |
|--------------------------------------|---------------------------------------------------|
| 0x0                                  | LED1_DRV                                          |
| 0x1                                  | LED2_DRV                                          |
| 0x2                                  | LED3_DRV                                          |
| 0x3                                  | LED4_DRV                                          |

This configuration of LED drivers and LED muxes is highly flexible, not only allowing any of the four LED driver pins to be used at any one time, but also allowing for any pin to sink up to 256mA by combining both drivers to generate a higher output current. In this compact design, LED4\_DRV shares the same pin package with the TRIG input. If LED4\_DRV is in use, TRIGLED4\_SEL[0](0x17) is configured to be 1. Figure 1 shows how the two LED drivers are connected to the four LED-driver pins.

Both LED drivers are low dropout-current sources allowing for low-noise, power-supply independent LED currents to be sourced with minimal voltage overhead; thereby, minimizing LED power consumption. Four full-scale range settings are provided to allow for the optimization of LED driver noise, and dropout voltage on the LEDn\_DRV (n = 1 to 4) pins. <u>Table</u> 2 illustrates this trade-off.

| Table 2. L | <b>.ED</b> Driver | <b>Full-Scale</b> | Range | <b>Trade-Off</b> |
|------------|-------------------|-------------------|-------|------------------|
|------------|-------------------|-------------------|-------|------------------|

| FULL-SCALE RANGE (mA) | RECOMMENDED MINIMUM VLEDn_DRV (mV) | PEAK REFLECTOR CARD SNR (dB)<br>WITH COI2 FILTER ENABLED |
|-----------------------|------------------------------------|----------------------------------------------------------|
| 32                    | 300                                | 87                                                       |
| 64                    | 500                                | 91                                                       |
| 96                    | 700                                | 92                                                       |
| 128                   | 900                                | 93                                                       |

The LED on-time is the sum of the receiver integration time selected in MEASx\_TINT, and the LED settling time selected in MEASx\_LED\_SETLNG. The duty cycle is set by the ratio of the LED on-time and the frame period. The average LED supply current is calculated as the product of the programmed LED current and the duty cycle.

Note:  $MEASx\_TINT[4:3]$  (x = 1-6) is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49 and  $MEASx\_LED\_SETLNG[4:3]$  (x = 1-6) is in registers 0x23, 0x2B, 0x33, 0x3B, 0x43, 0x4B.

The voltage on  $V_{LED}$  depends on the forward voltage ( $V_F$ ) of the LEDs driven by the MAX86174A/MAX86174B. The AFE requires a minimum of 2.7V applied to the  $V_{LED}$  pin (see the <u>Electrical Characteristics</u> table). Additionally, the minimum required  $V_{LED}$  voltage in a system is determined by the sum of forward voltage ( $V_F$ ) of each LED at maximum LED current and the minimum  $V_{LEDn\_DRV}$  voltage in <u>Table 2</u>. Also note that <u>Table 2</u> is based on the Maxim internal test board and it is recommended to test and verify the SNR with the best  $V_{LEDn\_DRV}$  on the different PCBs.

The  $V_{LED}$  voltage must be above this minimum to avoid compression, and allow for enough headroom to supply the LED drive current as needed; otherwise, the  $I_{LED}$  can be reduced and more sensitive to  $V_{LED}$  supply changes. The voltage on the LEDn\_DRV pins can be measured during an exposure to ensure the minimum headroom voltage is maintained during each LED exposure (LED on time). The minimum  $V_{LED}$  can be simply calculated by using the formulas below:

V<sub>LED</sub> ≥ 2.7V and V<sub>LED</sub> ≥ V<sub>F</sub> + V<sub>LEDn DRV</sub>

where, V<sub>F</sub> is a function of maximum LED current for the system.



Figure 1. LED Drivers

#### **Optical Receiver Overview**

The optical path in MAX86174A/MAX86174B is composed of a front-end photodiode biasing circuit with an analog ambient-light cancellation (ALC) sample and hold circuit that nulls the ambient-light photodiode current at the input of the ADC. This front-end photodiode biasing circuit is followed by a current integrating, continuous-time sigma-delta ADC with a proprietary discrete time filter. This discrete time filter uses multiple dark and exposure samples to generate an accurate 20-bit effective exposure output signal with excellent low- and high-frequency ambient-light rejection.

The MAX86174A incorporates dual optical-signal paths and the MAX86174B incorporates a single optical-signal path. Both have four photodiode input pins which are configured by MEASx\_PDSEL (x = 1 to 6) in each measurement. The on-chip Mux connects the two photodiode inputs to the optical signal path, as shown in Figure 2.

Note:  $MEASx_PDSEL[7:6]$  (x = 1-6) is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.

For scenarios with MAX86174A requiring only one optical-signal path to be active (for example, lower power consumption), either one of the two channels can be powered down by setting PPG1\_PWRDN[2](0x11) or PPG2\_PWRDN[3](0x11) to 1. In this way, the MAX86174A is used in a single-channel configuration. By default, the MAX86174A PPG has dual channels enabled.

Each optical signal path supports four full-scale range settings of  $4\mu$ A,  $8\mu$ A,  $16\mu$ A, and  $32\mu$ A set in the MEASx\_PPGy\_ADC\_RGE (x = 1 to 6, y = 1, 2 for MAX86174A, y = 1 for MAX86174B) field in each of the measurement configurations block. Also supported are four options for integration time, which effectively modulate the optical channel bandwidth, allowing for a trade-off between LED power consumption and PPG signal quality.

Note: MEASx\_PPG1\_ADC\_RGE[1:0] (x = 1–6) and MEASx\_PPG2\_ADC\_RGE[3:2] (x = 1–6) are in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A.

Each optical signal path also incorporates a 3-bit offset DAC for extending the optical dynamic range by sourcing some of the exposure current to the offset DAC. The current offset is selected in the MEASx\_PPGy\_DACOFF register bit field. This feature is especially useful under certain conditions that occur when attempting to limit the exposure ADC counts, for example, when avoiding saturation while increasing the exposure signal perfusion index.

Note:  $MEASx_PPG1_DACOFF[2:0]$  (x = 1-6) and  $MEASx_PPG2_DACOFF[6:4]$  (x = 1-6) are in registers 0x24, 0x2C, 0x34, 0x3C, 0x44, 0x4C.

Also, higher SNR is achieved by enabling the DAC offset in addition to utilizing the burst averaging and off-chip low-pass or band-pass filtering, allowing for 111dB SNR to be achieved. The optical channels also support multiple photodiode and LED settling time settings in order to support flexible multiparameter measurements for different types of photodiode/LED wavelength combinations.



Figure 2. On-Chip Mux for the PD1\_IN and PD2\_IN pins

Most significantly, each signal path supports up to six unique combinations of the above configurations as needed. This

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

allows a single optical AFE to support multiple optical measurements in a compact, energy-efficient design.

#### **Photodiode Biasing**

The MAX86174A/MAX86174B provide three photodiode biasing options to support a large range of photodiode capacitance. Each photodiode input can have a separate bias setting; thereby, allowing for different photodiodes to be used. The PDm\_BIAS (m = 1, 2, register 0x15) settings adjust the PDm\_IN bias point impedance to ensure that each photodiode settles rapidly enough to support the sample timing.

The PDm\_BIAS impacts the dark current noise of the MAX86174A/MAX86174B. Because of the increased noise with a higher PDm\_BIAS setting, the lowest recommended PDm\_BIAS value should be used for any given photodiode capacitance.

#### **Measurement Configuration and Timing**

A measurement is essentially one combination of LED (or LEDs) and PD (or PDs) that results in an optical measurement. The MAX86174A/MAX86174B support six individual measurements, each of which can be configured independently. Each measurement can be configured by the group of registers named PPG MEASx Setup (x = 1 to 6). These registers set up a number of parameters as listed below.

- Connection of each of the two LED drivers to one of the four LED driver pins
- Connection of ADC channel(s) to one of two possible photodiodes
- Ambient measurement
- LED driver range and drive currents
- LED settling time
- PD settling time
- Number of burst averages of each measurement
- Ambient rejection scheme (CDM or FDM)
- On-chip decimation filter selection (COI or SINC3)
- ADC integration time
- ADC range for each channel
- · DAC offset for each channel

A measurement can be configured to pulse one or two LED drivers sequentially at multiple wavelengths as is done in pulse oximetry measurements or simultaneously to drive multiple LEDs such as is done with heart-rate measurements on the wrist. A measurement is also configurable to measure direct ambient level. If direct ambient is enabled in a measurement through MEASx AMB, it must be the last measurement in the sequence of enabled measurements.

Note: MEASx AMB[6] (x = 1-6) is in registers 0x20, 0x28, 0x30, 0x38, 0x40, 0x48.

Figure 3 represents one measurement with only one of the LEDs active. No averaging is used. As seen in Figure 3 only LED1\_DRV is pulsing during the exposure time. In this mode, each driver pulse results in a single optical sampled value for each PD input to be stored in the FIFO. For example, in a single-channel configuration, only one sample is stored in the FIFO for each driver pulse but for a dual-channel configuration, two samples are stored in the FIFO for each driver pulse.

This timing mode in Figure 3 is used when heart rate is being measured with a single LED.



Figure 3. Measurement with One LED On

#### **Ambient-Light Cancellation**

The MAX86174A/MAX86174B implement ambient-light cancellation (ALC) in two steps, a coarse cancellation and a fine cancellation. Each PPG channel has its own dedicated ambient-light cancellation circuits. Also, each MEASx has its own ambient-light cancellation configuration. The coarse cancellation is in the analog domain. It is enabled by default and can be disabled by setting the ALC\_DISABLE[4](0x13) to 1. The fine cancellation is a digital cancellation scheme and is configured with either a central difference method (CDM) or forward difference method (FDM) through the MEASx\_FILT\_SEL (x = 1 to 6) bit.

Note: MEASx FILT SEL[6] (x = 1-6) is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A.

ALC coarse cancellation can cancel up to 200µA of DC photodiode current. Any drift or residual from coarse cancellation is canceled by CDM/FDM cancellation.

One CDM sample is comprised of 3 ADC conversions, with 2 ambient and 1 exposure conversion where ambient-light estimation is made from dark measurements before and after the exposure measurement. One FDM sample is comprised of 2 ADC conversions with 1 ambient only and 1 exposure conversion where the ambient light is estimated by a dark measurement before the exposure measurement. The ambient and exposure samples are used for digital cancellation of any residual error (from ALC) or drift (in ambient signal). The final computed value is the effective exposure signal that is stored in the FIFO.

See Figure 4 for the timing diagram of CDM and Figure 5 for the timing diagram of FDM.

Ambient-light cancellation in low frequency ambient light improves when using burst average by setting MEASx\_AVER ≥ 0x2. In addition, the MAX86174A/MAX86174B have a SINC3 decimation filter for the delta-sigma PPG ADC, which is enabled for each measurement individually by setting MEASx\_SINC3\_SEL. This filter provides improved high-frequency roll-off that improves the high-frequency ambient-light rejection. MAX86174A/MAX86174B by default uses a third order COI3 decimation filter that provides excellent quantization, but the roll-off at high frequencies is only 20dB/dec. The SINC3 filter provides a 60dB/dec roll-off for out-of-band frequencies; thus, improving ambient-light rejection at high frequencies. This filter is only available for MEASx\_TINT = 0x3 (117.1µs). See Figure 11 for different decimation filters.

Note:  $MEASx\_AVER[2:0]$  (x = 1-6) and  $MEASx\_TINT[4:3]$  (x = 1-6) are in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.  $MEASx\_SINC3\_SEL[7]$  (x = 1-6) is in registers 0x22, 0x2A, 0x3A, 0x4A.



Figure 4. Central Difference Method (CDM)



Figure 5. Forward Difference Method (FDM)

#### Frame and Frame Rate

A frame is a combination of one (min) to six (max) measurements configured in MEASx\_EN (x = 1 to 6) (register 0x12). The frame rate defines how frequently a frame is repeated and is expressed in units of frames per second (fps). Frame rate is defined by two methods:

- Frame Rate = 32768/FR\_CLK\_DIV, where FR\_CLK\_DIV = 16 to 32766 are directly programmable (see <u>Register</u> 0x1B and 0x1C) or
- Frame Rate = Active edge of the TRIG input with SYNC MODE[5:4](0x11) = 1.

Any combination of measurements can be enabled, but measurements are done in a numerical order inside a frame. For example, it is valid to enable MEAS1, MEAS2, and MEAS5 while MEAS3 and MEAS4 are skipped. But if a measurement of direct ambient is configured, then this measurement must be configured as the last measurement in the frame.

Figure 6 represents the timing diagram for one measurement with CDM enabled in each frame.

<u>Figure 7</u> illustrates timing for six measurements in each frame. Each measurement can be configured independently using the PPG MEASx Setup register blocks (0x20 to 0x4E). Alternatively, all measurements share the same configuration of MEAS1 by setting MEAS1\_CONFIG\_SEL[0](0x13) to 1.

<u>Figure 8</u> illustrates timing for six measurements in each frame with MEAS3 configured to have a burst average of 2. The result of MEAS3 in each frame only has one FIFO data pushed into FIFO per ADC channel. This FIFO data is the average of the two PD samples labeled as F1M3.



Figure 6. Frame with One Measurement



Figure 7. Frame with Six Measurements



Figure 8. Frame with Measurement Burst Averaging

#### **On-Chip Averaging**

The MAX86174A/MAX86174B incorprote both burst average and decimation average on chip. Burst average applies to one measurement where a given number of LED bursts are fired. Decimation average is frame-based where a given number of measurements from successive frames are averaged, resulting in a lower FIFO data rate.

#### **Burst Average**

Burst average defines the number of LED exposures in one measurement and it is configured by the MEASx\_AVER (x = 1 to 6) bit. Burst average works only with CDM, MEASx\_FILT\_SEL = 0. In each measurement, (2(MEASx\_AVER +1) + 1) ADC conversions of interleaved dark and exposure samples are made and the weighted computed average is fed to the digital low-pass filter. The example in Figure 9 has burst average of 2, MEASx\_AVER = 0x1; hence, there are 5 conversions. When ambient-light cancellation is configured as FDM in a given measurement (MEASx\_FILT\_SEL = 1), only one dark ADC conversion and one exposure ADC conversion are done, regardless of the value of MEASx\_AVER.

Note:  $MEASx\_AVER[2:0]$  (x = 1-6) is in register 0x21, 0x29, 0x31, 0x39, 0x41, 0x49 and  $MEASx\_FILT\_SEL[6]$  (x = 1-6) is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A.

Burst averaging improves the exposure SNR. SNR benefits of the higher burst average ratio are shown in the <u>Typical Operating Characteristics</u> section. Besides, burst averaging can be used to improve ambient-light cancellation at the same LED power consumption level. For example, one application requires signal quality at MEASx\_TINT = 117.1µs and burst average = 1x. Without increasing the LED illumination time, applying MEASx\_TINT = 29.2µs but burst average = 4x can keep the exposure SNR the same and have better ambient cancellation at MEASx\_TINT = 29.2µs.

Note:  $MEASx_TINT[4:3]$  (x = 1-6) is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.



Figure 9. Illustration of Measurement with Burst Averaging

#### **Decimation Average**

Decimation averaging operates on multi-frames, which does not impact the LED exposure sequence nor front-end signal acquisition. It reduces the FIFO data rate. <u>Figure 10</u> shows an example of a decimation average of 2.

Decimation averaging is integrated to reduce the data rate to FIFO in the digital low pass filter. See the <u>On-Chip Filtering</u> section for details.



Figure 10. Frames with Decimation Average of 2

#### **On-Chip Filtering**

The MAX86174A/MAX86174B have two stages of on-chip filtering, decimation filtering at the ADC stage and digital low-pass filtering after the ADC stage.

#### **ADC Decimation Filter**

Users can select a second-order decimation filter (COI2), a third-order decimation filter (COI3), or SINC3 decimation filter. MAX86174A/MAX86174B by default use a third-order cascade of integrators (COI3) decimation filter. This filter provides excellent quantization, but only a 20dB/dec roll-off at higher frequencies. COI2 has a narrower bandwidth as compared to the COI3, which improves the PPG SNR by about 1dB to 2dB. The SINC3 filter has a better rollover (60dB/dec), and therefore, provides higher AC ambient-light cancellation at high frequencies and  $V_{LED}$  power-supply rejection. The SINC3 filter generates poor quantization performance and is, thus, only available on the longest integration time, MEASx\_TINT = 0x3 (117.1 $\mu$ s). SINC3 is selected for each measurement individually by setting MEASx\_SINC3\_SEL to 1. To set the decimation filter to COI2 for all measurements, PPG\_FILT2\_SEL[7](0x14) is set to 1. Both SINC3 and COI2 can only be used with the longest integration time (MEASx\_TINT = 0x3).

Note: MEASx\_TINT[4:3] (x = 1-6) is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49 and MEASx\_SINC3\_SEL[7] (x = 1-6) is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A.

<u>Table 3</u> shows the configuration for different ADC decimation filters. Combinations of the 3 parameters out of this table are not suggested.

Table 3. Configuration for ADC Decimation Filter

| MEASx_SINC3_SEL | PPG_FILT2_SEL | MEASx_TINT | DECIMATION FILTER |
|-----------------|---------------|------------|-------------------|
| 0               | 0             | All TINTs  | COI3 (Default)    |
| 0               | 1             | TINT = 0x3 | COI2              |
| 1               | 0 or 1        | TINT = 0x3 | SINC3             |

See Figure 11 for the transfer function of different decimation filters.



Figure 11. Signal Transfer Function of Decimation Filters

#### **Digital Low-Pass Filter**

The digital low-pass filter processes data before it gets saved in the FIFO. Users can either select an on-chip IIR filter or decimation averaging for low-pass filtering. The digital low-pass filter improves the SNR significantly. To enable digital low-pass filter, for all enabled measurements, DLPF\_EN[5:4](0x14) is configured as needed. IIR filter configuration is programmed in IIR\_CFG[3](0x14) and decimation averaging is set in DEC\_AVE[2:0](0x14). The IIR cutoff frequency depends on the IIR\_CFG bit. The decimation averaging option reduces the FIFO data rate by a factor of  $2^{\text{DEC}}_{\text{AVE}}$ .

FIFO data rate = Frame rate x Number of enabled measurements x Number of enabled channels / 2DEC\_AVE.

#### **AFE Exposure Control and SNR**

MAX86174A/MAX86174B provide the options above to support extensive application scenarios that require different signal bandwidth and signal-to-noise (SNR) ratio. The  $\underline{\text{Table 4}}$  shows the SNR benefits when applying different parameters.

**Table 4. Typical SNR Benefit Of Various Parameters** 

| TINT (μs)  | BURST<br>AVERAGE | DAC<br>OFFSET | COI2<br>FILTER | DIGITAL<br>LPF | PEAK SNR<br>(dB) | DIFFERENCE<br>(dB) | BW<br>(Hz) |
|------------|------------------|---------------|----------------|----------------|------------------|--------------------|------------|
| 14.6/117.1 | 1                | 0             | OFF            | OFF            | 83.9/91.6        | +7.7               | 50         |
| 117.1      | 1/16             | 0             | OFF            | OFF            | 91.6/98.9        | +7.3               | 50         |
| 117.1      | 1                | 0/28          | OFF            | OFF            | 91.6/94.1        | +2.5               | 50         |
| 117.1      | 1                | 0             | OFF/ON         | OFF            | 91.6/92.7        | +1.1               | 50         |

| Table 4. 1 | ypical | <b>SNR</b> | <b>Benefit</b> | Of | <b>Various</b> | <b>Parameters</b> | (continued) | ) |
|------------|--------|------------|----------------|----|----------------|-------------------|-------------|---|
|------------|--------|------------|----------------|----|----------------|-------------------|-------------|---|

| TINT (µs) | BURST<br>AVERAGE | DAC<br>OFFSET | COI2<br>FILTER | DIGITAL<br>LPF | PEAK SNR<br>(dB) | DIFFERENCE<br>(dB) | BW<br>(Hz) |
|-----------|------------------|---------------|----------------|----------------|------------------|--------------------|------------|
| 117.1     | 1                | 0             | OFF            | OFF/ON         | 91.6/95.6        | +4                 | 11.5       |
| 117.1     | 1/16             | 0             | ON             | ON             | 96.5/101.6       | +5.1               | 11.5       |
| 117.1     | 16               | 0/24          | ON             | ON             | 101.6/106.6      | +5                 | 11.5       |
| 117.1     | 16               | 24            | ON             | ON             | 106.6/111.8*     | +5.2               | 0.5-4      |

<sup>\*</sup> shows performance without/with an external band-pass filter (0.5-4Hz).

#### **Threshold Detect Function**

The MAX86174A/MAX86174B include a threshold detect function that enables users to detect ADC counts higher than a specified range or lower than a specified range.

The threshold detect function is used in proximity mode to reduce energy consumption and extend battery life when the sensor is not in contact with skin. There are two separate instances of the threshold detect function available in MAX86174A/MAX86174B, THRESHOLD1 and THRESHOLD2. Both are disabled by default.

The threshold detect function is enabled by selecting a measurement in THRESHx\_MEAS\_SEL(x = 1, 2) in register 0x50. For the dual channel MAX86174A, the threshold detect function is set up for either PPG1 or PPG2 by configuring THRESHx\_PPG\_SEL in register 0x51. In order to configure the threshold detect function, both an upper limit and a lower limit must be set. These can be configured in the PPG Threshold Interrupts registers (0x50 to 0x55).

In addition, two features are available to make the threshold detect function more adaptable for various system and application requirements. These are Time Hysteresis and Level Hysteresis, which are configurable through the TIME\_HYST[4:3](0x51) and LEVEL\_HYST[2:0] (0x51). Time hysteresis sets the number of consecutive samples that must be outside the limits defined by THRESHOLDx\_UPPER and THRESHOLDx\_LOWER in order to assert the threshold interrupt. Level hysteresis defines the sample variation around THRESHOLDx\_UPPER and THRESHOLDx\_LOWER. This value is in ADC counts and is applied at  $\pm 0.5$  x LEVEL\_HYST around THREHSOLDx\_UPPER as well as  $\pm 0.5$  x LEVEL\_HYST around THRESHOLDx\_LOWER. Specifically, in order for a threshold interrupt to be asserted, a sample must either transition above the THRESHOLDx\_UPPER + 0.5 x LEVEL\_HYST and stay above THRESHOLDx\_UPPER - 0.5 x LEVEL\_HYST for the number of samples defined in TIME\_HYST or transition below THRESHOLDx\_LOWER - 0.5 x LEVEL\_HYST and stay below THRESHOLDx\_LOWER + 0.5 x LEVEL\_HYST for the number of samples defined in TIME HYST as shown in Figure 12.

Note: THRESHOLD1\_UPPER[7:0] is register 0x52, THRESHOLD2\_UPPER is register 0x54, THRESHOLD1\_LOWER is register 0x53, and THRESHOLD2\_LOWER is register 0x55.

If a threshold detect function instance is enabled, the corresponding THRESHx\_HILO interrupt bit (register 0x00) is asserted and threshold mode is activated when the ADC counts of the assigned measurement on the specified PPG channel drop below the lower limit, or exceed the upper limit (in consideration with LEVEL\_HYST and TIME\_HYST settings). The upper threshold check is disabled by setting THRESHx\_UPPER (0x52, 0x54) to 0xFF. The PPG ADC reading, if negative, is clipped to 0x00000 before comparing with the threshold limits. Therefore, programming THRESHOLDx LOWER to 0x00 effectively disables the lower threshold check.

Threshold detect function enables low power consumption while in automatic proximity detect mode. See the <u>Automatic Proximity Detect Mode</u> section for details. Alternatively, the LED configuration during the threshold detect active mode is determined by the firmware settings as needed for each application. Lower settings of LED current, ADC integration time, and frame rate result in reducing power consumption during situations when there is no reflective returned signal.



Figure 12. Threshold limits with LEVEL\_HYST

#### **Automatic Proximity Detect Mode**

The MAX86174A/MAX86174B include a proximity detect function that switches the device automatically between proximity detect mode (PROX mode) and normal mode. Using the threshold detect function (see the <u>Threshold Detect Function</u> section), the proximity mode significantly reduces energy consumption; thereby, extending battery life when the device is in PROX mode.

When PROX\_AUTO[2](0x13) is set to 1, PROX mode is enabled. In this mode, PPG measurement 6 (MEAS6) is reserved for proximity function and is automatically enabled even when MEAS6\_EN[5](0x12) is programmed to 0. THRESHOLD1 is used for proximity detect, but THRESH1\_MEAS\_SEL[2:0](0x50) is ignored. Instead measurement 6 is considered for this threshold instance.

The device enters PROX mode when the measurement 6 ADC reading is is below the threshold determined by the THRESHOLD1\_LOWER[7:0](0x53) register; otherwise, it is in normal mode. THRESHOLD1\_UPPER[7:0](0x52) is not used. The device switches between PROX mode and normal mode automatically. While in PROX mode, the frame rate automatically changes to 8fps, and only measurement 6 is selected for ADC conversions. While in normal mode, measurement 6 and all the enabled measurements 1 to 5 are selected for ADC conversions, and the frame rate is as programmed in the FR\_CLK\_DIV[14:0](0x1B, 0x1C). In order to reduce power consumption while in PROX mode, MEAS6 LED drive current should be as low as possible. The LED current for MEAS6 is configured through MEAS6\_DRVA\_PA[7:0](0x4D) and MEAS6\_DRVB\_PA[7:0](0x4E).

If THRESH1\_HILO interrupt is enabled using THRESH1\_HILO\_EN1[1](0x58), an interrupt is asserted on the INTB pin when the part switches from normal mode to PROX mode, and also for each ADC conversion while the part is in PROX mode. There is no interrupt when the part switches from PROX mode to normal mode.

In order to get an interrupt when switching from PROX mode to normal mode, a second threshold instance is enabled using the THRESH2\_HILO\_EN[2](0x58) interrupt enable bit. THRESHOLD2\_UPPER[7:0](0x54) should be programmed to be equal to THRESHOLD1\_LOWER, and THRESHOLD2\_LOWER[7:0](0x55) should be zero. THRESH2\_MEAS\_SEL[6:4](0x50) should be programmed to select MEAS6. THRESH2\_PPG\_SEL[7](0x51) should be programmed the same as THRESH1\_PPG\_SEL[6](0x51). When configured this way, THRESHOLD2 generates an interrupt when switching from PROX mode to normal mode and does not generate an interrupt when the part switches from normal mode to PROX mode.

If it is desired to reduce the number of interrupts, the THRESH1\_HILO interrupt should be enabled when the part is in normal mode, and THRESH2\_HILO should be enabled when the part is in PROX mode. If interrupts are not needed for detecting switching between PROX and normal modes, Threshold 2 Interrupt registers do not need to be programmed.

False detection of PROX mode and normal mode can be avoided by enabling time hysteresis and level hysteresis through TIME\_HYST[4:3](0x51) and LEVEL\_HYST[2:0](0x51) in register 0x51 as needed. See the <u>Threshold Detect Function</u> section for more details on threshold interrupts.

#### **Synchronization Modes**

The MAX86174A/MAX86174B support three modes of frame-rate control. These modes can be selected through SYNC MODE[5:4](0x11).

The three modes are an internally timed frame rate through an internal oscillator and divider, an externally timed frame rate through an external frame trigger input, and an externally timed frame rate through an external frame timing clock and the internal frame clock divider.

The three synchronization modes are explained in the following sections.

### **Table 5. Clock Sources in Each Synchronization Mode**

| SYNC_MODE | PPG ADC CLK                      | PPG FRAME RATE                       | PPG MEASUREMENT TIMING   |
|-----------|----------------------------------|--------------------------------------|--------------------------|
| 0x0       | Internal fast oscillator (10MHz) | Internal slow oscillator (32.768KHz) | Internal slow oscillator |
| 0x1       | Internal fast oscillator         | External pulse on TRIG               | Internal slow oscillator |
| 0x2, 0x3  | Internal fast oscillator         | External pulse on TRIG               | External pulse on TRIG   |

#### **Internal Frame Oscillator and Divider Mode**

SYNC\_MODE = 0x0 or 0x3 is the free running mode of operation. In this mode, the MAX86174A/MAX86174B use the internal 32.768kHz oscillator, and the internal user programmable divider, FR\_CLK\_DIV[14:0](0x1B, 0x1C) to set the time between subsequent frames or the frame rate. ADC Sync signals are generated internally using the 10MHz ADC clock.

In this mode, TRIGLED4 SEL[0](0x17) must be set to 1 and TRIG ICFG[0](0x16) is also ignored.

#### **External Frame Trigger Input Mode**

SYNC\_MODE = 0x1 enables the TRIG input pin to be a start for a frame sync signal. A frame cycle begins upon receipt of an active edge on the TRIG input. This frame includes powering up and then executing each enabled measurement from MEAS1 to MEAS6. ADC Sync signals are generated internally using the 10MHz ADC clock. The internal 32.768KHz frame clock is disabled.

#### **External Frame Clock Input Mode**

SYNC\_MODE = 0x2 enables the TRIG input to be an external frame clock input. This input clock effectively replaces the MAX86174A/MAX86174B internal 32.768kHz oscillator. The MAX86174A/MAX86174B use the FR\_CLK\_DIV register value to divide this external clock input 32.0kHz/32.768kHz to generate the effective frame rate. ADC clock signals are generated internally using the 10MHz clock. However, in this case the stability of the frame rate is driven entirely by the external frame clock input.

Start of sampling process can be controlled by an SPI software Sync command, which zeros out the frame rate divider and restarts the frame counting process. The device then advances with the external TRIG input clock. Subsequent software sync commands abort the current frame and restart a new frame.

This mode is useful when the microcontroller can output the crystal based RTC clock on a GPIO pin; thereby, enabling the user to synchronize multiple sensors through the same oscillator.

#### **FIFO Description**

The FIFO holds a maximum of 256 samples and supports various data types. Each sample in the FIFO is 3 bytes wide and includes a tag and data. FIFO\_DATA[23:20] contain the tag that identifies the source of each sample data. Data in FIFO\_DATA[23:0] is right justified for all data types. FIFO\_DATA[19:0] contain the data in two's complement form. The MSB of the PPG data FIFO\_DATA[19:0] is the sign bit. Table 6 shows each data type in the FIFO along with the associated tag for MAX86174A/MAX86174B.

The sequencing of exposures is controlled by MEAS1\_EN through MEAS6\_EN bits in the System Configuration 2 register. The ADC conversion sequence cycles through the enabled measurements starting from MEAS1.

When COLLECT\_RAW\_DATA[1](0x13) is set to 0, the computed data is saved as a single MEASx sample in the FIFO. When COLLECT\_RAW\_DATA is set to 1, the exposure sample and the dark (ambient) sample(s) are saved as separate samples in the FIFO (see the <u>Ambient Rejection</u> section). The raw exposure sample is tagged with its corresponding

MEASx (x = 1 to 6) and PPGy (y = 1, 2 for MAX86174A and y = 1 for MAX86174B) tag, but all dark samples are tagged with the same DARK tag which is common to all measurements.

#### Table 6. FIFO Tags

| TAG[3:0] | DATA TYPE      | DATA[19:0]                                                                                 |
|----------|----------------|--------------------------------------------------------------------------------------------|
| 0x0      | MEAS 1 PPG1    | Measurement 1 ADC1 data                                                                    |
| 0x1      | MEAS 2 PPG1    | Measurement 2 ADC1 data                                                                    |
| 0x2      | MEAS 3 PPG1    | Measurement 3 ADC1 data                                                                    |
| 0x3      | MEAS 4 PPG1    | Measurement 4 ADC1 data                                                                    |
| 0x4      | MEAS 5 PPG1    | Measurement 5 ADC1 data                                                                    |
| 0x5      | MEAS 6 PPG1    | Measurement 6 ADC1 data                                                                    |
| 0x6      | MEAS 1 PPG2    | Measurement 1 ADC2 data (MAX86174A only)                                                   |
| 0x7      | MEAS 2 PPG2    | Measurement 2 ADC2 data (MAX86174A only)                                                   |
| 0x8      | MEAS 3 PPG2    | Measurement 3 ADC2 data (MAX86174A only)                                                   |
| 0x9      | MEAS 4 PPG2    | Measurement 4 ADC2 data (MAX86174A only)                                                   |
| 0xA      | MEAS 5 PPG2    | Measurement 5 ADC2 data (MAX86174A only)                                                   |
| 0xB      | MEAS 6 PPG2    | Measurement 6 ADC2 data (MAX86174A only)                                                   |
| 0xC      | PPG1/2 DARK    | Dark data when COLLECT_RAW_DATA = 1                                                        |
| 0xD      | PPG1/2 ALC OVF | ALC overflow detected. Location of data indicates the measurement and the photodiode.      |
| 0xE      | PPG1/2 EXP OVF | Exposure overflow detected. Location of data indicates the measurement and the photodiode. |
|          | Marker         | 1111111111111111110 (0xFFFFE)                                                              |
|          | Invalid data   | 111111111111111111 (0xFFFFF)                                                               |

When both ALC overflow and exposure overflow are detected on the same measurement, the sample is tagged with the ALC OVF tag. An attempt to read an empty FIFO returns the INVALID DATA tag.

MAX86174A/MAX86174B provide a feature of saving a FIFO marker when needed in an application. For example, in order to distinguish data saved in FIFO before and after a configuration change, a marker can be saved in the FIFO just before the configuration change. The marker tag is 24 bits and it is 0xFFFFFE.

Setting FIFO\_MARK[5](0x09) to 1 saves the marker tag in the FIFO.

For details on FIFO configuration, see the <u>Register Map</u> (register 0x03 to 0x09).

FIFO configuration is best explained by a few examples.

Example 1: Single channel optical measurement using MAX86174B.

Assume it is desired to perform an  $SpO_2$  measurement and also monitor the ambient level on the photodiode to adjust the IR and red LED intensity using a single optical channel with photodiodes 1 and 2 selected for PPG1. To perform this measurement, configure the following registers.

```
//System Configuration
      MEAS1 EN = 0b1
                              //enable measurement 1, 2, and 3
      MEAS2 EN = 0b1
      MEAS3 EN = 0b1
//Measurement 1 Setup
      MEAS1 AMB = 0b0
                               //Ambient measurement off
                                //LED Driver A driving IR LED on LED1 DRV
      MEAS1 DRVA = 0b00
      MEAS1 AVER as desired
                                 //Number of LED pulses in each frame
      MEAS1_PPG_TINT as desired //ADC integration time control
                                 //Photodiode 1 and 2 selected on PPG channel 1
      MEAS1 PDSEL = 0b00
      MEAS1 PPG1 ADC RGE as desired//ADC range control for PPG1 ADC
```

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFF for Wearable Health

```
MEAS1 LED SETLNG as desired //LED settling time
            MEAS1 PD SETLNG as desired //Settling time for photodiode
                                         //LED driver A current driving the IR LED on LED1 DRV
            MEAS1 DRVA PA as desired
            MEAS1 DRVB PA = 0x00
                                         //LED driver B current should be set to 0
      //Measurement 2 Setup
            MEAS2_AMB = 0b0
                                      //Ambient measurement off
            MEAS2 DRVB= 0b01
                                       //LED Driver B driving red LED on LED2 DRV
                                        //Number of LED pulses in each frame
            MEAS2_AVER as desired
            MEAS2_PPG_TINT as desired //ADC integration time control
            MEAS2 PDSEL = 0b00
                                        //Photodiode 1 and 2 selected on PPG channel 1
            MEAS2 PPG1 ADC RGE as desired//ADC range control for PPG1 ADC
            MEAS2 LED SETLNG as desired //LED settling time
            MEAS2 PD SETLNG as desired //Settling time for photodiode
                                         //LED driver A current should be set to 0
            MEAS2 DRVA PA = 0x00
            MEAS2 DRVB PA as desired //LED driver B current driving the red LED on LED2 DRV
      //Measurement 3 Setup
            MEAS3 AMB = 0b1
                                      //Ambient measurement selected
            MEAS3 PPG TINT as desired //ADC integration time control
            MEAS3 PDSEL = 0b00
                                        //Photodiode 1 and 2 selected on PPG channel 1
            MEAS3 PPG1 ADC RGE as desired//ADC range control for PPG1 ADC
            MEAS3 PD SETLNG as desired //Settling time for photodiode
With this configuration the sample sequence and the data format in the FIFO follows the following time/location sequence.
```

```
tag 0, Measurement 1 PPG1 (sample from IR LED)
tag 1, Measurement 2 PPG1 (sample from red LED)
tag 2, Measurement 3 PPG1 (ambient sample)
tag 0, Measurement 1 PPG1 (sample from IR LED)
tag 1, Measurement 2 PPG1 (sample from red LED)
tag 2, Measurement 3 PPG1 (ambient sample)
... tag 0, Measurement 1 PPG1 (sample from IR LED)
tag 1, Measurement 2 PPG1 (sample from red LED)
tag 2, Measurement 3 PPG1 (ambient sample)
```

For a second example, assume it is desired to pulse IR LED and RED LED simultaneously while also monitoring the ambient level.

```
System Configuration
      MEAS1 EN = 1'b1
                              (IR LED and RED LED exposure)
      MEAS2_EN = 1'b0
                              (NONE)
      MEAS3 EN = 1'b0
                              (NONE)
      MEAS4 EN = 1'b1
                              (DIRECT AMBIENT exposure)
      MEAS5 EN = 1'b0
                              (NONE)
      MEAS6 EN = 1'b0
                              (NONE)
Measurement 1 Setup (IR LED on LED DRVA on pin 1, RED LED on LED DRVB on pin 3)
      MEAS1 AMB = 1'b0
                               (Ambient measurement off)
```

Analog Devices | 31 www.analog.com

### Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

```
MEAS1 DRVA= 2'b00
                                       (LED Driver A on LED1 DRV and Current is non-zero)
            MEAS1 DRVB= 2'b10
                                       (LED Driver B on LED3 DRV and Current is non-zero)
            MEAS1_PPG1_ADC_RGE[1:0]
                                            (PPG1 Gain Range Control)
                                            (PPG2 Gain Range Control)
            MEAS1 PPG2 ADC RGE[1:0]
            MEAS1_PPG_TINT[1:0]
                                        (LED Pulse Width Control)
            MEAS1_DRVA_PA[7:0] = 8'h0B
                                          (LED Driver A Current)
            MEAS1_DRVB_PA[7:0] = 8'h0E (LED Driver B Current)
      Measurement 4 Setup (Ambient measurement)
            MEAS4\_AMB = 1'b1
                                      (Ambient measurement selectedf)
            MEAS4 DRVA= 2'b00
                                       (Don't Care because MEAS4 AMB = 1)
            MEAS4 DRVB= 2'b00
                                       (Don't Care because MEAS4 AMB = 1)
            MEAS4 PPG1 ADC RGE[1:0]
                                            (PPG1 Gain Range Control)
            MEAS4 PPG2 ADC RGE[1:0]
                                            (PPG2 Gain Range Control)
            MEAS4 PPG TINT[1:0]
                                        (LED Pulse Width Control)
In this case, the sequencing in the FIFO is,
             tag 1, PPG1 IR+RED data
             tag 1, PPG2 IR+RED data
             tag 4, PPG 1 Ambient data
             tag 4, PPG 2 Ambient data
             tag 1, PPG1 IR+RED data
             tag 1, PPG2 IR+RED data
             tag 4, PPG1 Ambient data
             tag 4, PPG2 Ambient data
             ... tag 1, PPG1 IR+RED data
             tag 1, PPG2 IR+RED data
             tag 4, PPG1 Ambient data
             tag 4, PPG2 Ambient data
```

#### where:

```
PPGy IR_RED data = Ambient corrected exposure data from IR and RED for optical channel y PPGy Ambient data = Direct ambient corrected sample for optical channel y y is 1 for optical channel 1, and 2 for optical channel 2
```

The number of bytes of data for the two optical channels in one frame is given by: 2 x 3 x N where:

N = Number of measurements enabled in each frame

To calculate the number of data items available in the FIFO one can perform the following pseudo-code:

```
read the OVF_COUNTER register
read the FIFO_DATA_COUNT registers
if OVF_COUNTER == 0 //no overflow occurred
    NUM_AVAILABLE_SAMPLES = FIFO_DATA_COUNT
else
    NUM_AVAILABLE_SAMPLES = 256 // overflow occurred and data has been lost
endif
```

It is important to flush the FIFO after SW\_FORCE\_SYNC. When a frame is aborted, for example due to the

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

SW\_FORCE\_SYNC command, a new frame starts. But part of the frame before the SW\_FORCE\_SYNC command might have already been saved in the FIFO. Therefore, data alignment for the two optical channels might be lost.

#### **Digital Interface**

The MAX86174A/MAX86174B support both I<sup>2</sup>C and SPI interfaces. The I2C\_SEL pin selects between the two interfaces. When I2C\_SEL is pulled high, the interface is in the I<sup>2</sup>C mode and idles looking for a start condition on the SCL and SDA pins while the SPI interface is held in a reset state. When I2C\_SEL is pulled low, the I<sup>2</sup>C interface is disabled and the SPI interface is activated with the SDO pin going active. In the following sections both interface timings and protocols are described.

#### SPI/I<sup>2</sup>C Selection for Serial Interface

MAX86174A/MAX86174B can be configured to use either I<sup>2</sup>C or SPI for serial communication with an external host. When the CSB/I2C\_SEL pin is high, the device is in I<sup>2</sup>C mode. When the CSB/I2C\_SEL pin is low, the device is in SPI mode. Immediately after power up, either I<sup>2</sup>C or SPI can be used to do any read/write transaction if the host drives the CSB/I2C\_SEL pin.

If the application uses I<sup>2</sup>C for serial communication, the I2C\_SEL (CSB) input pin is permanently tied to '1.' The SCL (SCLK) and SDA (SDI) pins are used for serial communication using I<sup>2</sup>C for reading from and writing to registers. In I<sup>2</sup>C mode, ADDR (SDO) is an input pin and is used for I<sup>2</sup>C address select as shown in <u>Table 7</u>.

### Table 7. Slave Addresses for I<sup>2</sup>C Mode

| ADDR | WRITE ADDRESS | READ ADDRESS |
|------|---------------|--------------|
| 0    | 0xD4          | 0xD5         |
| 1    | 0xD6          | 0xD7         |

If the application uses SPI for serial communication, after power up the host should use the SPI interface to disable the  $I^2C$  interface by writing 1 to the DISABLE\_I2C[7](0x11). The SCLK (SCL), SDI (SDA), SDO (ADDR), and CSB (I2C\_SEL) pins are used for serial communication using SPI for reading from and writing to any other registers. In this mode, the SDO (ADDR) pin is an output pin and has a pullup. When idle or during SPI write transactions, this pin is in a high impedance state (Hi-Z). For SPI read, this pin is in a Hi-Z state during the address and command phases, and is driven high or low during the read phase.

#### **SPI Interface**

The SPI interface on the MAX86174A/MAX86174B is SPI-/QSPI-/Microwire-/DSP-compatible consisting of a serial data input (SDI), a serial data output (SDO), a serial clock line (SCLK), and a chip select (CSB). In SPI mode, the SDI/SDA pin operates as SDI and the SCLK/SCL pin operates as SCLK. The timing of the SPI interface is shown in Figure 13. Data is strobed on the SCLK rising edge while clocked out on the SCLK falling edge. All single-word SPI read and write operations are done in a 3-byte, 24-clock-cycle SPI instruction framed by a CSB low interval. The content of the SPI operation consists of a one-byte register address, A[7:0], followed by a one-byte command word, which defines the transaction as write or read, followed by a single-byte data word either written to or read from the register location provided in the first byte.



Figure 13. Detailed SPI Timing Diagram

#### Single Word SPI Register Read and Write Transactions

SPI Write mode operations are executed on the 24<sup>th</sup> SCLK rising edge using the first three bytes of data available. In write mode, any data supplied after the 24th SCLK rising edge is ignored as shown in <u>Figure 14</u>. Subsequent writes require CSB to deassert high and then assert low for the next write command. A rising CSB edge preceding the 24<sup>th</sup> rising edge of SCLK by t<sub>CSA</sub> as shown in <u>Figure 13</u>, results in the transaction being aborted.



Figure 14. SPI Write Transaction

Read mode operations access the requested data on the 16<sup>th</sup> SCLK rising edge, and present the MSB of the requested data on the following SCLK falling edge, allowing the microcontroller to latch the data MSB on the 17<sup>th</sup> SCLK rising edge as shown in <u>Figure 15</u>. Configuration and status registers are available using normal-mode read-back sequences. FIFO reads must be done with a burst mode FIFO read (see the <u>SPI Burst Mode Read Transaction</u> section). In a normal read sequence, any SCLK rising edges after the 24<sup>th</sup> SCLK rising edge are ignored and if more than 24 SCLK rising edges are provided the device reads back zeros.



Figure 15. SPI Read Transaction

#### **SPI Burst Mode Read Transaction**

The MAX86174A/MAX86174B have a FIFO burst read mode to increase data transfer efficiency. The first 16 SCLK cycles operate exactly as described for normal read mode—the first byte being the register address, the second being a read command. The subsequent SCLKs consist of FIFO data, 24 SCLKs per word. All words in the FIFO should be read with a single-FIFO burst-read command.

Each FIFO sample consists of 3 bytes per sample, and thus, requires 24 SCLKs per sample to readout. The first byte (SCLK 17 to 24) consists of a tag indicating the data type of the subsequent bits as well as the MSBs of the data. The next two bytes (SCLK 24 to 40) consist of data. For example, Figure 16 shows a FIFO burst read consisting of three PPG samples in FIFO, labeled A through C, each with a 4-bit tag and 20-bit data. The number of words in the FIFO depends on the FIFO configuration. See the FIFO Description section for more details the FIFO configuration and readout.



Figure 16. SPI FIFO Burst Mode Read Transaction

#### I<sup>2</sup>C-/SMBus-Compatible Serial Interface

The I<sup>2</sup>C interface on the MAX86174A/MAX86174B is an I<sup>2</sup>C-/SMBus-compatible, 2-wire serial interface consisting of a serial data line (SDA) and a serial clock line (SCL). In I<sup>2</sup>C mode, the SDI/SDA pin operates as SDA and the SCLK/SCL pin operates as SCL. These two pins are used for the communication between the MAX86174A/MAX86174B and the master at clock rates up to 400kHz. Figure 17 shows the 2-wire interface timing diagram. The master generates SCL and initiates data transfer on the bus. The master device writes data to the MAX86174A/MAX86174B by transmitting the proper slave address followed by the register address and then the data word. Each transmit sequence is framed by a START (S) or REPEATED START (Sr) condition and a STOP (P) condition. Each word transmitted to the MAX86174A/MAX86174B is 8-bits long and is followed by an acknowledge clock pulse. A master reading data from the MAX86174A/MAX86174B transmits the proper slave address followed by a series of nine SCL pulses. The MAX86174A/MAX86174B transmits data on SDA in sync with the master-generated SCL pulses. The master acknowledges receipt of each byte of data. Each read sequence is framed by a START (S) or REPEATED START (Sr) condition, a not acknowledge (NACK), and a STOP (P) condition. SDA operates as both an input and an open-drain output. A pullup resistor is required on SDA. SCL operates only as an input. A pullup resistor is required on SCL if there are multiple masters on the bus, or if the single master has an open-drain SCL output. Series resistors in line with SDA and SCL are optional. Series resistors protect the digital inputs from high voltage spikes on the bus lines, and minimize crosstalk and undershoot of the bus

signals.



Figure 17. Detailed I<sup>2</sup>C Timing Diagram

#### **Bit Transfer**

One data bit is transferred during each SCL cycle. The data on SDA must remain stable during the high period of the SCL pulse. Changes in SDA while SCL is high are control signals (see the <u>START and STOP Conditions</u> section).

#### **START and STOP Conditions**

SDA and SCL idle high when the bus is not in use. A master initiates communication by issuing a START condition, which indicates the beginning of a transmission. A START condition is a high-to-low transition on SDA while SCL is high as shown in <a href="Figure 18">Figure 18</a>. The master terminates transmission, and frees the bus, by issuing a STOP condition. A STOP condition is a low-to-high transition on SDA while SCL is high as shown in <a href="Figure 18">Figure 18</a>. The bus remains active if a REPEATED START condition is generated instead of a STOP condition. A REPEATED START condition is the same as a START condition (high-to-low transition with SCL high), but it is sent after a START condition.

The MAX86174A/MAX86174B recognize a STOP condition at any point during data transmission except if the STOP condition occurs in the same high pulse as a START condition. For proper operation, do not send a STOP condition during the same SCL high pulse as the START condition.



Figure 18. I<sup>2</sup>C START, STOP, and REPEATED START Conditions

#### **Acknowledge Bit**

The acknowledge bit (ACK) is a clocked 9th bit that the MAX86174A/MAX86174B use to handshake receive each byte of data when in write mode as shown in <u>Figure 19</u>. The MAX86174A/MAX86174B pulldown SDA during the entire master-generated 9th clock pulse if the previous byte is successfully received. Monitoring ACK allows for detection of unsuccessful data transfers. An unsuccessful data transfer occurs if a receiving device is busy or if a system fault has occurred. In the event of an unsuccessful data transfer, the bus master retries communication. The master pulls down SDA during the 9th clock cycle to acknowledge receipt of data when the MAX86174A/MAX86174B is in read mode. An acknowledge is sent by the master after each read byte to allow data transfer to continue. A not-acknowledge is sent when the master reads the final byte of data from the MAX86174A/MAX86174B, followed by a STOP condition.



Figure 19. I<sup>2</sup>C Acknowledge Bit

#### I<sup>2</sup>C Write Data Format

A write to the MAX86174A/MAX86174B includes transmission of a START condition, the slave address with the  $R/\overline{W}$  bit set to 0, one byte of data to configure the internal register address pointer, one or more bytes of data, and a STOP condition. Figure 20 illustrates the proper frame format for writing one byte of data. Figure 21 illustrates the frame format for writing multiple bytes of data.

The slave address with the R/W bit set to 0 indicates that the master intends to write data to the MAX86174A/ MAX86174B. The MAX86174A/MAX86174B acknowledge receipt of the address byte during the master-generated 9th SCL pulse.

The second byte transmitted from the master configures the internal register address pointer of the MAX86174A/MAX86174B. The pointer tells the MAX86174A/MAX86174B where to write the next byte of data. An acknowledge pulse is sent by the MAX86174A/MAX86174B upon receipt of the address pointer data.

The third byte sent to the MAX86174A/MAX86174B contains the data to be written to the pointed register. An acknowledge pulse from the MAX86174A/MAX86174B signals receipt of the data byte. The address pointer auto increments to the next register address after each received data byte. This auto-increment feature allows a master to write to sequential registers within one continuous frame. The master signals the end of transmission by issuing a STOP condition. The auto-increment feature is disabled when there is an attempt to write to the FIFO Data register(0x0C).



Figure 20. I<sup>2</sup>C Single Byte Write Transaction



Figure 21. I<sup>2</sup>C Multi-Byte Write Transaction

#### I<sup>2</sup>C Read Data Format

A read from the MAX86174A/MAX86174B includes sending the slave address with the  $R/\overline{W}$  bit set to 1 to initiate a read operation. The MAX86174A/MAX86174B acknowledges receipt of the slave address by pulling SDA low during the  $9^{th}$  SCL clock pulse. A START command followed by a read command resets the address pointer to register 0x00.

The first byte transmitted from the MAX86174A/MAX86174B has the contents of register 0x00. Transmitted data is valid on the rising edge of SCL. The address pointer auto-increments after each read data byte. This auto-increment feature allows all registers to be read sequentially within one continuous frame. The auto-increment feature is disabled when there is an attempt to read from the FIFO Data register (0x07). A STOP condition can be issued after any number of read data bytes. If a STOP condition is issued followed by another read operation, the first data byte to be read is from register 0x00.

The address pointer can be preset to a specific register before a read command is issued. The master presets the address pointer by first sending the MAX86174A/MAX86174B slave address with the R/W bit set to 0 followed by the register address. A REPEATED START condition is then sent followed by the slave address with the R/W bit set to 1. The MAX86174A/MAX86174B then transmit the contents of the specified register. The address pointer auto-increments after transmitting the first byte.

The master acknowledges receipt of each read byte during the acknowledge clock pulse. The master must acknowledge all correctly received bytes except the last byte. The final byte must be followed by a not acknowledge from the master and then a STOP condition. Figure 22 illustrates the frame format for reading one byte from the MAX86174A/MAX86174B. Figure 23 illustrates the frame format for reading multiple bytes from the MAX86174A/MAX86174B.



Figure 22. I<sup>2</sup>C Single Byte Read Transaction



Figure 23. I<sup>2</sup>C Multi-Byte Read Transaction

#### I<sup>2</sup>C Broadcast

The MAX86174A/MAX86174B provide a feature of I<sup>2</sup>C broadcast write transactions to multiple devices simultaneously using the I<sup>2</sup>C serial interface. The host microcontroller uses the address programmed in I<sup>2</sup>C\_BCAST\_ADDR[7:1](0x18) to send a write command to multiple devices and the slave devices respond with an ACK. To use the broadcast feature, I<sup>2</sup>C\_BCAST\_EN[0](0x18) must be set to 1.

This feature is especially useful for:

- 1. Synchronizing PPG ADC conversion on multiple devices using the SW\_FORCE\_SYNC bit.
- 2. Programming same configuration to multiple devices at the same time.

Read transactions in broadcast mode are not supported. If a host sends out a read command using the I<sup>2</sup>C broadcast address, the device responds with a NACK.

#### **Layout Guidelines**

MAX86174A/MAX86174B is a high dynamic range analog front-end (AFE) and its performance can be adversely impacted by the physical printed circuit board (PCB) layout. It is recommended that all bypass recommendations in the *Pin Description* table be followed, and it is recommended that GND and PGND be shorted to a single PCB ground plane.

The  $V_{DD}$  pin should be decoupled with a  $0.1\mu F$  or larger ceramic chip capacitor to the PCB Ground plane. In addition, the VREF pin should be decoupled to the PCB Ground plane with a  $1.0\mu F$  ceramic capacitor. The voltage on the VREF pin is nominally 1.21V, so a 6.3V-rated ceramic capacitor should be adequate for this purpose. It is recommended that all decoupling capacitors use individual vias to the PCB Ground plane to avoid mutual impedance coupling between decoupled supplies when sharing vias.

The most critical aspect of the PCB layout of MAX86174A/MAX86174B is the handling of the PDm\_IN (m = 1, 2) nodes. Parasitic capacitive coupling to the PDm\_IN can result in additional noise being injected into the MAX86174A/MAX86174B front-end. To minimize external interference coupling to PD\_IN, it is recommended the PD\_IN node be fully shielded by the pseudo PD\_GND node. An example of this recommendation is shown below. In the three layers shown, the PDm\_IN node is shielded with a coplanar pseudo PD\_GND trace on the top layer (Figure 24), the layer on which the MAX86174A/MAX86174B is mounted. On the bottom layer (Figure 26), the photodiode cathode is entirely shielded with the pseudo PD\_GND shield, which is also the photodiode anode. Note also that the PD\_GND shield also extends below the photodiode. This is done because in most photodiodes, the cathode is the bulk of the silicon. Thus, shielding beneath the photodiode terminates the capacitance to the bulk or cathode side to the reference node, PD\_GND. On the layer just above the bottom, layer 5 in this case (Figure 25), the section of the GND plane has been opened up, connected to PD\_GND to shield the PD\_IN node below the photodiode cathode contact. Finally, the pseudo PD\_GND should only be attached to the AFE GND pin in only one point.







Figure 25. Layer 5—Pseudo PD\_GND Shields PD\_IN



Figure 26. Bottom Layer—Optics Layer

### **Register Map**

### **User Register Map**

| ADDRESS              | NAME                              | MSB                              |                       |                       |                  |                   |                  |                          | LSB                      |  |
|----------------------|-----------------------------------|----------------------------------|-----------------------|-----------------------|------------------|-------------------|------------------|--------------------------|--------------------------|--|
| Status               |                                   |                                  | l                     |                       |                  |                   |                  |                          |                          |  |
| 0x00                 | Status 1[7:0]                     | A_FULL                           | FRAME_<br>RDY         | FIFO_D<br>ATA_RD<br>Y | ALC_OV<br>F      | EXP_OV<br>F       | THRESH<br>2_HILO | THRESH<br>1_HILO         | PWR_R<br>DY              |  |
| 0x01                 | Status 2[7:0]                     | INVALID<br>_CFG                  | _                     | _                     | _                | LED4_C<br>OMPB    | LED3_C<br>OMPB   | LED2_C<br>OMPB           | LED1_C<br>OMPB           |  |
| FIFO                 |                                   |                                  |                       |                       |                  |                   |                  |                          |                          |  |
| 0x03                 | FIFO Write Pointer[7:0]           |                                  |                       |                       | FIFO_WR          | _PTR[7:0]         |                  |                          |                          |  |
| 0x04                 | FIFO Read Pointer[7:0]            |                                  |                       |                       | FIFO_RD          | _PTR[7:0]         |                  |                          |                          |  |
| 0x05                 | FIFO Counter 1[7:0]               | FIFO_D<br>ATA_CO<br>UNT[8]       |                       |                       | OVF              | _COUNTER          | R[6:0]           |                          |                          |  |
| 0x06                 | FIFO Counter 2[7:0]               |                                  |                       | F                     | IFO_DATA         | _COUNT[7:0        | 0]               |                          |                          |  |
| 0x07                 | FIFO Data Register[7:0]           |                                  |                       |                       | FIFO_D           | ATA[7:0]          |                  |                          |                          |  |
| 0x08                 | FIFO Configuration 1[7:0]         |                                  |                       |                       | FIFO_A_          | FULL[7:0]         |                  |                          |                          |  |
| 0x09                 | FIFO Configuration 2[7:0]         | _                                | _                     | FIFO_M<br>ARK         | FLUSH_<br>FIFO   | FIFO_ST<br>AT_CLR | A_FULL<br>_TYPE  | FIFO_R<br>O              | ı                        |  |
| System Co            | ntrol                             |                                  |                       |                       |                  |                   |                  |                          |                          |  |
| 0x10                 | System Sync[7:0]                  | _                                | SW_FO<br>RCE_SY<br>NC | _                     | _                | _                 | _                | _                        | -                        |  |
| 0x11                 | System Configuration 1[7:0]       | DISABL<br>E_I2C                  | -                     | SYNC_N                | IODE[1:0]        | PPG2_P<br>WRDN    | PPG1_P<br>WRDN   | SHDN                     | RESET                    |  |
| 0x12                 | System Configuration 2[7:0]       | -                                | _                     | MEAS6_<br>EN          | MEAS5_<br>EN     | MEAS4_<br>EN      | MEAS3_<br>EN     | MEAS2_<br>EN             | MEAS1_<br>EN             |  |
| 0x13                 | System Configuration 3[7:0]       | _                                | _                     | _                     | ALC_DIS<br>ABLE  | PROX_D<br>ATA_EN  | PROX_A<br>UTO    | COLLEC<br>T_RAW_<br>DATA | MEAS1_<br>CONFIG<br>_SEL |  |
| 0x14                 | PPG Filter Setup[7:0]             | PPG_FIL<br>T2_SEL                | _                     | DLPF_                 | EN[1:0]          | IIR_CFG           | D                | EC_AVE[2:                | VE[2:0]                  |  |
| 0x15                 | Photodiode Bias[7:0]              | _                                | _                     | _                     | _                | PD2_B             | IAS[1:0]         | PD1_B                    | AS[1:0]                  |  |
| 0x16                 | Pin Functional Configuration[7:0] | _                                | _                     | _                     | _                | _                 | INTB_F           | CFG[1:0]                 | TRIG_IC<br>FG            |  |
| 0x17                 | Output Pin<br>Configuration[7:0]  | INTB_OCF                         |                       | CFG[1:0]              | TRIGLE<br>D4_SEL |                   |                  |                          |                          |  |
| 0x18                 | I2C Broadcast<br>Address[7:0]     | I2C_BCAST_ADDR[6:0] I2C_BCAST_EN |                       |                       |                  |                   | I2C_BCA<br>ST_EN |                          |                          |  |
| PPG Frame Rate Clock |                                   |                                  |                       |                       |                  |                   |                  |                          |                          |  |
| 0x1A                 | FR Clock Frequency<br>Select[7:0] | _                                | FR_CLK_FINE_TUNE[4:0] |                       |                  |                   |                  |                          |                          |  |
| 0x1B                 | FR Clock Divider<br>MSB[7:0]      | _                                |                       |                       | FR_              | _CLK_DIV[1        | 4:8]             |                          |                          |  |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

| ADDRESS  | NAME                          | MSB                                              |                        |          |                 |                  |                                |                       | LSB               |
|----------|-------------------------------|--------------------------------------------------|------------------------|----------|-----------------|------------------|--------------------------------|-----------------------|-------------------|
| 0x1C     | FR Clock Divider<br>LSB[7:0]  |                                                  |                        |          | FR_CLK          | _DIV[7:0]        |                                |                       |                   |
| PPG MEAS | 1 Setup                       |                                                  |                        |          |                 |                  |                                |                       |                   |
| 0x20     | MEAS1 Selects[7:0]            | _                                                | MEAS1_<br>AMB          | -        | _               | MEAS1_[          | DRVB[1:0]                      | MEAS1_[               | DRVA[1:0]         |
| 0x21     | MEAS1 Configuration 1[7:0]    | MEAS1_P                                          | DSEL[1:0]              | _        | MEAS1_          | TINT[1:0]        | ME                             | AS1_AVER              | [2:0]             |
| 0x22     | MEAS1 Configuration 2[7:0]    | MEAS1_<br>SINC3_S<br>EL                          | MEAS1_<br>FILT_SE<br>L |          | .ED_RGE[<br>:0] | MEAS1_P<br>_RGI  | PG2_ADC<br>E[1:0]              |                       | PG1_ADC<br>E[1:0] |
| 0x23     | MEAS1 Configuration 3[7:0]    | MEAS1                                            | _PD_SETL               | NG[2:0]  |                 | ED_SETL<br>[1:0] | -                              | _                     | _                 |
| 0x24     | MEAS1 Configuration 4[7:0]    | _                                                | MEAS1_                 | PPG2_DAC | OFF[2:0]        | _                | MEAS1_                         | PPG1_DAC              | OFF[2:0]          |
| 0x25     | MEAS1 LEDA<br>Current[7:0]    |                                                  |                        |          | MEAS1_DF        | RVA_PA[7:0]      |                                |                       |                   |
| 0x26     | MEAS1 LEDB<br>Current[7:0]    |                                                  |                        |          | MEAS1_DF        | RVB_PA[7:0]      |                                |                       |                   |
| PPG MEAS | 2 Setup                       |                                                  |                        |          |                 |                  |                                |                       |                   |
| 0x28     | MEAS2 Selects[7:0]            | _                                                | MEAS2_<br>AMB          | -        | _               | MEAS2_[          | DRVB[1:0]                      | B[1:0] MEAS2_DRVA[1:0 |                   |
| 0x29     | MEAS2 Configuration 1[7:0]    | MEAS2_P                                          | DSEL[1:0]              | -        | MEAS2_          | TINT[1:0]        | ME                             | AS2_AVER              | [2:0]             |
| 0x2A     | MEAS2 Configuration 2[7:0]    | MEAS2_<br>SINC3_S<br>EL                          | MEAS2_<br>FILT_SE<br>L |          | .ED_RGE[<br>0]  |                  | MEAS2_PPG2_ADC ME<br>_RGE[1:0] |                       | PG1_ADC<br>E[1:0] |
| 0x2B     | MEAS2 Configuration 3[7:0]    | MEAS2                                            | PD_SETL                | NG[2:0]  |                 | ED_SETL<br>[1:0] | -                              | -                     | _                 |
| 0x2C     | MEAS2 Configuration<br>4[7:0] | _                                                | MEAS2_                 | PPG2_DAC | OFF[2:0]        | _                | MEAS2_                         | PPG1_DAC              | OFF[2:0]          |
| 0x2D     | MEAS2 LEDA<br>Current[7:0]    |                                                  |                        |          | MEAS2_DF        | RVA_PA[7:0]      |                                |                       |                   |
| 0x2E     | MEAS2 LEDB<br>Current[7:0]    |                                                  |                        |          | MEAS2_DF        | RVB_PA[7:0]      |                                |                       |                   |
| PPG MEAS | 3 Setup                       |                                                  |                        |          |                 |                  |                                |                       |                   |
| 0x30     | MEAS3 Selects[7:0]            | _                                                | MEAS3_<br>AMB          | _        | _               | MEAS3_[          | DRVB[1:0]                      | MEAS3_[               | DRVA[1:0]         |
| 0x31     | MEAS3 Configuration 1[7:0]    | MEAS3_P                                          | DSEL[1:0]              | _        | MEAS3_          | TINT[1:0]        | ME                             | AS3_AVER              | [2:0]             |
| 0x32     | MEAS3 Configuration 2[7:0]    | MEAS3_<br>SINC3_S<br>EL                          | MEAS3_<br>FILT_SE<br>L |          | .ED_RGE[<br>0]  |                  | MEAS3_PPG2_ADC MI<br>_RGE[1:0] |                       | PG1_ADC<br>E[1:0] |
| 0x33     | MEAS3 Configuration 3[7:0]    | MEAS3_PD_SETLNG[2:0] MEAS3_LED_SETL              |                        |          |                 | _                |                                |                       |                   |
| 0x34     | MEAS3 Configuration<br>4[7:0] | - MEAS3_PPG2_DACOFF[2:0] - MEAS3_PPG1_DACOFF[2:0 |                        |          |                 |                  | OFF[2:0]                       |                       |                   |
| 0x35     | MEAS3 LEDA<br>Current[7:0]    | MEAS3_DRVA_PA[7:0]                               |                        |          |                 |                  |                                |                       |                   |
| 0x36     | MEAS3 LEDB<br>Current[7:0]    |                                                  | MEAS3_DRVB_PA[7:0]     |          |                 |                  |                                |                       |                   |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

| ADDRESS  | NAME                          | MSB                                               |                                                 |          |                 |                                 |                   |                             | LSB                         |  |
|----------|-------------------------------|---------------------------------------------------|-------------------------------------------------|----------|-----------------|---------------------------------|-------------------|-----------------------------|-----------------------------|--|
| PPG MEAS | 4 Setup                       |                                                   |                                                 |          |                 |                                 |                   |                             |                             |  |
| 0x38     | MEAS4 Selects[7:0]            | _                                                 | MEAS4_<br>AMB                                   | _        | _               | MEAS4_[                         | DRVB[1:0]         | MEAS4_[                     | DRVA[1:0]                   |  |
| 0x39     | MEAS4 Configuration 1[7:0]    | MEAS4_P                                           | MEAS4_PDSEL[1:0] - MEAS4_TINT[1:0] MEAS4_AVER[2 |          |                 |                                 | [2:0]             |                             |                             |  |
| 0x3A     | MEAS4 Configuration 2[7:0]    | MEAS4_<br>SINC3_S<br>EL                           | MEAS4_<br>FILT_SE<br>L                          | _        | .ED_RGE[<br>:0] | MEAS4_P<br>_RGI                 | PG2_ADC<br>E[1:0] |                             | MEAS4_PPG1_ADC<br>_RGE[1:0] |  |
| 0x3B     | MEAS4 Configuration<br>3[7:0] | MEAS4                                             | _PD_SETL                                        | NG[2:0]  |                 | ED_SETL<br>[1:0]                | _                 | _                           | _                           |  |
| 0x3C     | MEAS4 Configuration<br>4[7:0] | _                                                 | MEAS4_                                          | PPG2_DAC | OFF[2:0]        | -                               | MEAS4_            | PPG1_DAC                    | OFF[2:0]                    |  |
| 0x3D     | MEAS4 LEDA<br>Current[7:0]    |                                                   |                                                 |          | MEAS4_DF        | RVA_PA[7:0]                     |                   |                             |                             |  |
| 0x3E     | MEAS4 LEDB<br>Current[7:0]    |                                                   |                                                 |          | MEAS4_DF        | RVB_PA[7:0]                     |                   |                             |                             |  |
| PPG MEAS | 5 Setup                       |                                                   |                                                 |          |                 |                                 |                   |                             |                             |  |
| 0x40     | MEAS5 Selects[7:0]            | _                                                 | MEAS5_<br>AMB                                   | _        | _               | MEAS5_[                         | DRVB[1:0]         | MEAS5_[                     | DRVA[1:0]                   |  |
| 0x41     | MEAS5 Configuration 1[7:0]    | MEAS5_P                                           | DSEL[1:0]                                       | -        | MEAS5_          | TINT[1:0]                       | ME                | AS5_AVER                    | [2:0]                       |  |
| 0x42     | MEAS5 Configuration 2[7:0]    | MEAS5_<br>SINC3_S<br>EL                           | MEAS5_<br>FILT_SE<br>L                          |          | .ED_RGE[<br>:0] |                                 | PG2_ADC<br>E[1:0] | MEAS5_PPG1_ADC<br>_RGE[1:0] |                             |  |
| 0x43     | MEAS5 Configuration 3[7:0]    | MEAS5                                             | _PD_SETL                                        | NG[2:0]  |                 | .ED_SETL<br>[1:0]               | -                 | -                           | _                           |  |
| 0x44     | MEAS5 Configuration<br>4[7:0] | _                                                 | MEAS5_                                          | PPG2_DAC | OFF[2:0]        | _                               | MEAS5_            | PPG1_DAC                    | OFF[2:0]                    |  |
| 0x45     | MEAS5 LEDA<br>Current[7:0]    |                                                   |                                                 |          | MEAS5_DF        | RVA_PA[7:0]                     |                   |                             |                             |  |
| 0x46     | MEAS5 LEDB<br>Current[7:0]    |                                                   |                                                 |          | MEAS5_DF        | RVB_PA[7:0]                     |                   |                             |                             |  |
| PPG MEAS | 6 Setup                       |                                                   |                                                 |          |                 |                                 |                   |                             |                             |  |
| 0x48     | MEAS6 Selects[7:0]            | _                                                 | MEAS6_<br>AMB                                   | _        | _               | MEAS6_[                         | DRVB[1:0]         | MEAS6_I                     | DRVA[1:0]                   |  |
| 0x49     | MEAS6 Configuration 1[7:0]    | MEAS6_P                                           | DSEL[1:0]                                       | _        | MEAS6_          | TINT[1:0]                       | ME                | AS6_AVER                    | [2:0]                       |  |
| 0x4A     | MEAS6 Configuration 2[7:0]    | MEAS6_<br>SINC3_S<br>EL                           | MEAS6_<br>FILT_SE<br>L                          |          | .ED_RGE[<br>:0] | MEAS6_PPG2_ADC ME.<br>_RGE[1:0] |                   |                             | PG1_ADC<br>E[1:0]           |  |
| 0x4B     | MEAS6 Configuration 3[7:0]    | MEAS6_PD_SETLNG[2:0] MEAS6_LED_SETL               |                                                 |          |                 | _                               | _                 |                             |                             |  |
| 0x4C     | MEAS6 Configuration<br>4[7:0] | - MEAS6_PPG2_DACOFF[2:0] - MEAS6_PPG1_DACOFF[2:0] |                                                 |          |                 |                                 | OFF[2:0]          |                             |                             |  |
| 0x4D     | MEAS6 LEDA<br>Current[7:0]    |                                                   |                                                 |          | MEAS6_DF        | RVA_PA[7:0]                     |                   |                             |                             |  |
| 0x4E     | MEAS6 LEDB<br>Current[7:0]    |                                                   | MEAS6_DRVB_PA[7:0]                              |          |                 |                                 |                   |                             |                             |  |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

| ADDRESS      | NAME                       | MSB                     |                                                 |                          |                                |                       |                         |                         | LSB                   |
|--------------|----------------------------|-------------------------|-------------------------------------------------|--------------------------|--------------------------------|-----------------------|-------------------------|-------------------------|-----------------------|
| PPG Thresh   | hold Interrupts            | •                       |                                                 |                          |                                |                       |                         |                         |                       |
| 0x50         | THRESHOLD MEAS<br>SEL[7:0] | _                       | - THRESH2_MEAS_SEL[2:0] - THRESH1_MEAS_SEL[2:0] |                          |                                |                       |                         | SEL[2:0]                |                       |
| 0x51         | THRESHOLD<br>HYST[7:0]     | THRESH<br>2_PPG_<br>SEL | THRESH<br>1_PPG_<br>SEL                         | -                        | TIME_HYST[1:0] LEVEL_HYST[2:0] |                       |                         | 2:0]                    |                       |
| 0x52         | PPG HI<br>THRESHOLD1[7:0]  |                         |                                                 | TH                       | IRESHOLD                       | 1_UPPER[7             | :0]                     |                         |                       |
| 0x53         | PPG LO<br>THRESHOLD1[7:0]  |                         |                                                 | TH                       | IRESHOLD                       | 1_LOWER[7             | 7:0]                    |                         |                       |
| 0x54         | PPG HI<br>THRESHOLD2[7:0]  |                         |                                                 | TH                       | IRESHOLD                       | 2_UPPER[7             | :0]                     |                         |                       |
| 0x55         | PPG LO<br>THRESHOLD2[7:0]  |                         |                                                 | TH                       | IRESHOLD:                      | 2_LOWER[7             | 7:0]                    |                         |                       |
| Interrupt Er | nables                     |                         |                                                 |                          |                                |                       |                         |                         |                       |
| 0x58         | Interrupt Enable 1[7:0]    | A_FULL<br>_EN           | FRAME_<br>RDY_EN                                | FIFO_D<br>ATA_RD<br>Y_EN | ALC_OV<br>F_EN                 | EXP_OV<br>F_EN        | THRESH<br>2_HILO_<br>EN | THRESH<br>1_HILO_<br>EN | -                     |
| 0x59         | Interrupt Enable 2[7:0]    | INVALID<br>_CFG_E<br>N  | -                                               | -                        | _                              | LED4_C<br>OMPB_E<br>N | LED3_C<br>OMPB_E<br>N   | LED2_C<br>OMPB_E<br>N   | LED1_C<br>OMPB_E<br>N |
| Part ID      |                            |                         |                                                 |                          |                                |                       |                         |                         |                       |
| 0xFE         | Revision ID[7:0]           | _                       | _                                               | _                        | _                              | _                     | _                       | _                       | _                     |
| 0xFF         | Part ID[7:0]               |                         | PART_ID[7:0]                                    |                          |                                |                       |                         |                         |                       |

### **Register Details**

#### Status 1 (0x00)

| BIT            | 7         | 6             | 5                 | 4         | 3         | 2                | 1                | 0         |
|----------------|-----------|---------------|-------------------|-----------|-----------|------------------|------------------|-----------|
| Field          | A_FULL    | FRAME_RD<br>Y | FIFO_DATA<br>_RDY | ALC_OVF   | EXP_OVF   | THRESH2_<br>HILO | THRESH1_<br>HILO | PWR_RDY   |
| Reset          | 0         | 0             | 0                 | 0         | 0         | 0                | 0                | 1         |
| Access<br>Type | Read Only | Read Only     | Read Only         | Read Only | Read Only | Read Only        | Read Only        | Read Only |

#### A\_FULL

A\_FULL is set to 1 when the FIFO has reached the threshold programmed in the FIFO\_A\_FULL[7:0](0x08). This is a read-only bit and it is cleared when the Status 1 Register is read. It is also cleared when FIFO Data Register (0x07) is read, if FIFO\_STAT\_CLR[3](0x09) = 1.

| A_FULL | DECODE                                                                                  |
|--------|-----------------------------------------------------------------------------------------|
| 0      | Normal operation                                                                        |
| 1      | Indicates that the FIFO buffer has reached the threshold set by FIFO_A_FULL[7:0](0x08). |

#### FRAME\_RDY

FRAME\_RDY is set to 1 when a full frame conversion has completed and it is ready in FIFO. A frame consists of FIFO data for all the PPG ADC conversions for the sequence programmed in the MEASx (x = 1 to 6) enable registers. This is

a read-only bit and it is cleared by reading the Status 1 register. It is also cleared by reading the FIFO Data register (0x07) if FIFO\_STAT\_CLR[3](0x09) = 1.

| FRAME_RDY DECODE |                                            |  |  |
|------------------|--------------------------------------------|--|--|
| 0                | Normal operation                           |  |  |
| 1                | A complete PPG frame is ready in the FIFO. |  |  |

#### FIFO DATA RDY

FIFO\_DATA\_RDY is set to 1 when new data is available in the FIFO. This is a read-only bit and it is cleared by reading the Status 1 register (0x00). It is also cleared by reading the FIFO Data Register (0x07) if FIFO\_STAT\_CLR[3](0x09) = 1

| FIFO_DATA_RDY | DECODE                             |
|---------------|------------------------------------|
| 0             | Normal operation                   |
| 1             | New data is available in the FIFO. |

#### ALC OVF

ALC\_OVF is set to 1 when the ambient-light cancellation function of the photodiode has reached its maximum limit due to overflow, and therefore, ambient light is affecting the output of the ADC. This is a read-only bit and it is cleared by reading the Status 1 register (0x00).

| ALC_OVF | DECODE                                                                                                   |
|---------|----------------------------------------------------------------------------------------------------------|
| 0       | Normal operation                                                                                         |
| 1       | The ambient-light cancellation function of the photodiode has reached its maximum limit due to overflow. |

#### **EXP OVF**

EXP\_OVF is set to 1 when an exposure measurement is either over range or under range for any of the enabled PPG measurements. A measurement is over range if it is higher than positive full scale (524287) minus roughly 16384, or under range if it is lower than negative full-scale / 4 (-131072) minus roughly 16384. This is a read-only bit, and it is cleared by reading the Status 1 register.

| EXP_OVF | DECODE                                          |
|---------|-------------------------------------------------|
| 0       | Normal operation                                |
| 1       | The exposure data is over range or under range. |

#### THRESH2 HILO

THRESH2\_HILO is set to 1 when the THRESH2\_MEAS\_SEL[6:4](0x50) instance qualifies as above THRESHOLD2\_UPPER[7:0](0x54) or below THRESHOLD2\_LOWER[7:0](0x55). This is a read-only bit and it is cleared by reading the Status 1 register (0x00).

See the Threshold Detection Function section for a complete explanation of how the ADC is qualified as above or below threshold.

| THRESH2_HILO | DECODE                                                                                      |
|--------------|---------------------------------------------------------------------------------------------|
| 0            | ADC reading is within the threshold 2 range.                                                |
| 1            | ADC reading is either above the THRESHOLD2_UPPER level or below the THRESHOLD2_LOWER level. |

#### THRESH1\_HILO

THRESH1\_HILO is set to 1 when the THRESH1\_MEAS[2:0](0x50) instance qualifies as above THRESHOLD1\_UPPER[7:0](0x52) or below THRESHOLD1\_LOWER[7:0](0x53). This is a read-only bit and it is cleared by reading the Status 1 register (0x00).

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

See the Threshold Detection Function section for a complete explanation of how the ADC is qualified as above or below threshold.

| THRESH1_HILO | DECODE                                                                                      |
|--------------|---------------------------------------------------------------------------------------------|
| 0            | ADC reading is within the threshold 1 range.                                                |
| 1            | ADC reading is either above the THRESHOLD1_UPPER level or below the THRESHOLD1_LOWER level. |

#### PWR\_RDY

PWR\_RDY is set to 1 when  $V_{DD}$  goes below the undervoltage lockout (UVLO) threshold, which is approximately 1.3V. If this condition occurs, all registers are reset to their POR state. This bit is not triggered by a soft-reset. This is a read-only bit and it is cleared when the Status 1 register is read, or by setting the SHDN[1](0x11) bit to 1.

PWR RDY is a non-maskable interrupt, so it is asserted on the INTB pin.

| PWR_RDY | DECODE                                                        |
|---------|---------------------------------------------------------------|
| 0       | Normal operation                                              |
| 1       | Indicates that V <sub>DD</sub> goes below the UVLO threshold. |

#### **Status 2 (0x01)**

| BIT            | 7               | 6 | 5 | 4 | 3              | 2              | 1              | 0              |
|----------------|-----------------|---|---|---|----------------|----------------|----------------|----------------|
| Field          | INVALID_C<br>FG | _ | _ | _ | LED4_COM<br>PB | LED3_COM<br>PB | LED2_COM<br>PB | LED1_COM<br>PB |
| Reset          | 0               | _ | _ | _ | 0              | 0              | 0              | 0              |
| Access<br>Type | Read Only       | _ | _ | _ | Read Only      | Read Only      | Read Only      | Read Only      |

#### INVALID\_CFG

INVALID\_CFG is set to 1 when the frame rate set by clock divider FR\_CLK\_DIV[14:0] (0x1B, 0x1C) is too fast to accommodate the programmed PPG measurements enabled in a frame. This is a read-only bit and it gets cleared when the Status 2 register (0x01) is read.

| INVALID_CFG | DECODE                                                                                            |
|-------------|---------------------------------------------------------------------------------------------------|
| 0           | Normal operation                                                                                  |
| 1           | The PPG frame rate is too fast to accommodate the programmed PPG measurements enabled in a frame. |

#### LED4\_COMPB

LEDn\_COMPB (n = 1 to 4) is set to 1 when the voltage at the LEDn\_DRV pin is below the LED compliance voltage

. LEDn COMPB is a read-only bit and is cleared when the

Status 2 register (0x01) is read.

| LED4_COMPB | DECODE                                                                                                                                                     |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | The LEDn_DRV pin has sufficient voltage to support the programmed current.                                                                                 |
| 1          | The LEDn_DRV pin is below the voltage needed to support the programmed current. Power-supply rejection on LEDn is degraded and LEDn current is inaccurate. |

#### LED3\_COMPB

See LED4\_COMPB for details.

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### LED2 COMPB

See LED4\_COMPB for details.

#### **LED1 COMPB**

See LED4\_COMPB for details.

#### FIFO Write Pointer (0x03)

| BIT            | 7 | 6                | 5 | 4    | 3    | 2 | 1 | 0 |  |  |  |
|----------------|---|------------------|---|------|------|---|---|---|--|--|--|
| Field          |   | FIFO_WR_PTR[7:0] |   |      |      |   |   |   |  |  |  |
| Reset          |   | 0x00             |   |      |      |   |   |   |  |  |  |
| Access<br>Type |   |                  |   | Read | Only |   |   |   |  |  |  |

#### FIFO\_WR\_PTR

FIFO\_WR\_PTR points to the FIFO location where the next sample is written. This pointer advances for each sample pushed on to the circular FIFO. The write pointer wraps around to count 0x00 as the next FIFO location after count 0xFF.

#### FIFO Read Pointer (0x04)

| BIT            | 7 | 6                | 5 | 4         | 3         | 2 | 1 | 0 |  |  |  |
|----------------|---|------------------|---|-----------|-----------|---|---|---|--|--|--|
| Field          |   | FIFO_RD_PTR[7:0] |   |           |           |   |   |   |  |  |  |
| Reset          |   | 0x00             |   |           |           |   |   |   |  |  |  |
| Access<br>Type |   |                  |   | Write, Re | ead, Dual |   |   |   |  |  |  |

#### FIFO RD PTR

FIFO\_RD\_PTR points to the FIFO location from which the next sample is to be read using the serial interface. This pointer advances each time a sample is read from the circular FIFO. The read pointer can be both read and written to. This allows rereading (or retrying) samples from the FIFO. However, writing to FIFO\_RD\_PTR can have adverse effects if it results in the FIFO being almost full. The read pointer wraps around to count 0x00 after count 0xFF.

#### FIFO Counter 1 (0x05)

| BIT            | 7                      | 6 | 5                | 4 | 3         | 2 | 1 | 0 |  |  |
|----------------|------------------------|---|------------------|---|-----------|---|---|---|--|--|
| Field          | FIFO_DATA<br>_COUNT[8] |   | OVF_COUNTER[6:0] |   |           |   |   |   |  |  |
| Reset          | 0                      |   | 0x00             |   |           |   |   |   |  |  |
| Access<br>Type | Read Only              |   |                  |   | Read Only |   |   |   |  |  |

#### FIFO\_DATA\_COUNT

FIFO\_DATA\_COUNT[8](0x05) is a read-only bit that holds the most significant bit of the number of items available in the FIFO for the host to read. The lower 8 bits are in the FIFO\_DATA\_COUNT[7:0](0x06) register. FIFO\_DATA\_COUNT increments when a new item is pushed to the FIFO, and decrements when the host reads a item from the FIFO.

FIFO\_DATA\_COUNT is useful for debug.

#### OVF\_COUNTER

The overflow counter OVF\_COUNTER logs the number of samples lost if the FIFO is not read in a timely fashion. When FIFO is full any new samples results in either new or old samples getting lost depending on the FIFO\_RO[1](0x09) setting.

This is a read-only register. When a complete sample is read from the FIFO and the read pointer advances, the OVF\_COUNTER is reset to zero. It should be read immediately before reading the FIFO in order to check if an overflow condition has occured. This counter saturates at count value 0x7F.

#### FIFO Counter 2 (0x06)

| BIT            | 7 | 6                    | 5 | 4    | 3    | 2 | 1 | 0 |  |  |  |
|----------------|---|----------------------|---|------|------|---|---|---|--|--|--|
| Field          |   | FIFO_DATA_COUNT[7:0] |   |      |      |   |   |   |  |  |  |
| Reset          |   | 0x00                 |   |      |      |   |   |   |  |  |  |
| Access<br>Type |   |                      |   | Read | Only |   |   |   |  |  |  |

#### FIFO\_DATA\_COUNT

FIFO\_DATA\_COUNT[7:0] is a read-only register that holds the lower 8 bits of the number of items available in the FIFO for the host to read.

See the FIFO DATA COUNT[8](0x05) description for details.

#### FIFO Data Register (0x07)

| BIT            | 7 | 6              | 5 | 4    | 3    | 2 | 1 | 0 |  |  |  |
|----------------|---|----------------|---|------|------|---|---|---|--|--|--|
| Field          |   | FIFO_DATA[7:0] |   |      |      |   |   |   |  |  |  |
| Reset          |   | 0xFF           |   |      |      |   |   |   |  |  |  |
| Access<br>Type |   |                |   | Read | Only |   |   |   |  |  |  |

#### FIFO\_DATA

FIFO\_DATA is used to get data from the FIFO using burst reads only. When burst reading from this register, the register address pointer does not auto-increment, and the FIFO\_RD\_PTR[7:0](0x04) advances to provide subsequent samples. Each sample is three bytes, so burst reading three bytes in the FIFO\_DATA register through the serial interface advances the FIFO\_RD\_PTR by one count. The format and data type of the data stored in the FIFO is determined by the tag associated with the data. For details and examples of various data types in some use cases, see the FIFO Description section. This is a read-only register.

#### FIFO Configuration 1 (0x08)

| BIT            | 7 | 6                | 5 | 4      | 3    | 2 | 1 | 0 |  |  |  |
|----------------|---|------------------|---|--------|------|---|---|---|--|--|--|
| Field          |   | FIFO_A_FULL[7:0] |   |        |      |   |   |   |  |  |  |
| Reset          |   | 0x7F             |   |        |      |   |   |   |  |  |  |
| Access<br>Type |   |                  |   | Write, | Read |   |   |   |  |  |  |

#### FIFO\_A\_FULL

FIFO\_A\_FULL sets the high watermark for the FIFO and determines when the status bit A\_FULL[7](0x00) is asserted. The A\_FULL bit is asserted when the FIFO holds (256 FIFO\_A\_FULL) samples. For example, if set to 0x0F, A\_FULL gets asserted when there are 15 empty spaces left (241 samples in FIFO). If A\_FULL\_EN[7](0x58) is set to 1, then A\_FULL being asserted results in an interrupt on the interrupt pin INTB. This condition should prompt the processor to

read samples from FIFO before it fills and overflows

| FIFO_A_FULL | FREE SPACES BEFORE INTERRUPT IS ASSERTED | NUMBER OF SAMPLES IN FIFO |
|-------------|------------------------------------------|---------------------------|
| 0           | 0                                        | 256                       |
| 1           | 1                                        | 255                       |
| 2           | 2                                        | 254                       |
| 3           | 3                                        | 253                       |
|             |                                          |                           |
| 254         | 254                                      | 2                         |
| 255         | 255                                      | 1                         |

#### FIFO Configuration 2 (0x09)

| BIT            | 7 | 6 | 5             | 4              | 3                 | 2               | 1           | 0 |
|----------------|---|---|---------------|----------------|-------------------|-----------------|-------------|---|
| Field          | _ | _ | FIFO_MAR<br>K | FLUSH_FIF<br>O | FIFO_STAT<br>_CLR | A_FULL_TY<br>PE | FIFO_RO     | _ |
| Reset          | _ | _ | 0             | 0              | 1                 | 0               | 0           | _ |
| Access<br>Type | _ | _ | Write, Read   | Write, Read    | Write, Read       | Write, Read     | Write, Read | - |

#### FIFO MARK

When FIFO\_MARK is set to 1, a marker tag is pushed to the FIFO. FIFO\_MARK is a self-clearing bit. The marker tag is useful for differentiating the data in the FIFO before and after the tag.

See the FIFO Description section for the marker tag information.

| FIFO_MARK | DECODE                    |
|-----------|---------------------------|
| 0         | Normal data saved in FIFO |
| 1         | Save a marker in FIFO     |

#### FLUSH\_FIFO

When the FLUSH\_FIFO bit is set to 1, the FIFO gets flushed, FIFO\_WR\_PTR[7:0](0x03), FIFO\_RD\_PTR[7:0](0x04), FIFO\_DATA\_COUNT[8:0](0x05, 0x06), and OVF\_COUNTER[6:0](0x05) are reset to zero. The contents of the FIFO are lost. FLUSH\_FIFO is a self-clearing bit.

| FLUSH_FIFO | DECODE          |
|------------|-----------------|
| 0          | Normal mode     |
| 1          | FIFO is flushed |

#### FIFO\_STAT\_CLR

FIFO\_STAT\_CLR determines if a FIFO\_DATA[7:0](0x07) register read clears the status bits A\_FULL[7](0x00), FRAME\_RDY[6](0x00), and FIFO\_DATA\_RDY[5](0x00) and their corresponding interrupts.

| FIFO_STAT_CLR | DECODE                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | A_FULL, FRAME_RDY and FIFO_DATA_RDY status and interrupts do not get cleared by a FIFO_DATA[7:0](0x07) register read. They get cleared by a Status 1 register read. |
| 1             | A_FULL, FRAME_RDY and FIFO_DATA_RDY status and interrupts get cleared by a FIFO_DATA[7:0](0x07) register read or a Status 1 register read.                          |

#### A\_FULL\_TYPE

A\_FULL\_TYPE defines the behavior of the status bit A\_FULL[7](0x00) and its corresponding interrupt.

| A_FULL_TYPE | DECODE                                                                                                                                                                                                                       |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | A_FULL interrupt is asserted when the almost full condition is detected. It is cleared by a Status 1 register read, but re-asserts for every sample if the almost full condition persists.                                   |
| 1           | A_FULL interrupt is asserted when the almost full condition is detected. The interrupt gets cleared by a Status 1 register read, and does not re-assert until FIFO is read and then a new almost full condition is detected. |

#### FIFO\_RO

FIFO\_RO bit controls the behavior of the FIFO when the FIFO becomes completely filled with data. Push to FIFO is enabled when FIFO is full if FIFO\_RO is set to 1 and old samples are lost. Both FIFO Write Pointer (0x03) and FIFO Read Pointer (0x04) increment for each sample after the FIFO is full. If FIFO\_RO is set to 0, new samples are lost and the FIFO is not updated. FIFO Write Pointer and FIFO Read Pointer do not increment until a sample is read from the FIFO.

| FIFO_RO | DECODE                                     |
|---------|--------------------------------------------|
| 0       | The FIFO stops on full.                    |
| 1       | The FIFO automatically rolls over on full. |

### System Sync (0x10)

| BIT            | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-------------------|---|---|---|---|---|---|
| Field          | _ | SW_FORC<br>E_SYNC | ı | _ | _ | _ | _ | _ |
| Reset          | _ | 0                 | _ | _ | _ | _ | _ | _ |
| Access<br>Type | _ | Write, Read       | - | _ | _ | _ | _ | _ |

#### SW\_FORCE\_SYNC

Writing SW\_FORCE\_SYNC to 1 aborts the conversion of the current frame and starts a new frame. This is a self-clearing bit.

| SW_FORCE_SYNC | DECODE                    |
|---------------|---------------------------|
| 0             | Normal mode               |
| 1             | Manully start a new frame |

#### **System Configuration 1 (0x11)**

| BIT            | 7               | 6 | 5              | 4 | 3              | 2              | 1           | 0           |
|----------------|-----------------|---|----------------|---|----------------|----------------|-------------|-------------|
| Field          | DISABLE_I<br>2C | _ | SYNC_MODE[1:0] |   | PPG2_PW<br>RDN | PPG1_PW<br>RDN | SHDN        | RESET       |
| Reset          | 0               | - | 0x0            |   | 0              | 0              | 0           | 0           |
| Access<br>Type | Write, Read     | _ | Write, Read    |   | Write, Read    | Write, Read    | Write, Read | Write, Read |

#### **DISABLE 12C**

DISABLE\_I2C disables the  $I^2C$  interface or not. For the SPI interface, the user must set DISABLE\_I2C to 1 during initialization after powering up. See the Digital Interface section for details.

| DISABLE_I2C | DECODE                                                              |
|-------------|---------------------------------------------------------------------|
| 0           | The CSB/I2C_SEL pin selects interface.                              |
| 1           | I <sup>2</sup> C is disabled. The part uses the SPI interface only. |

#### SYNC MODE

SYNC MODE selects the frame synchronization modes. See the Synchronization Modes section for details.

| SYNC_MODE | TRIG INPUT                              | OPERATING MODES                            |
|-----------|-----------------------------------------|--------------------------------------------|
| 0x0, 0x3  | Not used                                | Internal frame oscillator and divider mode |
| 0x1       | Frame sync on TRIG input                | External frame trigger input mode          |
| 0x2       | External frame-rate clock on TRIG input | External frame-clock input mode            |

#### PPG2\_PWRDN

PPG2\_PWRDN enables or disables PPG channel 2. This bit is ignored in MAX86174B in which there is only a single PPG readout channel.

| PPG2_PWRDN | DECODE                         |
|------------|--------------------------------|
| 0          | PPG channel 2 is enabled.      |
| 1          | PPG channel 2 is powered down. |

#### PPG1\_PWRDN

PPG1\_PWRDN enables or disables PPG channel 1. This bit is ignored in MAX86174B in which there is only a single PPG readout channel.

| PPG1_PWRDN | DECODE                         |
|------------|--------------------------------|
| 0          | PPG channel 1 is enabled.      |
| 1          | PPG channel 1 is powered down. |

#### **SHDN**

Setting the SHDN bit to 1 puts the MAX86174A/MAX86174B into shutdown mode. While in shutdown mode, all configuration registers retain their values and the write/read operations function as normal. In this mode, the oscillator is shut down and the part draws minimum current. All interrupts are cleared. If this bit is asserted during an active conversion then the conversion is aborted. Set SHDN to 0 to put the part back in normal mode.

| SHDN | DECODE        |
|------|---------------|
| 0    | Normal mode   |
| 1    | Shutdown mode |

#### **RESET**

Setting RESET to 1 resets all registers to their power-on-reset state. This is a self-clearing bit and resets to 0 after the reset sequence is completed.

| RESET | DECODE                                          |
|-------|-------------------------------------------------|
| 0     | Normal mode                                     |
| 1     | All registers restored to power-on-reset state. |

#### **System Configuration 2 (0x12)**

| BIT            | 7 | 6 | 5           | 4           | 3           | 2           | 1           | 0           |
|----------------|---|---|-------------|-------------|-------------|-------------|-------------|-------------|
| Field          | _ | _ | MEAS6_EN    | MEAS5_EN    | MEAS4_EN    | MEAS3_EN    | MEAS2_EN    | MEAS1_EN    |
| Reset          | _ | - | 0           | 0           | 0           | 0           | 0           | 0           |
| Access<br>Type | _ | _ | Write, Read |

#### MEAS6\_EN

See MEAS1\_EN for details.

#### **MEAS5 EN**

See MEAS1\_EN for details.

#### MEAS4\_EN

See MEAS1\_EN for details.

#### MEAS3\_EN

See MEAS1 EN for details.

#### MEAS2\_EN

See MEAS1\_EN for details.

#### MEAS1\_EN

MEASx\_EN (x = 1 to 6) enables or disables PPG measurement programmed in the corresponding PPG MEASx Setup registers.

| MEASx_EN<br>(x = 1 to 6) | DECODE                     |
|--------------------------|----------------------------|
| 0                        | Measurement x is disabled. |
| 1                        | Measurement x is enabled.  |

#### **System Configuration 3 (0x13)**

| BIT            | 7 | 6 | 5 | 4               | 3                | 2             | 1                        | 0                    |
|----------------|---|---|---|-----------------|------------------|---------------|--------------------------|----------------------|
| Field          | _ | _ | _ | ALC_DISAB<br>LE | PROX_DAT<br>A_EN | PROX_AUT<br>O | COLLECT_<br>RAW_DAT<br>A | MEAS1_CO<br>NFIG_SEL |
| Reset          | _ | _ | _ | 0               | 0                | 0             | 0                        | 0                    |
| Access<br>Type | _ | _ | _ | Write, Read     | Write, Read      | Write, Read   | Write, Read              | Write, Read          |

#### ALC\_DISABLE

ALC\_DISABLE disables the front-end analog ambient-light cancellation circuit for PPG measurements. This bit does not alter the digital ambient-light cancellation.

| ALC_DISABLE | DECODE                                                   |  |  |  |
|-------------|----------------------------------------------------------|--|--|--|
| 0           | Normal operation                                         |  |  |  |
| 1           | Front-end analog ambient-light cancellation is disabled. |  |  |  |

#### PROX\_DATA\_EN

PROX\_DATA\_EN enables MEAS6 data to be saved in the FIFO when PROX\_AUTO[2](0x13) is 1. If PROX\_AUTO is set to 0, PROX\_DATA\_EN is ignored.

| PROX_DATA_EN | _DATA_EN DECODE                                      |  |  |  |
|--------------|------------------------------------------------------|--|--|--|
| 0            | MEAS6 data is not saved in FIFO when PROX_AUTO is 1. |  |  |  |
| 1            | MEAS6 data is saved in FIFO when PROX_AUTO is 1.     |  |  |  |

#### PROX\_AUTO

PROX\_AUTO enables automatic proximity detect mode. For more details, see the Automatic Proximity Detect Mode section.

| PROX_AUTO | DECODE                          |
|-----------|---------------------------------|
| 0         | Normal mode                     |
| 1         | Automatic proximity detect mode |

#### COLLECT\_RAW\_DATA

COLLECT\_RAW\_DATA pushes each ambient conversion and exposure conversion within a PPG measurement separately to the FIFO. Setting COLLECT\_RAW\_DATA to 1 inhibits the digital ambient cancellation. This allows a customized ambient rejection algorithm to be run in a host processor.

When COLLECT\_RAW\_DATA is set to 1, PROX\_AUTO[2](0x13), THRESH1\_MEAS\_SEL[2:0](0x50), and THRESH2\_MEAS\_SEL[6:4](0x50) should be set to zero.

| COLLECT_RAW_DATA | DECODE                                                                                             |
|------------------|----------------------------------------------------------------------------------------------------|
| 0                | Computed data for each measurement is saved in the FIFO.                                           |
| 1                | Raw data for all ambient conversions and LED conversions in each measurement is saved in the FIFO. |

#### MEAS1\_CONFIG\_SEL

MEAS1\_CONFIG\_SEL selects whether all enabled PPG measurements use the same configuration settings defined in MEAS1 setup registers (0x20 to 0x26). This allows for reduced setup configuration writes. The configuration settings used by all enabled measurements are as follows:

MEAS1 SINC3 SEL

MEAS1\_FILT2\_SEL

MEAS1\_FILT\_SEL

MEAS1\_TINT

MEAS1\_AVER

MEAS1\_PPG1\_ADC\_RGE

MEAS1 PPG2 ADC RGE

MEAS1\_PD\_SETLNG

MEAS1 LED SETLNG

MEAS1\_LED\_RGE

MEAS1\_PD1\_SEL

MEAS1\_PD2\_SEL

| MEAS1_CONFIG_SEL | DECODE                                                                               |  |  |  |
|------------------|--------------------------------------------------------------------------------------|--|--|--|
| 0                | Use measurement-specific configurations defined in each measurement setup registers. |  |  |  |
| 1                | Use MEAS1 configuration for all enabled measurements.                                |  |  |  |

#### PPG Filter Setup (0x14)

| BIT            | 7                 | 6 | 5            | 4          | 3           | 2            | 1           | 0 |
|----------------|-------------------|---|--------------|------------|-------------|--------------|-------------|---|
| Field          | PPG_FILT2<br>_SEL | - | DLPF_EN[1:0] |            | IIR_CFG     | DEC_AVE[2:0] |             |   |
| Reset          | 0                 | _ | 0:           | <b>k</b> 0 | 0           |              | 0x0         |   |
| Access<br>Type | Write, Read       | _ | Write, Read  |            | Write, Read |              | Write, Read |   |

#### PPG FILT2 SEL

PPG\_FILT2\_SEL enables either a second-order decimation filter or a third-order decimation filter. When PPG\_FILT2\_SEL is set to

1 (second-order decimation filter), MEASx\_SINC3\_SEL (x = 1 to 6) must be set to 0, and MEASx\_TINT must be 0x3.

Note: MEASx\_SINC3\_SEL[7] is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A and MEASx\_TINT[4:3] is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.

| PPG_FILT2_SEL | DECODE                                                                         |
|---------------|--------------------------------------------------------------------------------|
| 0             | 3rd order decimation filter is used.                                           |
| 1             | 2nd order decimation filter is used if MEASx_SINC3_SEL = 0 and MEASx_TINT = 3. |

#### DLPF\_EN

DLPF\_EN enables the digital low-pass filter as shown in the table below. When using the digital low-pass filter, COLLECT\_RAW\_DATA[1](0x13) must be set to 0. If COLLECT\_RAW\_DATA is 1, digital low-pass filter is disabled.

| DLPF_EN  | DECODE                                                                                       |
|----------|----------------------------------------------------------------------------------------------|
| 0x0      | Disable digital low-pass filter.                                                             |
| 0x1      | Enable digital low-pass filter using decimation averaging in DEC_AVE[2:0](0x14).             |
| 0x2, 0x3 | Enable digital low-pass filter using IIR with the cut-off frequency set in IIR_CFG[3](0x14). |

#### IIR\_CFG

IIR\_CFG selects the low-pass IIR filter configuration when DLPF\_EN is 0x2 or 0x3. When using the IIR filter, the PPG frame rates supported are 100Hz and 200Hz.

| IIR_CFG | DECODE                                       |
|---------|----------------------------------------------|
| 0       | Cut-off frequency, f <sub>CO</sub> = 11.5Hz  |
| 1       | Cut-off frequency, f <sub>CO</sub> = 12.07Hz |

#### **DEC AVE**

DEC\_AVE sets the number of adjacent samples from each individual PPG channel that are averaged on-chip before being written to the FIFO if DLPF\_EN[5:4](0x14) is 0x1. Number of samples averaged is 2<sup>DEC\_AVE</sup>. When DLPF\_EN is 0x2 or 0x3, DEC\_AVE defines the decimation ratio for the IIR low-pass filter output.

| DEC_AVE | NUMBER OF SAMPLES AVERAGED,<br>WHEN DLPF_EN = 0x1 | DECIMATION RATIO WHEN DLPF = 0x2 or 0x3 |
|---------|---------------------------------------------------|-----------------------------------------|
| 0       | 1                                                 | 1                                       |
| 0x1     | 2                                                 | 2                                       |
| 0x2     | 4                                                 | 4                                       |
| 0x3     | 8                                                 | 8                                       |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

| DEC_AVE          | NUMBER OF SAMPLES AVERAGED,<br>WHEN DLPF_EN = 0x1 | DECIMATION RATIO WHEN<br>DLPF = 0x2 or 0x3 |
|------------------|---------------------------------------------------|--------------------------------------------|
| 0x4              | 16                                                | 16                                         |
| 0x5, 0x6,<br>0x7 | 32                                                | 32                                         |

#### Photodiode Bias (0x15)

| BIT            | 7 | 6 | 5 | 4 | 3             | 2 | 1             | 0    |
|----------------|---|---|---|---|---------------|---|---------------|------|
| Field          | _ | _ | _ | _ | PD2_BIAS[1:0] |   | PD1_BIAS[1:0] |      |
| Reset          | _ | _ | _ | _ | 0x1           |   | 0x1           |      |
| Access<br>Type | _ | _ | _ | _ | Write, Read   |   | Write,        | Read |

#### PD2\_BIAS

PDm\_BIAS (m = 1, 2) selects the bias for photodiode m depending on the photodiode capacitance.

Note when PD1 and PD2 are connected to the same PPG channel (MEASx\_PDSEL = 0x0 or 0x3, x = 1 to 6), the greater of two PD bias settings is used.

Note: MEASx\_PDSEL[7:6] is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.

See the Photodiode Biasing section for details.

| PDm_BIAS (m = 1, 2) | PHOTODIODE CAPACITANCE (pF) |
|---------------------|-----------------------------|
| 0x0                 | Do not use                  |
| 0x1                 | 0 to 125                    |
| 0x2                 | 125 to 250                  |
| 0x3                 | 250 to 500                  |

#### PD1\_BIAS

See PD2\_BIAS[3:2](0x15) for details.

#### Pin Functional Configuration (0x16)

| BIT            | 7 | 6 | 5 | 4 | 3 | 2           | 1          | 0           |
|----------------|---|---|---|---|---|-------------|------------|-------------|
| Field          | _ | _ | _ | _ | _ | INTB_F      | CFG[1:0]   | TRIG_ICFG   |
| Reset          | _ | _ | _ | _ | - | 0>          | <b>k</b> 1 | 0           |
| Access<br>Type | _ | _ | _ | _ | - | Write, Read |            | Write, Read |

#### INTB\_FCFG

INTB\_FCFG controls the function of the INTB pin.

| INTB_FCFG | DECODE                                                                                                                                          |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0       | Disabled                                                                                                                                        |
| 0x1       | INTB is enabled and is cleared upon reading of any status register or FIFO as applicable.                                                       |
| 0x2       | INTB is enabled and is self-clearing after 30.5µs (if fast clock is 10MHz), or reading the corresponding Status register or FIFO as applicable. |
| 0x3       | INTB is enabled and is self-clearing after 244µs (if fast clock is 10MHz), or reading the corresponding Status register or FIFO as applicable.  |

#### TRIG\_ICFG

TRIG\_ICFG bit sets the input active edge of the TRIG pin.

| TRIG_ICFG | DECODE                                      |
|-----------|---------------------------------------------|
| 0         | TRIG active edge is falling (PORb default). |
| 1         | TRIG active edge is rising.                 |

### **Output Pin Configuration (0x17)**

| BIT            | 7 | 6 | 5 | 4 | 3 | 2           | 1        | 0                |
|----------------|---|---|---|---|---|-------------|----------|------------------|
| Field          | _ | _ | _ | _ | _ | INTB_O      | CFG[1:0] | TRIGLED4_<br>SEL |
| Reset          | - | - | - | - | - | 0x0         |          | 0                |
| Access<br>Type | _ | _ | _ | _ | _ | Write, Read |          | Write, Read      |

#### INTB\_OCFG

INTB\_OCFG[1:0] selects the output drive type for the INTB pin, as shown in the table below.

| INTB_OCFG | DECODE                                                                      |
|-----------|-----------------------------------------------------------------------------|
| 0x0       | Open-drain, active-low output                                               |
| 0x1       | Active drive to V <sub>DD</sub> and GND, the active level is a high output. |
| 0x2       | Active drive to V <sub>DD</sub> and GND, the active level is a low output.  |
| 0x3       | Do not use.                                                                 |

#### TRIGLED4\_SEL

TRIGLED4\_SEL selects the TRIG/LED4\_DRV pin to be used as the LED4\_DRV or TRIG input. It must only be set to 1 when SYNC\_MODE[5:4](0x11) is 0x0. TRIG\_ICFG[0](0x16) is also ignored when this bit is set.

| TRIGLED4_SEL | DECODE                                               |
|--------------|------------------------------------------------------|
| 0            | The LED4_DRV/TRIG pin is used as digital input TRIG. |
| 1            | The LED4_DRV/TRIG pin is used as LED4_DRV.           |

#### **I2C Broadcast Address (0x18)**

| BIT            | 7                   | 6 | 5 | 4 | 3 | 2 | 1                | 0 |
|----------------|---------------------|---|---|---|---|---|------------------|---|
| Field          | I2C_BCAST_ADDR[6:0] |   |   |   |   |   | I2C_BCAST<br>_EN |   |
| Reset          | 0x00                |   |   |   |   |   |                  | 0 |
| Access<br>Type | Write, Read         |   |   |   |   |   | Write, Read      |   |

#### I2C\_BCAST\_ADDR

I2C\_BCAST\_ADDR is used to define the upper 7 bits of the  $I^2C$  address in  $I^2C$  broadcast mode (I2C\_BCAST\_EN[0](0x18) = 1) when writing to multiple devices simultaneously using the  $I^2C$  serial interface. I2C BCAST ADDR is ignored in SPI mode.

See the I<sup>2</sup>C Broadcast section for more details.

#### I2C\_BCAST\_EN

I2C\_BCAST\_EN enables write transactions to multiple devices using the broadcast address programmed in

Note that for devices using SPI for serial interface, broadcast write transactions can be achieved by driving CSB pins low on multiple devices at the same time.

| I2C_BCAST_EN | DECODE                                                                               |  |  |  |
|--------------|--------------------------------------------------------------------------------------|--|--|--|
| 0            | Normal mode. I <sup>2</sup> C transactions are for one device only.                  |  |  |  |
| 1            | I <sup>2</sup> C broadcast mode. Write transactions to multiple devices are enabled. |  |  |  |

#### FR Clock Frequency Select (0x1A)

| BIT            | 7 | 6 | 5 | 4                     | 3 | 2 | 1 | 0 |
|----------------|---|---|---|-----------------------|---|---|---|---|
| Field          | _ | _ | _ | FR_CLK_FINE_TUNE[4:0] |   |   |   |   |
| Reset          | _ | _ | _ | 0x00                  |   |   |   |   |
| Access<br>Type | _ | _ | - | Write, Read           |   |   |   |   |

#### FR\_CLK\_FINE\_TUNE

FR\_CLK\_FINE\_TUNE is used to fine tune the internal 32.768kHz frame-rate clock. This register can be used to compensate the internal oscillator for thermal drift. This can be accomplished by measuring the time between interrupts using a microcontroller crystal-based real-time oscillator as a reference and computing the error in the time between interrupts. FR\_CLK\_FINE\_TUNE is a two's complement code with a resolution of 0.2%/LSB. The total range is -3.2% to +3.0% around the factory trimmed value. See the table below for the shift in internal primary frame-rate clock vs. trim code.

| FR_CLK_FINE_TUNE | SHIFT IN OSCILLATOR FREQUENCY (%) |
|------------------|-----------------------------------|
| 0x10             | -3.2                              |
| 0x11             | -3.0                              |
| 0x12             | -2.8                              |
| 0x13             | -2.6                              |
| 0x14             | -2.4                              |
| 0x15             | -2.2                              |
| 0x16             | -2.0                              |
| 0x17             | -1.8                              |
| 0x18             | -1.6                              |
| 0x19             | -1.4                              |
| 0x1A             | -1.2                              |
| 0x1B             | -1.0                              |
| 0x1C             | -0.8                              |
| 0x1D             | -0.6                              |
| 0x1E             | -0.4                              |
| 0x1F             | -0.2                              |
| 0x00             | 0.0                               |
| 0x01             | 0.2                               |
| 0x02             | 0.4                               |
| 0x03             | 0.6                               |
| 0x04             | 0.8                               |
| 0x05             | 1.0                               |

| FR_CLK_FINE_TUNE | SHIFT IN OSCILLATOR FREQUENCY (%) |
|------------------|-----------------------------------|
| 0x06             | 1.2                               |
| 0x07             | 1.4                               |
| 0x08             | 1.6                               |
| 0x09             | 1.8                               |
| 0x0A             | 2.0                               |
| 0x0B             | 2.2                               |
| 0x0C             | 2.4                               |
| 0x0D             | 2.6                               |
| 0x0E             | 2.8                               |
| 0x0F             | 3.0                               |

#### FR Clock Divider MSB (0x1B)

| BIT            | 7 | 6           | 5                | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-------------|------------------|---|---|---|---|---|
| Field          | _ |             | FR_CLK_DIV[14:8] |   |   |   |   |   |
| Reset          | _ |             | 0x01             |   |   |   |   |   |
| Access<br>Type | _ | Write, Read |                  |   |   |   |   |   |

#### FR CLK DIV

FR CLK DIV H has the upper 7 bits of the 15-bit FR CLK DIV[14:0] clock divider, which defines the PPG frame rate.

The FR\_CLK\_DIV should be programmed such that all the conversions selected in the MEASx\_EN (x = 1 to 6) bits in the System Configuration 2 (register 0x12) can be completed within the frame period. In the event that the number of enabled measurements as well as the integration time and number of burst average of each enabled measurement results in a frame measurement time that is longer than the primary frame clock period divided by FR\_CLK\_DIV, then a timing error occurs. This timing error produces the INVALID\_CFG[7](0x01) to be set.

FR\_CLK\_DIV = 0x7FFF and FR\_CLK\_DIV < 0x0010 are reserved. FR\_CLK\_DIV should be at least 0x0010, which corresponds to the period for the smallest frame.

The time for each frame to complete is given by:

tmeasurement = tinit1 + tmeas1 + tmeas2 + tmeas3 + ... + tmeas6

Where:

if the  $MEASx\_SINC3 = 1$  or  $MEASx\_FILT = 0$  then:

 $t_{MEASx} = [t_{init} + MEASx\_TINT * (2*MEASx\_AVER+1) + 2*MEASx\_AVER* MEASx\_PD\_SETLNG] * MEASx\_EN if MEASx_SINC3 = 0 and MEASx_FILT = 1 then:$ 

t<sub>MEASx</sub> = [t<sub>init</sub> + 2\*MEASx\_TINT + MEASx\_PD\_SETLNG] \* MEASx\_EN

 $t_{INIT1} = 7 \times t_{CLOCK}$ 

 $t_{INIT} = 3 \times t_{CLOCK}$ 

MEASx\_TINT = the integration time defined in measurement x = 1 to 6 and is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.

MEASx EN = 1 if the measurement is enabled and 0 if it is not, for measurement x = 1 to 6

MEAS $x_AVER = configuration of burst averages defined in measurement <math>x = 1$  to 6 and is in registers 0x21, 0x29, 0x31, 0x39, 0x41, 0x49.

MEASx\_PD\_SETLNG = photodiode settling time defined in measurement x = 1 to 6 and is in registers 0x23, 0x2B, 0x33, 0x3B, 0x43, 0x4B.

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

 $t_{CLOCK}$  = the frame-clock period, which is 1/(the slow oscillator) second. It is 1/32768s when SYNC\_MODE = 0x0  $t_{MEASx}$  is rounded up to an integer multiple of  $t_{CLOCK}$ .

In SYNC\_MODE = 0x0 and 0x2 a valid measurement requires:

t<sub>MEASUREMENT</sub> < FR\_CLK\_DIV/f<sub>PRIMARY\_FRAME\_CLOCK</sub>

Where:

fprimary\_frame\_clock = either the internal primary frame clock (SYNC\_MODE = 0) or the external frame clock input through the TRIG input (SYNC\_MODE = 0x2)

In SYNC\_MODE = 1 a valid measurement requires:

tmeasurement < trig\_period

Where:

 $t_{TRIG\ PERIOD}$  = Period of the TRIG input signal

| FR_CLK_DIV[14:0] | FRAME RATE (fps) |
|------------------|------------------|
| 0x7FFF           | Reserved         |
| 0x7FFE           | 1.000061         |
| 0x7FFD           | 1.000092         |
|                  |                  |
| 0x0100           | 128 (default)    |
|                  |                  |
| 0x0012           | 1820.44          |
| 0x0011           | 1927.53          |
| 0x0010           | 2048.00          |
| 0x000F to 0x0000 | Reserved         |

#### FR Clock Divider LSB (0x1C)

| BIT            | 7           | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|-------------|-----------------|---|---|---|---|---|---|
| Field          |             | FR_CLK_DIV[7:0] |   |   |   |   |   |   |
| Reset          | 0x00        |                 |   |   |   |   |   |   |
| Access<br>Type | Write, Read |                 |   |   |   |   |   |   |

#### FR\_CLK\_DIV

FR\_CLK\_DIV\_L is the lower byte of the 15-bit FR\_CLK\_DIV[14:0] clock divider that defines the frame rate. See FR\_CLK\_DIV\_H for more details.

### MEAS1 Selects (0x20)

| BIT            | 7 | 6             | 5 | 4 | 3                      | 2 | 1          | 0               |  |
|----------------|---|---------------|---|---|------------------------|---|------------|-----------------|--|
| Field          | _ | MEAS1_AM<br>B | ı | ı | MEAS1_DRVB[1:0]        |   | MEAS1_0    | MEAS1_DRVA[1:0] |  |
| Reset          | _ | 0             | - | _ | 0x0 0x0                |   | <b>(</b> 0 |                 |  |
| Access<br>Type | _ | Write, Read   | ı | - | Write, Read Write, Rea |   | Read       |                 |  |

#### MEAS1\_AMB

MEASx\_AMB (x = 1 to 6) enables or disables direct ambient measurement. When MEASx\_AMB is set to 1, MEASx\_DRVA, and MEASx\_DRVB are ignored.

Note: MEASx\_DRVA is in registers 0x25, 0x2D, 0x35, 0x3D, 0x45, 0x4D and MEASx\_DRVB is in registers 0x26, 0x2E, 0x36, 0x3E, 0x46, 0x4E.

The direct ambient measurement should always be the last enabled measurement in the frame.

| MEASx_AMB (x = 1 to 6) | DECODE                            |
|------------------------|-----------------------------------|
| 0                      | Normal mode                       |
| 1                      | Direct ambient-light measurement. |

#### MEAS1\_DRVB

MEASx\_DRVB (x = 1 to 6) selects the LEDn\_DRV pin (n = 1 to 4) driven by LED driver B.

| MEASx_DRVB (x = 1 to 6) | PIN DRIVEN BY LED DRIVER B |
|-------------------------|----------------------------|
| 0x0                     | LED1_DRV                   |
| 0x1                     | LED2_DRV                   |
| 0x2                     | LED3_DRV                   |
| 0x3                     | LED4_DRV                   |

#### MEAS1\_DRVA

MEASx\_DRVA (x = 1 to 6) selects the LEDn\_DRV pin (n = 1 to 4) driven by LED driver A.

| MEASx_DRVA (x = 1 to 6) | PIN DRIVEN BY LED DRIVER A |
|-------------------------|----------------------------|
| 0x0                     | LED1_DRV                   |
| 0x1                     | LED2_DRV                   |
| 0x2                     | LED3_DRV                   |
| 0x3                     | LED4_DRV                   |

#### **MEAS1 Configuration 1 (0x21)**

| BIT            | 7       | 6         | 5 | 4                 | 3    | 2               | 1           | 0   |
|----------------|---------|-----------|---|-------------------|------|-----------------|-------------|-----|
| Field          | MEAS1_P | DSEL[1:0] | _ | - MEAS1_TINT[1:0] |      | MEAS1_AVER[2:0] |             | :0] |
| Reset          | 0;      | x0        | _ | 0x3               |      | 0x0             |             |     |
| Access<br>Type | Write,  | Read      | _ | Write,            | Read |                 | Write, Read |     |

#### **MEAS1\_PDSEL**

MEASx\_PDSEL (x = 1 to 6) selects which PDm\_IN (m = 1, 2) pin is connected to optical channel 1 or 2.

| MEASx_PDSEL (x = 1 to 6) | MAX86174A                                    | MAX86174B                             |
|--------------------------|----------------------------------------------|---------------------------------------|
| 0x0                      | PD1 + PD2 combined and connected to PPG1     | Reserved                              |
| 0x1                      | PD2 connected to PPG1; PD1 connected to PPG2 | PD2 connected to a single PPG channel |
| 0x2                      | PD1 connected to PPG1; PD2 connected to PPG2 | PD2 connected to a single PPG channel |
| 0x3                      | PD1 + PD2 combined and connected to PPG2     | Reserved                              |

#### **MEAS1\_TINT**

MEASx TINT[1:0] (x = 1 to 6) bits set the integration time of PPG ADC as shown in the table below.

| MEASx_TINT<br>(x = 1 to 6) | INTEGRATION TIME (µs) (WITH 3rd ORDER DECIMATION FILTER) | INTEGRATION TIME (μs)<br>(WITH 2nd ORDER DECIMATION FILTER) |
|----------------------------|----------------------------------------------------------|-------------------------------------------------------------|
| 0x0                        | 14.6                                                     | -                                                           |
| 0x1                        | 29.2                                                     | -                                                           |
| 0x2                        | 58.6                                                     | -                                                           |
| 0x3                        | 117.1                                                    | 118.2                                                       |

### MEAS1\_AVER

MEASx\_AVER (x = 1 to 6) sets the number of exposures per burst that are averaged in order to improve the exposure SNR and improve ambient light cancellation. MEASx\_AVER works only with central ambient cancellation, MEASx\_FILT\_SEL = 0.

| MEASx_AVER (x = 1 to 6) | NUMBER OF LED PULSES IN BURST |
|-------------------------|-------------------------------|
| 0x0                     | 1                             |
| 0x1                     | 2                             |
| 0x2                     | 4                             |
| 0x3                     | 8                             |
| 0x4                     | 16                            |
| 0x5                     | 32                            |
| 0x6                     | 64                            |
| 0x7                     | 128                           |

#### **MEAS1 Configuration 2 (0x22)**

| BIT            | 7                   | 6                  | 5                  | 4 | 3                           | 2 | 1                           | 0    |
|----------------|---------------------|--------------------|--------------------|---|-----------------------------|---|-----------------------------|------|
| Field          | MEAS1_SI<br>NC3_SEL | MEAS1_FIL<br>T_SEL | MEAS1_LED_RGE[1:0] |   | MEAS1_PPG2_ADC_RGE<br>[1:0] |   | MEAS1_PPG1_ADC_RGE<br>[1:0] |      |
| Reset          | 0                   | 0                  | 0x3                |   | 0x2                         |   | 0x2                         |      |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |   | Write, Read                 |   | Write,                      | Read |

#### MEAS1\_SINC3\_SEL

MEASx\_SINC3\_SEL (x = 1 to 6) enables the SINC3 decimation filter for the PPG ADC. If MEASx\_SINC3\_SEL is set to 1, MEASx\_TINT must be set to 3 and MEASx\_FILT2\_SEL must be set to 0. For more information on SINC3 decimation filter, see the ADC Decimation Filter section.

| MEASx_SINC3_SEL (x = 1 to 6) | DECODE                                                              |
|------------------------------|---------------------------------------------------------------------|
| 0                            | SINC3 filter is not used.                                           |
| 1                            | SINC3 decimation filter is used only if MEASx_TINT = 0x3 (115.2µs). |

#### MEAS1\_FILT\_SEL

 $MEASx\_FILT\_SEL$  (x = 1 to 6) selects the digital ambient light rejection method to be used. See the Ambient Rejection section for details and if burst average is applied with ALC, see the Burst Average section for ADC conversions.

| MEASx_FILT_SEL (x = 1 to 6) | DECODE                                                  |
|-----------------------------|---------------------------------------------------------|
| 0                           | Center difference method (CDM)                          |
| 1                           | Forward difference method (FDM). MEASx_AVER is ignored. |

#### MEAS1\_LED\_RGE

MEASx\_LED\_RGE (x = 1 to 6) selects the drive-current range for both LED current drivers, DRVA and DRVB, for measurement x.

| MEASx_LED_RGE (x = 1 to 6) | LED FULL SCALE RANGE (mA) |
|----------------------------|---------------------------|
| 0x0                        | 32                        |
| 0x1                        | 64                        |
| 0x2                        | 96                        |
| 0x3                        | 128                       |

#### MEAS1\_PPG2\_ADC\_RGE

MEASx\_PPGy\_ADC\_RGE (x = 1 to 6, y = 1, 2) selects the positive full-scale range of the PPG ADC on channel y for measurement x.

| MEASx_PPGy_ADC_RGE (x = 1 to 6, y = 1, 2) | LSB (pA) | FULL SCALE (μA) |
|-------------------------------------------|----------|-----------------|
| 0x0                                       | 7.6      | 4.0             |
| 0x1                                       | 15.3     | 8.0             |
| 0x2                                       | 30.5     | 16.0            |
| 0x3                                       | 61.0     | 32.0            |

#### MEAS1\_PPG1\_ADC\_RGE

See MEAS1 PPG2 ADC RGE[3:2](0x22) for details.

#### **MEAS1 Configuration 3 (0x23)**

| BIT            | 7    | 6           | 5      | 4         | 3             | 2 | 1 | 0 |
|----------------|------|-------------|--------|-----------|---------------|---|---|---|
| Field          | MEAS | 1_PD_SETLN  | G[2:0] | MEAS1_LED | _SETLNG[1:    | _ | _ | _ |
| Reset          |      | 0x1         |        | 0>        | <b>&lt;</b> 1 | _ | _ | _ |
| Access<br>Type |      | Write, Read |        | Write,    | Read          | _ | _ | _ |

#### MEAS1\_PD\_SETLNG

MEAS $x_PD_SETLNG$  (x = 1 to 6) selects the time between dark and exposure samples for measurement x. This accomodates photodiodes with longer settling time.

PD settling time should always be more than LED settling time selected in MEASx\_LED\_SETLNG. Note that for the same setting of both MEASx\_PD\_SETLNG and MEASx\_LED\_SETLNG, the photodiode settling time is 0.1µs higher than the LED settling time, and thus, satisfies the requirement of higher PD settling time.

| MEASx_PD_SETLNG (x = 1 to 6) | TIME BETWEEN SAMPLES (μs) |
|------------------------------|---------------------------|
| 0x0                          | 8.1                       |
| 0x1                          | 12.1                      |
| 0x2                          | 16.1                      |
| 0x3                          | 24.1                      |
| 0x4                          | 32.1                      |
| 0x5                          | 48.1                      |
| 0x6                          | 64.1                      |
| 0x7                          | 80.1                      |

#### MEAS1\_LED\_SETLNG

MEASx\_LED\_SETLNG (x = 1 to 6) selects the delay from the rising edge of LED to start of the exposure ADC integration. This allows for the LED current to settle before the start of ADC integration. LED settling time for a measurement must always be less than the photodiode settling time for the same measurement.

| MEASx_LED_SETLNG (x = 1 to 6) | LED SETTLING TIME (μs) |
|-------------------------------|------------------------|
| 0x0                           | 8.0                    |
| 0x1                           | 12.0                   |
| 0x2                           | 16.0                   |
| 0x3                           | 24.0                   |

#### **MEAS1 Configuration 4 (0x24)**

| BIT            | 7 | 6     | 5           | 4        | 3 | 2                      | 1 | 0 |
|----------------|---|-------|-------------|----------|---|------------------------|---|---|
| Field          | ı | MEAS1 | _PPG2_DACC  | )FF[2:0] | ı | MEAS1_PPG1_DACOFF[2:0] |   |   |
| Reset          | - | 0x0   |             |          | _ | 0x0                    |   |   |
| Access<br>Type | - |       | Write, Read |          |   | Write, Read            |   |   |

#### MEAS1\_PPG2\_DACOFF

MEASx\_PPGy\_DACOFF (x = 1 to 6, y = 1, 2) selects the offset DAC current added to the ADC on PPG channel y during the exposure interval. This allows for a larger convertible exposure range for ADCy by sourcing some of the photodiode DC exposure current from the offset DAC.

| MEASx_PPGy_DACOFF ( $x = 1 \text{ to } 6, y = 1, 2$ ) | INJECTED OFFSET CURRENT TO ADCy (μA) |
|-------------------------------------------------------|--------------------------------------|
| 0x0                                                   | 0                                    |
| 0x1                                                   | 4                                    |
| 0x2                                                   | 8                                    |
| 0x3                                                   | 12                                   |
| 0x4                                                   | 16                                   |
| 0x5                                                   | 20                                   |
| 0x6                                                   | 24                                   |
| 0x7                                                   | 28                                   |

#### MEAS1\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### **MEAS1 LEDA Current (0x25)**

| BIT            | 7 | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|----------------|---|--------------------|---|---|---|---|---|---|--|--|--|
| Field          |   | MEAS1_DRVA_PA[7:0] |   |   |   |   |   |   |  |  |  |
| Reset          |   | 0x00               |   |   |   |   |   |   |  |  |  |
| Access<br>Type |   | Write, Read        |   |   |   |   |   |   |  |  |  |

#### MEAS1\_DRVA\_PA

MEASx\_DRVA\_PA (x = 1 to 6) selects the LED drive current on LED driver A for measurement x. If MEASx\_DRVA\_PA is set to 0x00, LED Driver A is disabled for measurement x. The full-scale range selected by MEASx\_LED\_RGE determines the LED current for each LSB of the MEASx\_DRVA\_PA setting. For example, when MEASx\_LED\_RGE = 0,

one LSB of MEASx\_DRVA\_PA is 0.125mA of the LED driver current on DRVA, but when MEASx\_LED\_RGE = 3, each LSB of MEASx\_DRVA\_PA setting is 0.5mA of the LED driver current on DRVA.

Note: MEASx\_LED\_RGE[5:4] is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A

| MEASx_DRVA_PA (x = 1 to 6) | LED CURRENT (mA) | LED CURRENT (mA) | LED CURRENT (mA) | LED CURRENT (mA) |
|----------------------------|------------------|------------------|------------------|------------------|
| MEASx_LED_RGE (x = 1 to 6) | 0x0              | 0x1              | 0x2              | 0x3              |
| 0x00                       | 0.000            | 0.000            | 0.000            | 0.000            |
| 0x01                       | 0.125            | 0.250            | 0.375            | 0.500            |
| 0x02                       | 0.250            | 0.500            | 0.750            | 1.000            |
| 0x03                       | 0.375            | 0.750            | 1.125            | 1.500            |
|                            |                  |                  |                  |                  |
| 0xFC                       | 31.500           | 63.000           | 94.500           | 126.000          |
| 0xFD                       | 31.625           | 63.250           | 94.875           | 126.500          |
| 0xFE                       | 31.750           | 63.500           | 95.250           | 127.000          |
| 0xFF                       | 31.875           | 63.750           | 95.625           | 127.500          |
| LSB                        | 0.125            | 0.250            | 0.375            | 0.500            |

#### **MEAS1 LEDB Current (0x26)**

| BIT            | 7 | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|----------------|---|--------------------|---|---|---|---|---|---|--|--|--|
| Field          |   | MEAS1_DRVB_PA[7:0] |   |   |   |   |   |   |  |  |  |
| Reset          |   | 0x00               |   |   |   |   |   |   |  |  |  |
| Access<br>Type |   | Write, Read        |   |   |   |   |   |   |  |  |  |

#### MEAS1\_DRVB\_PA

MEASx\_DRVB\_PA (x = 1 to 6) selects the LED drive current on LED driver B for measurement x. If MEASx\_DRVB\_PA is set to 0x00, LED Driver B is disabled for measurement x. The full-scale range selected by MEASx\_LED\_RGE determines the LED current for each LSB of the MEASx\_DRVB\_PA setting. For example, when MEASx\_LED\_RGE = 0, one LSB of MEASx\_DRVB\_PA is 0.125mA of the LED driver current on DRVB, but when MEASx\_LED\_RGE = 3, each LSB of MEASx\_DRVB\_PA setting is 0.5mA of the LED driver current on DRVB.

Note: MEASx LED RGE[5:4] is in registers 0x22, 0x2A, 0x32, 0x3A, 0x42, 0x4A

| MEASx_DRVB_PA (x = 1 to 6) | LED CURRENT (mA) | LED CURRENT (mA) | LED CURRENT (mA) | LED CURRENT (mA) |
|----------------------------|------------------|------------------|------------------|------------------|
| MEASx_LED_RGE (x = 1 to 6) | 0x0              | 0x1              | 0x2              | 0x3              |
| 0x00                       | 0.000            | 0.000            | 0.000            | 0.000            |
| 0x01                       | 0.125            | 0.250            | 0.375            | 0.500            |
| 0x02                       | 0.250            | 0.500            | 0.750            | 1.000            |
| 0x03                       | 0.375            | 0.750            | 1.125            | 1.500            |
|                            |                  |                  |                  |                  |
| 0xFC                       | 31.500           | 63.000           | 94.500           | 126.000          |
| 0xFD                       | 31.625           | 63.250           | 94.875           | 126.500          |
| 0xFE                       | 31.750           | 63.500           | 95.250           | 127.000          |
| 0xFF                       | 31.875           | 63.750           | 95.625           | 127.500          |
| LSB                        | 0.125            | 0.250            | 0.375            | 0.500            |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS2 Selects (0x28)

| BIT            | 7 | 6             | 5 | 4 | 3               | 2 | 1                    | 0 |
|----------------|---|---------------|---|---|-----------------|---|----------------------|---|
| Field          | _ | MEAS2_AM<br>B | - | _ | MEAS2_DRVB[1:0] |   | MEAS2_DRVA[1:0]      |   |
| Reset          | _ | 0             | _ | _ | 0x0             |   | 0x0                  |   |
| Access<br>Type | _ | Write, Read   | _ | _ | Write, Read     |   | rite, Read Write, Re |   |

#### MEAS2\_AMB

See MEAS1\_AMB[6](0x20) for details.

#### **MEAS2 DRVB**

See MEAS1\_DRVB[3:2](0x20) for details.

#### MEAS2\_DRVA

See MEAS1\_DRVA[1:0](0x20) for details.

#### **MEAS2 Configuration 1 (0x29)**

| BIT            | 7                | 6    | 5 | 4               | 3    | 2               | 1 | 0 |
|----------------|------------------|------|---|-----------------|------|-----------------|---|---|
| Field          | MEAS2_PDSEL[1:0] |      | _ | MEAS2_TINT[1:0] |      | MEAS2_AVER[2:0] |   |   |
| Reset          | 0x0              |      | _ | 0x3             |      | 0x0             |   |   |
| Access<br>Type | Write,           | Read | _ | Write,          | Read | Write, Read     |   |   |

#### MEAS2\_PDSEL

See MEAS1\_PDSEL[7:6](0x21) for details.

#### MEAS2\_TINT

See MEAS1\_TINT[4:3](0x21) or details.

#### MEAS2\_AVER

See MEAS1\_AVER[2:0](0x21) for details.

#### **MEAS2 Configuration 2 (0x2A)**

| BIT            | 7                   | 6                  | 5                  | 4   | 3                           | 2   | 1                           | 0          |
|----------------|---------------------|--------------------|--------------------|-----|-----------------------------|-----|-----------------------------|------------|
| Field          | MEAS2_SI<br>NC3_SEL | MEAS2_FIL<br>T_SEL | MEAS2_LED_RGE[1:0] |     | MEAS2_PPG2_ADC_RGE<br>[1:0] |     | MEAS2_PPG1_ADC_RGE<br>[1:0] |            |
| Reset          | 0                   | 0                  | 0:                 | 0x3 |                             | 0x2 |                             | <b>(</b> 2 |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |     | Write, Read                 |     | Write, Read                 |            |

#### MEAS2\_SINC3\_SEL

See MEAS1\_SINC3\_SEL[7](0x22) for details.

#### MEAS2\_FILT\_SEL

See MEAS1\_FILT\_SEL[6](0x22) for details.

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS2\_LED\_RGE

See MEAS1\_LED\_RGE[5:4](0x22) for details.

#### MEAS2\_PPG2\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### MEAS2\_PPG1\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### **MEAS2 Configuration 3 (0x2B)**

| BIT            | 7    | 6           | 5      | 4                      | 3          | 2 | 1 | 0 |
|----------------|------|-------------|--------|------------------------|------------|---|---|---|
| Field          | MEAS | S2_PD_SETLN | G[2:0] | MEAS2_LED_SETLNG[1: 0] |            | ı | _ | - |
| Reset          |      | 0x1         |        | 0:                     | <b>k</b> 1 | _ | _ | _ |
| Access<br>Type |      | Write, Read |        | Write,                 | Read       | ı | _ | - |

#### MEAS2\_PD\_SETLNG

See MEAS1\_PD\_SETLNG[7:5](0x23) for details.

#### MEAS2\_LED\_SETLNG

See MEAS1\_LED\_SETLNG[4:3](0x23) for details.

#### **MEAS2 Configuration 4 (0x2C)**

| BIT            | 7 | 6     | 5           | 4        | 3 | 2                      | 1 | 0 |
|----------------|---|-------|-------------|----------|---|------------------------|---|---|
| Field          | _ | MEAS2 | _PPG2_DACC  | )FF[2:0] | _ | MEAS2_PPG1_DACOFF[2:0] |   |   |
| Reset          | _ |       | 0x0         |          |   | 0x0                    |   |   |
| Access<br>Type | _ |       | Write, Read |          |   | Write, Read            |   |   |

#### MEAS2\_PPG2\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### MEAS2\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### MEAS2 LEDA Current (0x2D)

| BIT            | 7 | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|----------------|---|--------------------|---|---|---|---|---|---|--|--|--|
| Field          |   | MEAS2_DRVA_PA[7:0] |   |   |   |   |   |   |  |  |  |
| Reset          |   | 0x00               |   |   |   |   |   |   |  |  |  |
| Access<br>Type |   | Write, Read        |   |   |   |   |   |   |  |  |  |

#### MEAS2\_DRVA\_PA

See MEAS1\_DRVA\_PA[7:0](0x25) for details.

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS2 LEDB Current (0x2E)

| BIT            | 7 | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----------------|---|--------------------|---|---|---|---|---|---|--|--|
| Field          |   | MEAS2_DRVB_PA[7:0] |   |   |   |   |   |   |  |  |
| Reset          |   | 0x00               |   |   |   |   |   |   |  |  |
| Access<br>Type |   | Write, Read        |   |   |   |   |   |   |  |  |

#### MEAS2\_DRVB\_PA

See MEAS1\_DRVB\_PA[7:0](0x26) for details.

#### MEAS3 Selects (0x30)

| BIT            | 7 | 6             | 5 | 4 | 3               | 2 | 1               | 0          |
|----------------|---|---------------|---|---|-----------------|---|-----------------|------------|
| Field          | _ | MEAS3_AM<br>B | - | _ | MEAS3_DRVB[1:0] |   | MEAS3_DRVA[1:0] |            |
| Reset          | _ | 0             | - | _ | 0x0             |   | 0>              | <b>k</b> 0 |
| Access<br>Type | _ | Write, Read   | - | _ | Write, Read     |   | Write, Read     |            |

#### MEAS3\_AMB

See MEAS1\_AMB[6](0x20) for details.

#### MEAS3\_DRVB

See MEAS1\_DRVB[3:2](0x20) for details.

#### MEAS3\_DRVA

See MEAS1\_DRVA[1:0](0x20) for details.

#### **MEAS3 Configuration 1 (0x31)**

| BIT            | 7       | 6         | 5 | 4      | 3          | 2               | 1 | 0 |
|----------------|---------|-----------|---|--------|------------|-----------------|---|---|
| Field          | MEAS3_P | DSEL[1:0] | _ | MEAS3_ | TINT[1:0]  | MEAS3_AVER[2:0] |   |   |
| Reset          | 0:      | x0        | - | 0:     | <b>k</b> 3 | 0x0             |   |   |
| Access<br>Type | Write,  | Read      | ı | Write, | Read       | Write, Read     |   |   |

#### MEAS3\_PDSEL

See MEAS1\_PDSEL[7:6](0x21) for details.

### **MEAS3\_TINT**

See MEAS1\_TINT[4:3](0x21) for details.

#### MEAS3\_AVER

See MEAS1\_AVER[2:0](0x21) for details.

#### **MEAS3 Configuration 2 (0x32)**

| BIT            | 7                   | 6                  | 5                  | 4   | 3           | 2                                                  | 1           | 0          |
|----------------|---------------------|--------------------|--------------------|-----|-------------|----------------------------------------------------|-------------|------------|
| Field          | MEAS3_SI<br>NC3_SEL | MEAS3_FIL<br>T_SEL | MEAS3_LED_RGE[1:0] |     | _           | S3_PPG2_ADC_RGE   MEAS3_PPG1_ADC_RG<br>[1:0] [1:0] |             |            |
| Reset          | 0                   | 0                  | 0:                 | 0x3 |             | <b>&lt;</b> 2                                      | 0:          | <b>(</b> 2 |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |     | Write, Read |                                                    | Write, Read |            |

#### MEAS3\_SINC3\_SEL

See MEAS1\_SINC3\_SEL[7](0x22) for details.

#### MEAS3\_FILT\_SEL

See MEAS1\_FILT\_SEL[6](0x22) for details.

#### MEAS3\_LED\_RGE

See MEAS1\_LED\_RGE[5:4](0x22) for details.

#### MEAS3\_PPG2\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### MEAS3\_PPG1\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### **MEAS3 Configuration 3 (0x33)**

| BIT            | 7    | 6           | 5      | 4                      | 3 | 2            | 1 | 0 |
|----------------|------|-------------|--------|------------------------|---|--------------|---|---|
| Field          | MEAS | 3_PD_SETLN  | G[2:0] | MEAS3_LED_SETLNG[1: 0] |   | -            | _ | - |
| Reset          |      | 0x1         | 0x1    |                        | _ | _            | _ |   |
| Access<br>Type |      | Write, Read |        | Write, Read            |   | <del>-</del> | _ | _ |

#### MEAS3\_PD\_SETLNG

See MEAS1\_PD\_SETLNG[7:5](0x23) for details.

#### MEAS3\_LED\_SETLNG

See MEAS1\_LED\_SETLNG[4:3](0x23) for details.

### MEAS3 Configuration 4 (0x34)

| BIT            | 7 | 6     | 5                      | 4 | 3 | 2           | 1                      | 0 |  |
|----------------|---|-------|------------------------|---|---|-------------|------------------------|---|--|
| Field          | _ | MEAS3 | MEAS3_PPG2_DACOFF[2:0] |   |   | MEAS3       | MEAS3_PPG1_DACOFF[2:0] |   |  |
| Reset          | _ |       | 0x0                    |   |   |             | 0x0                    |   |  |
| Access<br>Type | _ |       | Write, Read            |   |   | Write, Read |                        |   |  |

#### MEAS3\_PPG2\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS3\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### **MEAS3 LEDA Current (0x35)**

| BIT            | 7 | 6                  | 5 | 4      | 3    | 2 | 1 | 0 |  |
|----------------|---|--------------------|---|--------|------|---|---|---|--|
| Field          |   | MEAS3_DRVA_PA[7:0] |   |        |      |   |   |   |  |
| Reset          |   | 0x00               |   |        |      |   |   |   |  |
| Access<br>Type |   |                    |   | Write, | Read |   |   |   |  |

### MEAS3\_DRVA\_PA

See MEAS1\_DRVA\_PA[7:0](0x25) for details.

### MEAS3 LEDB Current (0x36)

| BIT            | 7 | 6                  | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----------------|---|--------------------|---|---|---|---|---|---|--|--|
| Field          |   | MEAS3_DRVB_PA[7:0] |   |   |   |   |   |   |  |  |
| Reset          |   | 0x00               |   |   |   |   |   |   |  |  |
| Access<br>Type |   | Write, Read        |   |   |   |   |   |   |  |  |

#### MEAS3\_DRVB\_PA

See MEAS1\_DRVB\_PA[7:0](0x26) for details.

#### MEAS4 Selects (0x38)

| BIT            | 7 | 6             | 5 | 4 | 3               | 2 | 1               | 0          |
|----------------|---|---------------|---|---|-----------------|---|-----------------|------------|
| Field          | _ | MEAS4_AM<br>B | - | _ | MEAS4_DRVB[1:0] |   | MEAS4_DRVA[1:0] |            |
| Reset          | _ | 0             | - | _ | 0x0             |   | 0>              | <b>(</b> 0 |
| Access<br>Type | _ | Write, Read   | - | _ | Write, Read     |   | Write, Read     |            |

#### MEAS4\_AMB

See MEAS1\_AMB[6](0x20) for details.

#### MEAS4\_DRVB

See MEAS1\_DRVB[3:2](0x20) for details.

#### MEAS4\_DRVA

See MEAS1\_DRVA[1:0](0x20) for details.

#### **MEAS4 Configuration 1 (0x39)**

| BIT            | 7       | 6         | 5 | 4           | 3          | 2               | 1 | 0 |
|----------------|---------|-----------|---|-------------|------------|-----------------|---|---|
| Field          | MEAS4_P | DSEL[1:0] | _ | MEAS4_      | TINT[1:0]  | MEAS4_AVER[2:0] |   |   |
| Reset          | 0:      | x0        | _ | 0:          | <b>k</b> 3 | 0x0             |   |   |
| Access<br>Type | Write,  | Read      | - | Write, Read |            | Write, Read     |   |   |

#### **MEAS4\_PDSEL**

See MEAS1\_PDSEL[7:6](0x21) for details.

#### **MEAS4 TINT**

See MEAS1\_TINT[4:3](0x21) for details.

#### MEAS4\_AVER

See MEAS1\_AVER[2:0](0x21) for details.

#### **MEAS4 Configuration 2 (0x3A)**

| BIT            | 7                   | 6                  | 5                  | 4          | 3                           | 2  | 1                           | 0          |
|----------------|---------------------|--------------------|--------------------|------------|-----------------------------|----|-----------------------------|------------|
| Field          | MEAS4_SI<br>NC3_SEL | MEAS4_FIL<br>T_SEL | MEAS4_LED_RGE[1:0] |            | MEAS4_PPG2_ADC_RGE<br>[1:0] |    | MEAS4_PPG1_ADC_RGE<br>[1:0] |            |
| Reset          | 0                   | 0                  | 0>                 | <b>k</b> 3 | 0)                          | x2 | 0>                          | <b>(</b> 2 |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |            | Write, Read                 |    | Write, Read                 |            |

#### MEAS4\_SINC3\_SEL

See MEAS1\_SINC3\_SEL[7](0x22) for details.

#### MEAS4\_FILT\_SEL

See MEAS1\_FILT\_SEL[6](0x22) for details.

#### MEAS4\_LED\_RGE

See MEAS1\_LED\_RGE[5:4](0x22) for details.

#### MEAS4\_PPG2\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### MEAS4\_PPG1\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### **MEAS4 Configuration 3 (0x3B)**

| BIT            | 7    | 6           | 5      | 4                      | 3          | 2 | 1 | 0 |
|----------------|------|-------------|--------|------------------------|------------|---|---|---|
| Field          | MEAS | 64_PD_SETLN | G[2:0] | MEAS4_LED_SETLNG[1: 0] |            | - | _ | _ |
| Reset          |      | 0x1         |        | 0:                     | <b>k</b> 1 | - | _ | _ |
| Access<br>Type |      | Write, Read |        | Write,                 | Read       | - | _ | _ |

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS4\_PD\_SETLNG

See MEAS1\_PD\_SETLNG[7:5](0x23) for details.

#### MEAS4\_LED\_SETLNG

See MEAS1\_LED\_SETLNG[4:3](0x23) for details.

#### **MEAS4 Configuration 4 (0x3C)**

| BIT            | 7 | 6     | 5           | 4        | 3 | 2                      | 1   | 0   |  |
|----------------|---|-------|-------------|----------|---|------------------------|-----|-----|--|
| Field          | _ | MEAS4 | _PPG2_DACC  | )FF[2:0] | _ | MEAS4_PPG1_DACOFF[2:0] |     |     |  |
| Reset          | _ |       | 0x0         |          |   |                        | 0x0 | 0x0 |  |
| Access<br>Type | _ |       | Write, Read |          |   | Write, Read            |     |     |  |

#### MEAS4\_PPG2\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### MEAS4\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### **MEAS4 LEDA Current (0x3D)**

| BIT            | 7 | 6                  | 5 | 4      | 3    | 2 | 1 | 0 |  |
|----------------|---|--------------------|---|--------|------|---|---|---|--|
| Field          |   | MEAS4_DRVA_PA[7:0] |   |        |      |   |   |   |  |
| Reset          |   | 0x00               |   |        |      |   |   |   |  |
| Access<br>Type |   |                    |   | Write, | Read |   |   |   |  |

#### MEAS4\_DRVA\_PA

See MEAS1\_DRVA\_PA[7:0](0x25) for details.

#### MEAS4 LEDB Current (0x3E)

| BIT            | 7 | 6    | 5 | 4        | 3          | 2 | 1 | 0 |  |
|----------------|---|------|---|----------|------------|---|---|---|--|
| Field          |   |      |   | MEAS4_DR | VB_PA[7:0] |   |   |   |  |
| Reset          |   | 0x00 |   |          |            |   |   |   |  |
| Access<br>Type |   |      |   | Write,   | Read       |   |   |   |  |

#### MEAS4\_DRVB\_PA

See MEAS1\_DRVB\_PA[7:0](0x26) for details.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS5 Selects (0x40)

| BIT            | 7 | 6             | 5 | 4 | 3               | 2 | 1               | 0 |
|----------------|---|---------------|---|---|-----------------|---|-----------------|---|
| Field          | _ | MEAS5_AM<br>B | ı | ı | MEAS5_DRVB[1:0] |   | MEAS5_DRVA[1:0] |   |
| Reset          | _ | 0             | - | - | 0x0             |   | 0:              | 0 |
| Access<br>Type | _ | Write, Read   | - | - | Write, Read     |   | Write, Read     |   |

#### MEAS5\_AMB

See MEAS1\_AMB[6](0x20) for details.

#### **MEAS5 DRVB**

See MEAS1\_DRVB[3:2](0x20) for details.

#### MEAS5\_DRVA

See MEAS1\_DRVA[1:0](0x20) for details.

#### **MEAS5 Configuration 1 (0x41)**

| BIT            | 7       | 6         | 5 | 4                               | 3          | 2           | 1   | 0 |
|----------------|---------|-----------|---|---------------------------------|------------|-------------|-----|---|
| Field          | MEAS5_P | DSEL[1:0] | _ | MEAS5_TINT[1:0] MEAS5_AVER[2:0] |            |             | :0] |   |
| Reset          | 0:      | x0        | _ | 0:                              | <b>k</b> 3 | 0x0         |     |   |
| Access<br>Type | Write,  | Read      | _ | Write,                          | Read       | Write, Read |     |   |

#### MEAS5\_PDSEL

See MEAS1\_PDSEL[7:6](0x21) for details.

#### MEAS5\_TINT

See MEAS1\_TINT[4:3](0x21) for details.

#### MEAS5\_AVER

See MEAS1\_AVER[2:0](0x21) for details.

#### **MEAS5 Configuration 2 (0x42)**

| BIT            | 7                   | 6                  | 5                  | 4 | 3                | 2                | 1                                     | 0          |  |
|----------------|---------------------|--------------------|--------------------|---|------------------|------------------|---------------------------------------|------------|--|
| Field          | MEAS5_SI<br>NC3_SEL | MEAS5_FIL<br>T_SEL | MEAS5_LED_RGE[1:0] |   | MEAS5_PPG<br>[1: | 2_ADC_RGE<br>:0] | ADC_RGE   MEAS5_PPG1_ADC_RGE<br>[1:0] |            |  |
| Reset          | 0                   | 0                  | 0x3                |   | 0>               | <b>(</b> 2       | 0:                                    | <b>k</b> 2 |  |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |   | Write, Read      |                  | Write, Read                           |            |  |

#### MEAS5\_SINC3\_SEL

See MEAS1\_SINC3\_SEL[7](0x22) for details.

#### MEAS5\_FILT\_SEL

See MEAS1\_FILT\_SEL[6](0x22) for details.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS5\_LED\_RGE

See MEAS1\_LED\_RGE[5:4](0x22) for details.

#### MEAS5\_PPG2\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### MEAS5\_PPG1\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### **MEAS5 Configuration 3 (0x43)**

| BIT            | 7    | 6           | 5      | 4                      | 3          | 2 | 1 | 0 |
|----------------|------|-------------|--------|------------------------|------------|---|---|---|
| Field          | MEAS | S5_PD_SETLN | G[2:0] | MEAS5_LED_SETLNG[1: 0] |            | ı | _ | 1 |
| Reset          |      | 0x1         |        | 0:                     | <b>k</b> 1 | _ | _ | - |
| Access<br>Type |      | Write, Read |        | Write, Read            |            | - | _ | _ |

#### MEAS5\_PD\_SETLNG

See MEAS1\_PD\_SETLNG[7:5](0x23) for details.

#### MEAS5\_LED\_SETLNG

See MEAS1\_LED\_SETLNG[4:3](0x23) for details.

#### **MEAS5 Configuration 4 (0x44)**

| BIT            | 7 | 6     | 5                      | 4 | 3 | 2     | 1                      | 0 |  |
|----------------|---|-------|------------------------|---|---|-------|------------------------|---|--|
| Field          | _ | MEAS5 | MEAS5_PPG2_DACOFF[2:0] |   |   | MEAS5 | MEAS5_PPG1_DACOFF[2:0] |   |  |
| Reset          | _ |       | 0x0                    |   |   |       | 0x0                    |   |  |
| Access<br>Type | _ |       | Write, Read            |   |   |       | Write, Read            |   |  |

#### MEAS5\_PPG2\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### MEAS5\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### **MEAS5 LEDA Current (0x45)**

| BIT            | 7 | 6                  | 5 | 4      | 3    | 2 | 1 | 0 |  |
|----------------|---|--------------------|---|--------|------|---|---|---|--|
| Field          |   | MEAS5_DRVA_PA[7:0] |   |        |      |   |   |   |  |
| Reset          |   | 0x00               |   |        |      |   |   |   |  |
| Access<br>Type |   |                    |   | Write, | Read |   |   |   |  |

#### MEAS5\_DRVA\_PA

See MEAS1\_DRVA\_PA[7:0](0x25) for details.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### **MEAS5 LEDB Current (0x46)**

| BIT            | 7 | 6    | 5 | 4        | 3          | 2 | 1 | 0 |  |
|----------------|---|------|---|----------|------------|---|---|---|--|
| Field          |   |      |   | MEAS5_DR | VB_PA[7:0] |   |   |   |  |
| Reset          |   | 0x00 |   |          |            |   |   |   |  |
| Access<br>Type |   |      |   | Write,   | Read       |   |   |   |  |

### MEAS5\_DRVB\_PA

See MEAS1\_DRVB\_PA[7:0](0x26) for details.

#### MEAS6 Selects (0x48)

| BIT            | 7 | 6             | 5 | 4 | 3               | 2 | 1               | 0          |
|----------------|---|---------------|---|---|-----------------|---|-----------------|------------|
| Field          | _ | MEAS6_AM<br>B | - | _ | MEAS6_DRVB[1:0] |   | MEAS6_DRVA[1:0] |            |
| Reset          | _ | 0             | - | _ | 0x0             |   | 0>              | <b>(</b> 0 |
| Access<br>Type | _ | Write, Read   | - | _ | Write, Read     |   | Write, Read     |            |

#### MEAS6\_AMB

See MEAS1\_AMB[6](0x20) for details.

#### MEAS6\_DRVB

See MEAS1\_DRVB[3:2](0x20) for details.

### MEAS6\_DRVA

See MEAS1\_DRVA[1:0](0x20) for details.

#### **MEAS6 Configuration 1 (0x49)**

| BIT            | 7       | 6         | 5 | 4      | 3         | 2           | 1   | 0 |
|----------------|---------|-----------|---|--------|-----------|-------------|-----|---|
| Field          | MEAS6_P | DSEL[1:0] | _ | MEAS6_ | TINT[1:0] | MI          | :0] |   |
| Reset          | 0:      | 0x0       |   | 0:     | x3        | 0x0         |     |   |
| Access<br>Type | Write,  | Read      | - | Write, | Read      | Write, Read |     |   |

#### MEAS6\_PDSEL

See MEAS1\_PDSEL[7:6](0x21) for details.

### **MEAS6\_TINT**

See MEAS1\_TINT[4:3](0x21) for details.

#### MEAS6\_AVER

See MEAS1\_AVER[2:0](0x21) for details.

#### **MEAS6 Configuration 2 (0x4A)**

| BIT            | 7                   | 6                  | 5                  | 4   | 3                        | 2             | 1                        | 0             |
|----------------|---------------------|--------------------|--------------------|-----|--------------------------|---------------|--------------------------|---------------|
| Field          | MEAS6_SI<br>NC3_SEL | MEAS6_FIL<br>T_SEL | MEAS6_LED_RGE[1:0] |     | MEAS6_PPG2_ADC_RGE [1:0] |               | MEAS6_PPG1_ADC_RGE [1:0] |               |
| Reset          | 0                   | 0                  | 0:                 | 0x3 |                          | <b>&lt;</b> 2 | 0:                       | <b>&lt;</b> 2 |
| Access<br>Type | Write, Read         | Write, Read        | Write, Read        |     | Write, Read              |               | Write,                   | Read          |

#### MEAS6\_SINC3\_SEL

See MEAS1\_SINC3\_SEL[7](0x22) for details.

#### MEAS6\_FILT\_SEL

See MEAS1\_FILT\_SEL[6](0x22) for details.

#### MEAS6\_LED\_RGE

See MEAS1\_LED\_RGE[5:4](0x22) for details.

#### MEAS6\_PPG2\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### MEAS6\_PPG1\_ADC\_RGE

See MEAS1\_PPG2\_ADC\_RGE[3:2](0x22) for details.

#### **MEAS6 Configuration 3 (0x4B)**

| BIT            | 7           | 6           | 5                             | 4    | 3                | 2 | 1 | 0 |
|----------------|-------------|-------------|-------------------------------|------|------------------|---|---|---|
| Field          | MEAS        | 66_PD_SETLN | NG[2:0] MEAS6_LED_SETLNG[1 0] |      | _SETLNG[1:<br>)] | - | _ | _ |
| Reset          |             | 0x1         |                               | 0;   | <b>c</b> 1       | _ | _ | _ |
| Access<br>Type | Write, Read |             | Write,                        | Read | -                | _ | _ |   |

#### MEAS6\_PD\_SETLNG

See MEAS1\_PD\_SETLNG[7:5](0x23) for details.

#### MEAS6\_LED\_SETLNG

See MEAS1\_LED\_SETLNG[4:3](0x23) for details.

#### **MEAS6 Configuration 4 (0x4C)**

| BIT            | 7 | 6     | 5                      | 4 | 3 | 2     | 1           | 0        |
|----------------|---|-------|------------------------|---|---|-------|-------------|----------|
| Field          | _ | MEAS6 | MEAS6_PPG2_DACOFF[2:0] |   |   | MEAS6 | _PPG1_DACC  | )FF[2:0] |
| Reset          | _ |       | 0x0                    |   |   |       | 0x0         |          |
| Access<br>Type | _ |       | Write, Read            |   | _ |       | Write, Read |          |

#### MEAS6\_PPG2\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### MEAS6\_PPG1\_DACOFF

See MEAS1\_PPG2\_DACOFF[6:4](0x24) for details.

#### MEAS6 LEDA Current (0x4D)

| BIT            | 7 | 6                  | 5 | 4      | 3    | 2 | 1 | 0 |
|----------------|---|--------------------|---|--------|------|---|---|---|
| Field          |   | MEAS6_DRVA_PA[7:0] |   |        |      |   |   |   |
| Reset          |   | 0x00               |   |        |      |   |   |   |
| Access<br>Type |   |                    |   | Write, | Read |   |   |   |

#### MEAS6\_DRVA\_PA

See MEAS1\_DRVA\_PA[7:0](0x25) for details.

#### **MEAS6 LEDB Current (0x4E)**

| BIT            | 7 | 6                  | 5 | 4      | 3    | 2 | 1 | 0 |
|----------------|---|--------------------|---|--------|------|---|---|---|
| Field          |   | MEAS6_DRVB_PA[7:0] |   |        |      |   |   |   |
| Reset          |   | 0x00               |   |        |      |   |   |   |
| Access<br>Type |   |                    |   | Write, | Read |   |   |   |

#### MEAS6\_DRVB\_PA

See MEAS1\_DRVB\_PA[7:0](0x26) for details.

#### **THRESHOLD MEAS SEL (0x50)**

| BIT            | 7 | 6     | 5                     | 4 | 3 | 2    | 1           | 0       |
|----------------|---|-------|-----------------------|---|---|------|-------------|---------|
| Field          | _ | THRES | THRESH2_MEAS_SEL[2:0] |   |   | THRE | SH1_MEAS_S  | EL[2:0] |
| Reset          | _ |       | 0x0                   |   |   |      | 0x0         |         |
| Access<br>Type | _ |       | Write, Read           |   | _ |      | Write, Read |         |

#### THRESH2\_MEAS\_SEL

THRESH2\_MEAS\_SEL enables threshold detect function and selects the PPG measurement for the second instance of the threshold function. For details see the Threshold Detect Function section.

If threshold detect function is enabled, COLLECT\_RAW\_DATA[1](0x13) and SMP\_AVE[2:0](0x14) must be set to zero.

| THRESH2_MEAS_SEL | DECODE                                    |
|------------------|-------------------------------------------|
| 0x0              | THRESH2_HILO detect is disabled           |
| 0x1              | MEAS1 selected                            |
| 0x2              | MEAS2 selected                            |
| 0x3              | MEAS3 selected                            |
| 0x4              | MEAS4 selected                            |
| 0x5              | MEAS5 selected                            |
| 0x6              | MEAS6 selected                            |
| 0x7              | RESERVED, THRESH2_HILO detect is disabled |

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### THRESH1\_MEAS\_SEL

THRESH1\_MEAS\_SEL enables threshold detect function and selects the PPG measurement for the first instance of the threshold function. For details see the Threshold Detect Function section.

If the threshold detect function is enabled, COLLECT\_RAW\_DATA[1](0x13) and SMP\_AVE[2:0](0x14) must be set to zero.

| THRESH1_MEAS_SEL | DECODE                                    |
|------------------|-------------------------------------------|
| 0x0              | THRESH1_HILO detect is disabled           |
| 0x1              | MEAS1 selected                            |
| 0x2              | MEAS2 selected                            |
| 0x3              | MEAS3 selected                            |
| 0x4              | MEAS4 selected                            |
| 0x5              | MEAS5 selected                            |
| 0x6              | MEAS6 selected                            |
| 0x7              | RESERVED, THRESH1_HILO detect is disabled |

#### **THRESHOLD HYST (0x51)**

| BIT            | 7                   | 6                   | 5 | 4              | 3 | 2               | 1           | 0 |
|----------------|---------------------|---------------------|---|----------------|---|-----------------|-------------|---|
| Field          | THRESH2_<br>PPG_SEL | THRESH1_<br>PPG_SEL | ı | TIME_HYST[1:0] |   | LEVEL_HYST[2:0] |             |   |
| Reset          | 0                   | 0                   | - | 0x0            |   |                 | 0x0         |   |
| Access<br>Type | Write, Read         | Write, Read         | - | Write, Read    |   |                 | Write, Read |   |

#### THRESH2\_PPG\_SEL

THRESH1\_PPG\_SEL selects the optical channel for THRESHOLD 1.

| THRESH2_PPG_SEL CHANNEL THAT THRESHOLD2 IS APPLIED |                   |  |  |  |
|----------------------------------------------------|-------------------|--|--|--|
| 0                                                  | Optical Channel 1 |  |  |  |
| 1                                                  | Optical Channel 2 |  |  |  |

#### THRESH1\_PPG\_SEL

THRESH1\_PPG\_SEL selects the optical channel for THRESHOLD 1.

| THRESH1_PPG_SEL | CHANNEL THAT THRESHOLD1 IS APPLIED |
|-----------------|------------------------------------|
| 0               | Optical Channel 1                  |
| 1               | Optical Channel 2                  |

#### TIME HYST

Time hysteresis selects the number of consecutive samples outside the limits defined by THRESHOLDx\_UPPER (x = 1, 2) and THRESHOLDx\_LOWER in order to trigger the threshold interrupt THRESHx\_HILO (in register 0x00). TIME HYST applies to both instances of threshold interrupts. For details, see the Threshold Detect Function section.

| TIME_HYST | NUMBER OF SAMPLES BEFORE INTERRUPT IS SET |
|-----------|-------------------------------------------|
| 0x0       | Time hysteresis is disabled               |
| 0x1       | 2                                         |
| 0x2       | 4                                         |
| 0x3       | 8                                         |

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### LEVEL\_HYST

LEVEL\_HYST sets the variation in ADC counts permitted when the THRESHx\_HILO (x = 1, 2) interrupt is triggered. This value is in ADC counts and is applied at ±0.5 x LEVEL\_HYST around the THRESHOLDx\_UPPER and THRESHOLDx\_LOWER. LEVEL\_HYST applies to both instances of threshold interrupts. For details, see the Threshold Detect Function section.

| LEVEL_HYST | MAGNITUDE OF HYSTERESIS (LSBs) |
|------------|--------------------------------|
| 0x0        | Level hysteresis is disabled.  |
| 0x1        | 2                              |
| 0x2        | 4                              |
| 0x3        | 8                              |
| 0x4        | 16                             |
| 0x5        | 32                             |
| 0x6        | 64                             |
| 0x7        | 128                            |

#### PPG HI THRESHOLD1 (0x52)

| BIT            | 7 | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-----------------------|---|---|---|---|---|---|
| Field          |   | THRESHOLD1_UPPER[7:0] |   |   |   |   |   |   |
| Reset          |   | 0xFF                  |   |   |   |   |   |   |
| Access<br>Type |   | Write, Read           |   |   |   |   |   |   |

#### THRESHOLD1\_UPPER

THRESHOLDx\_UPPER (x = 1, 2) defines the upper threshold limit for THRESHOLD x. Each LSB of THRESHOLDx\_UPPER represents 2048 LSBs of the corresponding selected measurement (THRESHx\_MEAS\_SEL) ADC code.

THRESHOLDx\_UPPER must be programmed to be greater than THRESHOLDx\_LOWER; otherwise, the interrupt behavior is undefined.

| THRESHOLDx_UPPER (x = 1, 2) | UPPER LIMIT FOR THRESHOLD x    |
|-----------------------------|--------------------------------|
| 0x00                        | 0, upper threshold is disabled |
| 0x01                        | 2048                           |
| 0x02                        | 4096                           |
| 0x03                        | 6144                           |
|                             |                                |
| 0xFD                        | 518144                         |
| 0xFE                        | 520192                         |
| 0xFF                        | 522240                         |

#### PPG LO THRESHOLD1 (0x53)

| BIT            | 7 | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-----------------------|---|---|---|---|---|---|
| Field          |   | THRESHOLD1_LOWER[7:0] |   |   |   |   |   |   |
| Reset          |   | 0x00                  |   |   |   |   |   |   |
| Access<br>Type |   | Write, Read           |   |   |   |   |   |   |

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### THRESHOLD1\_LOWER

THRESHOLDx\_LOWER (x = 1, 2) defines the lower threshold limit for THRESHOLD x. Each LSB of THRESHOLDx\_LOWER represents 2048 LSBs of the selected measurement (THRESHx\_MEAS\_SEL) ADC code.

| THRESHOLDx_LOWER (x = 1, 2) | LOWER LIMIT FOR THRESHOLD x    |
|-----------------------------|--------------------------------|
| 0x00                        | 0, lower threshold is disabled |
| 0x01                        | 2048                           |
| 0x02                        | 4096                           |
| 0x03                        | 6144                           |
|                             |                                |
| 0xFD                        | 518144                         |
| 0xFE                        | 520192                         |
| 0xFF                        | 522240                         |

#### PPG HI THRESHOLD2 (0x54)

| BIT            | 7 | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|---|-----------------------|---|---|---|---|---|---|
| Field          |   | THRESHOLD2_UPPER[7:0] |   |   |   |   |   |   |
| Reset          |   | 0xFF                  |   |   |   |   |   |   |
| Access<br>Type |   | Write, Read           |   |   |   |   |   |   |

#### THRESHOLD2\_UPPER

See THRESHOLD1\_UPPER[7:0](0x52) for details.

#### **PPG LO THRESHOLD2 (0x55)**

| BIT            | 7           | 6                     | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|-------------|-----------------------|---|---|---|---|---|---|
| Field          |             | THRESHOLD2_LOWER[7:0] |   |   |   |   |   |   |
| Reset          |             | 0x00                  |   |   |   |   |   |   |
| Access<br>Type | Write, Read |                       |   |   |   |   |   |   |

#### THRESHOLD2\_LOWER

See THRESHOLD1\_LOWER[7:0](0x53) for details.

#### **Interrupt Enable 1 (0x58)**

| BIT            | 7             | 6                | 5                    | 4              | 3              | 2                   | 1                   | 0 |
|----------------|---------------|------------------|----------------------|----------------|----------------|---------------------|---------------------|---|
| Field          | A_FULL_E<br>N | FRAME_RD<br>Y_EN | FIFO_DATA<br>_RDY_EN | ALC_OVF_<br>EN | EXP_OVF_<br>EN | THRESH2_<br>HILO_EN | THRESH1_<br>HILO_EN | _ |
| Reset          | 0             | 0                | 0                    | 0              | 0              | 0                   | 0                   | _ |
| Access<br>Type | Write, Read   | Write, Read      | Write, Read          | Write, Read    | Write, Read    | Write, Read         | Write, Read         | _ |

#### A\_FULL\_EN

Enables the A\_FULL[7](0x00) status bit to trigger the INTB output pin.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

| A_FULL_EN | DECODE                                                     |
|-----------|------------------------------------------------------------|
| 0         | The A_FULL status bit does not impact the INTB output pin. |
| 1         | The INTB pin is triggered when A_FULL is set to 1.         |

#### FRAME\_RDY\_EN

Enables the FRAME\_RDY[6](0x00) status bit to trigger the INTB output pin.

| FRAME_RDY_EN | DECODE                                                        |  |  |  |  |
|--------------|---------------------------------------------------------------|--|--|--|--|
| 0            | The FRAME_RDY status bit does not impact the INTB output pin. |  |  |  |  |
| 1            | The INTB pin is triggered when FRAME_RDY is set to 1.         |  |  |  |  |

#### FIFO\_DATA\_RDY\_EN

Enables the FIFO\_DATA\_RDY[5](0x00) status bit to trigger the INTB output pin.

| FIFO_DATA_RDY_EN | DECODE                                                            |
|------------------|-------------------------------------------------------------------|
| 0                | The FIFO_DATA_RDY status bit does not impact the INTB output pin. |
| 1                | The INTB pin is triggered when FIFO_DATA_RDY is set to 1.         |

#### ALC\_OVF\_EN

Enables the ALC\_OVF[4](0x00) status bit to trigger the INTB output pin.

| ALC_OVF_EN | DECODE                                                      |
|------------|-------------------------------------------------------------|
| 0          | The ALC_OVF status bit does not impact the INTB output pin. |
| 1          | The INTB pin is triggered when ALC_OVF is set to 1.         |

#### EXP\_OVF\_EN

Enables the EXP\_OVF[3](0x00) status bit to trigger the INTB output pin.

| EXP_OVF_EN | DECODE                                                      |  |  |  |
|------------|-------------------------------------------------------------|--|--|--|
| 0          | The EXP_OVF status bit does not impact the INTB output pin. |  |  |  |
| 1          | The INTB pin is triggered when EXP_OVF is set to 1.         |  |  |  |

#### THRESH2\_HILO\_EN

Enables the THRESH2\_HILO[2](0x00) status bit to trigger the INTB output pin.

| THRESH2_HILO_EN | DECODE                                                           |
|-----------------|------------------------------------------------------------------|
| 0               | The THRESH2_HILO status bit does not impact the INTB output pin. |
| 1               | The INTB pin is triggered when THRESH2_HILO is set to 1.         |

#### THRESH1\_HILO\_EN

Enables the THRESH1\_HILO[1](0x00) status bit to trigger the INTB output pin.

| THRESH1_HILO_EN | DECODE                                                           |
|-----------------|------------------------------------------------------------------|
| 0               | The THRESH1_HILO status bit does not impact the INTB output pin. |
| 1               | The INTB pin is triggered when THRESH1_HILO is set to 1.         |

#### **Interrupt Enable 2 (0x59)**

| BIT            | 7                  | 6 | 5 | 4 | 3                 | 2                 | 1                 | 0                 |
|----------------|--------------------|---|---|---|-------------------|-------------------|-------------------|-------------------|
| Field          | INVALID_C<br>FG_EN | _ | _ | _ | LED4_COM<br>PB_EN | LED3_COM<br>PB_EN | LED2_COM<br>PB_EN | LED1_COM<br>PB_EN |
| Reset          | 0                  | _ | - | _ | 0                 | 0                 | 0                 | 0                 |
| Access<br>Type | Write, Read        | _ | _ | _ | Write, Read       | Write, Read       | Write, Read       | Write, Read       |

#### INVALID\_CFG\_EN

Enables the INVALID\_CFG[7](0x01) status bit to trigger the INTB output pin.

| INVALID_CFG_EN | DECODE                                                          |
|----------------|-----------------------------------------------------------------|
| 0              | The INVALID_CFG status bit does not impact the INTB output pin. |
| 1              | The INTB pin is triggered when INVALID_CFG is set to 1.         |

#### LED4\_COMPB\_EN

Enables the LED4\_COMPB[3](0x01) status bit to trigger the INTB output pin.

| LED4_COMPB_EN | DECODE                                                         |  |  |  |
|---------------|----------------------------------------------------------------|--|--|--|
| 0             | The LED4_COMPB status bit does not impact the INTB output pin. |  |  |  |
| 1             | The INTB pin is triggered when LED4_COMPB is set to 1.         |  |  |  |

#### LED3\_COMPB\_EN

Enables the LED3\_COMPB[2](0x01) status bit to trigger the INTB output pin.

| LED3_COMPB_EN | DECODE                                                         |  |  |  |  |
|---------------|----------------------------------------------------------------|--|--|--|--|
| 0             | The LED3_COMPB status bit does not impact the INTB output pin. |  |  |  |  |
| 1             | The INTB pin is triggered when LED3_COMPB is set to 1.         |  |  |  |  |

#### LED2\_COMPB\_EN

Enables the LED2\_COMPB[1](0x01) status bit to trigger the INTB output pin.

| LED2_COMPB_EN | DECODE                                                         |  |  |  |
|---------------|----------------------------------------------------------------|--|--|--|
| 0             | The LED2_COMPB status bit does not impact the INTB output pin. |  |  |  |
| 1             | The INTB pin is triggered when LED2_COMPB is set to 1.         |  |  |  |

#### LED1\_COMPB\_EN

Enables the LED1\_COMPB[0](0x01) status bit to trigger the INTB output pin.

| LED1_COMPB_EN | DECODE                                                         |  |  |  |
|---------------|----------------------------------------------------------------|--|--|--|
| 0             | The LED1_COMPB status bit does not impact the INTB output pin. |  |  |  |
| 1             | The INTB pin is triggered when LED1_COMPB is set to 1.         |  |  |  |

# Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

#### Part ID (0xFF)

| BIT            | 7            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|--------------|---|---|---|---|---|---|---|
| Field          | PART_ID[7:0] |   |   |   |   |   |   |   |
| Reset          | 0x40         |   |   |   |   |   |   |   |
| Access<br>Type | Read Only    |   |   |   |   |   |   |   |

## PART\_ID

This register stores the Part Identifier for the chip.

| PART_ID | PART NUMBER | DESCRIPTION        |
|---------|-------------|--------------------|
| 0x40    | MAX86174A   | Dual-PPG channel   |
| 0x41    | MAX86174B   | Single-PPG channel |

## **Typical Application Circuits**

#### MAX86174A/MAX86174B



## **Ordering Information**

| PART NUMBER     | TEMPERATURE RANGE | BUMP |
|-----------------|-------------------|------|
| MAX86174AENE+   | -40°C to +85°C    | 16   |
| MAX86174AENE+T  | -40°C to +85°C    | 16   |
| MAX86174BENE+*  | -40°C to +85°C    | 16   |
| MAX86174BENE+T* | -40°C to +85°C    | 16   |

<sup>+</sup> Denotes lead(Pb)-free/RoHS compliance.

T = Tape-and-reel.

<sup>\*</sup>Future product—contact factory for availability.

## Best-in-Class Optical Pulse Oximeter and Heart-Rate Sensor AFE for Wearable Health

## **Revision History**

| REVISION NUMBER | REVISION DATE | DESCRIPTION                                                                                                        | PAGES<br>CHANGED    |
|-----------------|---------------|--------------------------------------------------------------------------------------------------------------------|---------------------|
| 0               | 2/21          | Release for Market Intro                                                                                           | _                   |
| 1               | 2/22          | Updated General Description, Benefits and Features, Absolute Maximum Ratings, and Electrical Characteristics table | 1, 7, 9, 38, 39, 40 |



## **Mouser Electronics**

**Authorized Distributor** 

Click to View Pricing, Inventory, Delivery & Lifecycle Information:

MAX86174AENE+T