mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-23 07:27:05 +00:00
Minor fixes
This commit is contained in:
parent
b3764f6ed1
commit
539e24f0ac
@ -1,7 +1,7 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file dll_pll_veml_tracking.cc
|
* \file dll_pll_veml_tracking.cc
|
||||||
* \brief Implementation of a code DLL + carrier PLL tracking block.
|
* \brief Implementation of a code DLL + carrier PLL tracking block.
|
||||||
* \author Antonio Ramos, 2018 antonioramosdet(at)gmail.com
|
* \author Antonio Ramos, 2018 antonio.ramosdet(at)gmail.com
|
||||||
*
|
*
|
||||||
* Code DLL + carrier PLL according to the algorithms described in:
|
* Code DLL + carrier PLL according to the algorithms described in:
|
||||||
* [1] K.Borre, D.M.Akos, N.Bertelsen, P.Rinder, and S.H.Jensen,
|
* [1] K.Borre, D.M.Akos, N.Bertelsen, P.Rinder, and S.H.Jensen,
|
||||||
@ -112,7 +112,8 @@ dll_pll_veml_tracking::dll_pll_veml_tracking(
|
|||||||
float pll_bw_narrow_hz, float dll_bw_narrow_hz,
|
float pll_bw_narrow_hz, float dll_bw_narrow_hz,
|
||||||
float early_late_space_chips, float very_early_late_space_chips,
|
float early_late_space_chips, float very_early_late_space_chips,
|
||||||
float early_late_space_narrow_chips, float very_early_late_space_narrow_chips,
|
float early_late_space_narrow_chips, float very_early_late_space_narrow_chips,
|
||||||
int extend_correlation_symbols, bool track_pilot, char system, char signal[3]) : gr::block("dll_pll_veml_tracking", gr::io_signature::make(1, 1, sizeof(gr_complex)),
|
int extend_correlation_symbols, bool track_pilot, char system,
|
||||||
|
char signal[3]) : gr::block("dll_pll_veml_tracking", gr::io_signature::make(1, 1, sizeof(gr_complex)),
|
||||||
gr::io_signature::make(1, 1, sizeof(Gnss_Synchro)))
|
gr::io_signature::make(1, 1, sizeof(Gnss_Synchro)))
|
||||||
{
|
{
|
||||||
// Telemetry bit synchronization message port input
|
// Telemetry bit synchronization message port input
|
||||||
@ -191,7 +192,7 @@ dll_pll_veml_tracking::dll_pll_veml_tracking(
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "Invalid Signal argument when instantiating tracking blocks";
|
LOG(WARNING) << "Invalid Signal argument when instantiating tracking blocks";
|
||||||
std::cout << "Invalid Signal argument when instantiating tracking blocks" << std::endl;
|
std::cerr << "Invalid Signal argument when instantiating tracking blocks" << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (system == 'E')
|
else if (system == 'E')
|
||||||
@ -250,7 +251,7 @@ dll_pll_veml_tracking::dll_pll_veml_tracking(
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "Invalid System argument when instantiating tracking blocks";
|
LOG(WARNING) << "Invalid System argument when instantiating tracking blocks";
|
||||||
std::cout << "Invalid System argument when instantiating tracking blocks" << std::endl;
|
std::cerr << "Invalid System argument when instantiating tracking blocks" << std::endl;
|
||||||
d_correlation_length_ms = 1;
|
d_correlation_length_ms = 1;
|
||||||
d_secondary = false;
|
d_secondary = false;
|
||||||
interchange_iq = false;
|
interchange_iq = false;
|
||||||
@ -411,12 +412,11 @@ void dll_pll_veml_tracking::start_tracking()
|
|||||||
d_acq_carrier_doppler_hz = d_acquisition_gnss_synchro->Acq_doppler_hz;
|
d_acq_carrier_doppler_hz = d_acquisition_gnss_synchro->Acq_doppler_hz;
|
||||||
d_acq_sample_stamp = d_acquisition_gnss_synchro->Acq_samplestamp_samples;
|
d_acq_sample_stamp = d_acquisition_gnss_synchro->Acq_samplestamp_samples;
|
||||||
|
|
||||||
long int acq_trk_diff_samples = static_cast<long int>(d_sample_counter) - static_cast<long int>(d_acq_sample_stamp); //-d_vector_length;
|
long int acq_trk_diff_samples = static_cast<long int>(d_sample_counter) - static_cast<long int>(d_acq_sample_stamp);
|
||||||
double acq_trk_diff_seconds = static_cast<double>(acq_trk_diff_samples) / d_fs_in;
|
double acq_trk_diff_seconds = static_cast<double>(acq_trk_diff_samples) / d_fs_in;
|
||||||
DLOG(INFO) << "Number of samples between Acquisition and Tracking = " << acq_trk_diff_samples;
|
DLOG(INFO) << "Number of samples between Acquisition and Tracking = " << acq_trk_diff_samples;
|
||||||
DLOG(INFO) << "Number of seconds between Acquisition and Tracking = " << acq_trk_diff_seconds;
|
DLOG(INFO) << "Number of seconds between Acquisition and Tracking = " << acq_trk_diff_seconds;
|
||||||
// Doppler effect
|
// Doppler effect Fd = (C / (C + Vr)) * F
|
||||||
// Fd=(C/(C+Vr))*F
|
|
||||||
double radial_velocity = (d_signal_carrier_freq + d_acq_carrier_doppler_hz) / d_signal_carrier_freq;
|
double radial_velocity = (d_signal_carrier_freq + d_acq_carrier_doppler_hz) / d_signal_carrier_freq;
|
||||||
// new chip and prn sequence periods based on acq Doppler
|
// new chip and prn sequence periods based on acq Doppler
|
||||||
d_code_freq_chips = radial_velocity * d_code_chip_rate;
|
d_code_freq_chips = radial_velocity * d_code_chip_rate;
|
||||||
@ -766,6 +766,7 @@ void dll_pll_veml_tracking::clear_tracking_vars()
|
|||||||
d_last_prompt = gr_complex(0.0, 0.0);
|
d_last_prompt = gr_complex(0.0, 0.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void dll_pll_veml_tracking::update_tracking_vars()
|
void dll_pll_veml_tracking::update_tracking_vars()
|
||||||
{
|
{
|
||||||
T_chip_seconds = 1.0 / d_code_freq_chips;
|
T_chip_seconds = 1.0 / d_code_freq_chips;
|
||||||
@ -796,6 +797,7 @@ void dll_pll_veml_tracking::update_tracking_vars()
|
|||||||
d_rem_code_phase_chips = d_code_freq_chips * d_rem_code_phase_samples / d_fs_in;
|
d_rem_code_phase_chips = d_code_freq_chips * d_rem_code_phase_samples / d_fs_in;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void dll_pll_veml_tracking::save_correlation_results()
|
void dll_pll_veml_tracking::save_correlation_results()
|
||||||
{
|
{
|
||||||
if (d_secondary)
|
if (d_secondary)
|
||||||
@ -960,6 +962,263 @@ void dll_pll_veml_tracking::log_data(bool integrating)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int dll_pll_veml_tracking::save_matfile()
|
||||||
|
{
|
||||||
|
// READ DUMP FILE
|
||||||
|
std::ifstream::pos_type size;
|
||||||
|
int number_of_double_vars = 1;
|
||||||
|
int number_of_float_vars = 17;
|
||||||
|
int epoch_size_bytes = sizeof(unsigned long int) + sizeof(double) * number_of_double_vars +
|
||||||
|
sizeof(float) * number_of_float_vars + sizeof(unsigned int);
|
||||||
|
std::ifstream dump_file;
|
||||||
|
dump_file.exceptions(std::ifstream::failbit | std::ifstream::badbit);
|
||||||
|
try
|
||||||
|
{
|
||||||
|
dump_file.open(d_dump_filename.c_str(), std::ios::binary | std::ios::ate);
|
||||||
|
}
|
||||||
|
catch (const std::ifstream::failure &e)
|
||||||
|
{
|
||||||
|
std::cerr << "Problem opening dump file:" << e.what() << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
// count number of epochs and rewind
|
||||||
|
long int num_epoch = 0;
|
||||||
|
if (dump_file.is_open())
|
||||||
|
{
|
||||||
|
size = dump_file.tellg();
|
||||||
|
num_epoch = static_cast<long int>(size) / static_cast<long int>(epoch_size_bytes);
|
||||||
|
dump_file.seekg(0, std::ios::beg);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
float *abs_VE = new float[num_epoch];
|
||||||
|
float *abs_E = new float[num_epoch];
|
||||||
|
float *abs_P = new float[num_epoch];
|
||||||
|
float *abs_L = new float[num_epoch];
|
||||||
|
float *abs_VL = new float[num_epoch];
|
||||||
|
float *Prompt_I = new float[num_epoch];
|
||||||
|
float *Prompt_Q = new float[num_epoch];
|
||||||
|
unsigned long int *PRN_start_sample_count = new unsigned long int[num_epoch];
|
||||||
|
float *acc_carrier_phase_rad = new float[num_epoch];
|
||||||
|
float *carrier_doppler_hz = new float[num_epoch];
|
||||||
|
float *code_freq_chips = new float[num_epoch];
|
||||||
|
float *carr_error_hz = new float[num_epoch];
|
||||||
|
float *carr_error_filt_hz = new float[num_epoch];
|
||||||
|
float *code_error_chips = new float[num_epoch];
|
||||||
|
float *code_error_filt_chips = new float[num_epoch];
|
||||||
|
float *CN0_SNV_dB_Hz = new float[num_epoch];
|
||||||
|
float *carrier_lock_test = new float[num_epoch];
|
||||||
|
float *aux1 = new float[num_epoch];
|
||||||
|
double *aux2 = new double[num_epoch];
|
||||||
|
unsigned int *PRN = new unsigned int[num_epoch];
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (dump_file.is_open())
|
||||||
|
{
|
||||||
|
for (long int i = 0; i < num_epoch; i++)
|
||||||
|
{
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&abs_VE[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&abs_E[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&abs_P[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&abs_L[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&abs_VL[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&Prompt_I[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&Prompt_Q[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&PRN_start_sample_count[i]), sizeof(unsigned long int));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&acc_carrier_phase_rad[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&carrier_doppler_hz[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&code_freq_chips[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&carr_error_hz[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&carr_error_filt_hz[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&code_error_chips[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&code_error_filt_chips[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&CN0_SNV_dB_Hz[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&carrier_lock_test[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&aux1[i]), sizeof(float));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&aux2[i]), sizeof(double));
|
||||||
|
dump_file.read(reinterpret_cast<char *>(&PRN[i]), sizeof(unsigned int));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dump_file.close();
|
||||||
|
}
|
||||||
|
catch (const std::ifstream::failure &e)
|
||||||
|
{
|
||||||
|
std::cerr << "Problem reading dump file:" << e.what() << std::endl;
|
||||||
|
delete[] abs_VE;
|
||||||
|
delete[] abs_E;
|
||||||
|
delete[] abs_P;
|
||||||
|
delete[] abs_L;
|
||||||
|
delete[] abs_VL;
|
||||||
|
delete[] Prompt_I;
|
||||||
|
delete[] Prompt_Q;
|
||||||
|
delete[] PRN_start_sample_count;
|
||||||
|
delete[] acc_carrier_phase_rad;
|
||||||
|
delete[] carrier_doppler_hz;
|
||||||
|
delete[] code_freq_chips;
|
||||||
|
delete[] carr_error_hz;
|
||||||
|
delete[] carr_error_filt_hz;
|
||||||
|
delete[] code_error_chips;
|
||||||
|
delete[] code_error_filt_chips;
|
||||||
|
delete[] CN0_SNV_dB_Hz;
|
||||||
|
delete[] carrier_lock_test;
|
||||||
|
delete[] aux1;
|
||||||
|
delete[] aux2;
|
||||||
|
delete[] PRN;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// WRITE MAT FILE
|
||||||
|
mat_t *matfp;
|
||||||
|
matvar_t *matvar;
|
||||||
|
std::string filename = d_dump_filename;
|
||||||
|
filename.erase(filename.length() - 4, 4);
|
||||||
|
filename.append(".mat");
|
||||||
|
matfp = Mat_CreateVer(filename.c_str(), NULL, MAT_FT_MAT73);
|
||||||
|
if (reinterpret_cast<long *>(matfp) != NULL)
|
||||||
|
{
|
||||||
|
size_t dims[2] = {1, static_cast<size_t>(num_epoch)};
|
||||||
|
matvar = Mat_VarCreate("abs_VE", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("abs_E", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("abs_P", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_P, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("abs_L", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_L, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("abs_VL", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("Prompt_I", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, Prompt_I, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("Prompt_Q", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, Prompt_Q, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("PRN_start_sample_count", MAT_C_UINT64, MAT_T_UINT64, 2, dims, PRN_start_sample_count, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("acc_carrier_phase_rad", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, acc_carrier_phase_rad, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("carrier_doppler_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carrier_doppler_hz, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("code_freq_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_freq_chips, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("carr_error_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carr_error_hz, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("carr_error_filt_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carr_error_filt_hz, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("code_error_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_error_chips, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("code_error_filt_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_error_filt_chips, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("CN0_SNV_dB_Hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, CN0_SNV_dB_Hz, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("carrier_lock_test", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carrier_lock_test, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("aux1", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, aux1, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("aux2", MAT_C_DOUBLE, MAT_T_DOUBLE, 2, dims, aux2, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
|
||||||
|
matvar = Mat_VarCreate("PRN", MAT_C_UINT32, MAT_T_UINT32, 2, dims, PRN, 0);
|
||||||
|
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
||||||
|
Mat_VarFree(matvar);
|
||||||
|
}
|
||||||
|
Mat_Close(matfp);
|
||||||
|
delete[] abs_VE;
|
||||||
|
delete[] abs_E;
|
||||||
|
delete[] abs_P;
|
||||||
|
delete[] abs_L;
|
||||||
|
delete[] abs_VL;
|
||||||
|
delete[] Prompt_I;
|
||||||
|
delete[] Prompt_Q;
|
||||||
|
delete[] PRN_start_sample_count;
|
||||||
|
delete[] acc_carrier_phase_rad;
|
||||||
|
delete[] carrier_doppler_hz;
|
||||||
|
delete[] code_freq_chips;
|
||||||
|
delete[] carr_error_hz;
|
||||||
|
delete[] carr_error_filt_hz;
|
||||||
|
delete[] code_error_chips;
|
||||||
|
delete[] code_error_filt_chips;
|
||||||
|
delete[] CN0_SNV_dB_Hz;
|
||||||
|
delete[] carrier_lock_test;
|
||||||
|
delete[] aux1;
|
||||||
|
delete[] aux2;
|
||||||
|
delete[] PRN;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void dll_pll_veml_tracking::set_channel(unsigned int channel)
|
||||||
|
{
|
||||||
|
gr::thread::scoped_lock l(d_setlock);
|
||||||
|
d_channel = channel;
|
||||||
|
LOG(INFO) << "Tracking Channel set to " << d_channel;
|
||||||
|
// ############# ENABLE DATA FILE LOG #################
|
||||||
|
if (d_dump)
|
||||||
|
{
|
||||||
|
if (!d_dump_file.is_open())
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
d_dump_filename.append(boost::lexical_cast<std::string>(d_channel));
|
||||||
|
d_dump_filename.append(".dat");
|
||||||
|
d_dump_file.exceptions(std::ifstream::failbit | std::ifstream::badbit);
|
||||||
|
d_dump_file.open(d_dump_filename.c_str(), std::ios::out | std::ios::binary);
|
||||||
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
|
}
|
||||||
|
catch (const std::ifstream::failure &e)
|
||||||
|
{
|
||||||
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void dll_pll_veml_tracking::set_gnss_synchro(Gnss_Synchro *p_gnss_synchro)
|
||||||
|
{
|
||||||
|
gr::thread::scoped_lock l(d_setlock);
|
||||||
|
d_acquisition_gnss_synchro = p_gnss_synchro;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int dll_pll_veml_tracking::general_work(int noutput_items __attribute__((unused)), gr_vector_int &ninput_items,
|
int dll_pll_veml_tracking::general_work(int noutput_items __attribute__((unused)), gr_vector_int &ninput_items,
|
||||||
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
|
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
|
||||||
{
|
{
|
||||||
@ -970,7 +1229,7 @@ int dll_pll_veml_tracking::general_work(int noutput_items __attribute__((unused)
|
|||||||
|
|
||||||
switch (d_state)
|
switch (d_state)
|
||||||
{
|
{
|
||||||
case 0: // Standby - Pass Through. Full throttle
|
case 0: // Standby - Consume samples at full throttle, do nothing
|
||||||
{
|
{
|
||||||
d_sample_counter += ninput_items[0];
|
d_sample_counter += ninput_items[0];
|
||||||
consume_each(ninput_items[0]);
|
consume_each(ninput_items[0]);
|
||||||
@ -980,7 +1239,6 @@ int dll_pll_veml_tracking::general_work(int noutput_items __attribute__((unused)
|
|||||||
case 1: // Pull-in
|
case 1: // Pull-in
|
||||||
{
|
{
|
||||||
// Signal alignment (skip samples until the incoming signal is aligned with local replica)
|
// Signal alignment (skip samples until the incoming signal is aligned with local replica)
|
||||||
// Fill the acquisition data
|
|
||||||
unsigned long int acq_to_trk_delay_samples = d_sample_counter - d_acq_sample_stamp;
|
unsigned long int acq_to_trk_delay_samples = d_sample_counter - d_acq_sample_stamp;
|
||||||
double acq_trk_shif_correction_samples = static_cast<double>(d_current_prn_length_samples) - std::fmod(static_cast<double>(acq_to_trk_delay_samples), static_cast<double>(d_current_prn_length_samples));
|
double acq_trk_shif_correction_samples = static_cast<double>(d_current_prn_length_samples) - std::fmod(static_cast<double>(acq_to_trk_delay_samples), static_cast<double>(d_current_prn_length_samples));
|
||||||
int samples_offset = std::round(d_acq_code_phase_samples + acq_trk_shif_correction_samples);
|
int samples_offset = std::round(d_acq_code_phase_samples + acq_trk_shif_correction_samples);
|
||||||
@ -1253,260 +1511,3 @@ int dll_pll_veml_tracking::general_work(int noutput_items __attribute__((unused)
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int dll_pll_veml_tracking::save_matfile()
|
|
||||||
{
|
|
||||||
// READ DUMP FILE
|
|
||||||
std::ifstream::pos_type size;
|
|
||||||
int number_of_double_vars = 1;
|
|
||||||
int number_of_float_vars = 17;
|
|
||||||
int epoch_size_bytes = sizeof(unsigned long int) + sizeof(double) * number_of_double_vars +
|
|
||||||
sizeof(float) * number_of_float_vars + sizeof(unsigned int);
|
|
||||||
std::ifstream dump_file;
|
|
||||||
dump_file.exceptions(std::ifstream::failbit | std::ifstream::badbit);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
dump_file.open(d_dump_filename.c_str(), std::ios::binary | std::ios::ate);
|
|
||||||
}
|
|
||||||
catch (const std::ifstream::failure &e)
|
|
||||||
{
|
|
||||||
std::cerr << "Problem opening dump file:" << e.what() << std::endl;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
// count number of epochs and rewind
|
|
||||||
long int num_epoch = 0;
|
|
||||||
if (dump_file.is_open())
|
|
||||||
{
|
|
||||||
size = dump_file.tellg();
|
|
||||||
num_epoch = static_cast<long int>(size) / static_cast<long int>(epoch_size_bytes);
|
|
||||||
dump_file.seekg(0, std::ios::beg);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
float *abs_VE = new float[num_epoch];
|
|
||||||
float *abs_E = new float[num_epoch];
|
|
||||||
float *abs_P = new float[num_epoch];
|
|
||||||
float *abs_L = new float[num_epoch];
|
|
||||||
float *abs_VL = new float[num_epoch];
|
|
||||||
float *Prompt_I = new float[num_epoch];
|
|
||||||
float *Prompt_Q = new float[num_epoch];
|
|
||||||
unsigned long int *PRN_start_sample_count = new unsigned long int[num_epoch];
|
|
||||||
float *acc_carrier_phase_rad = new float[num_epoch];
|
|
||||||
float *carrier_doppler_hz = new float[num_epoch];
|
|
||||||
float *code_freq_chips = new float[num_epoch];
|
|
||||||
float *carr_error_hz = new float[num_epoch];
|
|
||||||
float *carr_error_filt_hz = new float[num_epoch];
|
|
||||||
float *code_error_chips = new float[num_epoch];
|
|
||||||
float *code_error_filt_chips = new float[num_epoch];
|
|
||||||
float *CN0_SNV_dB_Hz = new float[num_epoch];
|
|
||||||
float *carrier_lock_test = new float[num_epoch];
|
|
||||||
float *aux1 = new float[num_epoch];
|
|
||||||
double *aux2 = new double[num_epoch];
|
|
||||||
unsigned int *PRN = new unsigned int[num_epoch];
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (dump_file.is_open())
|
|
||||||
{
|
|
||||||
for (long int i = 0; i < num_epoch; i++)
|
|
||||||
{
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&abs_VE[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&abs_E[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&abs_P[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&abs_L[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&abs_VL[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&Prompt_I[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&Prompt_Q[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&PRN_start_sample_count[i]), sizeof(unsigned long int));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&acc_carrier_phase_rad[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&carrier_doppler_hz[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&code_freq_chips[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&carr_error_hz[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&carr_error_filt_hz[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&code_error_chips[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&code_error_filt_chips[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&CN0_SNV_dB_Hz[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&carrier_lock_test[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&aux1[i]), sizeof(float));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&aux2[i]), sizeof(double));
|
|
||||||
dump_file.read(reinterpret_cast<char *>(&PRN[i]), sizeof(unsigned int));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dump_file.close();
|
|
||||||
}
|
|
||||||
catch (const std::ifstream::failure &e)
|
|
||||||
{
|
|
||||||
std::cerr << "Problem reading dump file:" << e.what() << std::endl;
|
|
||||||
delete[] abs_VE;
|
|
||||||
delete[] abs_E;
|
|
||||||
delete[] abs_P;
|
|
||||||
delete[] abs_L;
|
|
||||||
delete[] abs_VL;
|
|
||||||
delete[] Prompt_I;
|
|
||||||
delete[] Prompt_Q;
|
|
||||||
delete[] PRN_start_sample_count;
|
|
||||||
delete[] acc_carrier_phase_rad;
|
|
||||||
delete[] carrier_doppler_hz;
|
|
||||||
delete[] code_freq_chips;
|
|
||||||
delete[] carr_error_hz;
|
|
||||||
delete[] carr_error_filt_hz;
|
|
||||||
delete[] code_error_chips;
|
|
||||||
delete[] code_error_filt_chips;
|
|
||||||
delete[] CN0_SNV_dB_Hz;
|
|
||||||
delete[] carrier_lock_test;
|
|
||||||
delete[] aux1;
|
|
||||||
delete[] aux2;
|
|
||||||
delete[] PRN;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// WRITE MAT FILE
|
|
||||||
mat_t *matfp;
|
|
||||||
matvar_t *matvar;
|
|
||||||
std::string filename = d_dump_filename;
|
|
||||||
filename.erase(filename.length() - 4, 4);
|
|
||||||
filename.append(".mat");
|
|
||||||
matfp = Mat_CreateVer(filename.c_str(), NULL, MAT_FT_MAT73);
|
|
||||||
if (reinterpret_cast<long *>(matfp) != NULL)
|
|
||||||
{
|
|
||||||
size_t dims[2] = {1, static_cast<size_t>(num_epoch)};
|
|
||||||
matvar = Mat_VarCreate("abs_VE", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("abs_E", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("abs_P", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_P, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("abs_L", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_L, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("abs_VL", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, abs_E, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("Prompt_I", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, Prompt_I, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("Prompt_Q", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, Prompt_Q, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("PRN_start_sample_count", MAT_C_UINT64, MAT_T_UINT64, 2, dims, PRN_start_sample_count, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("acc_carrier_phase_rad", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, acc_carrier_phase_rad, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("carrier_doppler_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carrier_doppler_hz, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("code_freq_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_freq_chips, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("carr_error_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carr_error_hz, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("carr_error_filt_hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carr_error_filt_hz, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("code_error_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_error_chips, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("code_error_filt_chips", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, code_error_filt_chips, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("CN0_SNV_dB_Hz", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, CN0_SNV_dB_Hz, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("carrier_lock_test", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, carrier_lock_test, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("aux1", MAT_C_SINGLE, MAT_T_SINGLE, 2, dims, aux1, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("aux2", MAT_C_DOUBLE, MAT_T_DOUBLE, 2, dims, aux2, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
|
|
||||||
matvar = Mat_VarCreate("PRN", MAT_C_UINT32, MAT_T_UINT32, 2, dims, PRN, 0);
|
|
||||||
Mat_VarWrite(matfp, matvar, MAT_COMPRESSION_ZLIB); // or MAT_COMPRESSION_NONE
|
|
||||||
Mat_VarFree(matvar);
|
|
||||||
}
|
|
||||||
Mat_Close(matfp);
|
|
||||||
delete[] abs_VE;
|
|
||||||
delete[] abs_E;
|
|
||||||
delete[] abs_P;
|
|
||||||
delete[] abs_L;
|
|
||||||
delete[] abs_VL;
|
|
||||||
delete[] Prompt_I;
|
|
||||||
delete[] Prompt_Q;
|
|
||||||
delete[] PRN_start_sample_count;
|
|
||||||
delete[] acc_carrier_phase_rad;
|
|
||||||
delete[] carrier_doppler_hz;
|
|
||||||
delete[] code_freq_chips;
|
|
||||||
delete[] carr_error_hz;
|
|
||||||
delete[] carr_error_filt_hz;
|
|
||||||
delete[] code_error_chips;
|
|
||||||
delete[] code_error_filt_chips;
|
|
||||||
delete[] CN0_SNV_dB_Hz;
|
|
||||||
delete[] carrier_lock_test;
|
|
||||||
delete[] aux1;
|
|
||||||
delete[] aux2;
|
|
||||||
delete[] PRN;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void dll_pll_veml_tracking::set_channel(unsigned int channel)
|
|
||||||
{
|
|
||||||
gr::thread::scoped_lock l(d_setlock);
|
|
||||||
d_channel = channel;
|
|
||||||
LOG(INFO) << "Tracking Channel set to " << d_channel;
|
|
||||||
// ############# ENABLE DATA FILE LOG #################
|
|
||||||
if (d_dump)
|
|
||||||
{
|
|
||||||
if (!d_dump_file.is_open())
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
d_dump_filename.append(boost::lexical_cast<std::string>(d_channel));
|
|
||||||
d_dump_filename.append(".dat");
|
|
||||||
d_dump_file.exceptions(std::ifstream::failbit | std::ifstream::badbit);
|
|
||||||
d_dump_file.open(d_dump_filename.c_str(), std::ios::out | std::ios::binary);
|
|
||||||
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
|
||||||
}
|
|
||||||
catch (const std::ifstream::failure &e)
|
|
||||||
{
|
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void dll_pll_veml_tracking::set_gnss_synchro(Gnss_Synchro *p_gnss_synchro)
|
|
||||||
{
|
|
||||||
gr::thread::scoped_lock l(d_setlock);
|
|
||||||
d_acquisition_gnss_synchro = p_gnss_synchro;
|
|
||||||
}
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file dll_pll_veml_tracking.h
|
* \file dll_pll_veml_tracking.h
|
||||||
* \brief Implementation of a code DLL + carrier PLL tracking block.
|
* \brief Implementation of a code DLL + carrier PLL tracking block.
|
||||||
* \author Antonio Ramos, 2018 antonioramosdet(at)gmail.com
|
* \author Antonio Ramos, 2018 antonio.ramosdet(at)gmail.com
|
||||||
*
|
*
|
||||||
* -------------------------------------------------------------------------
|
* -------------------------------------------------------------------------
|
||||||
*
|
*
|
||||||
@ -55,8 +55,7 @@ dll_pll_veml_tracking_sptr dll_pll_veml_make_tracking(double fs_in, unsigned int
|
|||||||
char system, char signal[3]);
|
char system, char signal[3]);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief This class implements a code DLL + carrier PLL VEML (Very Early
|
* \brief This class implements a code DLL + carrier PLL tracking block.
|
||||||
* Minus Late) tracking block for Galileo E1 signals
|
|
||||||
*/
|
*/
|
||||||
class dll_pll_veml_tracking : public gr::block
|
class dll_pll_veml_tracking : public gr::block
|
||||||
{
|
{
|
||||||
@ -67,12 +66,6 @@ public:
|
|||||||
void set_gnss_synchro(Gnss_Synchro *p_gnss_synchro);
|
void set_gnss_synchro(Gnss_Synchro *p_gnss_synchro);
|
||||||
void start_tracking();
|
void start_tracking();
|
||||||
|
|
||||||
/*!
|
|
||||||
* \brief Code DLL + carrier PLL according to the algorithms described in:
|
|
||||||
* K.Borre, D.M.Akos, N.Bertelsen, P.Rinder, and S.H.Jensen,
|
|
||||||
* A Software-Defined GPS and Galileo Receiver. A Single-Frequency Approach,
|
|
||||||
* Birkhauser, 2007
|
|
||||||
*/
|
|
||||||
int general_work(int noutput_items, gr_vector_int &ninput_items,
|
int general_work(int noutput_items, gr_vector_int &ninput_items,
|
||||||
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items);
|
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user