mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-22 23:17:03 +00:00
Now you can change the default /tmp directory with the flag --log_dir
$ ./gnss-sdr --log_dir=./log Added some documentation and comments git-svn-id: https://svn.code.sf.net/p/gnss-sdr/code/trunk@101 64b25241-fba3-4117-9849-534c7e92360d
This commit is contained in:
parent
27b5074152
commit
0cee2be18f
@ -76,7 +76,7 @@ gps_l1_ca_pvt_cc::gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr que
|
|||||||
d_averaging_depth=averaging_depth;
|
d_averaging_depth=averaging_depth;
|
||||||
d_flag_averaging=flag_averaging;
|
d_flag_averaging=flag_averaging;
|
||||||
/*!
|
/*!
|
||||||
* \todo Enable RINEX printer: The actual RINEX printer need a complete refactoring and some bug fixing work
|
* \todo Enable RINEX printer: The current RINEX printer need a complete refactoring and some bug fixing work
|
||||||
*/
|
*/
|
||||||
//d_rinex_printer.set_headers("GNSS-SDR");
|
//d_rinex_printer.set_headers("GNSS-SDR");
|
||||||
d_ls_pvt=new gps_l1_ca_ls_pvt(nchannels,d_dump_filename,d_dump);
|
d_ls_pvt=new gps_l1_ca_ls_pvt(nchannels,d_dump_filename,d_dump);
|
||||||
|
@ -136,7 +136,7 @@ void gps_l1_ca_pcps_acquisition_cc::set_satellite(unsigned int satellite)
|
|||||||
code_gen_complex_sampled(d_fft_if->get_inbuf(), satellite, d_fs_in, 0);
|
code_gen_complex_sampled(d_fft_if->get_inbuf(), satellite, d_fs_in, 0);
|
||||||
d_fft_if->execute(); // We need the FFT of GPS C/A code
|
d_fft_if->execute(); // We need the FFT of GPS C/A code
|
||||||
//Conjugate the local code
|
//Conjugate the local code
|
||||||
//TODO Optimize it !
|
//TODO Optimize it ! try conj()
|
||||||
for (unsigned int i = 0; i < d_fft_size; i++)
|
for (unsigned int i = 0; i < d_fft_size; i++)
|
||||||
{
|
{
|
||||||
d_fft_codes[i] = std::complex<float>(
|
d_fft_codes[i] = std::complex<float>(
|
||||||
@ -172,12 +172,12 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
/*!
|
/*!
|
||||||
* By J.Arribas
|
* By J.Arribas
|
||||||
* Acquisition A strategy (Kay Borre book + CFAR threshold):
|
* Acquisition A strategy (Kay Borre book + CFAR threshold):
|
||||||
* 1º- Compute the input signal power estimation
|
* 1. Compute the input signal power estimation
|
||||||
* 2º- Doppler serial search loop
|
* 2. Doppler serial search loop
|
||||||
* 3º- Perform the FFT-based circular convolution (parallel time search)
|
* 3. Perform the FFT-based circular convolution (parallel time search)
|
||||||
* 4º- record the maximum peak and the associated synchronization parameters
|
* 4. Record the maximum peak and the associated synchronization parameters
|
||||||
* 5º- Compute the test statistics and compare to the threshold
|
* 5. Compute the test statistics and compare to the threshold
|
||||||
* 6º- Declare positive or negative acquisition using a message queue
|
* 6. Declare positive or negative acquisition using a message queue
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!d_active)
|
if (!d_active)
|
||||||
@ -217,7 +217,8 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
<< d_threshold << ", doppler_max: " << d_doppler_max
|
<< d_threshold << ", doppler_max: " << d_doppler_max
|
||||||
<< ", doppler_step: " << d_doppler_step;
|
<< ", doppler_step: " << d_doppler_step;
|
||||||
|
|
||||||
// 1º Compute the input signal power estimation
|
// 1- Compute the input signal power estimation
|
||||||
|
//! \TODO try norm()
|
||||||
for (i = 0; i < d_fft_size; i++)
|
for (i = 0; i < d_fft_size; i++)
|
||||||
{
|
{
|
||||||
d_input_power += std::abs(in[i]) * std::abs(in[i]);
|
d_input_power += std::abs(in[i]) * std::abs(in[i]);
|
||||||
@ -225,7 +226,7 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
|
|
||||||
d_input_power = d_input_power / (float)d_fft_size;
|
d_input_power = d_input_power / (float)d_fft_size;
|
||||||
|
|
||||||
// 2º- Doppler frequency search loop
|
// 2- Doppler frequency search loop
|
||||||
for (doppler = (int)(-d_doppler_max); doppler < (int)d_doppler_max; doppler
|
for (doppler = (int)(-d_doppler_max); doppler < (int)d_doppler_max; doppler
|
||||||
+= d_doppler_step)
|
+= d_doppler_step)
|
||||||
{ // doppler search steps
|
{ // doppler search steps
|
||||||
@ -236,8 +237,10 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
d_fft_if->get_inbuf()[i] = in[i] * d_sine_if[i];
|
d_fft_if->get_inbuf()[i] = in[i] * d_sine_if[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
//3º- Perform the FFT-based circular convolution (parallel time search)
|
//3- Perform the FFT-based circular convolution (parallel time search)
|
||||||
d_fft_if->execute(); //TODO Optimize me
|
d_fft_if->execute();
|
||||||
|
|
||||||
|
//TODO Optimize me
|
||||||
for (i = 0; i < d_fft_size; i++)
|
for (i = 0; i < d_fft_size; i++)
|
||||||
{
|
{
|
||||||
d_ifft->get_inbuf()[i] = (d_fft_if->get_outbuf()[i]
|
d_ifft->get_inbuf()[i] = (d_fft_if->get_outbuf()[i]
|
||||||
@ -245,7 +248,7 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
}
|
}
|
||||||
d_ifft->execute();
|
d_ifft->execute();
|
||||||
|
|
||||||
// ASM accelerated version
|
// old version
|
||||||
//x86_gr_complex_mag(d_ifft->get_outbuf(), d_fft_size); // d_ifft->get_outbuf()=|abs(·)|^2 and the array is converted from CPX->Float
|
//x86_gr_complex_mag(d_ifft->get_outbuf(), d_fft_size); // d_ifft->get_outbuf()=|abs(·)|^2 and the array is converted from CPX->Float
|
||||||
//x86_float_max((float*)d_ifft->get_outbuf(), &indext, &magt,
|
//x86_float_max((float*)d_ifft->get_outbuf(), &indext, &magt,
|
||||||
// d_fft_size); // find max of |abs(·)|^2 -> index and magt
|
// d_fft_size); // find max of |abs(·)|^2 -> index and magt
|
||||||
@ -274,7 +277,7 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
d_dump_file.write((char*)d_ifft->get_outbuf(), n); //write directly |abs(·)|^2 in this Doppler bin
|
d_dump_file.write((char*)d_ifft->get_outbuf(), n); //write directly |abs(·)|^2 in this Doppler bin
|
||||||
d_dump_file.close();
|
d_dump_file.close();
|
||||||
}
|
}
|
||||||
// 4º- record the maximum peak and the associated synchronization parameters
|
// 4- record the maximum peak and the associated synchronization parameters
|
||||||
if (d_mag < magt)
|
if (d_mag < magt)
|
||||||
{
|
{
|
||||||
d_mag = magt;
|
d_mag = magt;
|
||||||
@ -283,9 +286,9 @@ int gps_l1_ca_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 5º- Compute the test statistics and compare to the threshold
|
// 5- Compute the test statistics and compare to the threshold
|
||||||
d_test_statistics = 2*d_fft_size*d_mag / d_input_power;
|
d_test_statistics = 2*d_fft_size*d_mag / d_input_power;
|
||||||
// 6º- Declare positive or negative acquisition using a message queue
|
// 6- Declare positive or negative acquisition using a message queue
|
||||||
|
|
||||||
if (d_test_statistics > d_threshold)
|
if (d_test_statistics > d_threshold)
|
||||||
{ //0.004
|
{ //0.004
|
||||||
|
@ -147,11 +147,12 @@ void gps_l1_ca_tong_pcps_acquisition_cc::set_satellite(unsigned int satellite)
|
|||||||
d_noise_power = 0.0;
|
d_noise_power = 0.0;
|
||||||
|
|
||||||
// The GPS codes are generated on the fly using a custom version of the GPS code generator
|
// The GPS codes are generated on the fly using a custom version of the GPS code generator
|
||||||
|
//! \TODO In-memory codes instead of generated on the fly
|
||||||
code_gen_complex_sampled(d_fft_if->get_inbuf(), satellite, d_fs_in, 0);
|
code_gen_complex_sampled(d_fft_if->get_inbuf(), satellite, d_fs_in, 0);
|
||||||
|
|
||||||
d_fft_if->execute(); // We need the FFT of GPS C/A code
|
d_fft_if->execute(); // We need the FFT of GPS C/A code
|
||||||
//Conjugate the local code
|
//Conjugate the local code
|
||||||
//TODO Optimize it !
|
//! \TODO Optimize it ! Try conj() or Armadillo
|
||||||
for (unsigned int i = 0; i < d_samples; i++)
|
for (unsigned int i = 0; i < d_samples; i++)
|
||||||
{
|
{
|
||||||
d_fft_codes[i] = std::complex<float>(
|
d_fft_codes[i] = std::complex<float>(
|
||||||
@ -210,22 +211,24 @@ int gps_l1_ca_tong_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
// vt = noise_envelope * sqrt( -2 * log( d_pfa ) );
|
// vt = noise_envelope * sqrt( -2 * log( d_pfa ) );
|
||||||
|
|
||||||
|
|
||||||
// 1º Compute the input signal power estimation
|
// 1- Compute the input signal power estimation
|
||||||
for (unsigned int i = 0; i < d_samples; i++)
|
for (unsigned int i = 0; i < d_samples; i++)
|
||||||
{
|
{
|
||||||
d_noise_power += std::abs(in[i]);
|
d_noise_power += std::abs(in[i]);
|
||||||
}
|
}
|
||||||
d_noise_power = sqrt(d_noise_power / (float)d_samples);
|
d_noise_power = sqrt(d_noise_power / (float)d_samples);
|
||||||
|
|
||||||
//Perform the carrier wipe-off
|
//2. Perform the carrier wipe-off
|
||||||
sine_gen_complex(d_if_sin, d_freq + d_doppler, d_fs_in, d_samples);
|
sine_gen_complex(d_if_sin, d_freq + d_doppler, d_fs_in, d_samples);
|
||||||
for (unsigned int i = 0; i < d_samples; i++)
|
for (unsigned int i = 0; i < d_samples; i++)
|
||||||
{
|
{
|
||||||
d_fft_if->get_inbuf()[i] = in[i] * d_if_sin[i];
|
d_fft_if->get_inbuf()[i] = in[i] * d_if_sin[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
//3º- Perform the FFT-based circular convolution (parallel time search)
|
//3- Perform the FFT-based circular convolution (parallel time search)
|
||||||
d_fft_if->execute(); //TODO Optimize me
|
d_fft_if->execute();
|
||||||
|
|
||||||
|
//TODO Optimize me: use Armadillo!
|
||||||
for (unsigned int i = 0; i < d_samples; i++)
|
for (unsigned int i = 0; i < d_samples; i++)
|
||||||
{
|
{
|
||||||
d_ifft->get_inbuf()[i] = d_fft_if->get_outbuf()[i]
|
d_ifft->get_inbuf()[i] = d_fft_if->get_outbuf()[i]
|
||||||
@ -233,6 +236,7 @@ int gps_l1_ca_tong_pcps_acquisition_cc::general_work(int noutput_items,
|
|||||||
}
|
}
|
||||||
|
|
||||||
d_ifft->execute();
|
d_ifft->execute();
|
||||||
|
|
||||||
x86_gr_complex_mag(d_ifft->get_outbuf(), d_samples); // d_ifft->get_outbuf()=|abs(·)|^2 and the array is converted from CPX->Float
|
x86_gr_complex_mag(d_ifft->get_outbuf(), d_samples); // d_ifft->get_outbuf()=|abs(·)|^2 and the array is converted from CPX->Float
|
||||||
x86_float_max((float*)d_ifft->get_outbuf(), &d_indext, &magt,
|
x86_float_max((float*)d_ifft->get_outbuf(), &d_indext, &magt,
|
||||||
d_samples); // find max of |abs(·)|^2 -> index and magt
|
d_samples); // find max of |abs(·)|^2 -> index and magt
|
||||||
|
@ -1,25 +1,37 @@
|
|||||||
/*! \file SSE.cpp
|
/*!
|
||||||
SIMD functionality, mainly for 32 bit interleaved complex integer type (CPX)
|
* \file gps_sdr_simd.cc
|
||||||
|
* \brief SIMD functionality, mainly for 32 bit interleaved complex integer type (CPX)
|
||||||
|
* \author Copyright 2008 Gregory W Heckler
|
||||||
|
*
|
||||||
|
* This class implements operations in assembler (SSE technology in Intel processors)
|
||||||
|
* It has been copied from Gregory W Heckler's GPS-SDR Project
|
||||||
|
* Please see http://github.com/gps-sdr/gps-sdr
|
||||||
|
*
|
||||||
|
* -------------------------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
||||||
|
*
|
||||||
|
* GNSS-SDR is a software defined Global Navigation
|
||||||
|
* Satellite Systems receiver
|
||||||
|
*
|
||||||
|
* This file is part of GNSS-SDR.
|
||||||
|
*
|
||||||
|
* GNSS-SDR is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* at your option) any later version.
|
||||||
|
*
|
||||||
|
* GNSS-SDR is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/************************************************************************************************
|
|
||||||
Copyright 2008 Gregory W Heckler
|
|
||||||
|
|
||||||
This file is part of the GPS Software Defined Radio (GPS-SDR)
|
|
||||||
|
|
||||||
The GPS-SDR is free software; you can redistribute it and/or modify it under the terms of the
|
|
||||||
GNU General Public License as published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The GPS-SDR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
|
|
||||||
even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along with GPS-SDR; if not,
|
|
||||||
write to the:
|
|
||||||
|
|
||||||
Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
************************************************************************************************/
|
|
||||||
#ifdef USE_SIMD
|
#ifdef USE_SIMD
|
||||||
#include "gps_sdr_simd.h"
|
#include "gps_sdr_simd.h"
|
||||||
|
|
||||||
|
@ -1,50 +1,54 @@
|
|||||||
/*! \file SIMD.h
|
/*!
|
||||||
Contains prototpyes for all the SIMD functions
|
* \file gps_sdr_simd.cc
|
||||||
|
* \brief Contains prototypes for SIMD instructions
|
||||||
|
* \author Copyright 2008 Gregory W Heckler
|
||||||
|
*
|
||||||
|
* This class implements operations in assembler (SSE technology in Intel processors)
|
||||||
|
* It has been copied from Gregory W Heckler's GPS-SDR Project
|
||||||
|
* Please see http://github.com/gps-sdr/gps-sdr
|
||||||
|
*
|
||||||
|
* -------------------------------------------------------------------------
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
||||||
|
*
|
||||||
|
* GNSS-SDR is a software defined Global Navigation
|
||||||
|
* Satellite Systems receiver
|
||||||
|
*
|
||||||
|
* This file is part of GNSS-SDR.
|
||||||
|
*
|
||||||
|
* GNSS-SDR is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* at your option) any later version.
|
||||||
|
*
|
||||||
|
* GNSS-SDR is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/************************************************************************************************
|
|
||||||
Copyright 2008 Gregory W Heckler
|
|
||||||
|
|
||||||
This file is part of the GPS Software Defined Radio (GPS-SDR)
|
|
||||||
|
|
||||||
The GPS-SDR is free software; you can redistribute it and/or modify it under the terms of the
|
|
||||||
GNU General Public License as published by the Free Software Foundation; either version 2 of the
|
|
||||||
License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The GPS-SDR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
|
|
||||||
even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License along with GPS-SDR; if not,
|
|
||||||
write to the:
|
|
||||||
|
|
||||||
Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
************************************************************************************************/
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef SIMD_H_
|
#ifndef SIMD_H_
|
||||||
#define SIMD_H_
|
#define SIMD_H_
|
||||||
|
|
||||||
|
|
||||||
//#ifdef GLOBALS_HERE
|
|
||||||
// #define EXTERN
|
|
||||||
//#else
|
|
||||||
// #define EXTERN extern
|
|
||||||
//#endif
|
|
||||||
|
|
||||||
#include "gps_sdr_defines.h"
|
#include "gps_sdr_defines.h"
|
||||||
#include "gps_sdr_signal_processing.h"
|
#include "gps_sdr_signal_processing.h"
|
||||||
|
|
||||||
/* Found in CPUID.cpp */
|
/* Found in CPUID.cpp */
|
||||||
/*----------------------------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------------------------*/
|
||||||
bool CPU_MMX(); //!< Does the CPU support MMX?
|
//bool CPU_MMX(); //!< Does the CPU support MMX?
|
||||||
bool CPU_SSE(); //!< Does the CPU support SSE?
|
//bool CPU_SSE(); //!< Does the CPU support SSE?
|
||||||
bool CPU_SSE2(); //!< Does the CPU support SSE2?
|
//bool CPU_SSE2(); //!< Does the CPU support SSE2?
|
||||||
bool CPU_SSE3(); //!< Does the CPU support SSE3?
|
//bool CPU_SSE3(); //!< Does the CPU support SSE3?
|
||||||
bool CPU_SSSE3(); //!< Does the CPU support SSSE3? No thats not a typo!
|
//bool CPU_SSSE3(); //!< Does the CPU support SSSE3? No thats not a typo!
|
||||||
bool CPU_SSE41(); //!< Does the CPU support SSE4.1?
|
//bool CPU_SSE41(); //!< Does the CPU support SSE4.1?
|
||||||
bool CPU_SSE42(); //!< Does the CPU support SSE4.2?
|
//bool CPU_SSE42(); //!< Does the CPU support SSE4.2?
|
||||||
void Init_SIMD(); //!< Initialize the global function pointers
|
//void Init_SIMD(); //!< Initialize the global function pointers
|
||||||
/*----------------------------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
/* Found in SSE.cpp */
|
/* Found in SSE.cpp */
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file control_thread.cc
|
* \file control_thread.cc
|
||||||
* \brief Brief description of the file here
|
* \brief This class implements the receiver control plane
|
||||||
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
||||||
*
|
*
|
||||||
* Detailed description of the file here if needed.
|
* GNSS Receiver Control Plane: connects the flowgraph, starts running it,
|
||||||
|
* and while it does not stop, reads the control messages generated by the blocks,
|
||||||
|
* process them, and apply the corresponding actions.
|
||||||
*
|
*
|
||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*
|
*
|
||||||
@ -71,16 +73,18 @@ ControlThread::~ControlThread()
|
|||||||
delete control_message_factory_;
|
delete control_message_factory_;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*! Main loop to read and process the control messages
|
|
||||||
|
void ControlThread::run()
|
||||||
|
{
|
||||||
|
/* Runs the control thread
|
||||||
|
*
|
||||||
|
* This is the main loop that reads and process the control messages
|
||||||
*
|
*
|
||||||
* 1- Connect the GNSS receiver flowgraph
|
* 1- Connect the GNSS receiver flowgraph
|
||||||
* 2- Start the GNSS receiver flowgraph
|
* 2- Start the GNSS receiver flowgraph
|
||||||
* while (flowgraph_->running() && !stop)_{
|
* while (flowgraph_->running() && !stop)_{
|
||||||
* 3- Read control messages and process them }
|
* 3- Read control messages and process them }
|
||||||
*/
|
*/
|
||||||
void ControlThread::run()
|
|
||||||
{
|
|
||||||
|
|
||||||
flowgraph_->connect();
|
flowgraph_->connect();
|
||||||
if (flowgraph_->connected())
|
if (flowgraph_->connected())
|
||||||
{
|
{
|
||||||
@ -128,12 +132,10 @@ void ControlThread::set_control_queue(gr_msg_queue_sptr control_queue)
|
|||||||
control_queue_ = control_queue;
|
control_queue_ = control_queue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*! Creates a control_queue_, a flowgraph_ and a control_message_factory,
|
|
||||||
* sets stop_ to false and initializes processed_control_messages_ and
|
|
||||||
* applied_actions_ to zero
|
|
||||||
*/
|
|
||||||
void ControlThread::init()
|
void ControlThread::init()
|
||||||
{
|
{
|
||||||
|
// Instantiates a control queue, a GNSS flowgraph, and a control message factory
|
||||||
control_queue_ = gr_make_msg_queue(0);
|
control_queue_ = gr_make_msg_queue(0);
|
||||||
flowgraph_ = new GNSSFlowgraph(configuration_, control_queue_);
|
flowgraph_ = new GNSSFlowgraph(configuration_, control_queue_);
|
||||||
control_message_factory_ = new ControlMessageFactory();
|
control_message_factory_ = new ControlMessageFactory();
|
||||||
|
@ -1,8 +1,12 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file control_thread.h
|
* \file control_thread.h
|
||||||
* \brief This class represents the main thread of the application, aka control thread.
|
* \brief Interface of the receiver control plane
|
||||||
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
||||||
*
|
*
|
||||||
|
* GNSS Receiver Control Plane: connects the flowgraph, starts running it,
|
||||||
|
* and while it does not stop, reads the control messages generated by the blocks,
|
||||||
|
* process them, and apply the corresponding actions.
|
||||||
|
*
|
||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*
|
*
|
||||||
* Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
* Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
||||||
@ -45,10 +49,12 @@ class ControlThread
|
|||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
/*!
|
||||||
//! Default constructor
|
* \brief Default constructor
|
||||||
|
*/
|
||||||
ControlThread();
|
ControlThread();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Constructor that initializes the class with parameters
|
* \brief Constructor that initializes the class with parameters
|
||||||
*
|
*
|
||||||
@ -56,11 +62,17 @@ public:
|
|||||||
*/
|
*/
|
||||||
ControlThread(ConfigurationInterface *configuration);
|
ControlThread(ConfigurationInterface *configuration);
|
||||||
|
|
||||||
//! Virtual destructor. Derived classes must implement the destructor
|
|
||||||
|
//! \brief Virtual destructor. Derived classes must implement the destructor
|
||||||
virtual ~ControlThread();
|
virtual ~ControlThread();
|
||||||
|
|
||||||
/*!
|
/*! \brief Runs the control thread
|
||||||
* \brief Runs the ControlThread
|
*
|
||||||
|
* This is the main loop that reads and process the control messages
|
||||||
|
* 1- Connect the GNSS receiver flowgraph
|
||||||
|
* 2- Start the GNSS receiver flowgraph
|
||||||
|
* while (flowgraph_->running() && !stop)_{
|
||||||
|
* 3- Read control messages and process them }
|
||||||
*/
|
*/
|
||||||
void run();
|
void run();
|
||||||
|
|
||||||
@ -71,6 +83,7 @@ public:
|
|||||||
*/
|
*/
|
||||||
void set_control_queue(gr_msg_queue_sptr control_queue);
|
void set_control_queue(gr_msg_queue_sptr control_queue);
|
||||||
|
|
||||||
|
|
||||||
unsigned int processed_control_messages()
|
unsigned int processed_control_messages()
|
||||||
{
|
{
|
||||||
return processed_control_messages_;
|
return processed_control_messages_;
|
||||||
@ -88,6 +101,7 @@ public:
|
|||||||
*/
|
*/
|
||||||
GNSSFlowgraph* flowgraph()
|
GNSSFlowgraph* flowgraph()
|
||||||
{
|
{
|
||||||
|
|
||||||
return flowgraph_;
|
return flowgraph_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,38 +215,46 @@ GNSSBlockInterface* GNSSBlockFactory::GetBlock(
|
|||||||
std::string implementation, unsigned int in_streams,
|
std::string implementation, unsigned int in_streams,
|
||||||
unsigned int out_streams, gr_msg_queue_sptr queue)
|
unsigned int out_streams, gr_msg_queue_sptr queue)
|
||||||
{
|
{
|
||||||
|
/*!
|
||||||
|
* \brief Returns the block with the required configuration and implementation
|
||||||
|
*
|
||||||
|
* PLEASE ADD YOUR NEW BLOCK HERE!!
|
||||||
|
*/
|
||||||
|
|
||||||
GNSSBlockInterface* block = NULL;
|
|
||||||
|
|
||||||
|
GNSSBlockInterface* block = NULL; //Change to nullptr when available in compilers (C++11)
|
||||||
|
|
||||||
|
// SIGNAL SOURCES
|
||||||
if (implementation.compare("File_Signal_Source") == 0)
|
if (implementation.compare("File_Signal_Source") == 0)
|
||||||
{
|
{
|
||||||
block = new FileSignalSource(configuration, role, in_streams,
|
block = new FileSignalSource(configuration, role, in_streams,
|
||||||
out_streams, queue);
|
out_streams, queue);
|
||||||
}
|
}
|
||||||
else if (implementation.compare("Pass_Through") == 0)
|
|
||||||
{
|
|
||||||
block = new PassThrough(configuration, role, in_streams, out_streams);
|
|
||||||
}
|
|
||||||
else if (implementation.compare("Null_Sink_Output_Filter") == 0)
|
|
||||||
{
|
|
||||||
block = new NullSinkOutputFilter(configuration, role, in_streams,
|
|
||||||
out_streams);
|
|
||||||
}
|
|
||||||
else if (implementation.compare("File_Output_Filter") == 0)
|
|
||||||
{
|
|
||||||
block = new FileOutputFilter(configuration, role, in_streams,
|
|
||||||
out_streams);
|
|
||||||
}
|
|
||||||
// else if (implementation.compare("USRP1_Signal_Source") == 0)
|
// else if (implementation.compare("USRP1_Signal_Source") == 0)
|
||||||
// {
|
// {
|
||||||
// block = new Usrp1SignalSource(configuration, role, in_streams,
|
// block = new Usrp1SignalSource(configuration, role, in_streams,
|
||||||
// out_streams, queue);
|
// out_streams, queue);
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
//! \todo Create a UHD block
|
||||||
|
|
||||||
|
// SIGNAL CONDITIONERS
|
||||||
|
|
||||||
|
else if (implementation.compare("Pass_Through") == 0)
|
||||||
|
{
|
||||||
|
block = new PassThrough(configuration, role, in_streams, out_streams);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
else if (implementation.compare("Direct_Resampler") == 0)
|
else if (implementation.compare("Direct_Resampler") == 0)
|
||||||
{
|
{
|
||||||
block = new DirectResamplerConditioner(configuration, role,
|
block = new DirectResamplerConditioner(configuration, role,
|
||||||
in_streams, out_streams);
|
in_streams, out_streams);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ACQUISITION BLOCKS
|
||||||
|
|
||||||
else if (implementation.compare("GPS_L1_CA_GPS_SDR_Acquisition") == 0)
|
else if (implementation.compare("GPS_L1_CA_GPS_SDR_Acquisition") == 0)
|
||||||
{
|
{
|
||||||
block = new GpsL1CaGpsSdrAcquisition(configuration, role, in_streams,
|
block = new GpsL1CaGpsSdrAcquisition(configuration, role, in_streams,
|
||||||
@ -262,6 +270,9 @@ GNSSBlockInterface* GNSSBlockFactory::GetBlock(
|
|||||||
block = new GpsL1CaTongPcpsAcquisition(configuration, role,
|
block = new GpsL1CaTongPcpsAcquisition(configuration, role,
|
||||||
in_streams, out_streams, queue);
|
in_streams, out_streams, queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TRACKING BLOCKS
|
||||||
|
|
||||||
else if (implementation.compare("GPS_L1_CA_DLL_PLL_Tracking") == 0)
|
else if (implementation.compare("GPS_L1_CA_DLL_PLL_Tracking") == 0)
|
||||||
{
|
{
|
||||||
block = new GpsL1CaDllPllTracking(configuration, role, in_streams,
|
block = new GpsL1CaDllPllTracking(configuration, role, in_streams,
|
||||||
@ -272,21 +283,42 @@ GNSSBlockInterface* GNSSBlockFactory::GetBlock(
|
|||||||
block = new GpsL1CaDllFllPllTracking(configuration, role, in_streams,
|
block = new GpsL1CaDllFllPllTracking(configuration, role, in_streams,
|
||||||
out_streams, queue);
|
out_streams, queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TELEMETRY DECODERS
|
||||||
|
|
||||||
else if (implementation.compare("GPS_L1_CA_Telemetry_Decoder") == 0)
|
else if (implementation.compare("GPS_L1_CA_Telemetry_Decoder") == 0)
|
||||||
{
|
{
|
||||||
block = new GpsL1CaTelemetryDecoder(configuration, role, in_streams,
|
block = new GpsL1CaTelemetryDecoder(configuration, role, in_streams,
|
||||||
out_streams, queue);
|
out_streams, queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OBSERVABLES
|
||||||
else if (implementation.compare("GPS_L1_CA_Observables") == 0)
|
else if (implementation.compare("GPS_L1_CA_Observables") == 0)
|
||||||
{
|
{
|
||||||
block = new GpsL1CaObservables(configuration, role, in_streams,
|
block = new GpsL1CaObservables(configuration, role, in_streams,
|
||||||
out_streams, queue);
|
out_streams, queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// PVT
|
||||||
|
|
||||||
else if (implementation.compare("GPS_L1_CA_PVT") == 0)
|
else if (implementation.compare("GPS_L1_CA_PVT") == 0)
|
||||||
{
|
{
|
||||||
block = new GpsL1CaPvt(configuration, role, in_streams,
|
block = new GpsL1CaPvt(configuration, role, in_streams,
|
||||||
out_streams, queue);
|
out_streams, queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OUTPUT FILTERS
|
||||||
|
else if (implementation.compare("Null_Sink_Output_Filter") == 0)
|
||||||
|
{
|
||||||
|
block = new NullSinkOutputFilter(configuration, role, in_streams,
|
||||||
|
out_streams);
|
||||||
|
}
|
||||||
|
else if (implementation.compare("File_Output_Filter") == 0)
|
||||||
|
{
|
||||||
|
block = new FileOutputFilter(configuration, role, in_streams,
|
||||||
|
out_streams);
|
||||||
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Log fatal. This causes execution to stop.
|
// Log fatal. This causes execution to stop.
|
||||||
|
@ -51,7 +51,6 @@ using google::LogMessage;
|
|||||||
GNSSFlowgraph::GNSSFlowgraph(ConfigurationInterface *configuration,
|
GNSSFlowgraph::GNSSFlowgraph(ConfigurationInterface *configuration,
|
||||||
gr_msg_queue_sptr queue)
|
gr_msg_queue_sptr queue)
|
||||||
{
|
{
|
||||||
|
|
||||||
connected_ = false;
|
connected_ = false;
|
||||||
running_ = false;
|
running_ = false;
|
||||||
configuration_ = configuration;
|
configuration_ = configuration;
|
||||||
@ -111,6 +110,10 @@ void GNSSFlowgraph::stop()
|
|||||||
|
|
||||||
void GNSSFlowgraph::connect()
|
void GNSSFlowgraph::connect()
|
||||||
{
|
{
|
||||||
|
/* Connects the blocks in the flowgraph
|
||||||
|
*
|
||||||
|
* Signal Source > Signal conditioner > Channels >> Observables >> PVT > Output filter
|
||||||
|
*/
|
||||||
DLOG(INFO) << "Connecting flowgraph";
|
DLOG(INFO) << "Connecting flowgraph";
|
||||||
if (connected_)
|
if (connected_)
|
||||||
{
|
{
|
||||||
@ -255,8 +258,8 @@ void GNSSFlowgraph::connect()
|
|||||||
DLOG(INFO) << "Channel " << i
|
DLOG(INFO) << "Channel " << i
|
||||||
<< " connected to observables and ready for acquisition";
|
<< " connected to observables and ready for acquisition";
|
||||||
}
|
}
|
||||||
/*!
|
/*
|
||||||
* Enabled the observables multichannel output connection to PVT
|
* Connect the observables output of each channel to the PVT block
|
||||||
*/
|
*/
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -309,7 +312,12 @@ void GNSSFlowgraph::wait()
|
|||||||
|
|
||||||
void GNSSFlowgraph::apply_action(unsigned int who, unsigned int what)
|
void GNSSFlowgraph::apply_action(unsigned int who, unsigned int what)
|
||||||
{
|
{
|
||||||
|
/*!
|
||||||
|
* \brief Applies an action to the flowgraph
|
||||||
|
*
|
||||||
|
* \param[in] who Who generated the action
|
||||||
|
* \param[in] what What is the action 0: acquisition failed
|
||||||
|
*/
|
||||||
DLOG(INFO) << "received " << what << " from " << who;
|
DLOG(INFO) << "received " << what << " from " << who;
|
||||||
|
|
||||||
switch (what)
|
switch (what)
|
||||||
@ -385,7 +393,9 @@ GNSSBlockInterface* GNSSFlowgraph::output_filter()
|
|||||||
|
|
||||||
void GNSSFlowgraph::init()
|
void GNSSFlowgraph::init()
|
||||||
{
|
{
|
||||||
|
/*!
|
||||||
|
* \brief Instantiates the receiver blocks
|
||||||
|
*/
|
||||||
blocks_->push_back(
|
blocks_->push_back(
|
||||||
block_factory_->GetSignalSource(configuration_, queue_));
|
block_factory_->GetSignalSource(configuration_, queue_));
|
||||||
blocks_->push_back(block_factory_->GetSignalConditioner(configuration_,
|
blocks_->push_back(block_factory_->GetSignalConditioner(configuration_,
|
||||||
@ -422,6 +432,14 @@ void GNSSFlowgraph::init()
|
|||||||
void GNSSFlowgraph::set_satellites_list()
|
void GNSSFlowgraph::set_satellites_list()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sets a sequential list of satellites (1...33)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \TODO Describe GNSS satellites more nicely, with RINEX notation
|
||||||
|
* See http://igscb.jpl.nasa.gov/igscb/data/format/rinex301.pdf (page 5)
|
||||||
|
*/
|
||||||
for (unsigned int id = 1; id < 33; id++)
|
for (unsigned int id = 1; id < 33; id++)
|
||||||
{
|
{
|
||||||
available_GPS_satellites_IDs_->push_back(id);
|
available_GPS_satellites_IDs_->push_back(id);
|
||||||
@ -445,7 +463,7 @@ void GNSSFlowgraph::set_satellites_list()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// std::cout << "Cola de satélites: ";
|
// std::cout << "Satellite queue: ";
|
||||||
// for (std::list<unsigned int>::iterator it =
|
// for (std::list<unsigned int>::iterator it =
|
||||||
// available_GPS_satellites_IDs_->begin(); it
|
// available_GPS_satellites_IDs_->begin(); it
|
||||||
// != available_GPS_satellites_IDs_->end(); it++)
|
// != available_GPS_satellites_IDs_->end(); it++)
|
||||||
|
@ -56,11 +56,15 @@ class GNSSFlowgraph
|
|||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
/*!
|
||||||
|
* \brief Constructor that initializes the receiver flowgraph
|
||||||
|
*/
|
||||||
GNSSFlowgraph(ConfigurationInterface* configuration,
|
GNSSFlowgraph(ConfigurationInterface* configuration,
|
||||||
gr_msg_queue_sptr queue);
|
gr_msg_queue_sptr queue);
|
||||||
|
|
||||||
//! Virtual destructor
|
/*!
|
||||||
|
* \brief Virtual destructor
|
||||||
|
*/
|
||||||
virtual ~GNSSFlowgraph();
|
virtual ~GNSSFlowgraph();
|
||||||
|
|
||||||
//! Start the flowgraph
|
//! Start the flowgraph
|
||||||
@ -69,7 +73,11 @@ public:
|
|||||||
//! Stop the flowgraph
|
//! Stop the flowgraph
|
||||||
void stop();
|
void stop();
|
||||||
|
|
||||||
//! Connect the defined flowgraph
|
/*!
|
||||||
|
* \brief Connects the defined blocks in the flowgraph
|
||||||
|
*
|
||||||
|
* Signal Source > Signal conditioner > Channels >> Observables >> PVT > Output filter
|
||||||
|
*/
|
||||||
void connect();
|
void connect();
|
||||||
|
|
||||||
void wait();
|
void wait();
|
||||||
|
@ -30,6 +30,8 @@
|
|||||||
*
|
*
|
||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
#include <gflags/gflags.h>
|
#include <gflags/gflags.h>
|
||||||
#include <glog/log_severity.h>
|
#include <glog/log_severity.h>
|
||||||
#include <glog/logging.h>
|
#include <glog/logging.h>
|
||||||
@ -43,6 +45,8 @@
|
|||||||
|
|
||||||
using google::LogMessage;
|
using google::LogMessage;
|
||||||
|
|
||||||
|
DECLARE_string(log_dir);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \todo make this queue generic for all the GNSS systems (javi)
|
* \todo make this queue generic for all the GNSS systems (javi)
|
||||||
*/
|
*/
|
||||||
@ -68,10 +72,28 @@ int main(int argc, char** argv)
|
|||||||
google::SetUsageMessage(intro_help);
|
google::SetUsageMessage(intro_help);
|
||||||
google::SetVersionString("0.1");
|
google::SetVersionString("0.1");
|
||||||
google::ParseCommandLineFlags(&argc, &argv, true);
|
google::ParseCommandLineFlags(&argc, &argv, true);
|
||||||
google::InitGoogleLogging(argv[0]);
|
|
||||||
|
|
||||||
std::cout<<"Initializing GNSS-SDR... Please wait"<<std::endl;
|
std::cout<<"Initializing GNSS-SDR... Please wait"<<std::endl;
|
||||||
|
|
||||||
|
google::InitGoogleLogging(argv[0]);
|
||||||
|
if (FLAGS_log_dir.empty())
|
||||||
|
{
|
||||||
|
std::cout << "Logging will be done at " << boost::filesystem::temp_directory_path() << std::endl
|
||||||
|
<< "Use gnss-sdr --log_dir=/path/to/log to change that."<< std::endl;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const boost::filesystem::path p (FLAGS_log_dir);
|
||||||
|
if (!boost::filesystem::exists(p))
|
||||||
|
{
|
||||||
|
std::cout << "The path " << FLAGS_log_dir << " does not exist, attepting to create it" << std::endl;
|
||||||
|
boost::filesystem::create_directory(p);
|
||||||
|
}
|
||||||
|
std::cout << "Logging with be done at " << FLAGS_log_dir << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ControlThread *control_thread = new ControlThread();
|
ControlThread *control_thread = new ControlThread();
|
||||||
|
|
||||||
control_thread->run();
|
control_thread->run();
|
||||||
|
Loading…
Reference in New Issue
Block a user