Program to read data from sensors, write them to a file which can then be interpreted by software to help show the path of a bicycle as it travels around a field
Dependencies: C12832_lcd FatFileSystemCpp MMA7660 CMPS03 GPS
Fork of MSCUsbHost by
Program to link a compass and a GPS to an MBED to produce a CSV file which can be used to track a bicycle around a field
Results can be found here
main.cpp
- Committer:
- mbedevilledEgg
- Date:
- 2017-03-21
- Revision:
- 15:b5b2ca683d64
- Parent:
- 14:d70e165ddf30
- Child:
- 16:30f9a5e6abc2
File content as of revision 15:b5b2ca683d64:
#include "mbed.h" // mbed library #include "MMA7660.h" // Accelerometer library #include "GPS.h" // GPS library #include "CMPS03.h" // Compass library #include "C12832_lcd.h" // LCD screen library #include "MSCFileSystem.h" #define FSNAME "USB" #define LIM 300 GPS gps(p9, p10); // GPS Connection CMPS03 compass(p28, p27, CMPS03_DEFAULT_I2C_ADDRESS); // Compass connection MMA7660 MMA(p28, p27); // Accelerometer connection C12832_LCD lcd; Serial pc(USBTX, USBRX); // Declarations float ax, ay, az; DigitalOut connectionLed(LED1); MSCFileSystem msc("USB"); // Mount USB stick under the name "USB" int main() { /* DIR *d; struct dirent *p; // For printing externally (USB Stick) d = opendir("/" FSNAME); */ if (MMA.testConnection()) connectionLed = 1; // Checking MMA connected correctly FILE *Accel = fopen("/USB/Accelerometer.csv", "w"); // Opens text file for Accelerometer FILE *GPS = fopen("/USB/GPS.csv", "w"); // Opens text file for GPS FILE *Comp = fopen("/USB/Compass.csv", "w"); // Opens text file for Compass int i; float bearing; while(i < LIM) { //Accelerometer Accel = fopen("/USB/Accelerometer.csv", "a"); ax=MMA.x(); ay=MMA.y(); az=MMA.z(); fprintf(Accel,"%f, %f, %f,\r\n",ax,ay,az); lcd.locate(1,21); lcd.printf("Accel: %.2f, %.2f, %.2f", ax, ay, az); //GPS GPS = fopen("/USB/GPS.csv", "a"); if (gps.sample()) { fprintf(GPS, "\n%f, %f, %f\r\n", gps.latitude, gps.longitude, gps.rtime); lcd.locate(1,1); lcd.printf("GPS: %.4f, %.4f, %f", gps.latitude, gps.longitude, gps.rtime); } else // For no signal { fprintf(GPS, "No Lock!\n\n"); lcd.locate(1,1); lcd.printf("GPS: No Lock!"); } // Compass //Offset = compass.readBearing(); // Initial definitions Comp = fopen("/USB/Compass.csv", "a"); lcd.locate(1,11); bearing = (compass.readBearing()/10) - 150; if (bearing < 0) { bearing = 360 + bearing; } lcd.printf("Bearing: %.2f\n", bearing); fprintf(Comp, "%.2f\r\n", bearing); //wait (); i++; fclose(Accel); fclose(GPS); fclose(Comp); } }