[][src]Crate kxcj9

This is a platform agnostic Rust driver for the KXCJ9 and KXCJB ultra-low-power tri-axis accelerometers (up to +/-16g) using the embedded-hal traits.

This driver allows you to:

Introductory blog post

The devices

The KXCJ9 is a high-performance, ultra-low-power, tri-axis accelerometer designed for mobile applications. It offers our best power performance along with an embedded wake-up feature, Fast-mode I²C and up to 14-bit resolution. The KXCJ9 sensor offers improved shock, reflow, and temperature performance, and the ASIC has internal voltage regulators that allow operation from 1.8 V to 3.6 V within the specified product performance.

The KXCJB is the thinnest tri-axis accelerometer available on the market today. This ultra-thin 3x3x0.45mm low-power accelerometer is also one of our most full-featured products. The KXCJB offers up to 14-bit resolution for greater precision. User-selectable parameters include ± 2g, 4g or 8g ranges and Output Data Rates (ODR) with programmable low-pass filter. The KXCJB also features the Kionix XAC sense element, our most advanced sense element, for outstanding stability over temperature, shock and post-reflow performance.

The communication is done through an I2C bidirectional bus.

Datasheet:

Application Note:

Usage examples (see also examples folder)

To use this driver, import this crate and an embedded_hal implementation, then instantiate the appropriate device.

Please find additional examples using hardware in this repository: driver-examples

Read acceleration in G

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
use kxcj9::{Kxcj9, SlaveAddr};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let address =  SlaveAddr::default();
let mut sensor = Kxcj9::new_kxcj9_1018(dev, address);
sensor.enable().unwrap();
loop {
    let acc = sensor.read().unwrap();
    println!("X: {:2}, Y: {:2}, Z: {:2}", acc.x, acc.y, acc.z);
}

Select high resolution

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
use kxcj9::{Kxcj9, Resolution, SlaveAddr};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let mut sensor = Kxcj9::new_kxcj9_1018(dev, SlaveAddr::default());
sensor.enable().unwrap();
sensor.set_resolution(Resolution::High).unwrap();
// with this settings measurements are taken with 12-bit resolution

Select +/-16g scale

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
use kxcj9::{GScale16, Kxcj9, SlaveAddr};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let mut sensor = Kxcj9::new_kxcj9_1018(dev, SlaveAddr::default());
sensor.enable().unwrap();
sensor.set_scale(GScale16::G16FP).unwrap();
// with this settings measurements are taken with 14-bit resolution

Select 200Hz output data rate

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
use kxcj9::{Kxcj9, OutputDataRate, SlaveAddr};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let mut sensor = Kxcj9::new_kxcj9_1018(dev, SlaveAddr::default());
sensor.enable().unwrap();
sensor.set_output_data_rate(OutputDataRate::Hz200).unwrap();

Configure and enable wake-up interrupt

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
use kxcj9::{
    Kxcj9, SlaveAddr, WakeUpInterruptConfig, WakeUpOutputDataRate,
    WakeUpTriggerMotion,
};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let mut sensor = Kxcj9::new_kxcj9_1008(dev, SlaveAddr::default());
let config = WakeUpInterruptConfig {
    trigger_motion: WakeUpTriggerMotion::default(),
    data_rate: WakeUpOutputDataRate::Hz3_125,
    fault_count: 3,
    threshold: 0.5, // G
};
// 0.5g acceleration must be present for 0.96s to trigger interrupt
sensor.enable_wake_up_interrupt(config).unwrap();

Perform a software reset and wait for it to finish

extern crate kxcj9;
extern crate linux_embedded_hal as hal;
#[macro_use(block)]
extern crate nb;
use kxcj9::{Kxcj9, OutputDataRate, SlaveAddr};

let dev = hal::I2cdev::new("/dev/i2c-1").unwrap();
let mut sensor = Kxcj9::new_kxcj9_1018(dev, SlaveAddr::default());
block!(sensor.reset());

Structs

InterruptInfo

Interrupt source information

Kxcj9

KXCJ9/KXCJB device driver

Measurement

Acceleration measurement scaled to configured G range

UnscaledMeasurement

Unscaled acceleration measurement

WakeUpInterruptConfig

Wake-up interrupt configuration

WakeUpTriggerMotion

Wake-up interrupt trigger motion

Enums

Error

All possible errors in this crate

GScale8

KXCJ9-1008 G scale (up to +/-8g)

GScale16

KXCJ9-1018 G scale (up to +/-16g)

InterruptPinLatching

Physical interrupt pin latching behavior

InterruptPinPolarity

Physical interrupt pin polarity

OutputDataRate

Output data rate

Resolution

Measurement resolution

SlaveAddr

Possible slave addresses

WakeUpOutputDataRate

Output data rate for wake-up motion detection