NavData.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_NAVDATA_HPP
40 #define GNSSTK_NAVDATA_HPP
41 
42 #include <memory>
43 #include <map>
44 #include <list>
45 #include "gnsstk_export.h"
46 #include "CommonTime.hpp"
47 #include "NavSignalID.hpp"
48 #include "NavMessageID.hpp"
49 #include "DumpDetail.hpp"
50 #include "SatMetaDataStore.hpp"
51 
52 #ifdef SWIG
53 // make sure SWIG doesn't generate broken accessor methods to this data
55 #endif
56 
57 namespace gnsstk
58 {
60 
61 
62  class NavData; // forward declaration
63 
65  typedef std::shared_ptr<NavData> NavDataPtr;
67  typedef std::map<CommonTime, NavDataPtr> NavMap;
69  typedef std::map<NavSatelliteID, NavMap> NavSatMap;
71  typedef std::map<NavMessageType, NavSatMap> NavMessageMap;
75  typedef std::list<NavDataPtr> NavDataPtrList;
77  typedef std::map<CommonTime, NavDataPtrList> NavNearMap;
79  typedef std::map<NavSatelliteID, NavNearMap> NavNearSatMap;
81  typedef std::map<NavMessageType, NavNearSatMap> NavNearMessageMap;
82 
86  class NavData
87  {
88  public:
90  GNSSTK_EXPORT static const std::string dumpTimeFmt;
92  GNSSTK_EXPORT static const std::string dumpTimeFmtBrief;
94  NavData();
96  virtual NavDataPtr clone() const = 0;
101  virtual bool validate() const = 0;
104  virtual std::string getClassName() const;
110  virtual CommonTime getUserTime() const
111  { return timeStamp + msgLenSec; }
115  virtual CommonTime getNearTime() const
116  { return timeStamp; }
126  virtual bool isSameData(const NavDataPtr& right) const;
134  virtual std::list<std::string> compare(const NavDataPtr& right) const;
142  virtual void dump(std::ostream& s, DumpDetail dl) const;
150  bool getSVN(const SatID& sat, const gnsstk::CommonTime& when,
151  std::string& svn)
152  const
153  {
154  return ((satMetaDataStore != nullptr) &&
155  satMetaDataStore->getSVN(sat,when,svn));
156  }
159  std::string getSignalString() const;
164  std::string getDumpTimeHdr(DumpDetail dl) const;
169  std::string getDumpTime(DumpDetail dl, const CommonTime& t) const;
176 
181  { satMetaDataStore = smds; }
184  { return satMetaDataStore; }
185 
193  std::string weekFmt;
194  protected:
199  double msgLenSec;
201  friend class RinexNavDataFactory;
202  };
203 
205 
206 }
207 
208 #endif // GNSSTK_NAVDATA_HPP
gnsstk::NavDataPtr
std::shared_ptr< NavData > NavDataPtr
Factories instantiate these in response to find() requests.
Definition: NavData.hpp:62
gnsstk::NavData::validate
virtual bool validate() const =0
gnsstk::NavData::getSignalString
std::string getSignalString() const
Definition: NavData.cpp:86
gnsstk::NavMessageID
Class used to identify/categorize navigation message data.
Definition: NavMessageID.hpp:52
gnsstk::NavData::getUserTime
virtual CommonTime getUserTime() const
Definition: NavData.hpp:110
gnsstk::NavData::msgLenSec
double msgLenSec
Definition: NavData.hpp:199
gnsstk::NavData::dump
virtual void dump(std::ostream &s, DumpDetail dl) const
Definition: NavData.cpp:79
gnsstk::NavData::compare
virtual std::list< std::string > compare(const NavDataPtr &right) const
Definition: NavData.cpp:66
gnsstk::NavNearMap
std::map< CommonTime, NavDataPtrList > NavNearMap
Map from "nearest" time reference (e.g. toe) to list of NavDataPtr.
Definition: NavData.hpp:77
gnsstk::NavMessageMap
std::map< NavMessageType, NavSatMap > NavMessageMap
Map nav message type to the rest of the storage.
Definition: NavData.hpp:71
gnsstk::NavData::satMetaDataStore
static GNSSTK_EXPORT gnsstk::SatMetaDataStore * satMetaDataStore
Set this to a valid store to get PRN->SVN translations in dump().
Definition: NavData.hpp:178
gnsstk::NavData
Definition: NavData.hpp:86
gnsstk::NavData::getDumpTime
std::string getDumpTime(DumpDetail dl, const CommonTime &t) const
Definition: NavData.cpp:145
gnsstk::SatID
Definition: SatID.hpp:89
gnsstk::NavDataPtrList
std::list< NavDataPtr > NavDataPtrList
Definition: NavData.hpp:75
gnsstk::NavData::getDumpTimeHdr
std::string getDumpTimeHdr(DumpDetail dl) const
Definition: NavData.cpp:127
gnsstk::NavData::signal
NavMessageID signal
Source signal identification for this navigation message data.
Definition: NavData.hpp:175
gnsstk
For Sinex::InputHistory.
Definition: BasicFramework.cpp:50
gnsstk::SatMetaDataStore::getSVN
bool getSVN(SatelliteSystem sys, uint32_t prn, const gnsstk::CommonTime &when, std::string &svn) const
Definition: SatMetaDataStore.cpp:569
gnsstk::NavData::timeStamp
CommonTime timeStamp
Definition: NavData.hpp:173
gnsstk::NavData::weekFmt
std::string weekFmt
Definition: NavData.hpp:193
gnsstk::NavData::dumpTimeFmtBrief
static const GNSSTK_EXPORT std::string dumpTimeFmtBrief
Time format used for the dump method (Brief).
Definition: NavData.hpp:92
NavMessageID.hpp
gnsstk::NavData::setSatMetaDataStore
static void setSatMetaDataStore(gnsstk::SatMetaDataStore *smds)
Accessor for python.
Definition: NavData.hpp:180
gnsstk::CommonTime
Definition: CommonTime.hpp:84
gnsstk::NavData::getNearTime
virtual CommonTime getNearTime() const
Definition: NavData.hpp:115
gnsstk::SatMetaDataStore
Definition: SatMetaDataStore.hpp:138
gnsstk::NavData::getSatMetaDataStore
static gnsstk::SatMetaDataStore * getSatMetaDataStore()
Accessor for python.
Definition: NavData.hpp:183
gnsstk::NavData::dumpTimeFmt
static const GNSSTK_EXPORT std::string dumpTimeFmt
Time format used for the dump method (Full).
Definition: NavData.hpp:90
gnsstk::NavData::NavData
NavData()
Initialize internal data fields.
Definition: NavData.cpp:50
gnsstk::DumpDetail
DumpDetail
Specify level of detail for dump output.
Definition: DumpDetail.hpp:51
CommonTime.hpp
gnsstk::RinexNavDataFactory
Definition: RinexNavDataFactory.hpp:57
gnsstk::NavMap
std::map< CommonTime, NavDataPtr > NavMap
Map nav message transmit time to nav message.
Definition: NavData.hpp:67
DumpDetail.hpp
gnsstk::NavData::clone
virtual NavDataPtr clone() const =0
Create a deep copy of this object, whatever it truly is.
gnsstk::NavData::getSVN
bool getSVN(const SatID &sat, const gnsstk::CommonTime &when, std::string &svn) const
Definition: NavData.hpp:150
gnsstk::NavNearMessageMap
std::map< NavMessageType, NavNearSatMap > NavNearMessageMap
Map nav message type to the rest of the storage.
Definition: NavData.hpp:81
SatMetaDataStore.hpp
NavSignalID.hpp
gnsstk::NavData::isSameData
virtual bool isSameData(const NavDataPtr &right) const
Definition: NavData.cpp:58
gnsstk::NavData::getClassName
virtual std::string getClassName() const
Definition: NavData.cpp:172
gnsstk::NavSatMap
std::map< NavSatelliteID, NavMap > NavSatMap
Map satellite to nav data.
Definition: NavData.hpp:69
gnsstk::NavNearSatMap
std::map< NavSatelliteID, NavNearMap > NavNearSatMap
Map satellite to nearest map.
Definition: NavData.hpp:79


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