chipKIT® Development Platform

Inspired by Arduino™

Read NMEA frames (MAX32)

Created Wed, 07 Mar 2012 00:06:47 +0000 by MGLSOFT


MGLSOFT

Wed, 07 Mar 2012 00:06:47 +0000

Someone could use Chipkit Max32 for reading NMEA frames by the USB port of any GPS? I am interested in learning how to do it, and if anyone knows an example that can be used as a starting point, I would appreciate passing the link where to find it.

Thanks in advance.


KM6VV

Wed, 07 Mar 2012 18:19:05 +0000

look for the GPS or NEMA parser libraries under the Arduino.

#include <TinyGPS.h>

Alan KM6VV


MGLSOFT

Thu, 08 Mar 2012 17:37:29 +0000

Thanks! This library can be used the way it is with Max32?


KM6VV

Thu, 08 Mar 2012 23:15:15 +0000

I suspect it can, I don't think it 't knows about hardware. You "push" a string into it, char by char.

Alan KM6VV


aflteam

Thu, 23 Aug 2012 05:49:44 +0000

I suspect it can, I don't think it 't knows about hardware. You "push" a string into it, char by char. Alan KM6VV

Hey,

I worked on that library for my Max32. And after some changes, it works now.

I basically followed the jeremy's guide [url]http://www.youtube.com/watch?v=TtZEZYQG0xk&feature=plcp[/url]

But some codes designed with AVR library which do not work with Chipkit. (For example dtostrf() ) So i changed some of them.

This is the latest version, it's output date,latitude and Longitude. If you watch guide , u can see there is another information. I basically closed those with //.

But there was a another trouble, my GPS device (UP501) was need 50 mA pick current and 40mA average current. I have to feed it with external power source. When i feed it with on the chipkit, signals are being very low and it doesnt connect. So keep that in mind.

//Derivated for Chipkit Max32
//Cihangir OdabaÅŸ
//cihangirodabas[AT]hotmail.com

//Jeremy Blum's Arduino Tutorial Series - Episode 15 - GPS Tracking
//Sample Code 2 - Logging GPS Data to an SD Card
//http://www.jeremyblum.com
//TinyGPS Library and Helper Functions by Mikal Hart http://arduiniana.org/libraries/tinygps/

  //These libariries allow us to use hardware features of PIC32MX795F512L (Referances: PIC32 Peripheral Libraries,PIC32MX5XX/6XX/7XX DataSheet)


#include &lt;TinyGPS.h&gt;


/* This sample code demonstrates the normal use of a TinyGPS object.
   It uses an Chipkit Max32 with a GPS attached to Serial2 at 9600 buad.
*/

TinyGPS gps;

static char dtostrfbuffer[20];

int LED = 13;

//Define String

char  Lat[20];
char  Lon[20];


String SD_date_time = "invalid";
String SD_lat = "invalid";
String SD_lon = "invalid";
String dataString ="";






static void gpsdump(TinyGPS &amp;gps);
static bool feedgps();
static void print_float(float val, float invalid, int len, int prec, int SD_val);
static void print_int(unsigned long val, unsigned long invalid, int len);
static void print_date(TinyGPS &amp;gps);
static void print_str(const char *str, int len);

void setup()
{

  pinMode(LED, OUTPUT);  //LED Indicator
  
  //Serial interfaces
  Serial.begin(115200);
  Serial2.begin(9600);  //GPS device connected to Serial2 changeable 
                                 // Serial com. speed should be fit with your device!
  
}

void loop()
{
  
  bool newdata = false;
  unsigned long start = millis();
  
  // Every second we print an update
  while (millis() - start &lt; 1000)
  {
    if (feedgps())
      newdata = true;
  }
  
  gpsdump(gps);
  
  //Write the newest information to the SD Card
  dataString = SD_date_time + "," + SD_lat + "," + SD_lon;
  
  if(SD_date_time != "invalid")
    digitalWrite(LED, HIGH);
  else
    digitalWrite(LED, LOW);
   
    Serial.println(dataString);
 
 
}

