/* * Author: Jon Trulson * Copyright (c) 2016 Intel Corporation. * * This program and the accompanying materials are made available under the * terms of the The MIT License which is available at * https://opensource.org/licenses/MIT. * * SPDX-License-Identifier: MIT */ #include #include #include "bmx055.hpp" #include "upm_utilities.h" using namespace std; int shouldRun = true; void sig_handler(int signo) { if (signo == SIGINT) shouldRun = false; } int main(int argc, char** argv) { signal(SIGINT, sig_handler); //! [Interesting] // Instantiate an BMX055 using default I2C parameters upm::BMX055 sensor; // now output data every 250 milliseconds while (shouldRun) { float x, y, z; sensor.update(); sensor.getAccelerometer(&x, &y, &z); cout << "Accelerometer x: " << x << " y: " << y << " z: " << z << " g" << endl; sensor.getGyroscope(&x, &y, &z); cout << "Gyroscope x: " << x << " y: " << y << " z: " << z << " degrees/s" << endl; sensor.getMagnetometer(&x, &y, &z); cout << "Magnetometer x: " << x << " y: " << y << " z: " << z << " uT" << endl; cout << endl; upm_delay_us(250000); } //! [Interesting] cout << "Exiting..." << endl; return 0; }