mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-19 05:33:02 +00:00
Improve const correctness
Remove all buprone conversions from signal_generator module
This commit is contained in:
parent
57f1b1ef34
commit
7bececeef6
@ -38,19 +38,19 @@ SignalGenerator::SignalGenerator(const ConfigurationInterface* configuration,
|
|||||||
Concurrent_Queue<pmt::pmt_t>* queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t>* queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
std::string default_dump_file = "./data/gen_source.dat";
|
const std::string default_dump_file("./data/gen_source.dat");
|
||||||
std::string default_system = "G";
|
const std::string default_system("G");
|
||||||
std::string default_signal = "1C";
|
const std::string default_signal("1C");
|
||||||
|
|
||||||
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
||||||
dump_ = configuration->property(role + ".dump", false);
|
dump_ = configuration->property(role + ".dump", false);
|
||||||
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
||||||
|
|
||||||
unsigned int fs_in = configuration->property("SignalSource.fs_hz", 4e6);
|
const unsigned int fs_in = configuration->property("SignalSource.fs_hz", static_cast<unsigned>(4e6));
|
||||||
bool data_flag = configuration->property("SignalSource.data_flag", false);
|
const bool data_flag = configuration->property("SignalSource.data_flag", false);
|
||||||
bool noise_flag = configuration->property("SignalSource.noise_flag", false);
|
const bool noise_flag = configuration->property("SignalSource.noise_flag", false);
|
||||||
float BW_BB = configuration->property("SignalSource.BW_BB", 1.0);
|
const float BW_BB = configuration->property("SignalSource.BW_BB", static_cast<float>(1.0));
|
||||||
unsigned int num_satellites = configuration->property("SignalSource.num_satellites", 1);
|
const unsigned int num_satellites = configuration->property("SignalSource.num_satellites", 1);
|
||||||
|
|
||||||
std::vector<std::string> signal1;
|
std::vector<std::string> signal1;
|
||||||
std::vector<std::string> system;
|
std::vector<std::string> system;
|
||||||
@ -79,39 +79,38 @@ SignalGenerator::SignalGenerator(const ConfigurationInterface* configuration,
|
|||||||
{
|
{
|
||||||
if (signal1[0].at(0) == '5')
|
if (signal1[0].at(0) == '5')
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GALILEO_E5A_CODE_CHIP_RATE_CPS / GALILEO_E5A_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GALILEO_E5A_CODE_CHIP_RATE_CPS / GALILEO_E5A_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
else if (signal1[0].at(0) == '7')
|
else if (signal1[0].at(0) == '7')
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GALILEO_E5B_CODE_CHIP_RATE_CPS / GALILEO_E5B_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GALILEO_E5B_CODE_CHIP_RATE_CPS / GALILEO_E5B_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GALILEO_E1_CODE_CHIP_RATE_CPS / GALILEO_E1_B_CODE_LENGTH_CHIPS)) * GALILEO_E1_C_SECONDARY_CODE_LENGTH;
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GALILEO_E1_CODE_CHIP_RATE_CPS / GALILEO_E1_B_CODE_LENGTH_CHIPS)) * GALILEO_E1_C_SECONDARY_CODE_LENGTH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (std::find(system.begin(), system.end(), "G") != system.end())
|
else if (std::find(system.begin(), system.end(), "G") != system.end())
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GPS_L1_CA_CODE_RATE_CPS / GPS_L1_CA_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GPS_L1_CA_CODE_RATE_CPS / GPS_L1_CA_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
else if (std::find(system.begin(), system.end(), "R") != system.end())
|
else if (std::find(system.begin(), system.end(), "R") != system.end())
|
||||||
{
|
{
|
||||||
if (signal1[0].at(0) == '1')
|
if (signal1[0].at(0) == '1')
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GLONASS_L1_CA_CODE_RATE_CPS / GLONASS_L1_CA_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GLONASS_L1_CA_CODE_RATE_CPS / GLONASS_L1_CA_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (GLONASS_L2_CA_CODE_RATE_CPS / GLONASS_L2_CA_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (GLONASS_L2_CA_CODE_RATE_CPS / GLONASS_L2_CA_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (std::find(system.begin(), system.end(), "B") != system.end())
|
else if (std::find(system.begin(), system.end(), "B") != system.end())
|
||||||
{
|
{
|
||||||
vector_length = round(static_cast<float>(fs_in) / (BEIDOU_B1I_CODE_RATE_CPS / BEIDOU_B1I_CODE_LENGTH_CHIPS));
|
vector_length = static_cast<unsigned int>(round(static_cast<float>(fs_in) / (BEIDOU_B1I_CODE_RATE_CPS / BEIDOU_B1I_CODE_LENGTH_CHIPS)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (item_type_ == "gr_complex")
|
if (item_type_ == "gr_complex")
|
||||||
{
|
{
|
||||||
item_size_ = sizeof(gr_complex);
|
item_size_ = sizeof(gr_complex);
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include <gnuradio/io_signature.h>
|
#include <gnuradio/io_signature.h>
|
||||||
#include <volk_gnsssdr/volk_gnsssdr.h>
|
#include <volk_gnsssdr/volk_gnsssdr.h>
|
||||||
#include <array>
|
#include <array>
|
||||||
|
#include <cmath>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
@ -63,7 +64,7 @@ signal_generator_c::signal_generator_c(std::vector<std::string> signal1,
|
|||||||
bool noise_flag,
|
bool noise_flag,
|
||||||
unsigned int fs_in,
|
unsigned int fs_in,
|
||||||
unsigned int vector_length,
|
unsigned int vector_length,
|
||||||
float BW_BB) : gr::block("signal_gen_cc", gr::io_signature::make(0, 0, sizeof(gr_complex)), gr::io_signature::make(1, 1, sizeof(gr_complex) * vector_length)),
|
float BW_BB) : gr::block("signal_gen_cc", gr::io_signature::make(0, 0, sizeof(gr_complex)), gr::io_signature::make(1, 1, static_cast<int>(sizeof(gr_complex) * vector_length))),
|
||||||
signal_(std::move(signal1)),
|
signal_(std::move(signal1)),
|
||||||
system_(std::move(system)),
|
system_(std::move(system)),
|
||||||
CN0_dB_(std::move(CN0_dB)),
|
CN0_dB_(std::move(CN0_dB)),
|
||||||
@ -71,7 +72,7 @@ signal_generator_c::signal_generator_c(std::vector<std::string> signal1,
|
|||||||
PRN_(PRN),
|
PRN_(PRN),
|
||||||
delay_chips_(std::move(delay_chips)),
|
delay_chips_(std::move(delay_chips)),
|
||||||
delay_sec_(std::move(delay_sec)),
|
delay_sec_(std::move(delay_sec)),
|
||||||
BW_BB_(BW_BB * static_cast<float>(fs_in) / 2.0),
|
BW_BB_(BW_BB * static_cast<float>(fs_in) / 2.0F),
|
||||||
fs_in_(fs_in),
|
fs_in_(fs_in),
|
||||||
num_sats_(PRN.size()),
|
num_sats_(PRN.size()),
|
||||||
vector_length_(vector_length),
|
vector_length_(vector_length),
|
||||||
@ -88,6 +89,14 @@ void signal_generator_c::init()
|
|||||||
work_counter_ = 0;
|
work_counter_ = 0;
|
||||||
|
|
||||||
complex_phase_.reserve(vector_length_);
|
complex_phase_.reserve(vector_length_);
|
||||||
|
start_phase_rad_.reserve(num_sats_);
|
||||||
|
current_data_bit_int_.reserve(num_sats_);
|
||||||
|
ms_counter_.reserve(num_sats_);
|
||||||
|
data_modulation_.reserve(num_sats_);
|
||||||
|
pilot_modulation_.reserve(num_sats_);
|
||||||
|
samples_per_code_.reserve(num_sats_);
|
||||||
|
num_of_codes_per_vector_.reserve(num_sats_);
|
||||||
|
data_bit_duration_ms_.reserve(num_sats_);
|
||||||
|
|
||||||
// True if Galileo satellites are present
|
// True if Galileo satellites are present
|
||||||
bool galileo_signal = std::find(system_.begin(), system_.end(), "E") != system_.end();
|
bool galileo_signal = std::find(system_.begin(), system_.end(), "E") != system_.end();
|
||||||
@ -165,7 +174,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
||||||
{
|
{
|
||||||
code[i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_);
|
code[i] *= std::sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,7 +196,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
||||||
{
|
{
|
||||||
code[i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_);
|
code[i] *= std::sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,7 +220,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < vector_length_; i++)
|
for (unsigned int i = 0; i < vector_length_; i++)
|
||||||
{
|
{
|
||||||
sampled_code_data_[sat][i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_ / 2);
|
sampled_code_data_[sat][i] *= std::sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_ / 2.0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -226,7 +235,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < vector_length_; i++)
|
for (unsigned int i = 0; i < vector_length_; i++)
|
||||||
{
|
{
|
||||||
sampled_code_data_[sat][i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_ / 2);
|
sampled_code_data_[sat][i] *= std::sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_ / 2.0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -244,7 +253,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
for (unsigned int i = 0; i < samples_per_code_[sat]; i++)
|
||||||
{
|
{
|
||||||
code[i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_ / 2);
|
code[i] *= std::sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_ / 2.0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,7 +276,7 @@ void signal_generator_c::generate_codes()
|
|||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < vector_length_; i++)
|
for (unsigned int i = 0; i < vector_length_; i++)
|
||||||
{
|
{
|
||||||
sampled_code_pilot_[sat][i] *= sqrt(pow(10, CN0_dB_[sat] / 10) / BW_BB_ / 2);
|
sampled_code_pilot_[sat][i] *= sqrt(std::pow(10.0F, CN0_dB_[sat] / 10.0F) / BW_BB_ / 2.0F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -304,13 +313,13 @@ int signal_generator_c::general_work(int noutput_items __attribute__((unused)),
|
|||||||
std::array<float, 1> _phase{};
|
std::array<float, 1> _phase{};
|
||||||
_phase[0] = -start_phase_rad_[sat];
|
_phase[0] = -start_phase_rad_[sat];
|
||||||
volk_gnsssdr_s32f_sincos_32fc(complex_phase_.data(), -phase_step_rad, _phase.data(), vector_length_);
|
volk_gnsssdr_s32f_sincos_32fc(complex_phase_.data(), -phase_step_rad, _phase.data(), vector_length_);
|
||||||
start_phase_rad_[sat] += vector_length_ * phase_step_rad;
|
start_phase_rad_[sat] += static_cast<float>(vector_length_) * phase_step_rad;
|
||||||
|
|
||||||
out_idx = 0;
|
out_idx = 0;
|
||||||
|
|
||||||
if (system_[sat] == "G")
|
if (system_[sat] == "G")
|
||||||
{
|
{
|
||||||
unsigned int delay_samples = (delay_chips_[sat] % static_cast<int>(GPS_L1_CA_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GPS_L1_CA_CODE_LENGTH_CHIPS;
|
auto delay_samples = static_cast<unsigned int>((delay_chips_[sat] % static_cast<int>(GPS_L1_CA_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GPS_L1_CA_CODE_LENGTH_CHIPS);
|
||||||
|
|
||||||
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
||||||
{
|
{
|
||||||
@ -338,12 +347,12 @@ int signal_generator_c::general_work(int noutput_items __attribute__((unused)),
|
|||||||
|
|
||||||
else if (system_[sat] == "R")
|
else if (system_[sat] == "R")
|
||||||
{
|
{
|
||||||
phase_step_rad = -static_cast<float>(TWO_PI) * (freq + (DFRQ1_GLO * GLONASS_PRN.at(PRN_[sat])) + doppler_Hz_[sat]) / static_cast<float>(fs_in_);
|
phase_step_rad = -static_cast<float>(TWO_PI) * (static_cast<float>(freq) + (static_cast<float>(DFRQ1_GLO) * GLONASS_PRN.at(PRN_[sat])) + doppler_Hz_[sat]) / static_cast<float>(fs_in_);
|
||||||
// std::cout << "sat " << PRN_[sat] << " SG - Freq = " << (freq + (DFRQ1_GLO * GLONASS_PRN.at(PRN_[sat]))) << " Doppler = " << doppler_Hz_[sat] << '\n';
|
// std::cout << "sat " << PRN_[sat] << " SG - Freq = " << (freq + (DFRQ1_GLO * GLONASS_PRN.at(PRN_[sat]))) << " Doppler = " << doppler_Hz_[sat] << '\n';
|
||||||
_phase[0] = -start_phase_rad_[sat];
|
_phase[0] = -start_phase_rad_[sat];
|
||||||
volk_gnsssdr_s32f_sincos_32fc(complex_phase_.data(), -phase_step_rad, _phase.data(), vector_length_);
|
volk_gnsssdr_s32f_sincos_32fc(complex_phase_.data(), -phase_step_rad, _phase.data(), vector_length_);
|
||||||
|
|
||||||
unsigned int delay_samples = (delay_chips_[sat] % static_cast<int>(GLONASS_L1_CA_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GLONASS_L1_CA_CODE_LENGTH_CHIPS;
|
auto delay_samples = static_cast<unsigned int>((delay_chips_[sat] % static_cast<int>(GLONASS_L1_CA_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GLONASS_L1_CA_CODE_LENGTH_CHIPS);
|
||||||
|
|
||||||
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
||||||
{
|
{
|
||||||
@ -435,7 +444,7 @@ int signal_generator_c::general_work(int noutput_items __attribute__((unused)),
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
unsigned int delay_samples = (delay_chips_[sat] % static_cast<int>(GALILEO_E1_B_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GALILEO_E1_B_CODE_LENGTH_CHIPS;
|
auto delay_samples = static_cast<unsigned int>((delay_chips_[sat] % static_cast<int>(GALILEO_E1_B_CODE_LENGTH_CHIPS)) * samples_per_code_[sat] / GALILEO_E1_B_CODE_LENGTH_CHIPS);
|
||||||
|
|
||||||
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
for (i = 0; i < num_of_codes_per_vector_[sat]; i++)
|
||||||
{
|
{
|
||||||
|
@ -48,12 +48,12 @@ Ad9361FpgaSignalSource::Ad9361FpgaSignalSource(const ConfigurationInterface *con
|
|||||||
const std::string &role, unsigned int in_stream, unsigned int out_stream,
|
const std::string &role, unsigned int in_stream, unsigned int out_stream,
|
||||||
Concurrent_Queue<pmt::pmt_t> *queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t> *queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
std::string default_gain_mode("slow_attack");
|
const std::string default_gain_mode("slow_attack");
|
||||||
double default_tx_attenuation_db = -10.0;
|
const double default_tx_attenuation_db = -10.0;
|
||||||
double default_manual_gain_rx1 = 64.0;
|
const double default_manual_gain_rx1 = 64.0;
|
||||||
double default_manual_gain_rx2 = 64.0;
|
const double default_manual_gain_rx2 = 64.0;
|
||||||
uint64_t default_bandwidth = 12500000;
|
const uint64_t default_bandwidth = 12500000;
|
||||||
std::string default_rf_port_select("A_BALANCED");
|
const std::string default_rf_port_select("A_BALANCED");
|
||||||
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
||||||
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(12500000));
|
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(12500000));
|
||||||
bandwidth_ = configuration->property(role + ".bandwidth", default_bandwidth);
|
bandwidth_ = configuration->property(role + ".bandwidth", default_bandwidth);
|
||||||
@ -91,7 +91,7 @@ Ad9361FpgaSignalSource::Ad9361FpgaSignalSource(const ConfigurationInterface *con
|
|||||||
rf_shutdown_ = configuration->property(role + ".rf_shutdown", FLAGS_rf_shutdown);
|
rf_shutdown_ = configuration->property(role + ".rf_shutdown", FLAGS_rf_shutdown);
|
||||||
|
|
||||||
// turn switch to A/D position
|
// turn switch to A/D position
|
||||||
std::string default_device_name = "/dev/uio1";
|
const std::string default_device_name("/dev/uio1");
|
||||||
std::string device_name = configuration->property(role + ".devicename", default_device_name);
|
std::string device_name = configuration->property(role + ".devicename", default_device_name);
|
||||||
switch_position = configuration->property(role + ".switch_position", 0);
|
switch_position = configuration->property(role + ".switch_position", 0);
|
||||||
if (switch_position != 0 && switch_position != 2)
|
if (switch_position != 0 && switch_position != 2)
|
||||||
@ -111,7 +111,7 @@ Ad9361FpgaSignalSource::Ad9361FpgaSignalSource(const ConfigurationInterface *con
|
|||||||
if (switch_position == 0) // Inject file(s) via DMA
|
if (switch_position == 0) // Inject file(s) via DMA
|
||||||
{
|
{
|
||||||
enable_DMA_ = true;
|
enable_DMA_ = true;
|
||||||
std::string empty_string;
|
const std::string empty_string;
|
||||||
filename_rx1 = configuration->property(role + ".filename", empty_string);
|
filename_rx1 = configuration->property(role + ".filename", empty_string);
|
||||||
|
|
||||||
// override value with commandline flag, if present
|
// override value with commandline flag, if present
|
||||||
@ -129,12 +129,12 @@ Ad9361FpgaSignalSource::Ad9361FpgaSignalSource(const ConfigurationInterface *con
|
|||||||
filename_rx1 = configuration->property(role + ".filename0", empty_string);
|
filename_rx1 = configuration->property(role + ".filename0", empty_string);
|
||||||
filename_rx2 = configuration->property(role + ".filename1", empty_string);
|
filename_rx2 = configuration->property(role + ".filename1", empty_string);
|
||||||
}
|
}
|
||||||
int l1_band = configuration->property("Channels_1C.count", 0) +
|
const int l1_band = configuration->property("Channels_1C.count", 0) +
|
||||||
configuration->property("Channels_1B.count", 0);
|
configuration->property("Channels_1B.count", 0);
|
||||||
|
|
||||||
int l2_band = configuration->property("Channels_L5.count", 0) +
|
const int l2_band = configuration->property("Channels_L5.count", 0) +
|
||||||
configuration->property("Channels_5X.count", 0) +
|
configuration->property("Channels_5X.count", 0) +
|
||||||
configuration->property("Channels_2S.count", 0);
|
configuration->property("Channels_2S.count", 0);
|
||||||
|
|
||||||
if (l1_band != 0)
|
if (l1_band != 0)
|
||||||
{
|
{
|
||||||
@ -295,9 +295,9 @@ Ad9361FpgaSignalSource::Ad9361FpgaSignalSource(const ConfigurationInterface *con
|
|||||||
enable_dynamic_bit_selection_ = configuration->property(role + ".enable_dynamic_bit_selection", true);
|
enable_dynamic_bit_selection_ = configuration->property(role + ".enable_dynamic_bit_selection", true);
|
||||||
if (enable_dynamic_bit_selection_)
|
if (enable_dynamic_bit_selection_)
|
||||||
{
|
{
|
||||||
std::string dynamic_bit_selection_default_device_name1 = "/dev/uio48";
|
const std::string dynamic_bit_selection_default_device_name1("/dev/uio48");
|
||||||
std::string device_name1 = configuration->property(role + ".dyn_bits_sel_devicename", dynamic_bit_selection_default_device_name1);
|
std::string device_name1 = configuration->property(role + ".dyn_bits_sel_devicename", dynamic_bit_selection_default_device_name1);
|
||||||
std::string dynamic_bit_selection_default_device_name2 = "/dev/uio49";
|
const std::string dynamic_bit_selection_default_device_name2("/dev/uio49");
|
||||||
std::string device_name2 = configuration->property(role + ".dyn_bits_sel_devicename", dynamic_bit_selection_default_device_name2);
|
std::string device_name2 = configuration->property(role + ".dyn_bits_sel_devicename", dynamic_bit_selection_default_device_name2);
|
||||||
dynamic_bit_selection_fpga = std::make_shared<Fpga_dynamic_bit_selection>(device_name1, device_name2);
|
dynamic_bit_selection_fpga = std::make_shared<Fpga_dynamic_bit_selection>(device_name1, device_name2);
|
||||||
thread_dynamic_bit_selection = std::thread([&] { run_dynamic_bit_selection_process(); });
|
thread_dynamic_bit_selection = std::thread([&] { run_dynamic_bit_selection_process(); });
|
||||||
@ -573,7 +573,7 @@ void Ad9361FpgaSignalSource::run_DMA_process(const std::string &FreqBand, const
|
|||||||
int num_bytes_sent = write(tx_fd, input_samples_dma.data(), nread_elements * 2);
|
int num_bytes_sent = write(tx_fd, input_samples_dma.data(), nread_elements * 2);
|
||||||
if (num_bytes_sent != num_transferred_bytes)
|
if (num_bytes_sent != num_transferred_bytes)
|
||||||
{
|
{
|
||||||
std::cerr << "Error: DMA could not send all the required samples \n";
|
std::cerr << "Error: DMA could not send all the required samples\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Throttle the DMA
|
// Throttle the DMA
|
||||||
@ -607,6 +607,7 @@ void Ad9361FpgaSignalSource::run_DMA_process(const std::string &FreqBand, const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Ad9361FpgaSignalSource::run_dynamic_bit_selection_process(void)
|
void Ad9361FpgaSignalSource::run_dynamic_bit_selection_process(void)
|
||||||
{
|
{
|
||||||
bool dynamic_bit_selection_active = true;
|
bool dynamic_bit_selection_active = true;
|
||||||
@ -625,6 +626,7 @@ void Ad9361FpgaSignalSource::run_dynamic_bit_selection_process(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Ad9361FpgaSignalSource::connect(gr::top_block_sptr top_block)
|
void Ad9361FpgaSignalSource::connect(gr::top_block_sptr top_block)
|
||||||
{
|
{
|
||||||
if (top_block)
|
if (top_block)
|
||||||
|
@ -35,12 +35,12 @@ FileSignalSource::FileSignalSource(const ConfigurationInterface* configuration,
|
|||||||
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "./example_capture.dat";
|
const std::string default_filename("./example_capture.dat");
|
||||||
std::string default_item_type = "short";
|
const std::string default_item_type("short");
|
||||||
std::string default_dump_filename = "./my_capture.dat";
|
const std::string default_dump_filename("./my_capture.dat");
|
||||||
|
|
||||||
|
const double default_seconds_to_skip = 0.0;
|
||||||
|
|
||||||
double default_seconds_to_skip = 0.0;
|
|
||||||
size_t header_size = 0;
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
filename_ = configuration->property(role + ".filename", default_filename);
|
filename_ = configuration->property(role + ".filename", default_filename);
|
||||||
@ -61,8 +61,8 @@ FileSignalSource::FileSignalSource(const ConfigurationInterface* configuration,
|
|||||||
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename);
|
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename);
|
||||||
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
||||||
|
|
||||||
double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
const double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
||||||
header_size = configuration->property(role + ".header_size", 0);
|
const size_t header_size = configuration->property(role + ".header_size", 0);
|
||||||
int64_t samples_to_skip = 0;
|
int64_t samples_to_skip = 0;
|
||||||
|
|
||||||
bool is_complex = false;
|
bool is_complex = false;
|
||||||
@ -131,32 +131,21 @@ FileSignalSource::FileSignalSource(const ConfigurationInterface* configuration,
|
|||||||
if (filename_ == default_filename)
|
if (filename_ == default_filename)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The configuration file has not been found."
|
<< "The configuration file has not been found.\n"
|
||||||
<< '\n'
|
<< "Please create a configuration file based on the examples at the 'conf/' folder\n"
|
||||||
<< "Please create a configuration file based on the examples at the 'conf/' folder "
|
<< "and then generate your own GNSS Software Defined Receiver by doing:\n"
|
||||||
<< '\n'
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n";
|
||||||
<< "and then generate your own GNSS Software Defined Receiver by doing:"
|
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n';
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "file_signal_source: Unable to open the samples file "
|
LOG(INFO) << "file_signal_source: Unable to open the samples file "
|
||||||
@ -193,15 +182,14 @@ FileSignalSource::FileSignalSource(const ConfigurationInterface* configuration,
|
|||||||
|
|
||||||
if (size > 0)
|
if (size > 0)
|
||||||
{
|
{
|
||||||
int64_t bytes_to_skip = samples_to_skip * item_size_;
|
const int64_t bytes_to_skip = samples_to_skip * item_size_;
|
||||||
int64_t bytes_to_process = static_cast<int64_t>(size) - bytes_to_skip;
|
const int64_t bytes_to_process = static_cast<int64_t>(size) - bytes_to_skip;
|
||||||
samples_ = floor(static_cast<double>(bytes_to_process) / static_cast<double>(item_size_) - ceil(0.002 * static_cast<double>(sampling_frequency_))); // process all the samples available in the file excluding at least the last 1 ms
|
samples_ = floor(static_cast<double>(bytes_to_process) / static_cast<double>(item_size_) - ceil(0.002 * static_cast<double>(sampling_frequency_))); // process all the samples available in the file excluding at least the last 1 ms
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
||||||
double signal_duration_s;
|
double signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
||||||
signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
|
||||||
|
|
||||||
if (is_complex)
|
if (is_complex)
|
||||||
{
|
{
|
||||||
|
@ -33,10 +33,10 @@ FlexibandSignalSource::FlexibandSignalSource(const ConfigurationInterface* confi
|
|||||||
unsigned int out_stream,
|
unsigned int out_stream,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t>* queue __attribute__((unused))) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
std::string default_item_type = "byte";
|
const std::string default_item_type("byte");
|
||||||
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
||||||
|
|
||||||
std::string default_firmware_file = "flexiband_I-1b.bit";
|
const std::string default_firmware_file("flexiband_I-1b.bit");
|
||||||
firmware_filename_ = configuration->property(role + ".firmware_file", default_firmware_file);
|
firmware_filename_ = configuration->property(role + ".firmware_file", default_firmware_file);
|
||||||
|
|
||||||
gain1_ = configuration->property(role + ".gain1", 0); // check gain DAC values for Flexiband frontend!
|
gain1_ = configuration->property(role + ".gain1", 0); // check gain DAC values for Flexiband frontend!
|
||||||
@ -45,7 +45,7 @@ FlexibandSignalSource::FlexibandSignalSource(const ConfigurationInterface* confi
|
|||||||
|
|
||||||
AGC_ = configuration->property(role + ".AGC", true); // enabled AGC by default
|
AGC_ = configuration->property(role + ".AGC", true); // enabled AGC by default
|
||||||
flag_read_file = configuration->property(role + ".flag_read_file", false); // disable read samples from file by default
|
flag_read_file = configuration->property(role + ".flag_read_file", false); // disable read samples from file by default
|
||||||
std::string default_signal_file = "flexiband_frame_samples.bin";
|
const std::string default_signal_file("flexiband_frame_samples.bin");
|
||||||
signal_file = configuration->property(role + ".signal_file", default_signal_file);
|
signal_file = configuration->property(role + ".signal_file", default_signal_file);
|
||||||
|
|
||||||
usb_packet_buffer_size_ = configuration->property(role + ".usb_packet_buffer", 128);
|
usb_packet_buffer_size_ = configuration->property(role + ".usb_packet_buffer", 128);
|
||||||
|
@ -39,8 +39,8 @@ Fmcomms2SignalSource::Fmcomms2SignalSource(const ConfigurationInterface *configu
|
|||||||
{
|
{
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
const std::string default_dump_file("./data/signal_source.dat");
|
const std::string default_dump_file("./data/signal_source.dat");
|
||||||
std::string default_gain_mode("slow_attack");
|
const std::string default_gain_mode("slow_attack");
|
||||||
double default_tx_attenuation_db = -10.0;
|
const double default_tx_attenuation_db = -10.0;
|
||||||
uri_ = configuration->property(role + ".device_address", std::string("192.168.2.1"));
|
uri_ = configuration->property(role + ".device_address", std::string("192.168.2.1"));
|
||||||
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
||||||
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(2600000));
|
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(2600000));
|
||||||
|
@ -30,8 +30,8 @@ Gn3sSignalSource::Gn3sSignalSource(const ConfigurationInterface* configuration,
|
|||||||
unsigned int out_stream,
|
unsigned int out_stream,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
std::string default_item_type = "short";
|
const std::string default_item_type("short");
|
||||||
std::string default_dump_file = "./data/gn3s_source.dat";
|
const std::string default_dump_file("./data/gn3s_source.dat");
|
||||||
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
||||||
dump_ = configuration->property(role + ".dump", false);
|
dump_ = configuration->property(role + ".dump", false);
|
||||||
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
||||||
|
@ -29,14 +29,14 @@ LabsatSignalSource::LabsatSignalSource(const ConfigurationInterface* configurati
|
|||||||
const std::string& role, unsigned int in_stream, unsigned int out_stream, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
const std::string& role, unsigned int in_stream, unsigned int out_stream, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
std::string default_dump_file = "./labsat_output.dat";
|
const std::string default_dump_file("./labsat_output.dat");
|
||||||
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
||||||
dump_ = configuration->property(role + ".dump", false);
|
dump_ = configuration->property(role + ".dump", false);
|
||||||
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
||||||
|
|
||||||
int channel_selector = configuration->property(role + ".selected_channel", 1);
|
const int channel_selector = configuration->property(role + ".selected_channel", 1);
|
||||||
|
|
||||||
std::string default_filename = "./example_capture.LS3";
|
const std::string default_filename("./example_capture.LS3");
|
||||||
filename_ = configuration->property(role + ".filename", default_filename);
|
filename_ = configuration->property(role + ".filename", default_filename);
|
||||||
|
|
||||||
if (item_type_ == "gr_complex")
|
if (item_type_ == "gr_complex")
|
||||||
|
@ -34,12 +34,11 @@ MultichannelFileSignalSource::MultichannelFileSignalSource(const ConfigurationIn
|
|||||||
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "./example_capture.dat";
|
const std::string default_filename("./example_capture.dat");
|
||||||
std::string default_item_type = "short";
|
const std::string default_item_type("short");
|
||||||
std::string default_dump_filename = "./my_capture.dat";
|
const std::string default_dump_filename("./my_capture.dat");
|
||||||
|
|
||||||
double default_seconds_to_skip = 0.0;
|
const double default_seconds_to_skip = 0.0;
|
||||||
size_t header_size = 0;
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
n_channels_ = configuration->property(role + ".total_channels", 1);
|
n_channels_ = configuration->property(role + ".total_channels", 1);
|
||||||
@ -53,8 +52,8 @@ MultichannelFileSignalSource::MultichannelFileSignalSource(const ConfigurationIn
|
|||||||
repeat_ = configuration->property(role + ".repeat", false);
|
repeat_ = configuration->property(role + ".repeat", false);
|
||||||
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
||||||
|
|
||||||
double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
const double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
||||||
header_size = configuration->property(role + ".header_size", 0);
|
size_t header_size = configuration->property(role + ".header_size", 0);
|
||||||
int64_t samples_to_skip = 0;
|
int64_t samples_to_skip = 0;
|
||||||
|
|
||||||
bool is_complex = false;
|
bool is_complex = false;
|
||||||
@ -126,32 +125,21 @@ MultichannelFileSignalSource::MultichannelFileSignalSource(const ConfigurationIn
|
|||||||
if (filename_vec_.at(0) == default_filename)
|
if (filename_vec_.at(0) == default_filename)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The configuration file has not been found."
|
<< "The configuration file has not been found.\n"
|
||||||
<< '\n'
|
<< "Please create a configuration file based on the examples at the 'conf/' folder\n"
|
||||||
<< "Please create a configuration file based on the examples at the 'conf/' folder "
|
<< "and then generate your own GNSS Software Defined Receiver by doing:\n"
|
||||||
<< '\n'
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n";
|
||||||
<< "and then generate your own GNSS Software Defined Receiver by doing:"
|
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n';
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "file_signal_source: Unable to open the samples file "
|
LOG(INFO) << "file_signal_source: Unable to open the samples file "
|
||||||
@ -194,8 +182,7 @@ MultichannelFileSignalSource::MultichannelFileSignalSource(const ConfigurationIn
|
|||||||
}
|
}
|
||||||
|
|
||||||
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
||||||
double signal_duration_s;
|
double signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
||||||
signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
|
||||||
|
|
||||||
if (is_complex)
|
if (is_complex)
|
||||||
{
|
{
|
||||||
|
@ -35,9 +35,9 @@ NsrFileSignalSource::NsrFileSignalSource(const ConfigurationInterface* configura
|
|||||||
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "../data/my_capture.dat";
|
const std::string default_filename("../data/my_capture.dat");
|
||||||
std::string default_item_type = "byte";
|
const std::string default_item_type("byte");
|
||||||
std::string default_dump_filename = "../data/my_capture_dump.dat";
|
const std::string default_dump_filename("../data/my_capture_dump.dat");
|
||||||
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
@ -76,20 +76,13 @@ NsrFileSignalSource::NsrFileSignalSource(const ConfigurationInterface* configura
|
|||||||
catch (const std::exception& e)
|
catch (const std::exception& e)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
|
|
||||||
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
||||||
<< filename_.c_str() << ", exiting the program.";
|
<< filename_.c_str() << ", exiting the program.";
|
||||||
@ -132,8 +125,7 @@ NsrFileSignalSource::NsrFileSignalSource(const ConfigurationInterface* configura
|
|||||||
}
|
}
|
||||||
|
|
||||||
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
||||||
double signal_duration_s;
|
const double signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
||||||
signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
|
||||||
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
||||||
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ OsmosdrSignalSource::OsmosdrSignalSource(const ConfigurationInterface* configura
|
|||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
// DUMP PARAMETERS
|
// DUMP PARAMETERS
|
||||||
std::string empty;
|
const std::string empty;
|
||||||
const std::string default_dump_file("./data/signal_source.dat");
|
const std::string default_dump_file("./data/signal_source.dat");
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<int64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<int64_t>(0));
|
||||||
|
@ -33,7 +33,7 @@ PlutosdrSignalSource::PlutosdrSignalSource(const ConfigurationInterface* configu
|
|||||||
{
|
{
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
const std::string default_dump_file("./data/signal_source.dat");
|
const std::string default_dump_file("./data/signal_source.dat");
|
||||||
std::string default_gain_mode("slow_attack");
|
const std::string default_gain_mode("slow_attack");
|
||||||
uri_ = configuration->property(role + ".device_address", std::string("192.168.2.1"));
|
uri_ = configuration->property(role + ".device_address", std::string("192.168.2.1"));
|
||||||
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
freq_ = configuration->property(role + ".freq", static_cast<uint64_t>(GPS_L1_FREQ_HZ));
|
||||||
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(3000000));
|
sample_rate_ = configuration->property(role + ".sampling_frequency", static_cast<uint64_t>(3000000));
|
||||||
|
@ -30,27 +30,23 @@ RawArraySignalSource::RawArraySignalSource(const ConfigurationInterface* configu
|
|||||||
std::string role, unsigned int in_stream, unsigned int out_stream, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
std::string role, unsigned int in_stream, unsigned int out_stream, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
const std::string default_item_type("gr_complex");
|
const std::string default_item_type("gr_complex");
|
||||||
std::string default_dump_file = "./data/raw_array_source.dat";
|
const std::string default_dump_file("./data/raw_array_source.dat");
|
||||||
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
item_type_ = configuration->property(role + ".item_type", default_item_type);
|
||||||
|
|
||||||
// dump_ = configuration->property(role + ".dump", false);
|
// dump_ = configuration->property(role + ".dump", false);
|
||||||
// dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
// dump_filename_ = configuration->property(role + ".dump_filename", default_dump_file);
|
||||||
dump_ = false;
|
dump_ = false;
|
||||||
|
|
||||||
std::string default_ethernet_dev = "eth0";
|
const std::string default_ethernet_dev("eth0");
|
||||||
eth_device_ = configuration->property(role + ".ethernet_dev", default_ethernet_dev);
|
eth_device_ = configuration->property(role + ".ethernet_dev", default_ethernet_dev);
|
||||||
|
|
||||||
int channels_;
|
int channels_ = configuration->property(role + ".channels", 8);
|
||||||
channels_ = configuration->property(role + ".channels", 8);
|
|
||||||
|
|
||||||
int snapshots_per_frame_;
|
int snapshots_per_frame_ = configuration->property(role + ".snapshots_per_frame", 80);
|
||||||
snapshots_per_frame_ = configuration->property(role + ".snapshots_per_frame", 80);
|
|
||||||
|
|
||||||
int inter_frame_delay_;
|
int inter_frame_delay_ = configuration->property(role + ".inter_frame_delay", 10);
|
||||||
inter_frame_delay_ = configuration->property(role + ".inter_frame_delay", 10);
|
|
||||||
|
|
||||||
int sampling_freq_;
|
int sampling_freq_ = configuration->property(role + ".sampling_freq", 5000000);
|
||||||
sampling_freq_ = configuration->property(role + ".sampling_freq", 5000000);
|
|
||||||
|
|
||||||
if (item_type_ == "gr_complex")
|
if (item_type_ == "gr_complex")
|
||||||
{
|
{
|
||||||
|
@ -34,9 +34,9 @@ SpirFileSignalSource::SpirFileSignalSource(const ConfigurationInterface* configu
|
|||||||
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
const std::string& role, unsigned int in_streams, unsigned int out_streams,
|
||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "../data/my_capture.dat";
|
const std::string default_filename("../data/my_capture.dat");
|
||||||
std::string default_item_type = "int";
|
const std::string default_item_type("int");
|
||||||
std::string default_dump_filename = "../data/my_capture_dump.dat";
|
const std::string default_dump_filename("../data/my_capture_dump.dat");
|
||||||
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
@ -75,20 +75,13 @@ SpirFileSignalSource::SpirFileSignalSource(const ConfigurationInterface* configu
|
|||||||
catch (const std::exception& e)
|
catch (const std::exception& e)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
|
|
||||||
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
||||||
<< filename_.c_str() << ", exiting the program.";
|
<< filename_.c_str() << ", exiting the program.";
|
||||||
@ -131,8 +124,7 @@ SpirFileSignalSource::SpirFileSignalSource(const ConfigurationInterface* configu
|
|||||||
}
|
}
|
||||||
|
|
||||||
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
||||||
double signal_duration_s;
|
double signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
||||||
signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
|
||||||
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
||||||
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
||||||
|
|
||||||
|
@ -31,8 +31,8 @@
|
|||||||
SpirGSS6450FileSignalSource::SpirGSS6450FileSignalSource(const ConfigurationInterface* configuration,
|
SpirGSS6450FileSignalSource::SpirGSS6450FileSignalSource(const ConfigurationInterface* configuration,
|
||||||
const std::string& role, uint32_t in_streams, uint32_t out_streams, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
const std::string& role, uint32_t in_streams, uint32_t out_streams, Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_streams_(in_streams), out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "../data/my_capture.dat";
|
const std::string default_filename("../data/my_capture.dat");
|
||||||
std::string default_dump_filename = "../data/my_capture_dump.dat";
|
const std::string default_dump_filename("../data/my_capture_dump.dat");
|
||||||
item_type_ = "int";
|
item_type_ = "int";
|
||||||
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
@ -47,8 +47,8 @@ SpirGSS6450FileSignalSource::SpirGSS6450FileSignalSource(const ConfigurationInte
|
|||||||
n_channels_ = configuration->property(role + ".total_channels", 1);
|
n_channels_ = configuration->property(role + ".total_channels", 1);
|
||||||
sel_ch_ = configuration->property(role + ".sel_ch", 1);
|
sel_ch_ = configuration->property(role + ".sel_ch", 1);
|
||||||
item_size_ = sizeof(int32_t);
|
item_size_ = sizeof(int32_t);
|
||||||
int64_t bytes_seek = configuration->property(role + ".bytes_to_skip", static_cast<int64_t>(65536));
|
const int64_t bytes_seek = configuration->property(role + ".bytes_to_skip", static_cast<int64_t>(65536));
|
||||||
double sample_size_byte = static_cast<double>(adc_bits_) / 4.0;
|
const double sample_size_byte = static_cast<double>(adc_bits_) / 4.0;
|
||||||
|
|
||||||
if (sel_ch_ > n_channels_)
|
if (sel_ch_ > n_channels_)
|
||||||
{
|
{
|
||||||
|
@ -39,9 +39,9 @@ TwoBitCpxFileSignalSource::TwoBitCpxFileSignalSource(
|
|||||||
in_streams_(in_streams),
|
in_streams_(in_streams),
|
||||||
out_streams_(out_streams)
|
out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "../data/my_capture.dat";
|
const std::string default_filename("../data/my_capture.dat");
|
||||||
std::string default_item_type = "byte";
|
const std::string default_item_type("byte");
|
||||||
std::string default_dump_filename = "../data/my_capture_dump.dat";
|
const std::string default_dump_filename("../data/my_capture_dump.dat");
|
||||||
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
@ -81,20 +81,13 @@ TwoBitCpxFileSignalSource::TwoBitCpxFileSignalSource(
|
|||||||
catch (const std::exception& e)
|
catch (const std::exception& e)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
|
|
||||||
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
||||||
<< filename_.c_str() << ", exiting the program.";
|
<< filename_.c_str() << ", exiting the program.";
|
||||||
@ -137,8 +130,7 @@ TwoBitCpxFileSignalSource::TwoBitCpxFileSignalSource(
|
|||||||
}
|
}
|
||||||
|
|
||||||
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
CHECK(samples_ > 0) << "File does not contain enough samples to process.";
|
||||||
double signal_duration_s;
|
const double signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
||||||
signal_duration_s = static_cast<double>(samples_) * (1 / static_cast<double>(sampling_frequency_));
|
|
||||||
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
LOG(INFO) << "Total number samples to be processed= " << samples_ << " GNSS signal duration= " << signal_duration_s << " [s]";
|
||||||
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
std::cout << "GNSS signal recorded time to be processed: " << signal_duration_s << " [s]\n";
|
||||||
|
|
||||||
|
@ -41,11 +41,11 @@ TwoBitPackedFileSignalSource::TwoBitPackedFileSignalSource(
|
|||||||
in_streams_(in_streams),
|
in_streams_(in_streams),
|
||||||
out_streams_(out_streams)
|
out_streams_(out_streams)
|
||||||
{
|
{
|
||||||
std::string default_filename = "../data/my_capture.dat";
|
const std::string default_filename("../data/my_capture.dat");
|
||||||
std::string default_item_type = "byte";
|
const std::string default_item_type("byte");
|
||||||
std::string default_dump_filename = "../data/my_capture_dump.dat";
|
const std::string default_dump_filename("../data/my_capture_dump.dat");
|
||||||
std::string default_sample_type = "real";
|
const std::string default_sample_type("real");
|
||||||
double default_seconds_to_skip = 0.0;
|
const double default_seconds_to_skip = 0.0;
|
||||||
|
|
||||||
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
samples_ = configuration->property(role + ".samples", static_cast<uint64_t>(0));
|
||||||
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
sampling_frequency_ = configuration->property(role + ".sampling_frequency", static_cast<int64_t>(0));
|
||||||
@ -69,7 +69,7 @@ TwoBitPackedFileSignalSource::TwoBitPackedFileSignalSource(
|
|||||||
dump_ = configuration->property(role + ".dump", false);
|
dump_ = configuration->property(role + ".dump", false);
|
||||||
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename);
|
dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename);
|
||||||
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
enable_throttle_control_ = configuration->property(role + ".enable_throttle_control", false);
|
||||||
double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
const double seconds_to_skip = configuration->property(role + ".seconds_to_skip", default_seconds_to_skip);
|
||||||
int64_t bytes_to_skip = 0;
|
int64_t bytes_to_skip = 0;
|
||||||
|
|
||||||
if (item_type_ == "byte")
|
if (item_type_ == "byte")
|
||||||
@ -145,20 +145,13 @@ TwoBitPackedFileSignalSource::TwoBitPackedFileSignalSource(
|
|||||||
catch (const std::exception& e)
|
catch (const std::exception& e)
|
||||||
{
|
{
|
||||||
std::cerr
|
std::cerr
|
||||||
<< "The receiver was configured to work with a file signal source "
|
<< "The receiver was configured to work with a file signal source\n"
|
||||||
<< '\n'
|
<< "but the specified file is unreachable by GNSS-SDR.\n"
|
||||||
<< "but the specified file is unreachable by GNSS-SDR."
|
<< "Please modify your configuration file\n"
|
||||||
<< '\n'
|
<< "and point SignalSource.filename to a valid raw data file. Then:\n"
|
||||||
<< "Please modify your configuration file"
|
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf\n"
|
||||||
<< '\n'
|
<< "Examples of configuration files available at:\n"
|
||||||
<< "and point SignalSource.filename to a valid raw data file. Then:"
|
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/\n";
|
||||||
<< '\n'
|
|
||||||
<< "$ gnss-sdr --config_file=/path/to/my_GNSS_SDR_configuration.conf"
|
|
||||||
<< '\n'
|
|
||||||
<< "Examples of configuration files available at:"
|
|
||||||
<< '\n'
|
|
||||||
<< GNSSSDR_INSTALL_DIR "/share/gnss-sdr/conf/"
|
|
||||||
<< '\n';
|
|
||||||
|
|
||||||
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
LOG(WARNING) << "file_signal_source: Unable to open the samples file "
|
||||||
<< filename_.c_str() << ", exiting the program.";
|
<< filename_.c_str() << ", exiting the program.";
|
||||||
@ -167,7 +160,7 @@ TwoBitPackedFileSignalSource::TwoBitPackedFileSignalSource(
|
|||||||
|
|
||||||
DLOG(INFO) << "file_source(" << file_source_->unique_id() << ")";
|
DLOG(INFO) << "file_source(" << file_source_->unique_id() << ")";
|
||||||
|
|
||||||
size_t output_item_size = (is_complex_ ? sizeof(gr_complex) : sizeof(float));
|
const size_t output_item_size = (is_complex_ ? sizeof(gr_complex) : sizeof(float));
|
||||||
|
|
||||||
if (samples_ == 0) // read all file
|
if (samples_ == 0) // read all file
|
||||||
{
|
{
|
||||||
|
@ -34,9 +34,9 @@ UhdSignalSource::UhdSignalSource(const ConfigurationInterface* configuration,
|
|||||||
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
Concurrent_Queue<pmt::pmt_t>* queue) : role_(role), in_stream_(in_stream), out_stream_(out_stream)
|
||||||
{
|
{
|
||||||
// DUMP PARAMETERS
|
// DUMP PARAMETERS
|
||||||
std::string empty;
|
const std::string empty;
|
||||||
const std::string default_dump_file("./data/signal_source.dat");
|
const std::string default_dump_file("./data/signal_source.dat");
|
||||||
std::string default_item_type = "cshort";
|
const std::string default_item_type("cshort");
|
||||||
|
|
||||||
// UHD COMMON PARAMETERS
|
// UHD COMMON PARAMETERS
|
||||||
uhd::device_addr_t dev_addr;
|
uhd::device_addr_t dev_addr;
|
||||||
|
Loading…
Reference in New Issue
Block a user