10 axis data logger to UART with NXP FRDM-K64F with FRDM-STBC-AGM01

Dependencies:   FXAS21002 FXOS8700 MPL3115A2 mbed

Fork of RD-KL25Z-AGMP01_SensorStream by NXP

Revision:
0:ac1207304de6
Child:
1:50c76138a9be
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp	Sun Jan 24 23:24:00 2016 +0000
@@ -0,0 +1,81 @@
+ /* Copyright (c) 2015 NXP Semiconductors. MIT License
+*
+* Permission is hereby granted, free of charge, to any person obtaining a copy of this software
+* and associated documentation files (the "Software"), to deal in the Software without
+* restriction, including without limitation the rights to use, copy, modify, merge, publish,
+* distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
+* Software is furnished to do so, subject to the following conditions:
+*
+* The above copyright notice and this permission notice shall be included in all copies or
+* substantial portions of the Software.
+*
+* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
+* BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+*/
+#include "FXAS21002.h"
+#include "FXOS8700.h"  
+#include "MPL3115.h" 
+#include "mbed.h"
+
+// Initialize Serial port
+Serial pc(USBTX, USBRX);
+
+// Initialize pins for I2C communication for sensors. Set jumpers J6,J7 in FRDM-STBC-AGM01 board accordingly.
+FXOS8700 accel(PTC2,PTC1);
+FXOS8700 mag(PTC2,PTC1);
+FXAS21002 gyro(PTC2,PTC1);
+MPL3115 mpl3115(PTC2,PTC1);
+
+
+    
+int main()
+{
+
+// Configure Accelerometer FXOS8700, Magnetometer FXOS8700 & Gyroscope FXAS21002
+    accel.accel_config();
+    mag.mag_config();
+    gyro.gyro_config();
+    mpl3115.MPL3115_config();
+ 
+    
+    float accel_data[3]; float accel_rms=0.0;
+    float mag_data[3];   float mag_rms=0.0;
+    float gyro_data[3];  float gyro_rms=0.0;
+    float alt_data[3];  float alt_rms=0.0;
+       
+    printf("Begin Data Acquisition....\r\n\r\n");
+    wait(0.5);
+    
+    while(1)
+    {
+      accel.acquire_accel_data_g(accel_data);
+      accel_rms = sqrt(((accel_data[0]*accel_data[0])+(accel_data[1]*accel_data[1])+(accel_data[2]*accel_data[2]))/3);
+      printf("%4.2f,%4.2f,%4.2f,\t",accel_data[0],accel_data[1],accel_data[2]);
+      wait(0.005);
+      
+         
+      mag.acquire_mag_data_uT(mag_data);
+      printf("%4.2f,%4.2f,%4.2f,\t",mag_data[0],mag_data[1],mag_data[2]);
+      mag_rms = sqrt(((mag_data[0]*mag_data[0])+(mag_data[1]*mag_data[1])+(mag_data[2]*mag_data[2]))/3);
+      wait(0.005);
+
+     
+      gyro.acquire_gyro_data_dps(gyro_data);
+      printf("%4.2f,%4.2f,%4.2f,",gyro_data[0],gyro_data[1],gyro_data[2]);
+      gyro_rms = sqrt(((gyro_data[0]*gyro_data[0])+(gyro_data[1]*gyro_data[1])+(gyro_data[2]*gyro_data[2]))/3);
+      wait(0.005);
+      
+      mpl3115.acquire_MPL3115_data_Altitude_in_m(alt_data);
+      printf("\t%f",alt_data[0]);
+      alt_rms = sqrt(((alt_data[0]*alt_data[0])+(alt_data[1]*alt_data[1])+(alt_data[2]*alt_data[2]))/3);
+      wait(0.005);
+      
+      printf("\n\r");
+   
+      
+     }
+      
+}
\ No newline at end of file