



# Compact, Precision Six Degrees of Freedom Inertial Sensor

## Data Sheet

**ADIS16446**

## FEATURES

**Triaxial digital gyroscope with digital range scaling**  
 $\pm 250^\circ/\text{sec}$ ,  $\pm 500^\circ/\text{sec}$ ,  $\pm 1000^\circ/\text{sec}$  settings  
**Axis to axis misalignment:  $\pm 0.05^\circ$**   
**Triaxial digital accelerometer dynamic range:  $\pm 18 g$  minimum**  
**Autonomous operation and data collection**  
No external configuration commands required  
205 ms typical power-on start-up time  
**Factory calibrated sensitivity, bias, and axial alignment**  
Calibration temperature range:  $-40^\circ\text{C}$  to  $+85^\circ\text{C}$   
**SPI-compatible**  
Optional burst read sequence for fast data transfer  
**Embedded temperature sensor**  
**Programmable operation and control**  
Automatic and manual bias correction controls  
Bartlett window FIR length, number of taps  
Digital I/O: data ready, alarm indicator, general-purpose  
Alarms for condition monitoring  
Optional external sync input clock up to 1.1 kHz  
Single command self test  
**Power supply voltage range: 3.15 V to 3.45 V**  
**2000 g mechanical shock survivability**  
**Operating temperature range:  $-40^\circ\text{C}$  to  $+105^\circ\text{C}$**

## APPLICATIONS

## Platform stabilization and control

### Navigation

### Robotics

## GENERAL DESCRIPTION

The ADIS16446 *iSensor*<sup>®</sup> device is a complete inertial system that includes a triaxial gyroscope, a triaxial accelerometer, and a temperature sensor. Each sensor in the ADIS16446 combines industry-leading *iMEMS*<sup>®</sup> technology with signal conditioning that optimizes dynamic performance. The factory calibration characterizes each sensor for sensitivity, bias, and alignment. As a result, each sensor has its own dynamic compensation formulas that provide accurate sensor measurements.

The ADIS16446 provides a simple, cost-effective method for integrating accurate multiaxis inertial sensing into industrial systems, especially when compared with the complexity and investment associated with discrete designs. All necessary motion testing and calibration are part of the production process at the factory, greatly reducing system integration time. Tight orthogonal alignment simplifies inertial frame alignment in navigation systems. The serial peripheral interface (SPI) and register structures provide a simple interface for data collection and configuration control.

