NavSatelliteID.cpp
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 //
28 // This software was developed by Applied Research Laboratories at the
29 // University of Texas at Austin, under contract to an agency or agencies
30 // within the U.S. Department of Defense. The U.S. Government retains all
31 // rights to use, duplicate, distribute, disclose, or release this software.
32 //
33 // Pursuant to DoD Directive 523024
34 //
35 // DISTRIBUTION STATEMENT A: This software has been approved for public
36 // release, distribution is unlimited.
37 //
38 //==============================================================================
39 #include "NavSatelliteID.hpp"
40 
41 namespace gnsstk
42 {
45  : sat(0,SatelliteSystem::Unknown), xmitSat(0,SatelliteSystem::Unknown)
46  {
47  }
48 
49 
52  : NavSignalID(right)
53  {
54  sat.makeWild();
55  xmitSat.makeWild();
56  }
57 
58 
60  NavSatelliteID(unsigned long subj, unsigned long xmit,
62  NavType nmt)
63  : NavSignalID(sys,car,track,nmt), sat(subj,sys), xmitSat(xmit,sys)
64  {
65  }
66 
67 
69  NavSatelliteID(unsigned long subj, SatelliteSystem sys, CarrierBand car,
70  TrackingCode track, XmitAnt ant, int freqOffs,
71  bool freqOffsWild, NavType nmt)
72  : NavSignalID(sys,ObsID(ObservationType::NavMsg,car,track,freqOffs,
73  ant,freqOffsWild),nmt),
74  sat(subj,sys)
75  {
76  xmitSat.makeWild();
77  }
78 
79 
81  NavSatelliteID(unsigned long subj, SatelliteSystem sys, const ObsID& oid,
82  NavType nmt)
83  : NavSignalID(sys,oid,nmt),
84  sat(subj,sys)
85  {
86  xmitSat.makeWild();
87  }
88 
89 
91  NavSatelliteID(unsigned long subj,
93  NavType nmt)
94  : NavSignalID(sys,car,track,nmt), sat(subj,sys)
95  {
96  xmitSat.makeWild();
97  }
98 
99 
101  NavSatelliteID(unsigned long subj, const SatID& xmit, const ObsID& oid,
102  const NavID& navid)
103  : NavSignalID(xmit.system, oid, navid.navType),
104  sat(subj, xmit.system),
105  xmitSat(xmit)
106  {
107  }
108 
109 
111  NavSatelliteID(const SatID& subj, const SatID& xmit, const ObsID& oid,
112  const NavID& navid)
113  : NavSignalID(xmit.system, oid, navid.navType),
114  sat(subj),
115  xmitSat(xmit)
116  {
117  }
118 
119 
121  NavSatelliteID(const SatID& subj, const SatID& xmit, CarrierBand car,
122  TrackingCode track, NavType nmt)
123  : NavSignalID(subj.system, car, track, nmt),
124  sat(subj), xmitSat(xmit)
125  {
126  }
127 
128 
130  NavSatelliteID(const SatID& subj)
131  : NavSignalID(subj.system, gnsstk::CarrierBand::Any,
133  sat(subj)
134  {
135  xmitSat.makeWild();
136  }
137 
138 
139  bool NavSatelliteID ::
140  operator<(const NavSatelliteID& right) const
141  {
142  // Use the order() method so we don't have to compare
143  // everything in the parent class twice.
144  if (sat < right.sat) return true;
145  if (right.sat < sat) return false;
146  if (xmitSat < right.xmitSat) return true;
147  if (right.xmitSat < xmitSat) return false;
148  int o = NavSignalID::order(right);
149  if (o < 0) return true;
150  return false;
151  }
152 
153 
154  bool NavSatelliteID ::
155  operator==(const NavSatelliteID& right) const
156  {
157  // std::cerr << __PRETTY_FUNCTION__ << std::endl;
158  // Use the order() method so we don't have to compare
159  // everything in the parent class twice.
160  return ((NavSignalID::order(right) == 0) && (sat == right.sat) &&
161  (xmitSat == right.xmitSat));
162  }
163 
164 
165  bool NavSatelliteID ::
166  isWild() const
167  {
168  return sat.isWild() || xmitSat.isWild() || NavSignalID::isWild();
169  }
170 
171 
172  bool NavSatelliteID ::
173  isGLOFDMA() const
174  {
176  {
177  return false;
178  }
180  (sat.wildSys != true))
181  {
182  return false;
183  }
184  switch (obs.band)
185  {
186  case CarrierBand::Any:
187  // FDMA still possible
188  break;
189  case CarrierBand::G1:
190  case CarrierBand::G2:
191  case CarrierBand::G1a:
192  case CarrierBand::G2a:
193  // FDMA certain
194  return true;
195  default:
196  return false;
197  }
198  switch (obs.code)
199  {
200  case TrackingCode::Any:
201  // FDMA still possible
202  break;
205  // should be GLONASS assuming someone didn't use w/o reading.
206  return true;
207  default:
208  return false;
209  }
210  if (nav == NavType::GloCivilF)
211  {
212  return true;
213  }
214  if (nav != NavType::Any)
215  {
216  return false;
217  }
218  // last possible check...
219  return !obs.freqOffsWild;
220  }
221 }
gnsstk::NavSignalID::nav
NavType nav
Navigation message structure of this signal.
Definition: NavSignalID.hpp:96
gnsstk::SatID::makeWild
void makeWild()
Definition: SatID.cpp:74
gnsstk::NavSatelliteID::operator<
bool operator<(const NavSatelliteID &right) const
Sorting so we can use this class as a map key.
Definition: NavSatelliteID.cpp:140
gnsstk::CarrierBand::G1
@ G1
GLONASS G1.
gnsstk::NavSatelliteID::isWild
bool isWild() const override
Return true if any of the fields are set to match wildcards.
Definition: NavSatelliteID.cpp:166
gnsstk::CarrierBand
CarrierBand
Definition: CarrierBand.hpp:54
gnsstk::NavSatelliteID
Definition: NavSatelliteID.hpp:57
gnsstk::NavSatelliteID::NavSatelliteID
NavSatelliteID()
Sets the IDs to 0.
Definition: NavSatelliteID.cpp:44
gnsstk::SatelliteSystem
SatelliteSystem
Supported satellite systems.
Definition: SatelliteSystem.hpp:55
gnsstk::CarrierBand::Any
@ Any
Used to match any carrier band.
NavSatelliteID.hpp
example5.oid
oid
Definition: example5.py:29
gnsstk::SatID
Definition: SatID.hpp:89
gnsstk::ObsID::band
CarrierBand band
Definition: ObsID.hpp:200
gnsstk::NavType::GloCivilF
@ GloCivilF
gnsstk::NavSignalID::isWild
virtual bool isWild() const
return true if any of the fields are set to match wildcards.
Definition: NavSignalID.cpp:100
gnsstk
For Sinex::InputHistory.
Definition: BasicFramework.cpp:50
gnsstk::IonexStoreStrategy::Unknown
@ Unknown
Unknown or uninitialized stategy value.
gnsstk::TrackingCode::Standard
@ Standard
Legacy Glonass civil signal.
gnsstk::ObservationType::NavMsg
@ NavMsg
Navigation Message data.
gnsstk::NavSignalID::order
int order(const NavSignalID &right) const
Definition: NavSignalID.cpp:83
gnsstk::NavType::Any
@ Any
Used to match any nav code.
gnsstk::NavSignalID::obs
ObsID obs
Carrier, tracking code, etc.
Definition: NavSignalID.hpp:95
gnsstk::NavSignalID::system
SatelliteSystem system
GNSS for this signal.
Definition: NavSignalID.hpp:94
gnsstk::SatID::wildSys
bool wildSys
If true, any system matches.
Definition: SatID.hpp:157
gnsstk::SatID::isWild
bool isWild() const
return true if any of the fields are set to match wildcards.
Definition: SatID.cpp:81
gnsstk::ObsID
Definition: ObsID.hpp:82
gnsstk::NavSatelliteID::sat
SatID sat
ID of satellite to which the nav data applies.
Definition: NavSatelliteID.hpp:169
gnsstk::CarrierBand::G1a
@ G1a
GLONASS G1a.
gnsstk::ObsID::code
TrackingCode code
Definition: ObsID.hpp:201
gnsstk::XmitAnt
XmitAnt
Definition: XmitAnt.hpp:53
gnsstk::SatID::system
SatelliteSystem system
System for this satellite.
Definition: SatID.hpp:156
gnsstk::CarrierBand::G2a
@ G2a
GLONASS G2a.
gnsstk::NavSignalID
Class used to identify navigation data signal types.
Definition: NavSignalID.hpp:54
gnsstk::ObsID::freqOffsWild
bool freqOffsWild
True=Treat freqOffs as a wildcard when matching.
Definition: ObsID.hpp:204
gnsstk::TrackingCode
TrackingCode
Definition: TrackingCode.hpp:64
gnsstk::NavSatelliteID::isGLOFDMA
bool isGLOFDMA() const
Return true if this object identifies a GLONASS FDMA signal.
Definition: NavSatelliteID.cpp:173
gnsstk::TrackingCode::Precise
@ Precise
Legacy Glonass precise signal.
gnsstk::SatelliteSystem::Glonass
@ Glonass
gnsstk::NavSatelliteID::operator==
bool operator==(const NavSatelliteID &right) const
Comparison, including wildcards.
Definition: NavSatelliteID.cpp:155
gnsstk::NavID
Definition: NavID.hpp:61
gnsstk::NavType
NavType
Supported navigation types.
Definition: NavType.hpp:58
gnsstk::NavSatelliteID::xmitSat
SatID xmitSat
ID of the satellite transmitting the nav data.
Definition: NavSatelliteID.hpp:170
gnsstk::TrackingCode::Any
@ Any
Used to match any tracking code.
gnsstk::CarrierBand::G2
@ G2
GLONASS G2.
gnsstk::ObservationType
ObservationType
The type of observation, mostly used by ObsID.
Definition: ObservationType.hpp:55


gnsstk
Author(s):
autogenerated on Wed Oct 25 2023 02:40:40