gnss-sdr/src/core/system_parameters/galileo_ephemeris.h

122 lines
4.1 KiB
C++

/*!
* \file galileo_ephemeris.h
* \brief Interface of a Galileo EPHEMERIS storage
* \author Javier Arribas, 2013. jarribas(at)cttc.es,
* \author Mara Branzanti 2013. mara.branzanti(at)gmail.com
*
* -----------------------------------------------------------------------------
*
* GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
* This file is part of GNSS-SDR.
*
* Copyright (C) 2010-2020 (see AUTHORS file for a list of contributors)
* SPDX-License-Identifier: GPL-3.0-or-later
*
* -----------------------------------------------------------------------------
*/
#ifndef GNSS_SDR_GALILEO_EPHEMERIS_H
#define GNSS_SDR_GALILEO_EPHEMERIS_H
#include "gnss_ephemeris.h"
#include <boost/serialization/nvp.hpp>
#include <cstdint>
/** \addtogroup Core
* \{ */
/** \addtogroup System_Parameters
* \{ */
/*!
* \brief This class is a storage and orbital model functions for the Galileo SV
* ephemeris data as described in Galileo ICD paragraph 5.1.1
*
* (See https://www.gsc-europa.eu/sites/default/files/sites/all/files/Galileo_OS_SIS_ICD_v2.0.pdf )
*
*/
class Galileo_Ephemeris : public Gnss_Ephemeris
{
public:
Galileo_Ephemeris()
{
this->System = 'E';
}
double Galileo_System_Time(double week_number, double TOW); //!< Galileo System Time (GST), ICD paragraph 5.1.2
int32_t IOD_ephemeris{};
int32_t IOD_nav{};
// SV status
int32_t SISA{}; //!< Signal in space accuracy index
int32_t E5a_HS{}; //!< E5a Signal Health Status
int32_t E5b_HS{}; //!< E5b Signal Health Status
int32_t E1B_HS{}; //!< E1B Signal Health Status
bool E5a_DVS{}; //!< E5a Data Validity Status
bool E5b_DVS{}; //!< E5b Data Validity Status
bool E1B_DVS{}; //!< E1B Data Validity Status
double BGD_E1E5a{}; //!< E1-E5a Broadcast Group Delay [s]
double BGD_E1E5b{}; //!< E1-E5b Broadcast Group Delay [s]
bool flag_all_ephemeris{};
template <class Archive>
/*!
* \brief Serialize is a boost standard method to be called by the boost XML
* serialization. Here is used to save the ephemeris data on disk file.
*/
inline void serialize(Archive& archive, const uint32_t version)
{
if (version)
{
};
archive& BOOST_SERIALIZATION_NVP(PRN);
archive& BOOST_SERIALIZATION_NVP(M_0);
archive& BOOST_SERIALIZATION_NVP(delta_n);
archive& BOOST_SERIALIZATION_NVP(ecc);
archive& BOOST_SERIALIZATION_NVP(sqrtA);
archive& BOOST_SERIALIZATION_NVP(OMEGA_0);
archive& BOOST_SERIALIZATION_NVP(i_0);
archive& BOOST_SERIALIZATION_NVP(omega);
archive& BOOST_SERIALIZATION_NVP(OMEGAdot);
archive& BOOST_SERIALIZATION_NVP(idot);
archive& BOOST_SERIALIZATION_NVP(Cuc);
archive& BOOST_SERIALIZATION_NVP(Cus);
archive& BOOST_SERIALIZATION_NVP(Crc);
archive& BOOST_SERIALIZATION_NVP(Crs);
archive& BOOST_SERIALIZATION_NVP(Cic);
archive& BOOST_SERIALIZATION_NVP(Cis);
archive& BOOST_SERIALIZATION_NVP(toe);
archive& BOOST_SERIALIZATION_NVP(toc);
archive& BOOST_SERIALIZATION_NVP(af0);
archive& BOOST_SERIALIZATION_NVP(af1);
archive& BOOST_SERIALIZATION_NVP(af2);
archive& BOOST_SERIALIZATION_NVP(WN);
archive& BOOST_SERIALIZATION_NVP(tow);
archive& BOOST_SERIALIZATION_NVP(satClkDrift);
archive& BOOST_SERIALIZATION_NVP(dtr);
archive& BOOST_SERIALIZATION_NVP(IOD_ephemeris);
archive& BOOST_SERIALIZATION_NVP(IOD_nav);
archive& BOOST_SERIALIZATION_NVP(SISA);
archive& BOOST_SERIALIZATION_NVP(E5a_HS);
archive& BOOST_SERIALIZATION_NVP(E5b_HS);
archive& BOOST_SERIALIZATION_NVP(E1B_HS);
archive& BOOST_SERIALIZATION_NVP(E5a_DVS);
archive& BOOST_SERIALIZATION_NVP(E5b_DVS);
archive& BOOST_SERIALIZATION_NVP(E1B_DVS);
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5a);
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5b);
archive& BOOST_SERIALIZATION_NVP(flag_all_ephemeris);
}
};
/** \} */
/** \} */
#endif // GNSS_SDR_GALILEO_EPHEMERIS_H