Main Page
Related Pages
API Reference
Namespace List
Namespace List
Namespace Members
All
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Functions
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
x
y
Variables
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
a
b
c
d
g
i
n
o
p
r
s
t
v
w
x
z
Enumerations
a
b
c
d
e
f
g
i
l
m
n
o
p
r
s
t
w
x
Enumerator
a
b
c
d
e
f
g
h
i
l
m
n
p
r
s
t
u
v
w
x
y
z
Class List
Class List
Class Hierarchy
Class Members
All
:
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
a
b
c
d
e
f
g
i
k
l
m
n
o
p
r
s
t
v
z
Enumerations
b
c
e
f
g
h
k
o
p
r
s
t
v
Enumerator
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
q
r
s
t
u
v
w
y
z
Related Functions
:
c
d
e
f
g
i
l
m
n
o
p
r
s
t
u
Files
File List
File Members
All
_
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
r
s
t
u
v
w
x
y
Functions
_
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
v
Variables
_
a
b
c
d
e
f
g
h
i
j
l
m
n
o
p
r
s
t
u
v
w
x
y
Typedefs
Enumerations
Enumerator
Macros
_
a
c
d
f
g
h
i
l
m
n
o
p
r
s
t
v
x
Examples
core
lib
NavFilter
LNavOrderFilter.hpp
Go to the documentation of this file.
1
//==============================================================================
2
//
3
// This file is part of GNSSTk, the ARL:UT GNSS Toolkit.
4
//
5
// The GNSSTk is free software; you can redistribute it and/or modify
6
// it under the terms of the GNU Lesser General Public License as published
7
// by the Free Software Foundation; either version 3.0 of the License, or
8
// any later version.
9
//
10
// The GNSSTk is distributed in the hope that it will be useful,
11
// but WITHOUT ANY WARRANTY; without even the implied warranty of
12
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
// GNU Lesser General Public License for more details.
14
//
15
// You should have received a copy of the GNU Lesser General Public
16
// License along with GNSSTk; if not, write to the Free Software Foundation,
17
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
18
//
19
// This software was developed by Applied Research Laboratories at the
20
// University of Texas at Austin.
21
// Copyright 2004-2022, The Board of Regents of The University of Texas System
22
//
23
//==============================================================================
24
25
//==============================================================================
26
//
27
// This software was developed by Applied Research Laboratories at the
28
// University of Texas at Austin, under contract to an agency or agencies
29
// within the U.S. Department of Defense. The U.S. Government retains all
30
// rights to use, duplicate, distribute, disclose, or release this software.
31
//
32
// Pursuant to DoD Directive 523024
33
//
34
// DISTRIBUTION STATEMENT A: This software has been approved for public
35
// release, distribution is unlimited.
36
//
37
//==============================================================================
38
39
#ifndef LNAVORDERFILTER_HPP
40
#define LNAVORDERFILTER_HPP
41
42
#include "
NavFilterMgr.hpp
"
43
#include "
NavFilter.hpp
"
44
#include "
LNavFilterData.hpp
"
45
46
namespace
gnsstk
47
{
49
50
51
56
struct
LNavTimeSort
57
: std::binary_function<LNavFilterData*,LNavFilterData*,bool>
58
{
59
inline
bool
operator()
(
const
LNavFilterData
*
const
& l,
60
const
LNavFilterData
*
const
& r)
61
const
;
62
};
63
88
class
LNavOrderFilter
:
public
NavFilter
89
{
90
public
:
95
unsigned
epochInSeconds
;
96
98
LNavOrderFilter
(
unsigned
depth = 3,
unsigned
epoch
= 6);
99
107
virtual
void
validate
(
NavMsgList
& msgBitsIn,
NavMsgList
& msgBitsOut);
108
112
virtual
void
finalize
(
NavMsgList
& msgBitsOut);
113
115
virtual
unsigned
processingDepth
()
const
noexcept
116
{
return
procDepth
; }
117
119
virtual
std::string
filterName
()
const
noexcept
120
{
return
"Order"
; }
121
122
unsigned
procDepth
;
123
124
protected
:
125
typedef
std::set<LNavFilterData*, LNavTimeSort>
SubframeSet
;
126
128
SubframeSet
orderedNav
;
129
133
void
examineSubframes
(
NavMsgList
& msgBitsOut);
134
};
135
137
138
139
bool
LNavTimeSort ::
140
operator()
(
const
LNavFilterData
*
const
& l,
const
LNavFilterData
*
const
& r)
141
const
142
{
143
if
(l->
timeStamp
< r->
timeStamp
)
144
return
true
;
145
if
(l->
timeStamp
> r->
timeStamp
)
146
return
false
;
147
return
(l < r);
148
}
149
150
}
// namespace gnsstk
151
152
#endif // LNAVORDERFILTER_HPP
gnsstk::LNavTimeSort::operator()
bool operator()(const LNavFilterData *const &l, const LNavFilterData *const &r) const
Definition:
LNavOrderFilter.hpp:140
gnsstk::LNavOrderFilter
Definition:
LNavOrderFilter.hpp:88
const
#define const
Definition:
getopt.c:43
gnsstk::LNavTimeSort
Definition:
LNavOrderFilter.hpp:56
gnsstk::LNavOrderFilter::finalize
virtual void finalize(NavMsgList &msgBitsOut)
Definition:
LNavOrderFilter.cpp:86
LNavFilterData.hpp
gnsstk::LNavOrderFilter::filterName
virtual std::string filterName() const noexcept
Return the filter name.
Definition:
LNavOrderFilter.hpp:119
gnsstk
For Sinex::InputHistory.
Definition:
BasicFramework.cpp:50
NavFilter.hpp
gnsstk::LNavOrderFilter::LNavOrderFilter
LNavOrderFilter(unsigned depth=3, unsigned epoch=6)
Initialize internal structures and set the processing depth.
Definition:
LNavOrderFilter.cpp:46
gnsstk::LNavOrderFilter::SubframeSet
std::set< LNavFilterData *, LNavTimeSort > SubframeSet
Definition:
LNavOrderFilter.hpp:125
NavFilterMgr.hpp
gnsstk::LNavOrderFilter::procDepth
unsigned procDepth
Definition:
LNavOrderFilter.hpp:122
gnsstk::NavFilter
Definition:
NavFilter.hpp:55
gnsstk::LNavOrderFilter::orderedNav
SubframeSet orderedNav
Ordered set of nav message subframes.
Definition:
LNavOrderFilter.hpp:128
example5.epoch
epoch
Definition:
example5.py:24
gnsstk::LNavOrderFilter::validate
virtual void validate(NavMsgList &msgBitsIn, NavMsgList &msgBitsOut)
Definition:
LNavOrderFilter.cpp:54
gnsstk::LNavOrderFilter::examineSubframes
void examineSubframes(NavMsgList &msgBitsOut)
Definition:
LNavOrderFilter.cpp:95
gnsstk::LNavOrderFilter::processingDepth
virtual unsigned processingDepth() const noexcept
Internal storage includes a user-specified number of epochs.
Definition:
LNavOrderFilter.hpp:115
gnsstk::LNavFilterData
Definition:
LNavFilterData.hpp:52
gnsstk::NavFilter::NavMsgList
std::list< NavFilterKey * > NavMsgList
Definition:
NavFilter.hpp:58
gnsstk::LNavOrderFilter::epochInSeconds
unsigned epochInSeconds
Definition:
LNavOrderFilter.hpp:95
gnsstk::NavFilterKey::timeStamp
gnsstk::CommonTime timeStamp
Definition:
NavFilterKey.hpp:75
gnsstk
Author(s):
autogenerated on Wed Oct 25 2023 02:40:39