The ADIS16446 has a compatible pinout for systems that currently use other Analog Devices, Inc., inertial measurement unit (IMU) products, such as the [ADIS16334](#), [ADIS16485](#), or [ADIS16448](#). The ADIS16446 is a 20-lead module that is 24.15 mm × 37.70 mm × 10.80 mm and has a standard connector interface.

## FUNCTIONAL BLOCK DIAGRAM



Figure 1.

Rev. 0

Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties that may result from its use. Specifications subject to change without notice. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. Trademarks and registered trademarks are the property of their respective owners.

## Document Feedback

One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A.  
Tel: 781.329.4700 ©2021 Analog Devices, Inc. All rights reserved.  
**Technical Support** [www.analog.com](http://www.analog.com)

## TABLE OF CONTENTS

|                                                  |    |                                        |    |
|--------------------------------------------------|----|----------------------------------------|----|
| Features .....                                   | 1  | Product Identification.....            | 14 |
| Applications.....                                | 1  | Self-Test Function .....               | 14 |
| General Description .....                        | 1  | Status and Error Flags.....            | 15 |
| Functional Block Diagram .....                   | 1  | Input and Output Configuration.....    | 16 |
| Revision History .....                           | 2  | Data Ready Indicator .....             | 16 |
| Specifications.....                              | 3  | General-Purpose Input and Output ..... | 16 |
| Timing Specifications .....                      | 5  | Digital Processing Configuration.....  | 17 |
| Absolute Maximum Ratings.....                    | 6  | Gyrosopes and Accelerometers .....     | 17 |
| Thermal Resistance .....                         | 6  | Input Clock Configuration .....        | 17 |
| ESD Caution.....                                 | 6  | Calibration.....                       | 18 |
| Pin Configuration and Function Descriptions..... | 7  | Gyrosopes .....                        | 18 |
| Typical Performance Characteristics .....        | 8  | Accelerometers .....                   | 18 |
| Theory of Operation .....                        | 9  | Alarms.....                            | 20 |
| Device Operation .....                           | 9  | Static Alarm Use .....                 | 20 |
| Reading Sensor Data.....                         | 10 | Dynamic Alarm Use .....                | 20 |
| Device Configuration .....                       | 10 | Alarm Reporting .....                  | 20 |
| User Registers.....                              | 11 | Applications Information .....         | 21 |
| Output Data Registers.....                       | 12 | Mounting Tips .....                    | 21 |
| Gyrosopes .....                                  | 12 | Power Supply Considerations.....       | 21 |
| Accelerometers.....                              | 12 | Evaluation Tools .....                 | 21 |
| Internal Temperature .....                       | 13 | X-Ray Sensitivity .....                | 22 |
| System Functions.....                            | 14 | Outline Dimensions.....                | 23 |
| Global Commands .....                            | 14 | Ordering Guide .....                   | 23 |

## REVISION HISTORY

2/2021—Revision 0: Initial Version

## SPECIFICATIONS

$T_A = 25^\circ\text{C}$ ,  $VDD = 3.3\text{ V}$ , angular rate =  $0^\circ/\text{sec}$ , and dynamic range =  $\pm 1000^\circ/\text{sec} \pm 1\text{ g}$ , unless otherwise noted.

Table 1.

| Parameter                             | Test Conditions/Comments                                             | Min        | Typ        | Max | Unit                                     |
|---------------------------------------|----------------------------------------------------------------------|------------|------------|-----|------------------------------------------|
| GYROSCOPES                            |                                                                      |            |            |     |                                          |
| Dynamic Range                         |                                                                      | $\pm 1000$ | $\pm 1200$ |     | $^\circ/\text{sec}$                      |
| Initial Sensitivity                   | $\pm 1000^\circ/\text{sec}$ , see Table 12                           | 0.04       |            |     | $^\circ/\text{sec}/\text{LSB}$           |
|                                       | $\pm 500^\circ/\text{sec}$ , see Table 12                            | 0.02       |            |     | $^\circ/\text{sec}/\text{LSB}$           |
|                                       | $\pm 250^\circ/\text{sec}$ , see Table 12                            | 0.01       |            |     | $^\circ/\text{sec}/\text{LSB}$           |
| Repeatability <sup>1</sup>            | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  |            |            | 1   | %                                        |
| Sensitivity Temperature Coefficient   | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | $\pm 40$   |            |     | $\text{ppm}/^\circ\text{C}$              |
| Misalignment                          | Axis to axis                                                         | $\pm 0.05$ |            |     | Degrees                                  |
|                                       | Axis to frame (package)                                              | $\pm 0.5$  |            |     | Degrees                                  |
| Nonlinearity                          | Best fit straight line                                               | $\pm 0.1$  |            |     | % of FS                                  |
| Bias Repeatability <sup>1, 2</sup>    | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$ , $1\sigma$      | 0.5        |            |     | $^\circ/\text{sec}$                      |
| In-Run Bias Stability                 | $1\sigma$ , SMPL_PRD = 0x0001                                        | 14.5       |            |     | $^\circ/\text{hr}$                       |
| Angular Random Walk                   | $1\sigma$ , SMPL_PRD = 0x0001                                        | 0.66       |            |     | $^\circ/\sqrt{\text{hr}}$                |
| Bias Temperature Coefficient          | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | 0.005      |            |     | $^\circ/\text{sec}/^\circ\text{C}$       |
| Linear Acceleration Effect on Bias    | Any axis, $1\sigma$                                                  | 0.015      |            |     | $^\circ/\text{sec}/g$                    |
| Bias Supply Sensitivity               | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | 0.2        |            |     | $^\circ/\text{sec}/V$                    |
| Output Noise                          | $\pm 1000^\circ/\text{sec}$ range, no filtering                      | 0.27       |            |     | $^\circ/\text{sec rms}$                  |
| Rate Noise Density                    | $f = 25\text{ Hz}$ , $\pm 1000^\circ/\text{sec}$ range, no filtering | 0.0135     |            |     | $^\circ/\text{sec}/\sqrt{\text{Hz rms}}$ |
| $-3\text{ dB}$ Bandwidth              |                                                                      | 330        |            |     | Hz                                       |
| Sensor Resonant Frequency             |                                                                      | 17.5       |            |     | kHz                                      |
| ACCELEROMETERS                        |                                                                      |            |            |     |                                          |
| Dynamic Range                         | Each axis                                                            |            |            |     |                                          |
| Sensitivity                           | See Table 16 for data format                                         | $\pm 18$   | 0.833      |     | $g$                                      |
| Repeatability <sup>1</sup>            | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  |            |            | 1   | %                                        |
| Sensitivity Temperature Coefficient   | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | $\pm 40$   |            |     | $\text{ppm}/^\circ\text{C}$              |
| Misalignment                          | Axis to axis                                                         | 0.2        |            |     | Degrees                                  |
|                                       | Axis to frame (package)                                              | $\pm 0.5$  |            |     | Degrees                                  |
| Nonlinearity                          | Best fit straight line                                               | 0.2        |            |     | % of FS                                  |
| Bias Repeatability <sup>1, 2, 3</sup> | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$ , $1\sigma$      | 20         |            |     | $mg$                                     |
| In-Run Bias Stability                 | $1\sigma$ , SMPL_PRD = 0x0001                                        | 0.25       |            |     | $mg$                                     |
| Velocity Random Walk                  | $1\sigma$ , SMPL_PRD = 0x0001                                        | 0.11       |            |     | $\text{m/sec}/\sqrt{\text{hr}}$          |
| Bias Temperature Coefficient          | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | $\pm 0.15$ |            |     | $mg/\text{C}$                            |
| Bias Supply Sensitivity               | $-40^\circ\text{C} \leq T_A \leq +85^\circ\text{C}$                  | 5          |            |     | $mg/V$                                   |
| Output Noise                          | No filtering                                                         | 5.1        |            |     | $mg \text{ rms}$                         |
| Noise Density                         | No filtering                                                         | 0.23       |            |     | $mg/\sqrt{\text{Hz rms}}$                |
| $-3\text{ dB}$ Bandwidth              |                                                                      | 330        |            |     | Hz                                       |
| Sensor Resonant Frequency             |                                                                      | 5.5        |            |     | kHz                                      |
| TEMPERATURE                           |                                                                      |            |            |     |                                          |
| Sensitivity                           | See Table 17                                                         |            | 0.07386    |     | $^\circ\text{C}/\text{LSB}$              |
| Factory Calibration Temperature Range |                                                                      | -40        |            | +85 | $^\circ\text{C}$                         |

| Parameter                                       | Test Conditions/Comments                 | Min    | Typ       | Max      | Unit          |
|-------------------------------------------------|------------------------------------------|--------|-----------|----------|---------------|
| LOGIC INPUTS <sup>4</sup>                       |                                          |        |           |          |               |
| Input High Voltage, $V_{IH}$                    |                                          | 2.0    |           |          | V             |
| Input Low Voltage, $V_{IL}$                     |                                          |        | 0.8       |          | V             |
| Logic 1 Input Current, $I_{IH}$                 | $V_{IH} = 3.3\text{ V}$                  |        | $\pm 0.2$ | $\pm 10$ | $\mu\text{A}$ |
| Logic 0 Input Current, $I_{IL}$                 | $V_{IL} = 0\text{ V}$                    |        |           |          |               |
| All Pins Except $\overline{RST}$                |                                          | 40     |           | 60       | $\mu\text{A}$ |
| $\overline{RST}$ Pin                            |                                          | 1      |           |          | mA            |
| Input Capacitance, $C_{IN}$                     |                                          | 10     |           |          | pF            |
| DIGITAL OUTPUTS <sup>4</sup>                    |                                          |        |           |          |               |
| Output High Voltage, $V_{OH}$                   | Source current ( $I_{SOURCE}$ ) = 1.6 mA | 2.4    |           |          | V             |
| Output Low Voltage, $V_{OL}$                    | Sink current ( $I_{SINK}$ ) = 1.6 mA     |        | 0.4       |          | V             |
| FLASH MEMORY                                    | Endurance <sup>5</sup>                   | 10,000 |           |          | Cycles        |
| Data Retention <sup>6</sup>                     | $T_J = 85^\circ\text{C}$                 | 20     |           |          | Years         |
| FUNCTIONAL TIMES <sup>7</sup>                   | Time until new data is available         |        |           |          |               |
| Power-On Start-Up Time                          |                                          | 205    |           |          | ms            |
| Reset Recovery Time <sup>8</sup>                |                                          | 90     |           |          | ms            |
| Flash Memory Back-Up Time                       |                                          | 75     |           |          | ms            |
| Flash Memory Test Time                          |                                          | 20     |           |          | ms            |
| Automatic Self-Test Time                        | $SMPL\_PRD = 0x0001$                     | 45     |           |          | ms            |
| CONVERSION RATE                                 |                                          |        |           |          |               |
| $xGYRO\_OUT$ and $xACCL\_OUT$                   | $SMPL\_PRD = 0x0001$                     | 819.2  |           |          | SPS           |
| Clock Accuracy                                  |                                          |        | $\pm 3$   |          | %             |
| Optional External Sync Input Clock <sup>9</sup> |                                          | 0.8    | 1.1       |          | kHz           |
| POWER SUPPLY VOLTAGE RANGE                      | VDD                                      | 3.15   | 3.3       | 3.45     | V             |
| Power Supply Current                            |                                          | 76     | 104       |          | mA            |

<sup>1</sup> The repeatability specifications represent analytical projections, which are based off of the following drift contributions and conditions: temperature hysteresis ( $-40^\circ\text{C}$  to  $+85^\circ\text{C}$ ), electronics drift (high temperature operating life test:  $85^\circ\text{C}$ , 500 hours), drift from temperature cycling (JESD22, Method A104-C, Method N, 500 cycles,  $-40^\circ\text{C}$  to  $+85^\circ\text{C}$ ), rate random walk (10 year projection), and broadband noise.

<sup>2</sup> Bias repeatability describes a long-term behavior, over a variety of conditions. Short-term repeatability is related to the in-run bias stability and noise density specifications.

<sup>3</sup> X-ray exposure may degrade this performance metric.

<sup>4</sup> The digital I/O signals are driven by an internal 3.3 V supply, and the inputs are 5 V tolerant.

<sup>5</sup> Endurance is qualified as per JEDEC Standard 22, Method A117, and measured at  $-40^\circ\text{C}$ ,  $+25^\circ\text{C}$ ,  $+85^\circ\text{C}$ , and  $+125^\circ\text{C}$ .

<sup>6</sup> The data retention lifetime equivalent is at  $T_J$  of  $85^\circ\text{C}$  as per JEDEC Standard 22, Method A117. Data retention lifetime decreases with junction temperature.

<sup>7</sup> These times do not include thermal settling and internal filter response times (330 Hz bandwidth), which may affect overall accuracy.

<sup>8</sup> The  $\overline{RST}$  line must be held low for at least 10  $\mu\text{s}$  to assure a proper reset and recovery sequence.

<sup>9</sup> The sync input clock functions below the specified minimum value but at reduced performance levels.

## TIMING SPECIFICATIONS

$T_A = 25^\circ\text{C}$  and  $VDD = 3.3\text{ V}$ , unless otherwise noted.

Table 2.

| Parameter              | Description                                                        | Normal Mode      |     |                  | Burst Read       |     |      | Unit          |
|------------------------|--------------------------------------------------------------------|------------------|-----|------------------|------------------|-----|------|---------------|
|                        |                                                                    | Min <sup>1</sup> | Typ | Max              | Min <sup>1</sup> | Typ | Max  |               |
| $f_{SCLK}$             | Serial clock                                                       | 0.01             | 2.0 | 0.01             | 0.01             | 1.0 | 0.01 | MHz           |
| $t_{STALL}$            | Stall period between data                                          | 20               |     | N/A <sup>2</sup> |                  |     |      | $\mu\text{s}$ |
| $t_{READRATE}$         | Read rate                                                          | 40               |     |                  |                  |     |      | $\mu\text{s}$ |
| $t_{CS}$               | Chip select to SCLK edge                                           | 48.8             |     | 48.8             |                  |     |      | ns            |
| $t_{DAV}$              | DOUT valid after SCLK edge                                         |                  | 100 |                  |                  | 100 |      | ns            |
| $t_{DSU}$              | DIN setup time before SCLK rising edge                             | 24.4             |     | 24.4             |                  |     |      | ns            |
| $t_{DHD}$              | DIN hold time after SCLK rising edge                               | 48.8             |     | 48.8             |                  |     |      | ns            |
| $t_{SCLKR}, t_{SCLKF}$ | SCLK rise and fall times, not shown in the Timing Diagrams section |                  | 5   | 12.5             |                  | 5   | 12.5 | ns            |
| $t_{DR}, t_{DF}$       | DOUT rise and fall times, not shown in the Timing Diagrams section |                  | 5   | 12.5             |                  | 5   | 12.5 | ns            |
| $t_{SFS}$              | CS high after SCLK edge                                            | 5                |     | 5                |                  |     |      | ns            |
| $t_1$                  | Input sync positive pulse width                                    | 25               |     | 25               |                  |     |      | $\mu\text{s}$ |
| $t_{STDTR}$            | Input sync to data ready valid transition                          |                  | 600 |                  |                  | 600 |      | $\mu\text{s}$ |
| $t_{NV}$               | Data invalid time                                                  |                  | 210 |                  |                  | 210 |      | $\mu\text{s}$ |
| $t_3$                  | Input sync period                                                  | 910              |     | 910              |                  |     |      | $\mu\text{s}$ |

<sup>1</sup> Guaranteed by design and characterization but not tested in production.

<sup>2</sup> When using the burst read function, the stall period is not applicable.

## Timing Diagrams



Figure 2. SPI Timing and Sequence



Figure 3. Stall Time and Data Rate



Figure 4. Input Clock Timing Diagram

## ABSOLUTE MAXIMUM RATINGS

Table 3.

| Parameter                           | Rating                |
|-------------------------------------|-----------------------|
| Mechanical Shock Survivability      |                       |
| Any Axis, Unpowered, 0.5 ms, ½ Sine | 2000 g                |
| Any Axis, Powered, 0.5 ms, ½ Sine   | 2000 g                |
| VDD to GND                          | –0.3 V to +3.45 V     |
| Digital Input Voltage to GND        | –0.3 V to VDD + 0.3 V |
| Digital Output Voltage to GND       | –0.3 V to VDD + 0.3 V |
| Temperature                         |                       |
| Operating Range                     | –40°C to +105°C       |
| Storage Range <sup>1,2</sup>        | –65°C to +125°C       |

<sup>1</sup> Extended exposure to temperatures outside the specified temperature range of –40°C to +105°C can adversely affect the accuracy of factory calibration. For best accuracy, store the device within the specified operating range of –40°C to +105°C.

<sup>2</sup> Although the device is capable of withstanding short-term exposure to 150°C, long-term exposure threatens internal mechanical integrity.

Stresses at or above those listed under Absolute Maximum Ratings may cause permanent damage to the product. This is a stress rating only; functional operation of the product at these or any other conditions above those indicated in the operational section of this specification is not implied. Operation beyond the maximum operating conditions for extended periods may affect product reliability.

## THERMAL RESISTANCE

Thermal performance is directly linked to printed circuit board (PCB) design and operating environment. Careful attention to PCB thermal design is required.

$\theta_{JA}$  is the junction to ambient thermal resistance, and  $\theta_{JC}$  is the junction to case thermal resistance.

Table 4. Thermal Resistance

| Package Type    | $\theta_{JA}$ (°C/W) | $\theta_{JC}$ (°C/W) | Mass (grams) |
|-----------------|----------------------|----------------------|--------------|
| 20-Lead ML-20-3 | 36.5                 | 16.9                 | 15           |

## ESD CAUTION



**ESD (electrostatic discharge) sensitive device.** Charged devices and circuit boards can discharge without detection. Although this product features patented or proprietary protection circuitry, damage may occur on devices subjected to high energy ESD. Therefore, proper ESD precautions should be taken to avoid performance degradation or loss of functionality.

## PIN CONFIGURATION AND FUNCTION DESCRIPTIONS



## NOTES

1. THIS REPRESENTATION DISPLAYS THE TOP VIEW WHEN THE CONNECTOR IS VISIBLE AND FACING UP.
2. MATING CONNECTOR: SAMTEC CLM-110-02 OR EQUIVALENT.
3. DNC = DO NOT CONNECT.

25519-005

Figure 5. Pin Configuration



Figure 6. Pin Locations

25519-106

Table 5. Pin Function Descriptions

| Pin No.            | Mnemonic   | Type           | Description                                                                                            |
|--------------------|------------|----------------|--------------------------------------------------------------------------------------------------------|
| 1                  | DIO3       | Input/output   | Configurable Digital Input and Output.                                                                 |
| 2                  | DIO4/CLKIN | Input/output   | Configurable Digital Input and Output or Sync Clock Input.                                             |
| 3                  | SCLK       | Input          | SPI Serial Clock.                                                                                      |
| 4                  | DOUT       | Output         | SPI Data Output. DOUT clocks the output on the SCLK falling edge.                                      |
| 5                  | DIN        | Input          | SPI Data Input. DIN clocks the input on the SCLK rising edge.                                          |
| 6                  | <u>CS</u>  | Input          | SPI Chip Select.                                                                                       |
| 7                  | DIO1       | Input/output   | Configurable Digital Input and Output.                                                                 |
| 8                  | <u>RST</u> | Input          | Reset.                                                                                                 |
| 9                  | DIO2       | Input/output   | Configurable Digital Input and Output.                                                                 |
| 10, 11, 12         | VDD        | Supply         | Power Supply. It is recommended to place a 10 $\mu$ F capacitor between the VDD pins and the GND pins. |
| 13, 14, 15         | GND        | Supply         | Power Ground.                                                                                          |
| 16, 17, 18, 19, 20 | DNC        | Not applicable | Do Not Connect. Do not connect to the DNC pins.                                                        |

## TYPICAL PERFORMANCE CHARACTERISTICS



Figure 7. Gyroscope Root Allan Variance

25519-127



Figure 8. Accelerometer Root Allan Variance

25519-128

## THEORY OF OPERATION

The ADIS16446 is an autonomous system that requires no user initialization. When the device has a valid power supply, it initializes itself and starts sampling, processing, and loading sensor data into the output registers at a sample rate of 819.2 SPS. DIO1 pulses high after each sample cycle concludes. The SPI enables simple integration with many embedded processor platforms, as shown in Figure 9 (electrical connection) and Table 6 (pin functions). Note that the use of  $33\ \Omega$  series resistors placed near the transmitters on the SPI lines shown in Figure 9 can provide additional signal integrity but are not required in most applications.



Figure 9. Electrical Connection Diagram

Table 6. Generic Master Processor Pin Names and Functions

| Pin Name | Function                   |
|----------|----------------------------|
| SS       | Slave select               |
| SCLK     | Serial clock               |
| MOSI     | Master output, slave input |
| MISO     | Master input, slave output |
| IRQ      | Interrupt request          |

The ADIS16446 SPI supports full duplex serial communication (simultaneous transmit and receive) and uses the bit sequence shown in Figure 10. Table 7 provides a list of the most common settings used to initialize the serial port of a processor for the ADIS16446 SPI.

Table 7. Generic Master Processor SPI Settings

| Processor Setting                   | Description                               |
|-------------------------------------|-------------------------------------------|
| Master                              | The ADIS16446 operates as a slave         |
| SCLK Rate $\leq$ 2 MHz <sup>1</sup> | Maximum serial clock rate                 |
| SPI Mode 3                          | CPOL = 1 (polarity), and CPHA = 1 (phase) |
| MSB First Mode                      | Bit sequence                              |
| 16-Bit Mode                         | Shift register and data length            |

<sup>1</sup> For burst read, SCLK rate  $\leq$  1 MHz.

## DEVICE OPERATION

During normal operation, the ADIS16446 generates a data ready pulse every time a new sample is available. In the default configuration, the 819.2 SPS sample clock that generates the data ready pulse is internally generated, although the user has the option of synchronizing the data sampling to an external clock. The ADIS16446 registers are updated when the data ready signal is inactive. Therefore, the user must not attempt to read the ADIS16446 registers during this time.

When performing operations such as part configuration, reset, self test, or flash memory update, the best way to know if the operation is complete is by monitoring the data ready pulse because the data ready pulse automatically resumes after the desired operation completes. Note that excessive SPI transactions (such as polling a status register) during a self test or flash memory update delay completion of the task. See the Data Ready Indicator section for further information on the data ready indicator.



Figure 10. SPI Communication Bit Sequence

## READING SENSOR DATA

The ADIS16446 provides two different options for acquiring sensor data: the single register and the burst register. A single register read requires two 16-bit SPI cycles. The first cycle requests the contents of the register using the bit assignments in Figure 10. Bit DC7 to Bit DC0 are don't cares for a read, and then the output register contents follow on DOUT during the second sequence. Figure 11 includes three single register reads in succession. In this example, the process starts with DIN = 0x0400 to request the contents of XGYRO\_OUT, then follows with 0x0600 to request YGYRO\_OUT, and 0x0800 to request ZGYRO\_OUT. Full duplex operation enables processors to use the same 16-bit SPI cycle to read data from DOUT while requesting the next set of data on DIN. Figure 12 provides an example of the four SPI signals when reading XGYRO\_OUT in a repeating pattern.



Figure 11. SPI Read Example



Figure 12. Example SPI Read, Second 16-Bit Sequence

## Burst Read Function

The burst read function provides a way to read all of the data in one continuous stream of bits (no stall time). As shown in Figure 13, start this mode by setting DIN = 0x3E00 while keeping CS low for 8 additional 16-bit read cycles. These 8 cycles produce the following sequence of output registers on DOUT: DIAG\_STAT, XGYRO\_OUT, YGYRO\_OUT, ZGYRO\_OUT, XACCL\_OUT, YACCL\_OUT, ZACCL\_OUT, and TEMP\_OUT. Note that Figure 13 shows the first, second, and final bytes of the burst sequence only.



Figure 13. Burst Read Sequence

## SPI Read Test Sequence

Figure 14 provides a test pattern for testing SPI communication. In this pattern, write 0x5600 to the DIN line in a repeating pattern and raise CS in between each repeating 16-bit sequence. CS must remain high for at least the  $t_{STALL}$  time listed in Table 2 in between each 16-bit sequence. Starting with the second 16-bit sequence, DOUT produces the contents of the PROD\_ID register (see Table 22), 0x403E.



Figure 14. SPI Test Read Pattern DIN = 0x5600, DOUT = 0x403E

## DEVICE CONFIGURATION

The control registers in Table 8 provide users with a variety of configuration options. The SPI provides access to these registers, one byte at a time, using the bit assignments in Figure 10. Each register has 16 bits, where Bits[7:0] represent the lower address, and Bits[15:8] represent the upper address. Figure 15 provides an example of writing 0x04 to Address 0x36 (SMPL\_PRD, Bits[15:8]), using DIN = 0xB704. This example reduces the sample rate by a factor of eight (see Table 28).



Figure 15. Example SPI Write Sequence

## Dual Memory Structure

Writing configuration data to a control register updates its SRAM contents, which are volatile. After optimizing each relevant control register setting in a system, set GLOB\_CMD, Bit 3 = 1 (DIN = 0xBE08) to backup these settings in the nonvolatile flash memory. The flash backup process requires a valid power supply level for the entire process time, 75 ms. Table 8 provides a user register memory map that includes a flash backup column. A yes in this column indicates that a register has a mirror location in flash and, when backed up properly, it automatically restores itself during startup or after a reset. Figure 16 provides a diagram of the dual memory structure used to manage operation and store critical user settings.



Figure 16. SRAM and Flash Memory Diagram

## USER REGISTERS

Table 8. User Register Memory Map<sup>1</sup>

| Name       | R/W | Flash Backup | Address <sup>2</sup> | Default | Function                                         | Bit Assignments |
|------------|-----|--------------|----------------------|---------|--------------------------------------------------|-----------------|
| FLASH_CNT  | R   | Yes          | 0x00                 | N/A     | Flash memory write count                         | See Table 26    |
| Reserved   | N/A | N/A          | 0x02                 | N/A     | N/A                                              | N/A             |
| XGYRO_OUT  | R   | No           | 0x04                 | N/A     | X-axis gyroscope output                          | See Table 9     |
| YGYRO_OUT  | R   | No           | 0x06                 | N/A     | Y-axis gyroscope output                          | See Table 10    |
| ZGYRO_OUT  | R   | No           | 0x08                 | N/A     | Z-axis gyroscope output                          | See Table 11    |
| XACCL_OUT  | R   | No           | 0x0A                 | N/A     | X-axis accelerometer output                      | See Table 13    |
| YACCL_OUT  | R   | No           | 0x0C                 | N/A     | Y-axis accelerometer output                      | See Table 14    |
| ZACCL_OUT  | R   | No           | 0x0E                 | N/A     | Z-axis accelerometer output                      | See Table 15    |
| Reserved   | N/A | No           | 0x10 to 0x17         | N/A     | Reserved                                         | N/A             |
| TEMP_OUT   | R   | No           | 0x18                 | N/A     | Temperature output                               | See Table 17    |
| XGYRO_OFF  | R/W | Yes          | 0x1A                 | 0x0000  | X-axis gyroscope bias offset factor              | See Table 30    |
| YGYRO_OFF  | R/W | Yes          | 0x1C                 | 0x0000  | Y-axis gyroscope bias offset factor              | See Table 31    |
| ZGYRO_OFF  | R/W | Yes          | 0x1E                 | 0x0000  | Z-axis gyroscope bias offset factor              | See Table 32    |
| XACCL_OFF  | R/W | Yes          | 0x20                 | 0x0000  | X-axis acceleration bias offset factor           | See Table 33    |
| YACCL_OFF  | R/W | Yes          | 0x22                 | 0x0000  | Y-axis acceleration bias offset factor           | See Table 34    |
| ZACCL_OFF  | R/W | Yes          | 0x24                 | 0x0000  | Z-axis acceleration bias offset factor           | See Table 35    |
| Reserved   | N/A | No           | 0x26 to 0x31         | N/A     | Reserved                                         | N/A             |
| GPIO_CTRL  | R/W | No           | 0x32                 | 0x0000  | Auxiliary digital input/output control           | See Table 27    |
| MSC_CTRL   | R/W | Yes          | 0x34                 | 0x0006  | Miscellaneous control                            | See Table 24    |
| SMPL_PRD   | R/W | Yes          | 0x36                 | 0x0001  | Internal sample period (rate) control            | See Table 28    |
| SENS_AVG   | R/W | Yes          | 0x38                 | 0x0402  | Dynamic range and digital filter control         | See Table 29    |
| Reserved   | N/A | N/A          | 0x3A to 0x3B         | N/A     | Reserved                                         | N/A             |
| DIAG_STAT  | R   | No           | 0x3C                 | 0x0000  | System status                                    | See Table 25    |
| GLOB_CMD   | W   | N/A          | 0x3E                 | 0x0000  | System command                                   | See Table 19    |
| ALM_MAG1   | R/W | Yes          | 0x40                 | 0x0000  | Alarm 1 amplitude threshold                      | See Table 36    |
| ALM_MAG2   | R/W | Yes          | 0x42                 | 0x0000  | Alarm 2 amplitude threshold                      | See Table 37    |
| ALM_SMPL1  | R/W | Yes          | 0x44                 | 0x0000  | Alarm 1 sample size                              | See Table 38    |
| ALM_SMPL2  | R/W | Yes          | 0x46                 | 0x0000  | Alarm 2 sample size                              | See Table 39    |
| ALM_CTRL   | R/W | Yes          | 0x48                 | 0x0000  | Alarm control                                    | See Table 40    |
| Reserved   | N/A | N/A          | 0x4A to 0x51         | N/A     | Reserved                                         | N/A             |
| LOT_ID1    | R   | Yes          | 0x52                 | N/A     | Lot identification number                        | See Table 20    |
| LOT_ID2    | R   | Yes          | 0x54                 | N/A     | Lot identification number                        | See Table 21    |
| PROD_ID    | R   | Yes          | 0x56                 | 0x403E  | Product identifier (0x403E equals 16446 decimal) | See Table 22    |
| SERIAL_NUM | R   | Yes          | 0x58                 | N/A     | Lot specific serial number                       | See Table 23    |

<sup>1</sup> N/A means not applicable.<sup>2</sup> Each register contains two bytes. The address of the lower byte is displayed. The address of the upper byte is equal to the address of the lower byte plus 1.

## OUTPUT DATA REGISTERS

Each sensor in the **ADIS16446** has a dedicated output register in the user register map (see Table 8). Figure 17 provides arrows that describe the direction or rotation ( $g_x$ ,  $g_y$ ,  $g_z$ ) and acceleration ( $a_x$ ,  $a_y$ ,  $a_z$ ) that produce a positive response in its output data.

### GYROSCOPES

XGYRO\_OUT (see Table 9) contains x-axis gyroscope data ( $g_x$  in Figure 17), YGYRO\_OUT (see Table 10) contains y-axis gyroscope data ( $g_y$  in Figure 17), and ZGYRO\_OUT (see Table 11) contains z-axis gyroscope data ( $g_z$  in Figure 17). Table 12 illustrates the gyroscope data format with numerical examples.

**Table 9. XGYRO\_OUT (Base Address = 0x04), Read Only**

| Bits   | Description                                                                                                |
|--------|------------------------------------------------------------------------------------------------------------|
| [15:0] | X-axis gyroscope data, twos complement format, 25 LSB/°/sec (SENS_AVG, Bits[15:8] = 0x04), 0°/sec = 0x0000 |

**Table 10. YGYRO\_OUT (Base Address = 0x06), Read Only**

| Bits   | Description                                                                                                |
|--------|------------------------------------------------------------------------------------------------------------|
| [15:0] | Y-axis gyroscope data, twos complement format, 25 LSB/°/sec (SENS_AVG, Bits[15:8] = 0x04), 0°/sec = 0x0000 |

**Table 11. ZGYRO\_OUT (Base Address = 0x08), Read Only**

| Bits   | Description                                                                                                |
|--------|------------------------------------------------------------------------------------------------------------|
| [15:0] | Z-axis gyroscope data, twos complement format, 25 LSB/°/sec (SENS_AVG, Bits[15:8] = 0x04), 0°/sec = 0x0000 |

**Table 12. Rotation Rate, Twos Complement Format<sup>1</sup>**

| Rotation Rate (°/sec) | Decimal | Hex     | Binary              |
|-----------------------|---------|---------|---------------------|
| +1000                 | +25,000 | 0x61A8  | 0110 0001 1010 1000 |
| +2 ÷ 25               | +2      | 0x0002  | 0000 0000 0000 0010 |
| +1 ÷ 25               | +1      | 0x0001  | 0000 0000 0000 0001 |
| 0                     | 0       | 0x0000  | 0000 0000 0000 0000 |
| -1 ÷ 25               | -1      | 0xFFFF  | 1111 1111 1111 1111 |
| -2 ÷ 25               | -2      | 0xFFFFE | 1111 1111 1111 1110 |
| -1000                 | -25,000 | 0x9E58  | 1001 1110 0101 1000 |

<sup>1</sup> SENS\_AVG, Bits[15:8] = 0x04, see Table 29.

### ACCELEROMETERS

XACCL\_OUT (see Table 13) contains x-axis accelerometer data ( $a_x$  in Figure 17), YACCL\_OUT (see Table 14) contains y-axis accelerometer data ( $a_y$  in Figure 17), and ZACCL\_OUT (see Table 15) contains z-axis accelerometer data ( $a_z$  in Figure 17). Table 16 illustrates the accelerometer data format with numerical examples.

**Table 13. XACCL\_OUT (Base Address = 0x0A), Read Only**

| Bits   | Description                                                                |
|--------|----------------------------------------------------------------------------|
| [15:0] | X-axis acceleration data, twos complement format, 1200 LSB/g, 0 g = 0x0000 |

**Table 14. YACCL\_OUT (Base Address = 0x0C), Read Only**

| Bits   | Description                                                                |
|--------|----------------------------------------------------------------------------|
| [15:0] | Y-axis acceleration data, twos complement format, 1200 LSB/g, 0 g = 0x0000 |

**Table 15. ZACCL\_OUT (Base Address = 0x0E), Read Only**

| Bits   | Description                                                                |
|--------|----------------------------------------------------------------------------|
| [15:0] | Z-axis acceleration data, twos complement format, 1200 LSB/g, 0 g = 0x0000 |

**Table 16. Acceleration, Twos Complement Format**

| Acceleration (g) | Decimal | Hex     | Binary              |
|------------------|---------|---------|---------------------|
| +18              | +21,600 | 0x5460  | 0101 0100 0101 0000 |
| +2 ÷ 1200        | +2      | 0x0002  | 0000 0000 0000 0010 |
| +1 ÷ 1200        | +1      | 0x0001  | 0000 0000 0000 0001 |
| 0                | 0       | 0x0000  | 0000 0000 0000 0000 |
| -1 ÷ 1200        | -1      | 0xFFFF  | 1111 1111 1111 1111 |
| -2 ÷ 1200        | -2      | 0xFFFFE | 1111 1111 1111 1110 |
| -18              | -21,600 | 0xABA0  | 1010 1011 1010 0000 |



Figure 17. Inertial Sensor Direction Reference

2519-206

**INTERNAL TEMPERATURE**

The internal temperature measurement data loads into the TEMP\_OUT register (see Table 17). Table 18 illustrates the temperature data format. Note that this temperature represents an internal temperature reading and does not precisely represent external conditions. The intended use of TEMP\_OUT is to monitor relative changes in temperature.

**Table 17. TEMP\_OUT (Base Address = 0x18), Read Only**

| Bits    | Description                                  |
|---------|----------------------------------------------|
| [15:12] | Not used                                     |
| [11:0]  | Twos complement, 0.07386°C/LSB, 31°C = 0x000 |

**Table 18. Temperature, Twos Complement Format**

| Temperature (°C) | Decimal | Hex | Binary         |
|------------------|---------|-----|----------------|
| +105             | +1002   | 3EA | 0011 1110 1010 |
| +85              | +731    | 2DB | 0010 1101 1011 |
| +31.14772        | +2      | 2   | 0000 0000 0010 |
| +31.07386        | +1      | 0   | 0000 0000 0001 |
| +31              | 0       | 0   | 0000 0000 0000 |
| +30.92614        | -1      | FFF | 1111 1111 1111 |
| +30.85228        | -2      | FFE | 1111 1111 1110 |
| -40              | -962    | C3E | 1100 0011 1110 |

## SYSTEM FUNCTIONS

### GLOBAL COMMANDS

The GLOB\_CMD register in Table 19 provides trigger bits for software reset, flash memory management, and calibration control. Start each of these functions by writing a 1 to the assigned bit in the GLOB\_CMD register. After completing the task, the bit automatically returns to 0. For example, set GLOB\_CMD, Bit 7 = 1 (DIN = 0xBE80) to initiate a software reset. Set GLOB\_CMD, Bit 3 = 1 (DIN = 0xBE08) to back up the user register contents in the nonvolatile flash. This sequence includes loading the control registers with the data in their respective flash memory locations prior to producing new data.

**Table 19. GLOB\_CMD (Base Address = 0x3E), Write Only**

| Bits   | Description (Default = 0x0000) |
|--------|--------------------------------|
| [15:8] | Not used                       |
| 7      | Software reset                 |
| [6:4]  | Not used                       |
| 3      | Flash update                   |
| 2      | Not used                       |
| 1      | Factory calibration restore    |
| 0      | Gyroscope bias correction      |

#### Flash Update

When using the user calibration registers to optimize system level accuracy, set GLOB\_CMD, Bit 3 = 1 (DIN = 0xBE04) to save these settings in the nonvolatile flash memory. Be sure to consider the endurance rating of the flash memory when determining how often to update the user correction factors in the flash memory.

#### Restoring Factory Calibration

Set GLOB\_CMD, Bit 1 = 1 (DIN = 0xBE02) to execute the factory calibration restore function, which resets the gyroscope and accelerometer offset registers to 0x0000 and all sensor data to 0. Restoring the factory calibration automatically updates the flash memory and restarts sampling and processing data. See Table 19 for information on GLOB\_CMD.

### PRODUCT IDENTIFICATION

The PROD\_ID register in Table 22 contains the binary equivalent of 16,446. This register provides a product specific variable for systems that must track this in their system software. The LOT\_ID1 and LOT\_ID2 registers in Table 20 and Table 21 combine to provide a unique, 32-bit lot identification code. The SERIAL\_NUM register in Table 23 contains a binary number that represents the serial number on the device label. The assigned serial numbers in SERIAL\_NUM are lot specific.

**Table 20. LOT\_ID1 (Base Address = 0x52), Read Only**

| Bits   | Description                     |
|--------|---------------------------------|
| [15:0] | Lot identification, binary code |

**Table 21. LOT\_ID2 (Base Address = 0x54), Read Only**

| Bits   | Description                     |
|--------|---------------------------------|
| [15:0] | Lot identification, binary code |

**Table 22. PROD\_ID (Base Address = 0x56), Read Only**

| Bits   | Description (Default = 0x403E)                                           |
|--------|--------------------------------------------------------------------------|
| [15:0] | Product identification = 0x403E. Note that 0x403E equals 16,446 decimal. |

**Table 23. SERIAL\_NUM (Base Address = 0x58), Read Only**

| Bits    | Description                      |
|---------|----------------------------------|
| [15:12] | Reserved                         |
| [11:0]  | Serial number, 1 to 4094 (0xFFE) |

### SELF-TEST FUNCTION

The MSC\_CTRL register in Table 24 provides a self test function for the gyroscopes and accelerometers. This function allows the user to verify the mechanical integrity of each MEMS sensor. When enabled, the self test function applies an electrostatic force to each internal sensor element which causes them to move. The movement in each element simulates its response to actual rotation and/or acceleration and generates a predictable electrical response in the sensor outputs. Set MSC\_CTRL, Bit 10 = 1 (DIN = 0xB504) to activate the internal self test routine, which compares the response to an expected range of responses and reports a pass or fail response to DIAG\_STAT, Bit 5. If this is high, review DIAG\_STAT, Bits[15:10] to identify the failing sensor.

**Table 24. MSC\_CTRL (Base Address = 0x34), Read/Write**

| Bits    | Description (Default = 0x0006)                                                                 |
|---------|------------------------------------------------------------------------------------------------|
| [15:12] | Not used, always set to 0000                                                                   |
| 11      | Checksum memory test (cleared upon completion) <sup>1</sup><br>1 = enabled, 0 = disabled       |
| 10      | Internal self test (cleared upon completion) <sup>1</sup><br>1 = enabled, 0 = disabled         |
| [9:7]   | Not used. Always set to 000                                                                    |
| 6       | Point of percussion, see Figure 21<br>1 = enabled, 0 = disabled                                |
| [5:3]   | Not used, always set to 000                                                                    |
| 2       | Data ready enable<br>1 = enabled, 0 = disabled                                                 |
| 1       | Data ready polarity<br>1 = active high when data is valid<br>0 = active low when data is valid |
| 0       | Data ready line select<br>1 = DIO2, 0 = DIO1                                                   |

<sup>1</sup> Bit 11 and Bit 10 are automatically reset to 0 after finishing their respective tests.

## STATUS AND ERROR FLAGS

The DIAG\_STAT register in Table 25 provides error flags for a number of functions. Each flag uses 1 to indicate an error condition and 0 to indicate a normal condition. Reading this register provides access to the status of each flag and resets all of the bits to 0 for monitoring future operation. If the error condition remains, the error flag returns to 1 at the conclusion of the next sample cycle. The SPI communication error flag in DIAG\_STAT, Bit 3 indicates that the number of SCLKs in a SPI sequence did not equal a multiple of 16 SCLKs.

**Table 25. DIAG\_STAT (Base Address = 0x3C), Read Only**

| Bits | Description (Default = 0x0000)                               |
|------|--------------------------------------------------------------|
| 15   | Z-axis accelerometer self test failure<br>1 = fail, 0 = pass |
| 14   | Y-axis accelerometer self test failure<br>1 = fail, 0 = pass |
| 13   | X-axis accelerometer self test failure<br>1 = fail, 0 = pass |
| 12   | Z-axis gyroscope self test failure<br>0 = pass               |
| 11   | Y-axis gyroscope self test failure<br>1 = fail, 0 = pass     |
| 10   | X-axis gyroscope self test failure<br>1 = fail, 0 = pass     |
| 9    | Alarm 2 status<br>1 = active, 0 = inactive                   |
| 8    | Alarm 1 status<br>1 = active, 0 = inactive                   |
| 7    | Unused                                                       |
| 6    | Flash test, checksum flag<br>1 = fail, 0 = pass              |
| 5    | Self test diagnostic error flag<br>1 = fail, 0 = pass        |
| 4    | Sensor overrange<br>1 = overrange, 0 = normal                |
| 3    | SPI communication failure<br>1 = fail, 0 = pass              |
| 2    | Flash update failure<br>1 = fail, 0 = pass                   |
| 1    | Unused                                                       |
| 0    | Unused                                                       |

## Memory Management

The FLASH\_CNT register in Table 26 provides a 16-bit counter that helps track the number of write cycles to the nonvolatile flash memory. The flash updates every time a manual flash update occurs. A manual flash update is initiated by GLOB\_CMD, Bit 3 and is performed at the completion of the GLOB\_CMD, Bits[1:0] functions (see Table 19).

**Table 26. FLASH\_CNT (Base Address = 0x00), Read Only**

| Bits   | Description    |
|--------|----------------|
| [15:0] | Binary counter |

## Checksum Test

Set MSC\_CTRL, Bit 11 = 1 (DIN = 0xB508) to perform a checksum test of the internal program memory. This function takes a summation of the internal program memory and compares it with the original summation value for the same locations (from factory configuration). If the sum matches the correct value, DIAG\_STAT, Bit 6 is equal to 0. If it does not match, DIAG\_STAT, Bit 6 is equal to 1. Make sure that the power supply is within specification for the entire 20 ms that this function takes to complete.

## INPUT AND OUTPUT CONFIGURATION

### DATA READY INDICATOR

The data ready indicator provides a signal that indicates when the registers are updating so that system processors can avoid data collision, which is a condition when the internal register updates happen at the same time that an external processor requests it. The data ready signal has valid and invalid states. Using the transition from invalid to valid to trigger an interrupt service routine provides the most time for data acquisition (before the next register update). See Figure 4 and Table 2 for specific timing information. **MSC\_CTRL**, Bits[2:0] (see Table 24) provide control bits for enabling this function, selecting the polarity of the valid state and I/O line assignment (DIO1 and DIO2). The factory default setting of **MSC\_CTRL**, Bits[2:0] = 110 (DIN = 0xB406) establishes DIO1 as a data ready output line and assigns the valid state with a logic high (1). Set **MSC\_CTRL**, Bits[2:0] = 100 (DIN = 0xB404) to change the polarity of the data ready signal on DIO1 for interrupt inputs that require negative logic inputs for activation.

### GENERAL-PURPOSE INPUT AND OUTPUT

DIO1, DIO2, DIO3, and DIO4 are configurable, general-purpose input and output lines that serve multiple purposes. The data ready controls in **MSC\_CTRL**, Bits[2:0] have the highest priority for configuring DIO1 and DIO2. The alarm indicator controls in **ALM\_CTRL**, Bits[2:0] have the second highest priority for configuring DIO1 and DIO2. The external clock control associated with **SMPL\_PRD**, Bit 0 has the highest priority for DIO4 configuration (see Table 28). **GPIO\_CTRL** in Table 27 has the lowest priority for configuring DIO1, DIO2, and DIO4, and has absolute control over DIO3.

**Table 27. GPIO\_CTRL (Base Address = 0x32), Read/Write**

| Bits    | Description (Default = 0x0000)                                               |
|---------|------------------------------------------------------------------------------|
| [15:12] | Not used                                                                     |
| 11      | General-Purpose I/O Line 4 (DIO4) data level                                 |
| 10      | General-Purpose I/O Line 3 (DIO3) data level                                 |
| 9       | General-Purpose I/O Line 2 (DIO2) data level                                 |
| 8       | General-Purpose I/O Line 1 (DIO1) data level                                 |
| [7:4]   | Not used                                                                     |
| 3       | General-Purpose I/O Line 4 (DIO4) direction control<br>1 = output, 0 = input |
| 2       | General-Purpose I/O Line 3 (DIO3) direction control<br>1 = output, 0 = input |
| 1       | General-Purpose I/O Line 2 (DIO2) direction control<br>1 = output, 0 = input |
| 0       | General-Purpose I/O Line 1 (DIO1) direction control<br>1 = output, 0 = input |

#### **Example Input and Output Configuration**

For example, set **GPIO\_CTRL**, Bits[3:0] = 0100 (DIN = 0xB204) to set DIO3 as an output signal pin and DIO1, DIO2, and DIO4 as input signal pins. Set the output on DIO3 to 1 by setting **GPIO\_CTRL**, Bit 10 = 1 (DIN = 0xB304). Then, read **GPIO\_CTRL**, Bits[7:0] (DIN = 0x3200) and mask off **GPIO\_CTRL**, Bits[9:8] and **GPIO\_CTRL**, Bit 11 to monitor the digital signal levels on DIO4, DIO2, and DIO1.

## DIGITAL PROCESSING CONFIGURATION

### GYROSCOPES AND ACCELEROMETERS

Figure 19 details the all signal processing components for the gyroscopes and accelerometers. The internal sampling system produces new data in the xGYRO\_OUT and xACCL\_OUT output data registers at a rate of 819.2 SPS. The SMPL\_PRD register in Table 28 provides two functional controls that affect sampling and register update rates. SMPL\_PRD, Bits[12:8] provide a control for reducing the update rate, using an averaging filter with a decimated output. These bits provide a binomial control that divides the data rate by a factor of 2 every time this number increases by 1. For example, set SMPL\_PRD, Bits[15:8] = 0x04 (DIN = 0xB704) to set the decimation factor to 16, which reduces the update rate to 51.2 SPS and the bandwidth to  $\sim 25$  Hz. The SMPL\_PRD, Bits[12:8], setting affects the update rate for the TEMP\_OUT register (see Table 17) as well.

Table 28. SMPL\_PRD (Base Address = 0x36), Read/Write

| Bits    | Description (Default = 0x0001)                                                 |
|---------|--------------------------------------------------------------------------------|
| [15:13] | Not used                                                                       |
| [12:8]  | D, decimation rate setting, binomial, see Figure 19                            |
| [7:1]   | Not used                                                                       |
| 0       | Clock<br>1 = internal sampling clock, 819.2 SPS<br>0 = external sampling clock |

### INPUT CLOCK CONFIGURATION

SMPL\_PRD, Bit 0 (see Table 28) provides a control for synchronizing the internal sampling to an external clock source. Set SMPL\_PRD, Bit 0 = 0 (DIN = 0xB600) and GPIO\_CTRL, Bit 3 = 0 (DIN = 0xB200) to enable the external clock. See Table 2 and Figure 4 for timing information.

### Digital Filtering

The SENS\_AVG register in Table 29 provides user controls for the low-pass filter. This filter contains two cascaded averaging filters that provide a Bartlett window, FIR filter response (see Figure 18). For example, set SENS\_AVG, Bits[2:0] = 100 (DIN = 0xB804) to set each stage to 16 taps. When used with the default sample rate of 819.2 SPS and zero decimation

(SMPL\_PRD, Bits[15:8] = 0x00), this value reduces the sensor bandwidth to approximately 16 Hz.



Figure 18. Bartlett Window, FIR Filter Frequency Response  
(Phase Delay = N Samples)

### Dynamic Range

The SENS\_AVG, Bits[10:8] provide three dynamic range settings for the gyroscopes. The lower dynamic range settings ( $\pm 250^\circ/\text{sec}$  and  $\pm 500^\circ/\text{sec}$ ) limit the minimum filter tap sizes to maintain resolution. For example, set SENS\_AVG, Bits[10:8] = 010 (DIN = 0xB902) for a measurement range of  $\pm 500^\circ/\text{sec}$ . Because this setting can influence the filter settings, program SENS\_AVG, Bits[10:8] before programming SENS\_AVG, Bits[2:0] if more filtering is required.

Table 29. SENS\_AVG (Base Address = 0x38), Read/Write

| Bits    | Description (Default = 0x0402)                                                                                                                                                                                                                                              |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:11] | Not used                                                                                                                                                                                                                                                                    |
| [10:8]  | Measurement range (sensitivity) selection<br>100 = $\pm 1000^\circ/\text{sec}$ (default condition)<br>010 = $\pm 500^\circ/\text{sec}$ , filter taps $\geq 4$ (Bits[2:0] $\geq 0x02$ )<br>001 = $\pm 250^\circ/\text{sec}$ , filter taps $\geq 16$ (Bits[2:0] $\geq 0x04$ ) |
| [7:3]   | Not used                                                                                                                                                                                                                                                                    |
| [2:0]   | Filter Size Variable B<br>Number of taps in each stage; $N_B = 2^B$<br>See Figure 18 for filter response                                                                                                                                                                    |



Figure 19. Sampling and Frequency Response Block Diagram

## CALIBRATION

The mechanical structure and assembly process of the ADIS16446 provide excellent position and alignment stability for each sensor, even after subjected to temperature cycles, shock, vibration, and other environmental conditions. The factory calibration includes a dynamic characterization of each gyroscope and accelerometer over temperature and generates sensor specific correction formulas.

### GYROSCOPES

The XGYRO\_OFF (see Table 30), YGYRO\_OFF (see Table 31), and ZGYRO\_OFF (see Table 32) registers provide an user programmable bias adjustment function for the x-, y-, and z-axis gyroscopes, respectively. Figure 20 illustrates that the registers contain bias correction factors that adjust to the sensor data immediately before the data loads into the output register.



25516-020

Figure 20. User Calibration, Gyroscopes, and Accelerometers

### Gyroscope Bias Error Estimation

Any system level calibration function must start with an estimate of the bias errors, which typically comes from a sample of gyroscope output data, when the device is not in motion. The sample size of data depends on the accuracy goals. Figure 7 provides a trade-off relationship between the averaging time and the expected accuracy of a bias measurement. Vibration, thermal gradients, and power supply instability can influence the accuracy of this process.

Table 30. XGYRO\_OFF (Base Address = 0x1A), Read/Write

| Bits   | Description (Default = 0x0000)                                                              |
|--------|---------------------------------------------------------------------------------------------|
| [15:0] | X-axis, gyroscope offset correction factor, twos complement, 0.01°/sec/LSB, 0°/sec = 0x0000 |

Table 31. YGYRO\_OFF (Base Address = 0x1C), Read/Write

| Bits   | Description (Default = 0x0000)                                                              |
|--------|---------------------------------------------------------------------------------------------|
| [15:0] | Y-axis, gyroscope offset correction factor, twos complement, 0.01°/sec/LSB, 0°/sec = 0x0000 |

Table 32. ZGYRO\_OFF (Base Address = 0x1E), Read/Write

| Bits   | Description (Default = 0x0000)                                                              |
|--------|---------------------------------------------------------------------------------------------|
| [15:0] | Z-axis, gyroscope offset correction factor, twos complement, 0.01°/sec/LSB, 0°/sec = 0x0000 |

### Gyroscope Bias Correction Factors

When the bias estimate is complete, multiply the estimate by -1 to change its polarity, convert it into digital format for the offset correction registers (see Table 30, Table 31, and Table 32), and write the correction factors to the correction registers. For example, lower the x-axis bias by 10 LSB (0.1°/sec) by setting XGYRO\_OFF = 0xFFFF (DIN = 0x9BFF, 0x9AF6).

### Single Command Bias Correction

GLOB\_CMD, Bit 0 (see Table 19) loads the xGYRO\_OFF registers with the values that are the opposite of the values that are in xGYRO\_OUT at the time of initiation. Use this command, together with the decimation filter (SMPL\_PRD, Bits[12:8], see Table 28), to automatically average the gyroscope data and improve the accuracy of this function, as follows:

1. Set SENS\_AVG, Bits[10:8] = 001 (DIN = 0xB901) to optimize the xGYRO\_OUT sensitivity to 0.01°/sec/LSB.
2. Set SMPL\_PRD, Bits[12:8] = 10000 (DIN = 0xB710) to set the decimation rate to 65,536 ( $2^{16}$ ), which provides an averaging time of 80 seconds ( $65,536 \div 819.2$  SPS).
3. Wait for 80 seconds while keeping the device motionless.
4. Set GLOB\_CMD, Bit 0 = 1 (DIN = 0xBE01).
5. The ADI16446 automatically updates the flash memory upon completion of the bias update. The user must wait the time specified in Table 1 for the flash memory back-up time, or until the data ready signal starts to toggle again, whichever is longer.

## ACCELEROMETERS

The XACCL\_OFF (see Table 33), YACCL\_OFF (see Table 34), and ZACCL\_OFF (see Table 35) registers provide user programmable bias adjustment function for the x-, y-, and z-axis accelerometers, respectively. These registers adjust the accelerometer data in the same manner as XGYRO\_OFF in Figure 20.

Table 33. XACCL\_OFF (Base Address = 0x20), Read/Write

| Bits   | Description (Default = 0x0000)                                                              |
|--------|---------------------------------------------------------------------------------------------|
| [15:0] | X-axis, accelerometer offset correction factor, twos complement, 1/1200 g/LSB, 0 g = 0x0000 |

Table 34. YACCL\_OFF (Base Address = 0x22), Read/Write

| Bits    | Description (Default = 0x0000)                                                              |
|---------|---------------------------------------------------------------------------------------------|
| [15:14] | Not used                                                                                    |
| [13:0]  | Y-axis, accelerometer offset correction factor, twos complement, 1/1200 g/LSB, 0 g = 0x0000 |

Table 35. ZACCL\_OFF (Base Address = 0x24), Read/Write

| Bits    | Description (Default = 0x0000)                                                              |
|---------|---------------------------------------------------------------------------------------------|
| [15:14] | Not used                                                                                    |
| [13:0]  | Z-axis, accelerometer offset correction factor, twos complement, 1/1200 g/LSB, 0 g = 0x0000 |

### Accelerometer Bias Error Estimation

Under static conditions, orient each accelerometer in positions where the response to gravity is predictable. A common approach to this is to measure the response of each accelerometer when each is oriented in the peak response position, that is, where  $\pm 1\text{ g}$  is the ideal measurement position. Next, average the  $+1\text{ g}$  and  $-1\text{ g}$  accelerometer measurements together to estimate the residual bias error. Note that using more points in the rotation can improve the accuracy of the response.

### Accelerometer Bias Correction Factors

When the bias estimate is complete, multiply the estimate by  $-1$  to change its polarity, convert it to the digital format for the offset correction registers (see Table 33, Table 34 or Table 35) and write the correction factors to the correction registers. For example, lower the x-axis bias by 12 LSB (10 mg) by setting XACCL\_OFF = 0xFFFF (DIN = 0xA1FF, 0xA0F4).

### Point of Percussion Alignment

Set MSC\_CTRL, Bit 6 = 1 (DIN = 0xB446) to enable this feature and maintain the factory default settings for DIO1. This feature performs a point of percussion translation to the point identified in Figure 21. See Table 24 for more information on MSC\_CTRL.



25519-19

Figure 21. Point of Percussion Physical Reference

## ALARMS

Alarm 1 and Alarm 2 provide two independent alarms with programmable levels, polarity, and data sources.

### STATIC ALARM USE

The static alarms setting compares the data source selection (ALM\_CTRL, Bits[15:8]) with the values in the ALM\_MAGx registers listed in Table 36 and Table 37, using ALM\_MAGx, Bits 15, to determine the trigger polarity. The data format in these registers matches the format of the data selection in ALM\_CTRL, Bits[15:8]. See Table 41, Alarm 1, for a static alarm configuration example.

**Table 36. ALM\_MAG1 (Base Address = 0x40), Read/Write**

| Bits   | Description (Default = 0x0000)                                                              |
|--------|---------------------------------------------------------------------------------------------|
| [15:0] | Threshold setting, matches the format of the ALM_CTRL, Bits[11:8] output register selection |

**Table 37. ALM\_MAG2 (Base Address = 0x42), Read/Write**

| Bits   | Description (Default = 0x0000)                                                               |
|--------|----------------------------------------------------------------------------------------------|
| [15:0] | Threshold setting, matches the format of the ALM_CTRL, Bits[15:12] output register selection |

### DYNAMIC ALARM USE

The dynamic alarm setting monitors the data selection for a rate of change comparison. The rate of change comparison is represented by the magnitude in the ALM\_MAGx registers over the time represented by the number of samples setting in the ALM\_SMPLx registers (see Table 38 and Table 39). See Table 41, Alarm 2, for a dynamic alarm configuration example.

**Table 38. ALM\_SMPL1 (Base Address = 0x44), Read/Write**

| Bits   | Description (Default = 0x0000)                     |
|--------|----------------------------------------------------|
| [15:8] | Not used                                           |
| [7:0]  | Binary, number of samples (both 0x00 and 0x01 = 1) |

**Table 39. ALM\_SMPL2 (Base Address = 0x46), Read/Write**

| Bits   | Description (Default = 0x0000)                     |
|--------|----------------------------------------------------|
| [15:8] | Not used                                           |
| [7:0]  | Binary, number of samples (both 0x00 and 0x01 = 1) |

### ALARM REPORTING

Bits[9:8] of DIAG\_STAT provide error flags that indicate an alarm condition. Bits[2:0] of ALM\_CTRL provide controls for a hardware indicator using DIO1 or DIO2.

**Table 40. ALM\_CTRL (Base Address = 0x48), Read/Write**

| Bits    | Description (Default = 0x0000)                                                                                                                                                                                                                                 |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:12] | Alarm 2 data source selection<br>0000 = disable<br>0001 = XGYRO_OUT<br>0010 = YGYRO_OUT<br>0011 = ZGYRO_OUT<br>0100 = XACCL_OUT<br>0101 = YACCL_OUT<br>0110 = ZACCL_OUT<br>0111 = unused<br>1001 = unused<br>1010 = unused<br>1011 = unused<br>1100 = TEMP_OUT |
| [11:8]  | Alarm 1 data source selection (same as Alarm 2)                                                                                                                                                                                                                |
| 7       | Alarm 2, dynamic or static (1 = dynamic, 0 = static)                                                                                                                                                                                                           |
| 6       | Alarm 1, dynamic or static (1 = dynamic, 0 = static)                                                                                                                                                                                                           |
| 5       | Alarm 2, polarity (1 = greater than ALM_MAG2)                                                                                                                                                                                                                  |
| 4       | Alarm 1, polarity (1 = greater than ALM_MAG1)                                                                                                                                                                                                                  |
| 3       | Data source filtering (1 = filtered, 0 = unfiltered)                                                                                                                                                                                                           |
| 2       | Alarm indicator (1 = enabled, 0 = disabled)                                                                                                                                                                                                                    |
| 1       | Alarm indicator active polarity (1 = high, 0 = low)                                                                                                                                                                                                            |
| 0       | Alarm output line select (1 = DIO2, 0 = DIO1)                                                                                                                                                                                                                  |

