1 /* Copyright (c) 2012-2013, 2015-2020 The Linux Foundation. All rights reserved.
2  *
3  * Redistribution and use in source and binary forms, with or without
4  * modification, are permitted provided that the following conditions are
5  * met:
6  *     * Redistributions of source code must retain the above copyright
7  *       notice, this list of conditions and the following disclaimer.
8  *     * Redistributions in binary form must reproduce the above
9  *       copyright notice, this list of conditions and the following
10  *       disclaimer in the documentation and/or other materials provided
11  *       with the distribution.
12  *     * Neither the name of The Linux Foundation nor the names of its
13  *       contributors may be used to endorse or promote products derived
14  *       from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
17  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
20  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
23  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
25  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  *
28  */
29 
30 #ifndef LOC_ENG_NMEA_H
31 #define LOC_ENG_NMEA_H
32 
33 #include <gps_extended.h>
34 #include <vector>
35 #include <string>
36 #define NMEA_SENTENCE_MAX_LENGTH 200
37 
38 /** gnss datum type */
39 #define LOC_GNSS_DATUM_WGS84          0
40 #define LOC_GNSS_DATUM_PZ90           1
41 
42 /* len of semi major axis of ref ellips*/
43 #define MAJA               (6378137.0)
44 /* flattening coef of ref ellipsoid*/
45 #define FLAT               (1.0/298.2572235630)
46 /* 1st eccentricity squared*/
47 #define ESQR               (FLAT*(2.0 - FLAT))
48 /*1 minus eccentricity squared*/
49 #define OMES               (1.0 - ESQR)
50 #define MILARCSEC2RAD      (4.848136811095361e-09)
51 /*semi major axis */
52 #define C_PZ90A            (6378136.0)
53 /*semi minor axis */
54 #define C_PZ90B            (6356751.3618)
55 /* Transformation from WGS84 to PZ90
56  * Cx,Cy,Cz,Rs,Rx,Ry,Rz,C_SYS_A,C_SYS_B*/
57 const double DatumConstFromWGS84[9] =
58         {+0.003, +0.001, 0.000, (1.0+(0.000*1E-6)), (-0.019*MILARCSEC2RAD),
59         (+0.042*MILARCSEC2RAD), (-0.002*MILARCSEC2RAD), C_PZ90A, C_PZ90B};
60 
61 /** Represents a LTP*/
62 typedef struct {
63     double     lat;
64     double     lon;
65     double     alt;
66 } LocLla;
67 
68 /** Represents a ECEF*/
69 typedef struct {
70     double     X;
71     double     Y;
72     double     Z;
73 } LocEcef;
74 
75 void loc_nmea_generate_sv(const GnssSvNotification &svNotify,
76                               std::vector<std::string> &nmeaArraystr);
77 
78 void loc_nmea_generate_pos(const UlpLocation &location,
79                                const GpsLocationExtended &locationExtended,
80                                const LocationSystemInfo &systemInfo,
81                                unsigned char generate_nmea,
82                                bool custom_gga_fix_quality,
83                                std::vector<std::string> &nmeaArraystr,
84                                int& indexOfGGA,
85                                bool isTagBlockGroupingEnabled);
86 
87 #define DEBUG_NMEA_MINSIZE 6
88 #define DEBUG_NMEA_MAXSIZE 4096
loc_nmea_is_debug(const char * nmea,int length)89 inline bool loc_nmea_is_debug(const char* nmea, int length) {
90     return ((nullptr != nmea) &&
91             (length >= DEBUG_NMEA_MINSIZE) && (length <= DEBUG_NMEA_MAXSIZE) &&
92             (nmea[0] == '$') && (nmea[1] == 'P') && (nmea[2] == 'Q') && (nmea[3] == 'W'));
93 }
94 
95 #endif // LOC_ENG_NMEA_H
96