1
Fork 0
mpu6050/examples/test.rs
2021-02-19 10:20:28 +01:00

91 lines
No EOL
3.3 KiB
Rust

use mpu6050::*;
use linux_embedded_hal::{I2cdev, Delay};
use i2cdev::linux::LinuxI2CError;
use mpu6050::device::{ACCEL_HPF, CLKSEL};
fn main() -> Result<(), Mpu6050Error<LinuxI2CError>> {
let i2c = I2cdev::new("/dev/i2c-1")
.map_err(Mpu6050Error::I2c)?;
let mut delay = Delay;
let mut mpu = Mpu6050::new(i2c);
mpu.init(&mut delay)?;
// Test power management
println!("Test power management");
// Test gyro config
println!("Test gyro config");
assert_eq!(mpu.get_gyro_range()?, range::GyroRange::D250);
mpu.set_gyro_range(range::GyroRange::D500)?;
assert_eq!(mpu.get_gyro_range()?, range::GyroRange::D500);
// Test accel config
println!("Test accel config");
assert_eq!(mpu.get_accel_range()?, range::AccelRange::G2);
mpu.set_accel_range(range::AccelRange::G4)?;
assert_eq!(mpu.get_accel_range()?, range::AccelRange::G4);
// accel_hpf: per default RESET/no filter, see ACCEL_CONFIG
println!("Test accel hpf");
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_RESET);
mpu.set_accel_hpf(ACCEL_HPF::_1P25)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_1P25);
mpu.set_accel_hpf(ACCEL_HPF::_2P5)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_2P5);
mpu.set_accel_hpf(ACCEL_HPF::_5)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_5);
mpu.set_accel_hpf(ACCEL_HPF::_0P63)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_0P63);
mpu.set_accel_hpf(ACCEL_HPF::_HOLD)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_HOLD);
// test sleep. Default no, in wake()
println!("Test sleep");
assert_eq!(mpu.get_sleep_enabled()?, false);
mpu.set_sleep_enabled(true)?;
assert_eq!(mpu.get_sleep_enabled()?, true);
mpu.set_sleep_enabled(false)?;
assert_eq!(mpu.get_sleep_enabled()?, false);
// test temp enable/disable
println!("Test temp enable/disable");
mpu.set_temp_enabled(false)?;
assert_eq!(mpu.get_temp_enabled()?, false);
assert_eq!(mpu.get_temp()?, 36.53);
mpu.set_temp_enabled(true)?;
assert_eq!(mpu.get_temp_enabled()?, true);
assert_ne!(mpu.get_temp()?, 36.53);
// Test clksel: GXAXIS per default, set in wake()
println!("Test CLKSEL");
assert_eq!(mpu.get_clock_source()?, CLKSEL::GXAXIS);
mpu.set_clock_source(CLKSEL::GYAXIS)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::GYAXIS);
mpu.set_clock_source(CLKSEL::GZAXIS)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::GZAXIS);
mpu.set_clock_source(CLKSEL::OSCILL)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::OSCILL);
mpu.set_clock_source(CLKSEL::STOP)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::STOP);
mpu.set_clock_source(CLKSEL::RESERV)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::RESERV);
mpu.set_clock_source(CLKSEL::EXT_19P2)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::EXT_19P2);
mpu.set_clock_source(CLKSEL::EXT_32p7)?;
assert_eq!(mpu.get_clock_source()?, CLKSEL::EXT_32p7);
// reset
println!("Test reset");
mpu.reset_device(&mut delay)?;
assert_eq!(mpu.get_accel_hpf()?, ACCEL_HPF::_RESET);
assert_eq!(mpu.get_accel_range()?, range::AccelRange::G2);
assert_eq!(mpu.get_gyro_range()?, range::GyroRange::D250);
assert_eq!(mpu.get_sleep_enabled()?, true);
assert_eq!(mpu.get_temp_enabled()?, true);
println!("Test successful");
Ok(())
}