NAME

    Device::Chip::BNO055 - chip driver for BNO055

SYNOPSIS

       use Device::Chip::BNO055;
       use Future::AsyncAwait;
    
       my $chip = Device::Chip::BNO055->new;
       await $chip->mount( Device::Chip::Adapter::...->new );

DESCRIPTION

    This Device::Chip subclass provides specific communications to a Bosch
    BNO055 orientation sensor chip.

    The reader is presumed to be familiar with the general operation of
    this chip; the documentation here will not attempt to explain or define
    chip-specific concepts or features, only the use of this module to
    access them.

METHODS

    The following methods documented in an await expression return Future
    instances.

 read_ids

       $ids = await $chip->read_ids;

    Returns an 8-character string composed of the four ID registers. For a
    BNO055 chip this should be the string

       "A0FB320F"

 read_config

       $config = await $chip->read_config;

    Returns the current chip configuration.

 change_config

       await $chip->change_config( %changes );

    Changes the configuration. Any field names not mentioned will be
    preserved at their existing values.

    This method can only be used while the chip is in config mode, and
    cannot itself be used to set OPR_MODE. For that, use "set_opr_mode".

 set_opr_mode

       await $chip->set_opr_mode( $mode );

    Sets the OPR_MODE register.

 read_accelerometer_raw

       ( $x, $y, $z ) = await $chip->read_accelerometer_raw;

    Returns the most recent accelerometer readings in raw 16bit signed
    integers

 read_accelerometer

       ( $x, $y, $z ) = await $chip->read_accelerometer;

    Returns the most recent accelerometer readings in converted units,
    either m/s² or G depending on the chip's ACC_Unit configuration.

 read_magnetometer_raw

       ( $x, $y, $z ) = await $chip->read_magnetometer_raw;

    Returns the most recent magnetometer readings in raw 16bit signed
    integers

 read_magnetometer

       ( $x, $y, $z ) = await $chip->read_magnetometer;

    Returns the most recent magnetometer readings in converted units of µT.

 read_gyroscope_raw

       ( $x, $y, $z ) = await $chip->read_gyroscope_raw;

    Returns the most recent gyroscope readings in raw 16bit signed integers

 read_gyroscope

       ( $x, $y, $z ) = await $chip->read_gyroscope;

    Returns the most recent gyroscope readings in converted units, either
    dps or rps depending on the chip's GYR_Unit configuration.

 read_euler_angles

       ( $heading, $roll, $pitch ) = await $chip->read_euler_angles;

    Returns the most recent Euler angle fusion readings in converted units,
    either degrees or radians depending on the chip's EUL_units
    configuration.

 read_quarternion

       ( $w, $x, $y, $z ) = await $chip->read_quarternion;

    Returns the most recent quarternion fusion readings in converted units
    as scaled numbers between -1 and 1.

 read_linear_acceleration

       ( $x, $y, $z ) = await $chip->read_linear_acceleration;

    Returns the most recent linear acceleration fusion readings in
    converted units, either m/s² or G depending on the chip's ACC_units
    configuration.

 read_linear_acceleration

       ( $x, $y, $z ) = await $chip->read_linear_acceleration;

    Returns the most recent gravity fusion readings in converted units,
    either m/s² or G depending on the chip's ACC_units configuration.

AUTHOR

    Paul Evans <leonerd@leonerd.org.uk>