upm  0.2.0
Sensor/Actuator repository for libmraa (v0.6.1)
Public Member Functions

C++ API for LSM303. More...

Detailed Description

This file defines the LSM303DLH 3-axis magnetometer/3-axis accelerometer. This module was tested with the SeedStudio Grove [6-Axis Accelerometer&Compass] module that is used over i2c. The magnometer and acceleromter are accessed at two seperate i2c addresses.

lsm303.jpeg
#include "lsm303.h"
int
main(int argc, char **argv)
{
// Instantiate LSM303 compass on I2C
upm::LSM303 *sensor = new upm::LSM303(0);
// Get the coordinate data
sensor->getCoordinates();
int16_t* coor = sensor->getRawCoorData(); // in XYZ order.
// The sensor returns XZY, but the driver compensates and makes it XYZ
// Print out the X, Y, and Z coordinate data using two different methods
std::cout << "coor: rX " << (int)coor[0]
<< " - rY " << (int)coor[1]
<< " - rZ " << (int)coor[2]
<< std::endl;
std::cout << "coor: gX " << sensor->getCoorX()
<< " - gY " << sensor->getCoorY()
<< " - gZ " << sensor->getCoorZ()
<< std::endl;
// Get and print out the heading
std::cout << "heading: "
<< sensor->getHeading()
<< std::endl;
// Get the acceleration
sensor->getAcceleration();
int16_t* accel = sensor->getRawAccelData();
// Print out the X, Y, and Z acceleration data using two different methods
std::cout << "acc: rX " << (int)accel[0]
<< " - rY " << (int)accel[1]
<< " - Z " << (int)accel[2]
<< std::endl;
std::cout << "acc: gX " << sensor->getAccelX()
<< " - gY " << sensor->getAccelY()
<< " - gZ " << sensor->getAccelZ()
<< std::endl;
return 0;
}

Public Member Functions

 LSM303 (int bus, int addrMag=LSM303_MAG, int addrAcc=LSM303_ACC, int accScale=8)
 
 ~LSM303 ()
 
float getHeading ()
 
mraa_result_t getCoordinates ()
 
mraa_result_t getAcceleration ()
 
int16_t * getRawCoorData ()
 
int16_t getCoorX ()
 
int16_t getCoorY ()
 
int16_t getCoorZ ()
 
int16_t * getRawAccelData ()
 
int16_t getAccelX ()
 
int16_t getAccelY ()
 
int16_t getAccelZ ()
 

Constructor & Destructor Documentation

LSM303 ( int  bus,
int  addrMag = LSM303_MAG,
int  addrAcc = LSM303_ACC,
int  accScale = 8 
)

Instanciates a LSM303 object

Parameters
i2cbus
addrmagometer
addraccelerometer
~LSM303 ( )

LSM303 object destructor

Member Function Documentation

float getHeading ( )

Get Current Heading, headings <0 indicate an error occured

Returns
float

Here is the call graph for this function:

mraa_result_t getCoordinates ( )

Get the coordinates in XYZ order

Here is the caller graph for this function:

mraa_result_t getAcceleration ( )

Get accelerometer values Call before calling other "get" functions for acceleration

int16_t * getRawCoorData ( )

Get the raw coordinate data, this will get updated when getCoordinates() is called

int16_t getCoorX ( )

Just get the X component of the coordinate data

int16_t getCoorY ( )

Just get the Y component of the coordinate data

int16_t getCoorZ ( )

Just get the Z component of the coordinate data

int16_t * getRawAccelData ( )

Get the raw accelerometer data, this will get updated when getAcceleration() is called

int16_t getAccelX ( )

Just get the X component of the acceleration

int16_t getAccelY ( )

Just get the Y component of the acceleration

int16_t getAccelZ ( )

Just get the Z component of the acceleration


The documentation for this class was generated from the following files: