Dependents:   V2_GPSRTC

Committer:
joosttromp
Date:
Fri Jun 17 12:37:03 2011 +0000
Revision:
0:62fa44dd600b

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
joosttromp 0:62fa44dd600b 1 /*
joosttromp 0:62fa44dd600b 2 Copyright (c) 2010 Andy Kirkham
joosttromp 0:62fa44dd600b 3
joosttromp 0:62fa44dd600b 4 Permission is hereby granted, free of charge, to any person obtaining a copy
joosttromp 0:62fa44dd600b 5 of this software and associated documentation files (the "Software"), to deal
joosttromp 0:62fa44dd600b 6 in the Software without restriction, including without limitation the rights
joosttromp 0:62fa44dd600b 7 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
joosttromp 0:62fa44dd600b 8 copies of the Software, and to permit persons to whom the Software is
joosttromp 0:62fa44dd600b 9 furnished to do so, subject to the following conditions:
joosttromp 0:62fa44dd600b 10
joosttromp 0:62fa44dd600b 11 The above copyright notice and this permission notice shall be included in
joosttromp 0:62fa44dd600b 12 all copies or substantial portions of the Software.
joosttromp 0:62fa44dd600b 13
joosttromp 0:62fa44dd600b 14 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
joosttromp 0:62fa44dd600b 15 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
joosttromp 0:62fa44dd600b 16 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
joosttromp 0:62fa44dd600b 17 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
joosttromp 0:62fa44dd600b 18 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
joosttromp 0:62fa44dd600b 19 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
joosttromp 0:62fa44dd600b 20 THE SOFTWARE.
joosttromp 0:62fa44dd600b 21 */
joosttromp 0:62fa44dd600b 22
joosttromp 0:62fa44dd600b 23 #include "GPS_Geodetic.h"
joosttromp 0:62fa44dd600b 24
joosttromp 0:62fa44dd600b 25 void
joosttromp 0:62fa44dd600b 26 GPS_Geodetic::nmea_gga(char *s) {
joosttromp 0:62fa44dd600b 27 char *token;
joosttromp 0:62fa44dd600b 28 int token_counter = 0;
joosttromp 0:62fa44dd600b 29 char *latitude = (char *)NULL;
joosttromp 0:62fa44dd600b 30 char *longitude = (char *)NULL;
joosttromp 0:62fa44dd600b 31 char *lat_dir = (char *)NULL;
joosttromp 0:62fa44dd600b 32 char *lon_dir = (char *)NULL;
joosttromp 0:62fa44dd600b 33 char *qual = (char *)NULL;
joosttromp 0:62fa44dd600b 34 char *altitude = (char *)NULL;
joosttromp 0:62fa44dd600b 35 char *sats = (char *)NULL;
joosttromp 0:62fa44dd600b 36
joosttromp 0:62fa44dd600b 37 token = strtok(s, ",");
joosttromp 0:62fa44dd600b 38 while (token) {
joosttromp 0:62fa44dd600b 39 switch (token_counter) {
joosttromp 0:62fa44dd600b 40 case 2: latitude = token; break;
joosttromp 0:62fa44dd600b 41 case 4: longitude = token; break;
joosttromp 0:62fa44dd600b 42 case 3: lat_dir = token; break;
joosttromp 0:62fa44dd600b 43 case 5: lon_dir = token; break;
joosttromp 0:62fa44dd600b 44 case 6: qual = token; break;
joosttromp 0:62fa44dd600b 45 case 7: sats = token; break;
joosttromp 0:62fa44dd600b 46 case 9: altitude = token; break;
joosttromp 0:62fa44dd600b 47 }
joosttromp 0:62fa44dd600b 48 token = strtok((char *)NULL, ",");
joosttromp 0:62fa44dd600b 49 token_counter++;
joosttromp 0:62fa44dd600b 50 }
joosttromp 0:62fa44dd600b 51
joosttromp 0:62fa44dd600b 52 // If the fix quality is valid set our location information.
joosttromp 0:62fa44dd600b 53 if (latitude && longitude && altitude && sats) {
joosttromp 0:62fa44dd600b 54 lat = convert_lat_coord(latitude, lat_dir[0]);
joosttromp 0:62fa44dd600b 55 lon = convert_lon_coord(longitude, lon_dir[0]);
joosttromp 0:62fa44dd600b 56 alt = convert_height(altitude);
joosttromp 0:62fa44dd600b 57 num_of_gps_sats = atoi(sats);
joosttromp 0:62fa44dd600b 58 gps_satellite_quality = atoi(qual);
joosttromp 0:62fa44dd600b 59 }
joosttromp 0:62fa44dd600b 60 else {
joosttromp 0:62fa44dd600b 61 gps_satellite_quality = 0;
joosttromp 0:62fa44dd600b 62 }
joosttromp 0:62fa44dd600b 63 }
joosttromp 0:62fa44dd600b 64
joosttromp 0:62fa44dd600b 65 double
joosttromp 0:62fa44dd600b 66 GPS_Geodetic::convert_lat_coord(char *s, char north_south)
joosttromp 0:62fa44dd600b 67 {
joosttromp 0:62fa44dd600b 68 int deg, min, sec;
joosttromp 0:62fa44dd600b 69 double fsec, val;
joosttromp 0:62fa44dd600b 70
joosttromp 0:62fa44dd600b 71 deg = ( (s[0] - '0') * 10) + s[1] - '0';
joosttromp 0:62fa44dd600b 72 min = ( (s[2] - '0') * 10) + s[3] - '0';
joosttromp 0:62fa44dd600b 73 sec = ( ((s[5] - '0') * 1000) + ((s[6] - '0') * 100) + ((s[7] - '0') * 10) + (s[8] - '0'));
joosttromp 0:62fa44dd600b 74 fsec = (double)((double)sec /10000.0);
joosttromp 0:62fa44dd600b 75 val = (double)deg + ((double)((double)min/60.0)) + (fsec/60.0);
joosttromp 0:62fa44dd600b 76 if (north_south == 'S') { val *= -1.0; }
joosttromp 0:62fa44dd600b 77 lat = val;
joosttromp 0:62fa44dd600b 78 return val;
joosttromp 0:62fa44dd600b 79 }
joosttromp 0:62fa44dd600b 80
joosttromp 0:62fa44dd600b 81 double
joosttromp 0:62fa44dd600b 82 GPS_Geodetic::convert_lon_coord(char *s, char east_west)
joosttromp 0:62fa44dd600b 83 {
joosttromp 0:62fa44dd600b 84 int deg, min, sec;
joosttromp 0:62fa44dd600b 85 double fsec, val;
joosttromp 0:62fa44dd600b 86
joosttromp 0:62fa44dd600b 87 deg = ( (s[0] - '0') * 100) + ((s[1] - '0') * 10) + (s[2] - '0');
joosttromp 0:62fa44dd600b 88 min = ( (s[3] - '0') * 10) + s[4] - '0';
joosttromp 0:62fa44dd600b 89 sec = ( ((s[6] - '0') * 1000) + ((s[7] - '0') * 100) + ((s[8] - '0') * 10) + (s[9] - '0'));
joosttromp 0:62fa44dd600b 90 fsec = (double)((double)sec /10000.0);
joosttromp 0:62fa44dd600b 91 val = (double)deg + ((double)((double)min/60.0)) + (fsec/60.0);
joosttromp 0:62fa44dd600b 92 if (east_west == 'W') { val *= -1.0; }
joosttromp 0:62fa44dd600b 93 lon = val;
joosttromp 0:62fa44dd600b 94 return val;
joosttromp 0:62fa44dd600b 95
joosttromp 0:62fa44dd600b 96 }
joosttromp 0:62fa44dd600b 97
joosttromp 0:62fa44dd600b 98 double
joosttromp 0:62fa44dd600b 99 GPS_Geodetic::convert_height(char *s)
joosttromp 0:62fa44dd600b 100 {
joosttromp 0:62fa44dd600b 101 //double val = (double)(atof(s) / 1000.0);
joosttromp 0:62fa44dd600b 102 double val = (double)(atof(s) * 3.2808399);
joosttromp 0:62fa44dd600b 103 alt = val;
joosttromp 0:62fa44dd600b 104 return val;
joosttromp 0:62fa44dd600b 105 }
joosttromp 0:62fa44dd600b 106
joosttromp 0:62fa44dd600b 107