static void gpsdump(TinyGPS &amp;gps)
{
  float flat, flon;
  unsigned long age, date, time, chars = 0;
  unsigned short sentences = 0, failed = 0;
  static const float LONDON_LAT = 51.508131, LONDON_LON = -0.128002;
  
  print_int(gps.satellites(), TinyGPS::GPS_INVALID_SATELLITES, 5);
  print_int(gps.hdop(), TinyGPS::GPS_INVALID_HDOP, 5);
  gps.f_get_position(&amp;flat, &amp;flon, &amp;age); 
  print_float(flat, TinyGPS::GPS_INVALID_F_ANGLE, 9, 5, 1); //LATITUDE
  print_float(flon, TinyGPS::GPS_INVALID_F_ANGLE, 10, 5, 2); //LONGITUDE
  print_int(age, TinyGPS::GPS_INVALID_AGE, 5);

  print_date(gps); //DATE AND TIME

  print_float(gps.f_altitude(), TinyGPS::GPS_INVALID_F_ALTITUDE, 8, 2, 0);
  print_float(gps.f_course(), TinyGPS::GPS_INVALID_F_ANGLE, 7, 2, 0);
  print_float(gps.f_speed_kmph(), TinyGPS::GPS_INVALID_F_SPEED, 6, 2, 0);
  print_str(gps.f_course() == TinyGPS::GPS_INVALID_F_ANGLE ? "*** " : TinyGPS::cardinal(gps.f_course()), 6);
  print_int(flat == TinyGPS::GPS_INVALID_F_ANGLE ? 0UL : (unsigned long)TinyGPS::distance_between(flat, flon, LONDON_LAT, LONDON_LON) / 1000, 0xFFFFFFFF, 9);
  print_float(flat == TinyGPS::GPS_INVALID_F_ANGLE ? 0.0 : TinyGPS::course_to(flat, flon, 51.508131, -0.128002), TinyGPS::GPS_INVALID_F_ANGLE, 7, 2, 0);
  print_str(flat == TinyGPS::GPS_INVALID_F_ANGLE ? "*** " : TinyGPS::cardinal(TinyGPS::course_to(flat, flon, LONDON_LAT, LONDON_LON)), 6);

  gps.stats(&amp;chars, &amp;sentences, &amp;failed);
  print_int(chars, 0xFFFFFFFF, 6);
  print_int(sentences, 0xFFFFFFFF, 10);
  print_int(failed, 0xFFFFFFFF, 9);
  Serial.println();
}

static void print_int(unsigned long val, unsigned long invalid, int len)
{
  char sz[32];
  if (val == invalid)
    strcpy(sz, "*******");
  else
    sprintf(sz, "%ld", val);
  sz[len] = 0;
  for (int i=strlen(sz); i&lt;len; ++i)
    sz[i] = ' ';
  if (len &gt; 0) 
    sz[len-1] = ' ';
  //Serial.print(sz);
  feedgps();
}

static void print_float(float val, float invalid, int len, int prec, int SD_val)
{
  char sz[32];
  if (val == invalid)
  {
    strcpy(sz, "*******");
    sz[len] = 0;
        if (len &gt; 0) 
          sz[len-1] = ' ';
    for (int i=7; i&lt;len; ++i)
        sz[i] = ' ';
    //Serial.print(sz);
    if(SD_val == 1) SD_lat = sz;
    else if(SD_val == 2) SD_lon = sz;
  }
  else
  {
    
    //Serial.print(val, prec);
    
    if (SD_val == 1)       {sprintf(Lat,"%f",val);   SD_lat=Lat; } //SD_lat = dtostrf(val,10,5,dtostrfbuffer);
    else if (SD_val == 2)  {sprintf(Lon,"%f",val);   SD_lon=Lon; } //SD_lon = dtostrf(val,10,5,dtostrfbuffer);
    int vi = abs((int)val);
    int flen = prec + (val &lt; 0.0 ? 2 : 1);
    flen += vi &gt;= 1000 ? 4 : vi &gt;= 100 ? 3 : vi &gt;= 10 ? 2 : 1;
    //for (int i=flen; i&lt;len; ++i)
      //Serial.print(" ");
  }
  feedgps();
}

static void print_date(TinyGPS &amp;gps)
{
  int year;
  byte month, day, hour, minute, second, hundredths;
  unsigned long age;
  gps.crack_datetime(&amp;year, &amp;month, &amp;day, &amp;hour, &amp;minute, &amp;second, &amp;hundredths, &amp;age);
  if (age == TinyGPS::GPS_INVALID_AGE)
  {
    Serial.print("*******    *******    ");
    SD_date_time = "invalid";
  }
  else
  {
    char sz[32];
    sprintf(sz, "%02d/%02d/%02d %02d:%02d:%02d   ",
        month, day, year, hour, minute, second);
    //Serial.print(sz);
    SD_date_time = sz;
  }
  print_int(age, TinyGPS::GPS_INVALID_AGE, 5);
  feedgps();
}

static void print_str(const char *str, int len)
{
  int slen = strlen(str);
  //for (int i=0; i&lt;len; ++i)
  //  Serial.print(i&lt;slen ? str[i] : ' ');
  feedgps();
}

static bool feedgps()
{
  while (Serial2.available())
  {
    if (gps.encode(Serial2.read()))
      return true;
  }
  return false;
}