### Alarm Example

Table 41 offers an example that configures Alarm 1 to trigger when filtered ZACCL\_OUT data drops below 0.7 g and Alarm 2 to trigger when filtered ZGYRO\_OUT data changes by more than 50°/sec over a 100 ms period, or 500°/sec<sup>2</sup>. The filter setting helps reduce false triggers from noise and refines the accuracy of the trigger points. The ALM\_SMPL2 setting of 82 samples provides a comparison period that is approximately equal to 100 ms for an internal sample rate of 819.2 SPS.

**Table 41. Alarm Configuration Example**

| DIN            | Description                                                                                                                                                                        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC936, 0xC8AF | ALM_CTRL = 0x36AF<br>Alarm 2: dynamic, Δ-ZGYRO_OUT (Δ-time, ALM_SMPL2) > ALM_MAG2<br>Alarm 1: static, ZACCL_OUT < ALM_MAG1, filtered data DIO2 output indicator, positive polarity |
| 0xC313, 0xC288 | ALM_MAG2 = 0x04E2 = 1,250 LSB = 50°/sec                                                                                                                                            |
| 0xC10A, 0xC0F0 | ALM_MAG1 = 0x0348 = 840 LSB = +0.7 g                                                                                                                                               |
| 0x652          | ALM_SMPL2, Bits[7:0] = 0x52 = 82 samples, 82 samples ÷ 819.2 SPS = ~100 ms                                                                                                         |

