RinexNavDataFactory.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 //
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 #ifndef GNSSTK_RINEXNAVDATAFACTORY_HPP
40 #define GNSSTK_RINEXNAVDATAFACTORY_HPP
41 
43 #include "Rinex3NavData.hpp"
44 #include "GPSLNavEph.hpp"
45 
46 namespace gnsstk
47 {
49 
50 
58  {
59  public:
62 
65  {
66  }
67 
75  bool loadIntoMap(const std::string& filename,
76  NavMessageMap& navMap,
77  NavNearMessageMap& navNearMap,
78  OffsetCvtMap& ofsMap) override;
79 
81  bool process(const std::string& filename,
82  NavDataFactoryCallback& cb) override;
83 
85  std::string getFactoryFormats() const override;
86 
95  static bool convertToOrbit(const Rinex3NavData& navIn,
96  NavDataPtr& navOut);
97 
103  static void convertToOrbitDataKepler(const Rinex3NavData& navIn,
104  OrbitDataKepler* navOut);
105 
114  static bool convertToHealth(const Rinex3NavData& navIn,
115  NavDataPtrList& healthOut);
116 
121  static void convertToHealthE1B(const Rinex3NavData& navIn,
122  NavDataPtrList& healthOut);
123 
128  static void convertToHealthE5a(const Rinex3NavData& navIn,
129  NavDataPtrList& healthOut);
130 
135  static void convertToHealthE5b(const Rinex3NavData& navIn,
136  NavDataPtrList& healthOut);
137 
144  static bool convertToOffset(const Rinex3NavHeader& navIn,
145  NavDataPtrList& navOut);
146 
158  static bool convertToIono(const CommonTime& when,
159  const Rinex3NavHeader& navIn,
160  NavDataPtrList& navOut);
161 
168  static bool convertToISC(const Rinex3NavData& navIn,
169  NavDataPtr& navOut);
170 
180  static void fillNavData(const Rinex3NavData& navIn, NavDataPtr& navOut);
181 
187  static void fixTimeGPS(const Rinex3NavData& navIn, GPSLNavEph& navOut);
188 
194  static void fixTimeGalileo(const Rinex3NavData& navIn,
195  OrbitDataKepler& navOut);
196 
202  static void fixTimeBeiDou(const Rinex3NavData& navIn,
203  OrbitDataKepler& navOut);
204 
210  static uint8_t decodeSISA(double accuracy);
211 
218  static double encodeSISA(uint8_t sisa);
219  };
220 
222 
223 }
224 
225 #endif // GNSSTK_RINEXNAVDATAFACTORY_HPP
gnsstk::NavDataPtr
std::shared_ptr< NavData > NavDataPtr
Factories instantiate these in response to find() requests.
Definition: NavData.hpp:62
gnsstk::RinexNavDataFactory::convertToHealth
static bool convertToHealth(const Rinex3NavData &navIn, NavDataPtrList &healthOut)
Definition: RinexNavDataFactory.cpp:628
gnsstk::RinexNavDataFactory::convertToOffset
static bool convertToOffset(const Rinex3NavHeader &navIn, NavDataPtrList &navOut)
Definition: RinexNavDataFactory.cpp:811
gnsstk::Rinex3NavData
Definition: Rinex3NavData.hpp:69
gnsstk::RinexNavDataFactory::fillNavData
static void fillNavData(const Rinex3NavData &navIn, NavDataPtr &navOut)
Definition: RinexNavDataFactory.cpp:1115
gnsstk::NavDataFactoryWithStore::OffsetCvtMap
std::map< TimeCvtKey, OffsetEpochMap > OffsetCvtMap
Map from the time system conversion pair to the conversion objects.
Definition: NavDataFactoryWithStore.hpp:74
gnsstk::NavMessageMap
std::map< NavMessageType, NavSatMap > NavMessageMap
Map nav message type to the rest of the storage.
Definition: NavData.hpp:71
gnsstk::RinexNavDataFactory::encodeSISA
static double encodeSISA(uint8_t sisa)
Definition: RinexNavDataFactory.cpp:1318
gnsstk::RinexNavDataFactory::convertToIono
static bool convertToIono(const CommonTime &when, const Rinex3NavHeader &navIn, NavDataPtrList &navOut)
Definition: RinexNavDataFactory.cpp:861
gnsstk::RinexNavDataFactory::decodeSISA
static uint8_t decodeSISA(double accuracy)
Definition: RinexNavDataFactory.cpp:1293
gnsstk::NavDataPtrList
std::list< NavDataPtr > NavDataPtrList
Definition: NavData.hpp:75
gnsstk::RinexNavDataFactory::RinexNavDataFactory
RinexNavDataFactory()
Fill supportedSignals.
Definition: RinexNavDataFactory.cpp:73
gnsstk
For Sinex::InputHistory.
Definition: BasicFramework.cpp:50
gnsstk::RinexNavDataFactory::fixTimeGPS
static void fixTimeGPS(const Rinex3NavData &navIn, GPSLNavEph &navOut)
Definition: RinexNavDataFactory.cpp:1219
Rinex3NavData.hpp
gnsstk::NavDataFactoryWithStoreFile
Define an interface for loading nav data from a file.
Definition: NavDataFactoryWithStoreFile.hpp:51
gnsstk::NavDataFactoryCallback
Definition: NavDataFactoryCallback.hpp:54
gnsstk::Rinex3NavHeader
Definition: Rinex3NavHeader.hpp:107
gnsstk::RinexNavDataFactory::fixTimeBeiDou
static void fixTimeBeiDou(const Rinex3NavData &navIn, OrbitDataKepler &navOut)
Definition: RinexNavDataFactory.cpp:1285
gnsstk::CommonTime
Definition: CommonTime.hpp:84
gnsstk::RinexNavDataFactory::convertToISC
static bool convertToISC(const Rinex3NavData &navIn, NavDataPtr &navOut)
Definition: RinexNavDataFactory.cpp:1032
gnsstk::RinexNavDataFactory::convertToOrbit
static bool convertToOrbit(const Rinex3NavData &navIn, NavDataPtr &navOut)
Definition: RinexNavDataFactory.cpp:326
NavDataFactoryWithStoreFile.hpp
gnsstk::RinexNavDataFactory::convertToHealthE5a
static void convertToHealthE5a(const Rinex3NavData &navIn, NavDataPtrList &healthOut)
Definition: RinexNavDataFactory.cpp:744
gnsstk::RinexNavDataFactory::~RinexNavDataFactory
virtual ~RinexNavDataFactory()
Clean up.
Definition: RinexNavDataFactory.hpp:64
gnsstk::RinexNavDataFactory::convertToOrbitDataKepler
static void convertToOrbitDataKepler(const Rinex3NavData &navIn, OrbitDataKepler *navOut)
Definition: RinexNavDataFactory.cpp:598
gnsstk::OrbitDataKepler
Base class for orbit information that uses Keplerian parameters.
Definition: OrbitDataKepler.hpp:52
gnsstk::RinexNavDataFactory::loadIntoMap
bool loadIntoMap(const std::string &filename, NavMessageMap &navMap, NavNearMessageMap &navNearMap, OffsetCvtMap &ofsMap) override
Definition: RinexNavDataFactory.cpp:107
gnsstk::RinexNavDataFactory
Definition: RinexNavDataFactory.hpp:57
gnsstk::RinexNavDataFactory::process
bool process(const std::string &filename, NavDataFactoryCallback &cb) override
Definition: RinexNavDataFactory.cpp:116
gnsstk::GPSLNavEph
Class containing data elements unique to GPS LNav ephemerides.
Definition: GPSLNavEph.hpp:51
gnsstk::RinexNavDataFactory::getFactoryFormats
std::string getFactoryFormats() const override
Return a comma-separated list of formats supported by this factory.
Definition: RinexNavDataFactory.cpp:311
GPSLNavEph.hpp
gnsstk::RinexNavDataFactory::convertToHealthE5b
static void convertToHealthE5b(const Rinex3NavData &navIn, NavDataPtrList &healthOut)
Definition: RinexNavDataFactory.cpp:777
gnsstk::NavNearMessageMap
std::map< NavMessageType, NavNearSatMap > NavNearMessageMap
Map nav message type to the rest of the storage.
Definition: NavData.hpp:81
gnsstk::RinexNavDataFactory::fixTimeGalileo
static void fixTimeGalileo(const Rinex3NavData &navIn, OrbitDataKepler &navOut)
Definition: RinexNavDataFactory.cpp:1273
gnsstk::RinexNavDataFactory::convertToHealthE1B
static void convertToHealthE1B(const Rinex3NavData &navIn, NavDataPtrList &healthOut)
Definition: RinexNavDataFactory.cpp:706


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