pud: adjust to new nmealib
[olsrd.git] / lib / pud / src / posAvg.h
1 #ifndef _PUD_POSAVG_H_
2 #define _PUD_POSAVG_H_
3
4 /* Plugin includes */
5
6 /* OLSR includes */
7
8 /* System includes */
9 #include <nmea/info.h>
10 #include <stdbool.h>
11
12 /** Stores an nmeaINFO entry, used in the averaging */
13 typedef struct _PositionUpdateEntry {
14                 nmeaINFO nmeaInfo; /**< the position information */
15 } PositionUpdateEntry;
16
17 /**
18  Counts the number of GPxxx based entries. Some parameters in nmeaINFO are
19  dependent on different GPxxx NMEA sentences. These counters are used to
20  determine which information would be valid for the average position.
21  Also counts the fix values.
22  */
23 typedef struct _PositionUpdateCounters {
24                 /* present */
25                 unsigned long long smask; /**< the number of entries with SMASK present */
26                 unsigned long long utcdate; /**< the number of entries with UTCDATE present */
27                 unsigned long long utctime; /**< the number of entries with UTCTIME present */
28                 unsigned long long sig; /**< the number of entries with SIG present */
29                 unsigned long long fix; /**< the number of entries with FIX present */
30                 unsigned long long pdop; /**< the number of entries with PDOP present */
31                 unsigned long long hdop; /**< the number of entries with HDOP present */
32                 unsigned long long vdop; /**< the number of entries with VDOP present */
33                 unsigned long long lat; /**< the number of entries with LAT present */
34                 unsigned long long lon; /**< the number of entries with LON present */
35                 unsigned long long elv; /**< the number of entries with ELV present */
36                 unsigned long long speed; /**< the number of entries with SPEED present */
37                 unsigned long long track; /**< the number of entries with TRACK present */
38                 unsigned long long mtrack; /**< the number of entries with MTRACK present */
39                 unsigned long long magvar; /**< the number of entries with MAGVAR present */
40                 unsigned long long satinusecount; /**< the number of entries with SATINUSECOUNT present */
41                 unsigned long long satinuse; /**< the number of entries with SATINUSE present */
42                 unsigned long long satinview; /**< the number of entries with SATINVIEW present */
43
44                 /* smask */
45                 unsigned long long gpgga; /**< the number of GPGGA based entries */
46                 unsigned long long gpgsa; /**< the number of GPGSA based entries */
47                 unsigned long long gpgsv; /**< the number of GPGSV based entries */
48                 unsigned long long gprmc; /**< the number of GPRMC based entries */
49                 unsigned long long gpvtg; /**< the number of GPVTG based entries */
50
51                 /* sig */
52                 unsigned long long sigBad; /**< the number of entries with a bad sig */
53                 unsigned long long sigLow; /**< the number of entries with a low sig */
54                 unsigned long long sigMid; /**< the number of entries with a mid sig */
55                 unsigned long long sigHigh; /**< the number of entries with a high sig */
56
57                 /* fix */
58                 unsigned long long fixBad; /**< the number of entries with a bad fix */
59                 unsigned long long fix2d; /**< the number of entries with a 2D fix */
60                 unsigned long long fix3d; /**< the number of entries with a 3D fix */
61 } PositionUpdateCounters;
62
63 /**
64  A list of position updates that are used to determine the average position.
65
66  The list uses 1 extra entry: when 5 entries have to be averaged then the list
67  will have 6 entries. The 6th entry is used for the incoming entry, so that
68  it is already in the list (together with the old entry that will be removed
69  from the average) and does not need to be copied into the list. This is for
70  better performance.
71
72  The list is a circular list.
73  This means that there is a gap/unused entry in the list between the
74  newest entry and the oldest entry, which is the 'incoming entry'.
75
76  Note that 'positionAverageCumulative' stores cumulative values for parameters
77  for which an average is calculated. The reason is to minimise the number of
78  calculations to be performed.
79  */
80 typedef struct _PositionAverageList {
81                 unsigned long long entriesMaxCount; /**< the maximum number of entries in the list */
82                 PositionUpdateEntry * entries; /**< the list entries */
83
84                 unsigned long long entriesCount; /**< the number of entries in the list */
85                 unsigned long long newestEntryIndex; /**< index of the newest entry in the list (zero-based) */
86                 PositionUpdateCounters counters; /**< the counters */
87
88                 PositionUpdateEntry positionAverageCumulative; /**< the average position with cumulative values */
89                 PositionUpdateEntry positionAverage; /**< the average position */
90 } PositionAverageList;
91
92 /**
93  Enumeration describing the type of an entry position in the average list
94  */
95 typedef enum _AverageEntryPositionType {
96         OLDEST, NEWEST, INCOMING, AVERAGECUMULATIVE, AVERAGE
97 } AverageEntryPositionType;
98
99 bool initPositionAverageList(PositionAverageList * positionAverageList,
100                 unsigned long long maxEntries);
101 void flushPositionAverageList(PositionAverageList * positionAverageList);
102 void destroyPositionAverageList(PositionAverageList * positionAverageList);
103
104 PositionUpdateEntry * getPositionAverageEntry(
105                 PositionAverageList * positionAverageList,
106                 AverageEntryPositionType positionType);
107
108 void addNewPositionToAverage(PositionAverageList * positionAverageList,
109                 PositionUpdateEntry * newEntry);
110
111 #endif /* _PUD_POSAVG_H_ */