use in class project

Dependencies:   mbed BNO055 ros_lib_kinetic

Files at this revision

API Documentation at this revision

Comitter:
chawankorn
Date:
Wed Dec 19 08:24:48 2018 +0000
Parent:
0:7f3dd28ad889
Commit message:
for class project

Changed in this revision

main.cpp Show annotated file Show diff for this revision Revisions of this file
ros_lib_kinetic.lib Show annotated file Show diff for this revision Revisions of this file
diff -r 7f3dd28ad889 -r 1e40c57efbb1 main.cpp
--- a/main.cpp	Sat Dec 15 08:49:09 2018 +0000
+++ b/main.cpp	Wed Dec 19 08:24:48 2018 +0000
@@ -1,13 +1,22 @@
 #include "mbed.h"
 #include "BNO055.h"
+#include <ros.h>
+#include <std_msgs/Float64.h>
 
 Serial pc(USBTX, USBRX);
 BNO055 imu(I2C_SDA,I2C_SCL);
 DigitalOut led(LED1);
 
+ros::NodeHandle nh;
+
+std_msgs::Float64 E_roll;
+ros::Publisher pub_roll("Euler roll", &E_roll);
+
 int main() {
     pc.baud(115200);
-    pc.printf("BNO055 Hello World\r\n\r\n");
+    nh.initNode();
+    nh.advertise(pub_roll);
+    //pc.printf("BNO055 Hello World++\r\n\r\n");
     led = 1;
     // Reset the BNO055
     imu.reset();
@@ -18,7 +27,7 @@
             wait(0.1);
         }
     // Display sensor information
-    pc.printf("BNO055 found\r\n\r\n");
+    /*pc.printf("BNO055 found\r\n\r\n");
     pc.printf("Chip          ID: %u\r\n",imu.ID.id);
     pc.printf("Accelerometer ID: %u\r\n",imu.ID.accel);
     pc.printf("Gyroscope     ID: %u\r\n",imu.ID.gyro);
@@ -29,17 +38,24 @@
     for (int i = 0; i<4; i++){
         pc.printf("%u.%u.%u.%u\r\n",imu.ID.serial[i*4],imu.ID.serial[i*4+1],imu.ID.serial[i*4+2],imu.ID.serial[i*4+3]);
     }
-    pc.printf("\r\n");
+    pc.printf("\r\n");*/
 
-    while (true) {
+    while (true) {     
         imu.setmode(OPERATION_MODE_NDOF);
         imu.get_calib();
         imu.get_angles();
         imu.get_temp();
         imu.get_quat();
+        
+        float roll_angle;
+        roll_angle = imu.euler.roll;        
+        E_roll.data = roll_angle;
+        pub_roll.publish(&E_roll);
         pc.printf("Temperature\t%d\n", imu.temperature);
-        pc.printf("Quaternion: w:%f\tx:%f\ty:%f\tz:%f\n", imu.quat.w, imu.quat.x, imu.quat.y, imu.quat.z);
-        //pc.printf("%u\t\t%5.1d\t\t%5.1d\t\t%5.1d\r\n",imu.calib,imu.euler.roll,imu.euler.pitch,imu.euler.yaw);
+        //pc.printf("Quaternion: w:%f\tx:%f\ty:%f\tz:%f\n", imu.quat.w, imu.quat.x, imu.quat.y, imu.quat.z);
+        pc.printf("%u\t roll:%5.1f\t pitch:%5.1f\t yaw:%5.1f\r\n",imu.calib,imu.euler.roll,imu.euler.pitch,imu.euler.yaw);
+        nh.spinOnce();
         wait(0.5);
     }
+    nh.spinOnce();
 }
\ No newline at end of file
diff -r 7f3dd28ad889 -r 1e40c57efbb1 ros_lib_kinetic.lib
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ros_lib_kinetic.lib	Wed Dec 19 08:24:48 2018 +0000
@@ -0,0 +1,1 @@
+http://mbed.org/users/garyservin/code/ros_lib_kinetic/#a849bf78d77f