2012-07-12 21:17:37 +00:00
|
|
|
/*!
|
|
|
|
* \file galileo_e1_signal_processing.h
|
|
|
|
* \brief This library implements various functions for Galileo E1 signals
|
|
|
|
* \author Luis Esteve, 2012. luis(at)epsilon-formacion.com
|
|
|
|
*
|
|
|
|
*
|
2020-07-28 14:57:15 +00:00
|
|
|
* -----------------------------------------------------------------------------
|
2012-07-12 21:17:37 +00:00
|
|
|
*
|
2020-07-28 14:57:15 +00:00
|
|
|
* Copyright (C) 2010-2020 (see AUTHORS file for a list of contributors)
|
2012-07-12 21:17:37 +00:00
|
|
|
*
|
|
|
|
* GNSS-SDR is a software defined Global Navigation
|
|
|
|
* Satellite Systems receiver
|
|
|
|
*
|
|
|
|
* This file is part of GNSS-SDR.
|
|
|
|
*
|
2020-02-08 00:20:02 +00:00
|
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
2012-07-12 21:17:37 +00:00
|
|
|
*
|
2020-07-28 14:57:15 +00:00
|
|
|
* -----------------------------------------------------------------------------
|
2012-07-12 21:17:37 +00:00
|
|
|
*/
|
|
|
|
|
2020-02-08 09:10:46 +00:00
|
|
|
#ifndef GNSS_SDR_GALILEO_E1_SIGNAL_PROCESSING_H
|
|
|
|
#define GNSS_SDR_GALILEO_E1_SIGNAL_PROCESSING_H
|
2012-07-12 21:17:37 +00:00
|
|
|
|
2019-06-28 23:28:30 +00:00
|
|
|
#include <array>
|
2012-07-12 21:17:37 +00:00
|
|
|
#include <complex>
|
2018-08-13 08:18:05 +00:00
|
|
|
#include <cstdint>
|
2020-05-07 19:47:45 +00:00
|
|
|
#if HAS_STD_SPAN
|
|
|
|
#include <span>
|
2020-05-07 21:11:11 +00:00
|
|
|
namespace own = std;
|
2020-05-07 19:47:45 +00:00
|
|
|
#else
|
|
|
|
#include <gsl/gsl>
|
2020-05-07 21:11:11 +00:00
|
|
|
namespace own = gsl;
|
2020-05-07 19:47:45 +00:00
|
|
|
#endif
|
2019-06-28 23:28:30 +00:00
|
|
|
|
2016-01-10 21:21:31 +00:00
|
|
|
|
2018-03-16 11:21:13 +00:00
|
|
|
/*!
|
|
|
|
* \brief This function generates Galileo E1 code (can select E1B or E1C sinboc).
|
|
|
|
*
|
|
|
|
*/
|
2020-05-07 21:11:11 +00:00
|
|
|
void galileo_e1_code_gen_sinboc11_float(own::span<float> _dest, const std::array<char, 3>& _Signal, uint32_t _prn);
|
2012-07-12 21:17:37 +00:00
|
|
|
|
|
|
|
/*!
|
2017-09-11 14:21:05 +00:00
|
|
|
* \brief This function generates Galileo E1 code (can select E1B or E1C, cboc or sinboc
|
|
|
|
* and the sample frequency _fs).
|
2012-07-12 21:17:37 +00:00
|
|
|
*
|
|
|
|
*/
|
2020-05-07 21:11:11 +00:00
|
|
|
void galileo_e1_code_gen_float_sampled(own::span<float> _dest, const std::array<char, 3>& _Signal,
|
2018-08-13 08:18:05 +00:00
|
|
|
bool _cboc, uint32_t _prn, int32_t _fs, uint32_t _chip_shift,
|
2018-03-03 01:03:39 +00:00
|
|
|
bool _secondary_flag);
|
2016-01-11 10:32:41 +00:00
|
|
|
|
2012-07-12 21:17:37 +00:00
|
|
|
/*!
|
2017-09-11 14:21:05 +00:00
|
|
|
* \brief This function generates Galileo E1 code (can select E1B or E1C, cboc or sinboc
|
|
|
|
* and the sample frequency _fs).
|
2012-07-12 21:17:37 +00:00
|
|
|
*
|
|
|
|
*/
|
2020-05-07 21:11:11 +00:00
|
|
|
void galileo_e1_code_gen_float_sampled(own::span<float> _dest, const std::array<char, 3>& _Signal,
|
2018-08-13 08:18:05 +00:00
|
|
|
bool _cboc, uint32_t _prn, int32_t _fs, uint32_t _chip_shift);
|
2017-09-11 14:21:05 +00:00
|
|
|
|
2012-07-12 21:17:37 +00:00
|
|
|
/*!
|
|
|
|
* \brief This function generates Galileo E1 code (can select E1B or E1C, cboc or sinboc
|
|
|
|
* and the sample frequency _fs).
|
|
|
|
*
|
|
|
|
*/
|
2020-05-07 21:11:11 +00:00
|
|
|
void galileo_e1_code_gen_complex_sampled(own::span<std::complex<float>> _dest, const std::array<char, 3>& _Signal,
|
2018-08-13 08:18:05 +00:00
|
|
|
bool _cboc, uint32_t _prn, int32_t _fs, uint32_t _chip_shift,
|
2018-03-03 01:03:39 +00:00
|
|
|
bool _secondary_flag);
|
2013-07-23 18:03:07 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief galileo_e1_code_gen_complex_sampled without _secondary_flag for backward compatibility.
|
|
|
|
*/
|
2020-05-07 21:11:11 +00:00
|
|
|
void galileo_e1_code_gen_complex_sampled(own::span<std::complex<float>> _dest, const std::array<char, 3>& _Signal,
|
2018-08-13 08:18:05 +00:00
|
|
|
bool _cboc, uint32_t _prn, int32_t _fs, uint32_t _chip_shift);
|
2012-07-12 21:17:37 +00:00
|
|
|
|
2020-02-08 09:10:46 +00:00
|
|
|
#endif // GNSS_SDR_GALILEO_E1_SIGNAL_PROCESSING_H
|