## APPLICATIONS INFORMATION

### MOUNTING TIPS

The mounting and installation process can influence gyroscope bias repeatability and other key parametric behaviors. To preserve the best performance, use the following guidelines when developing an attachment approach for the [ADIS16446](#):

- Focus mounting force at the machine screw locations.
- Avoid direct force application on the substrate.
- Avoid placing mounting pressure on the package lid, except for the edges that border the exposed side of the substrate.
- Use a consistent mounting torque of 28 inch ounces on the mounting hardware.
- Avoid placing translational forces on the electrical connector.

For additional mounting ideas and tips, refer to the [AN-1305 Application Note](#).

### POWER SUPPLY CONSIDERATIONS

The power supply must be within 3.15 V and 3.45 V for normal operation and optimal performance. During start up, the internal power conversion system starts drawing current when VDD reaches 1.6 V. The internal processor begins initializing when VDD is equal to 2.35 V. After the processor starts, VDD must reach 2.7 V within 128 ms. Also, make sure that the power supply drops below 1.6 V to shut the device down. Using an optional 10  $\mu$ F external capacitor between VDD and GND is recommended for the filtering of power supply noise.

### EVALUATION TOOLS

#### *Breakout Board, ADIS16IMU2/PCBZ*

The [ADIS1644X/FLEX](#) and [ADIS16IMU2/PCBZ](#) accessories (sold separately) provide access to the ADIS16446 through larger connectors that support standard 1 mm ribbon cabling and a simplified method for connecting to an embedded processor platform. These accessories also provide an easy way to connect the ADIS16446 to either the [EVAL-ADIS-FX3](#) or to the older [EVAL-ADIS2](#) evaluation system. Figure 23 provides a mechanical design example for using these two components with the ADIS16446 IMU in a system.

Figure 22 provides the pin assignments for J1 on the [ADIS16IMU2/PCBZ](#) breakout board.

| J1   |            |
|------|------------|
| RST  | 1          |
| 2    | SCLK       |
| CS   | 3          |
| 4    | DOUT       |
| DNC  | 5          |
| 6    | DIN        |
| GND  | 7          |
| 8    | GND        |
| GND  | 9          |
| 10   | VDD        |
| VDD  | 11         |
| 12   | VDD        |
| DIO1 | 13         |
| 14   | DIO2       |
| DIO3 | 15         |
| 16   | DIO4/CLKIN |

25519-21

Figure 22. J1Pin Assignments for the [ADIS16IMU2/PCBZ](#)

The C1 and C2 locations on the [ADIS16IMU2/PCBZ](#) provide users with the pads to install 10  $\mu$ F of capacitance across VDD and GND, which Figure 9 recommends for best performance.



NOTES  
 1. USE FOUR M2 MACHINE SCREWS TO ATTACH THE ADIS16446.  
 2. USE FOUR M3 MACHINE SCREWS TO ATTACH THE INTERFACE PCB.  
 3. EITHER A SAMTEC FFSD-08-D-12.00-01-N OR FFSD-08-D-24.00-01-N CABLE ASSEMBLY CAN BE USED TO CONNECT THE ADIS16IMU2 TO THE EVAL-ADIS2Z EVALUATION BOARD.

25519-21

Figure 23. Physical Diagram for [ADIS16446](#) Accessories

**PC-Based Evaluation, EVAL-ADIS-FX3 and EVAL-ADIS2**

In addition to supporting quick prototype connections between the [ADIS16446](#) and an embedded processing system, J1 on the [ADIS16IMU2/PCBZ](#) breakout board also connects directly to J1 on both the [EVAL-ADIS-FX3](#) and the older [EVAL-ADIS2](#) evaluation system.

EVAL-ADIS-FX3 is a new and completely open source evaluation platform for Windows-based systems. The FX3 application programming interface (API) manages all the complex USB transactions and implements all the necessary tools to begin capturing high speed, high performance data in custom applications. This .NET-compatible API, written in VB.NET and C#, includes data streaming features tailored to reliably capturing inertial sensor data at the maximum data rate. The API is also fully documented, open sourced and is licensed under the MIT license. The API also includes a wrapper library that allows users to use the same API in any development environment

with support for .NET (MATLAB®, LabVIEW®, Python™, etc.) Refer to the [EVAL-ADIS-FX3 Evaluation System Wiki Guide](#) for more information on connecting the ADIS16446 to the EVAL-ADIS-FX3 system.

Alternatively, the [EVAL-ADIS2](#) provides a simple, functional test platform that allows users to configure and collect data from the ADIS16446 IMUs. It is used in conjunction with the [IMU Evaluation Software for the EVAL-ADISX Platforms](#).

**X-RAY SENSITIVITY**

Exposure to high dose rate x-rays, such as those in production systems that inspect solder joints in electronic assemblies, may affect accelerometer bias errors. For optimal performance, avoid exposing the ADIS16446 to this type of inspection.

## OUTLINE DIMENSIONS



Figure 24. 20-Lead Module with Connector Interface [MODULE]  
(ML-20-3)  
Dimensions shown in millimeters

02-072-2013-B

## ORDERING GUIDE

| Model <sup>1</sup> | Temperature Range | Package Description                              | Package Option |
|--------------------|-------------------|--------------------------------------------------|----------------|
| ADIS16446BMLZ      | -40°C to +105°C   | 20-Lead Module with Connector Interface [MODULE] | ML-20-3        |
| ADIS16IMU2/PCBZ    |                   | ADIS16IMU2/PCBZ Breakout Board                   |                |
| EVAL-ADIS-FX3Z     |                   | EVAL-ADIS-FX3 Evaluation System                  |                |
| EVAL-ADIS2Z        |                   | EVAL-ADIS2 Previous Generation Evaluation System |                |
| ADIS1644X/FLEX     |                   | ADIS1644X/FLEX Cable for ADIS1644X IMUs          |                |

<sup>1</sup> Z = RoHS Compliant Part.