mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-07 07:50:32 +00:00
Add PRN in binary data written by Tracking blocks if dump=true
Matlab scripts updated
This commit is contained in:
parent
37998c11a4
commit
61b41bf3a8
@ -199,6 +199,7 @@ galileo_e1_dll_pll_veml_tracking_cc::galileo_e1_dll_pll_veml_tracking_cc(
|
|||||||
d_acc_code_phase_secs = 0.0;
|
d_acc_code_phase_secs = 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void galileo_e1_dll_pll_veml_tracking_cc::start_tracking()
|
void galileo_e1_dll_pll_veml_tracking_cc::start_tracking()
|
||||||
{
|
{
|
||||||
d_acq_code_phase_samples = d_acquisition_gnss_synchro->Acq_delay_samples;
|
d_acq_code_phase_samples = d_acquisition_gnss_synchro->Acq_delay_samples;
|
||||||
@ -247,6 +248,7 @@ void galileo_e1_dll_pll_veml_tracking_cc::start_tracking()
|
|||||||
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
galileo_e1_dll_pll_veml_tracking_cc::~galileo_e1_dll_pll_veml_tracking_cc()
|
galileo_e1_dll_pll_veml_tracking_cc::~galileo_e1_dll_pll_veml_tracking_cc()
|
||||||
{
|
{
|
||||||
d_dump_file.close();
|
d_dump_file.close();
|
||||||
@ -260,7 +262,6 @@ galileo_e1_dll_pll_veml_tracking_cc::~galileo_e1_dll_pll_veml_tracking_cc()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int galileo_e1_dll_pll_veml_tracking_cc::general_work (int noutput_items __attribute__((unused)), gr_vector_int &ninput_items __attribute__((unused)),
|
int galileo_e1_dll_pll_veml_tracking_cc::general_work (int noutput_items __attribute__((unused)), gr_vector_int &ninput_items __attribute__((unused)),
|
||||||
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)
|
||||||
{
|
{
|
||||||
@ -477,10 +478,13 @@ int galileo_e1_dll_pll_veml_tracking_cc::general_work (int noutput_items __attri
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_float), sizeof(float));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_float), sizeof(float));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "Exception writing trk dump file " << e.what() << std::endl;
|
LOG(WARNING) << "Exception writing trk dump file " << e.what();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
consume_each(d_current_prn_length_samples); // this is required for gr_block derivates
|
consume_each(d_current_prn_length_samples); // this is required for gr_block derivates
|
||||||
@ -510,7 +514,7 @@ void galileo_e1_dll_pll_veml_tracking_cc::set_channel(unsigned int channel)
|
|||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what() << std::endl;
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -485,6 +485,10 @@ int Galileo_E1_Tcp_Connector_Tracking_cc::general_work (int noutput_items __attr
|
|||||||
d_dump_file.write((char*)&tmp_float, sizeof(float));
|
d_dump_file.write((char*)&tmp_float, sizeof(float));
|
||||||
tmp_double = (double)(d_sample_counter+d_current_prn_length_samples);
|
tmp_double = (double)(d_sample_counter+d_current_prn_length_samples);
|
||||||
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
|
@ -304,14 +304,12 @@ void Galileo_E5a_Dll_Pll_Tracking_cc::start_tracking()
|
|||||||
std::cout << "Tracking of Galileo E5a signal started on channel " << d_channel << " for satellite " << Gnss_Satellite(systemName[sys], d_acquisition_gnss_synchro->PRN) << std::endl;
|
std::cout << "Tracking of Galileo E5a signal started on channel " << d_channel << " for satellite " << Gnss_Satellite(systemName[sys], d_acquisition_gnss_synchro->PRN) << std::endl;
|
||||||
LOG(INFO) << "Galileo E5a starting tracking of satellite " << Gnss_Satellite(systemName[sys], d_acquisition_gnss_synchro->PRN) << " on channel " << d_channel;
|
LOG(INFO) << "Galileo E5a starting tracking of satellite " << Gnss_Satellite(systemName[sys], d_acquisition_gnss_synchro->PRN) << " on channel " << d_channel;
|
||||||
|
|
||||||
|
|
||||||
// enable tracking
|
// enable tracking
|
||||||
d_state = 1;
|
d_state = 1;
|
||||||
|
|
||||||
LOG(INFO) << "PULL-IN Doppler [Hz]=" << d_carrier_doppler_hz
|
LOG(INFO) << "PULL-IN Doppler [Hz]=" << d_carrier_doppler_hz
|
||||||
<< " Code Phase correction [samples]=" << delay_correction_samples
|
<< " Code Phase correction [samples]=" << delay_correction_samples
|
||||||
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -434,8 +432,6 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
// Secondary code Chip
|
// Secondary code Chip
|
||||||
if (d_secondary_lock)
|
if (d_secondary_lock)
|
||||||
{
|
{
|
||||||
// sec_sign_Q = gr_complex((Galileo_E5a_Q_SECONDARY_CODE[d_acquisition_gnss_synchro->PRN-1].at(d_secondary_delay)=='0' ? 1 : -1),0);
|
|
||||||
// sec_sign_I = gr_complex((Galileo_E5a_I_SECONDARY_CODE.at(d_secondary_delay%Galileo_E5a_I_SECONDARY_CODE_LENGTH)=='0' ? 1 : -1),0);
|
|
||||||
sec_sign_Q = gr_complex((Galileo_E5a_Q_SECONDARY_CODE[d_acquisition_gnss_synchro->PRN-1].at(d_secondary_delay) == '0' ? -1 : 1), 0);
|
sec_sign_Q = gr_complex((Galileo_E5a_Q_SECONDARY_CODE[d_acquisition_gnss_synchro->PRN-1].at(d_secondary_delay) == '0' ? -1 : 1), 0);
|
||||||
sec_sign_I = gr_complex((Galileo_E5a_I_SECONDARY_CODE.at(d_secondary_delay % Galileo_E5a_I_SECONDARY_CODE_LENGTH) == '0' ? -1 : 1), 0);
|
sec_sign_I = gr_complex((Galileo_E5a_I_SECONDARY_CODE.at(d_secondary_delay % Galileo_E5a_I_SECONDARY_CODE_LENGTH) == '0' ? -1 : 1), 0);
|
||||||
}
|
}
|
||||||
@ -464,7 +460,6 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
multicorrelator_cpu_Q.set_local_code_and_taps(Galileo_E5a_CODE_LENGTH_CHIPS, d_codeQ, d_local_code_shift_chips);
|
multicorrelator_cpu_Q.set_local_code_and_taps(Galileo_E5a_CODE_LENGTH_CHIPS, d_codeQ, d_local_code_shift_chips);
|
||||||
multicorrelator_cpu_I.set_local_code_and_taps(Galileo_E5a_CODE_LENGTH_CHIPS, d_codeI, &d_local_code_shift_chips[1]);
|
multicorrelator_cpu_I.set_local_code_and_taps(Galileo_E5a_CODE_LENGTH_CHIPS, d_codeI, &d_local_code_shift_chips[1]);
|
||||||
|
|
||||||
|
|
||||||
// ################# CARRIER WIPEOFF AND CORRELATORS ##############################
|
// ################# CARRIER WIPEOFF AND CORRELATORS ##############################
|
||||||
// perform carrier wipe-off and compute Early, Prompt and Late correlation
|
// perform carrier wipe-off and compute Early, Prompt and Late correlation
|
||||||
multicorrelator_cpu_Q.set_input_output_vectors(d_correlator_outs,in);
|
multicorrelator_cpu_Q.set_input_output_vectors(d_correlator_outs,in);
|
||||||
@ -487,7 +482,6 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
code_phase_step_chips,
|
code_phase_step_chips,
|
||||||
d_current_prn_length_samples);
|
d_current_prn_length_samples);
|
||||||
|
|
||||||
|
|
||||||
// Accumulate results (coherent integration since there are no bit transitions in pilot signal)
|
// Accumulate results (coherent integration since there are no bit transitions in pilot signal)
|
||||||
d_Early += (*d_Single_Early) * sec_sign_Q;
|
d_Early += (*d_Single_Early) * sec_sign_Q;
|
||||||
d_Prompt += (*d_Single_Prompt) * sec_sign_Q;
|
d_Prompt += (*d_Single_Prompt) * sec_sign_Q;
|
||||||
@ -516,9 +510,9 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
// New code Doppler frequency estimation
|
// New code Doppler frequency estimation
|
||||||
d_code_freq_chips = Galileo_E5a_CODE_CHIP_RATE_HZ + ((d_carrier_doppler_hz * Galileo_E5a_CODE_CHIP_RATE_HZ) / Galileo_E5a_FREQ_HZ);
|
d_code_freq_chips = Galileo_E5a_CODE_CHIP_RATE_HZ + ((d_carrier_doppler_hz * Galileo_E5a_CODE_CHIP_RATE_HZ) / Galileo_E5a_FREQ_HZ);
|
||||||
}
|
}
|
||||||
//carrier phase accumulator for (K) doppler estimation
|
// carrier phase accumulator for (K) doppler estimation
|
||||||
d_acc_carrier_phase_rad -= 2.0 * GALILEO_PI * d_carrier_doppler_hz * GALILEO_E5a_CODE_PERIOD;
|
d_acc_carrier_phase_rad -= 2.0 * GALILEO_PI * d_carrier_doppler_hz * GALILEO_E5a_CODE_PERIOD;
|
||||||
//remanent carrier phase to prevent overflow in the code NCO
|
// remnant carrier phase to prevent overflow in the code NCO
|
||||||
d_rem_carr_phase_rad = d_rem_carr_phase_rad + 2.0 * GALILEO_PI * d_carrier_doppler_hz * GALILEO_E5a_CODE_PERIOD;
|
d_rem_carr_phase_rad = d_rem_carr_phase_rad + 2.0 * GALILEO_PI * d_carrier_doppler_hz * GALILEO_E5a_CODE_PERIOD;
|
||||||
d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, 2.0 * GALILEO_PI);
|
d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, 2.0 * GALILEO_PI);
|
||||||
|
|
||||||
@ -628,7 +622,6 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
||||||
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
||||||
current_synchro_data.CN0_dB_hz = d_CN0_SNV_dB_Hz;
|
current_synchro_data.CN0_dB_hz = d_CN0_SNV_dB_Hz;
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -638,7 +631,6 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
current_synchro_data.Tracking_sample_counter = d_sample_counter;
|
current_synchro_data.Tracking_sample_counter = d_sample_counter;
|
||||||
current_synchro_data.Carrier_phase_rads = 0.0;
|
current_synchro_data.Carrier_phase_rads = 0.0;
|
||||||
current_synchro_data.CN0_dB_hz = 0.0;
|
current_synchro_data.CN0_dB_hz = 0.0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -700,6 +692,10 @@ int Galileo_E5a_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute
|
|||||||
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure & e)
|
catch (const std::ifstream::failure & e)
|
||||||
{
|
{
|
||||||
@ -729,11 +725,11 @@ void Galileo_E5a_Dll_Pll_Tracking_cc::set_channel(unsigned int channel)
|
|||||||
d_dump_filename.append(".dat");
|
d_dump_filename.append(".dat");
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit);
|
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);
|
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() << std::endl;
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what() << std::endl;
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -625,6 +625,10 @@ int gps_l1_ca_dll_pll_c_aid_tracking_cc::general_work (int noutput_items __attri
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
@ -654,7 +658,7 @@ void gps_l1_ca_dll_pll_c_aid_tracking_cc::set_channel(unsigned int channel)
|
|||||||
d_dump_filename.append(".dat");
|
d_dump_filename.append(".dat");
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit);
|
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);
|
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() << std::endl;
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
|
@ -619,6 +619,10 @@ int gps_l1_ca_dll_pll_c_aid_tracking_fpga_sc::general_work (int noutput_items __
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
|
@ -628,6 +628,10 @@ int gps_l1_ca_dll_pll_c_aid_tracking_sc::general_work (int noutput_items __attri
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
@ -657,11 +661,11 @@ void gps_l1_ca_dll_pll_c_aid_tracking_sc::set_channel(unsigned int channel)
|
|||||||
d_dump_filename.append(".dat");
|
d_dump_filename.append(".dat");
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit);
|
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);
|
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() << std::endl;
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e->what() << std::endl;
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e->what();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -484,6 +484,10 @@ int Gps_L1_Ca_Dll_Pll_Tracking_cc::general_work (int noutput_items __attribute__
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter);
|
tmp_double = static_cast<double>(d_sample_counter);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
|
@ -510,6 +510,10 @@ int Gps_L1_Ca_Dll_Pll_Tracking_GPU_cc::general_work (int noutput_items __attribu
|
|||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_correlation_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
@ -538,11 +542,11 @@ void Gps_L1_Ca_Dll_Pll_Tracking_GPU_cc::set_channel(unsigned int channel)
|
|||||||
d_dump_filename.append(".dat");
|
d_dump_filename.append(".dat");
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit);
|
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);
|
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() << std::endl;
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure* e)
|
catch (const std::ifstream::failure* e)
|
||||||
{
|
{
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e->what() << std::endl;
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e->what();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -520,6 +520,10 @@ int Gps_L1_Ca_Tcp_Connector_Tracking_cc::general_work (int noutput_items __attri
|
|||||||
tmp_float = 0;
|
tmp_float = 0;
|
||||||
d_dump_file.write((char*)&tmp_float, sizeof(float));
|
d_dump_file.write((char*)&tmp_float, sizeof(float));
|
||||||
d_dump_file.write((char*)&d_sample_counter_seconds, sizeof(double));
|
d_dump_file.write((char*)&d_sample_counter_seconds, sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
}
|
}
|
||||||
catch (const std::ifstream::failure &e)
|
catch (const std::ifstream::failure &e)
|
||||||
{
|
{
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file gps_l2_m_dll_pll_tracking_cc.cc
|
* \file gps_l2_m_dll_pll_tracking_cc.cc
|
||||||
* \brief Implementation of a code DLL + carrier PLL tracking block
|
* \brief Implementation of a code DLL + carrier PLL tracking block for GPS L2C
|
||||||
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
* \author Carlos Aviles, 2010. carlos.avilesr(at)googlemail.com
|
||||||
* Javier Arribas, 2011. jarribas(at)cttc.es
|
* Javier Arribas, 2011. jarribas(at)cttc.es
|
||||||
*
|
*
|
||||||
@ -87,7 +87,6 @@ void gps_l2_m_dll_pll_tracking_cc::forecast (int noutput_items,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
gps_l2_m_dll_pll_tracking_cc::gps_l2_m_dll_pll_tracking_cc(
|
gps_l2_m_dll_pll_tracking_cc::gps_l2_m_dll_pll_tracking_cc(
|
||||||
long if_freq,
|
long if_freq,
|
||||||
long fs_in,
|
long fs_in,
|
||||||
@ -131,9 +130,9 @@ gps_l2_m_dll_pll_tracking_cc::gps_l2_m_dll_pll_tracking_cc(
|
|||||||
d_n_correlator_taps = 3; // Early, Prompt, and Late
|
d_n_correlator_taps = 3; // Early, Prompt, and Late
|
||||||
d_correlator_outs = static_cast<gr_complex*>(volk_gnsssdr_malloc(d_n_correlator_taps*sizeof(gr_complex), volk_gnsssdr_get_alignment()));
|
d_correlator_outs = static_cast<gr_complex*>(volk_gnsssdr_malloc(d_n_correlator_taps*sizeof(gr_complex), volk_gnsssdr_get_alignment()));
|
||||||
for (int n = 0; n < d_n_correlator_taps; n++)
|
for (int n = 0; n < d_n_correlator_taps; n++)
|
||||||
{
|
{
|
||||||
d_correlator_outs[n] = gr_complex(0,0);
|
d_correlator_outs[n] = gr_complex(0,0);
|
||||||
}
|
}
|
||||||
d_local_code_shift_chips = static_cast<float*>(volk_gnsssdr_malloc(d_n_correlator_taps*sizeof(float), volk_gnsssdr_get_alignment()));
|
d_local_code_shift_chips = static_cast<float*>(volk_gnsssdr_malloc(d_n_correlator_taps*sizeof(float), volk_gnsssdr_get_alignment()));
|
||||||
// Set TAPs delay values [chips]
|
// Set TAPs delay values [chips]
|
||||||
d_local_code_shift_chips[0] = - d_early_late_spc_chips;
|
d_local_code_shift_chips[0] = - d_early_late_spc_chips;
|
||||||
@ -222,9 +221,9 @@ void gps_l2_m_dll_pll_tracking_cc::start_tracking()
|
|||||||
double corrected_acq_phase_samples, delay_correction_samples;
|
double corrected_acq_phase_samples, delay_correction_samples;
|
||||||
corrected_acq_phase_samples = fmod((d_acq_code_phase_samples + T_prn_diff_seconds * N_prn_diff * static_cast<double>(d_fs_in)), T_prn_true_samples);
|
corrected_acq_phase_samples = fmod((d_acq_code_phase_samples + T_prn_diff_seconds * N_prn_diff * static_cast<double>(d_fs_in)), T_prn_true_samples);
|
||||||
if (corrected_acq_phase_samples < 0)
|
if (corrected_acq_phase_samples < 0)
|
||||||
{
|
{
|
||||||
corrected_acq_phase_samples = T_prn_mod_samples + corrected_acq_phase_samples;
|
corrected_acq_phase_samples = T_prn_mod_samples + corrected_acq_phase_samples;
|
||||||
}
|
}
|
||||||
delay_correction_samples = d_acq_code_phase_samples - corrected_acq_phase_samples;
|
delay_correction_samples = d_acq_code_phase_samples - corrected_acq_phase_samples;
|
||||||
|
|
||||||
d_acq_code_phase_samples = corrected_acq_phase_samples;
|
d_acq_code_phase_samples = corrected_acq_phase_samples;
|
||||||
@ -241,9 +240,9 @@ void gps_l2_m_dll_pll_tracking_cc::start_tracking()
|
|||||||
|
|
||||||
multicorrelator_cpu.set_local_code_and_taps(static_cast<int>(GPS_L2_M_CODE_LENGTH_CHIPS), d_ca_code, d_local_code_shift_chips);
|
multicorrelator_cpu.set_local_code_and_taps(static_cast<int>(GPS_L2_M_CODE_LENGTH_CHIPS), d_ca_code, d_local_code_shift_chips);
|
||||||
for (int n = 0; n < d_n_correlator_taps; n++)
|
for (int n = 0; n < d_n_correlator_taps; n++)
|
||||||
{
|
{
|
||||||
d_correlator_outs[n] = gr_complex(0,0);
|
d_correlator_outs[n] = gr_complex(0,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
d_carrier_lock_fail_counter = 0;
|
d_carrier_lock_fail_counter = 0;
|
||||||
d_rem_code_phase_samples = 0;
|
d_rem_code_phase_samples = 0;
|
||||||
@ -265,10 +264,11 @@ void gps_l2_m_dll_pll_tracking_cc::start_tracking()
|
|||||||
d_enable_tracking = true;
|
d_enable_tracking = true;
|
||||||
|
|
||||||
LOG(INFO) << "GPS L2CM PULL-IN Doppler [Hz]=" << d_carrier_doppler_hz
|
LOG(INFO) << "GPS L2CM PULL-IN Doppler [Hz]=" << d_carrier_doppler_hz
|
||||||
<< " Code Phase correction [samples]=" << delay_correction_samples
|
<< " Code Phase correction [samples]=" << delay_correction_samples
|
||||||
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
<< " PULL-IN Code Phase [samples]=" << d_acq_code_phase_samples;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
gps_l2_m_dll_pll_tracking_cc::~gps_l2_m_dll_pll_tracking_cc()
|
gps_l2_m_dll_pll_tracking_cc::~gps_l2_m_dll_pll_tracking_cc()
|
||||||
{
|
{
|
||||||
d_dump_file.close();
|
d_dump_file.close();
|
||||||
@ -282,7 +282,6 @@ gps_l2_m_dll_pll_tracking_cc::~gps_l2_m_dll_pll_tracking_cc()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int gps_l2_m_dll_pll_tracking_cc::general_work (int noutput_items __attribute__((unused)), gr_vector_int &ninput_items __attribute__((unused)),
|
int gps_l2_m_dll_pll_tracking_cc::general_work (int noutput_items __attribute__((unused)), gr_vector_int &ninput_items __attribute__((unused)),
|
||||||
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)
|
||||||
{
|
{
|
||||||
@ -300,230 +299,231 @@ int gps_l2_m_dll_pll_tracking_cc::general_work (int noutput_items __attribute__(
|
|||||||
Gnss_Synchro **out = (Gnss_Synchro **) &output_items[0];
|
Gnss_Synchro **out = (Gnss_Synchro **) &output_items[0];
|
||||||
|
|
||||||
if (d_enable_tracking == true)
|
if (d_enable_tracking == true)
|
||||||
{
|
|
||||||
// Fill the acquisition data
|
|
||||||
current_synchro_data = *d_acquisition_gnss_synchro;
|
|
||||||
// Receiver signal alignment
|
|
||||||
if (d_pull_in == true)
|
|
||||||
{
|
{
|
||||||
int samples_offset;
|
// Fill the acquisition data
|
||||||
double acq_trk_shif_correction_samples;
|
current_synchro_data = *d_acquisition_gnss_synchro;
|
||||||
int acq_to_trk_delay_samples;
|
// Receiver signal alignment
|
||||||
acq_to_trk_delay_samples = d_sample_counter - d_acq_sample_stamp;
|
if (d_pull_in == true)
|
||||||
acq_trk_shif_correction_samples = d_current_prn_length_samples - fmod(static_cast<float>(acq_to_trk_delay_samples), static_cast<float>(d_current_prn_length_samples));
|
{
|
||||||
samples_offset = round(d_acq_code_phase_samples + acq_trk_shif_correction_samples);
|
int samples_offset;
|
||||||
current_synchro_data.Tracking_sample_counter = d_sample_counter + samples_offset;
|
double acq_trk_shif_correction_samples;
|
||||||
d_sample_counter = d_sample_counter + samples_offset; // count for the processed samples
|
int acq_to_trk_delay_samples;
|
||||||
d_pull_in = false;
|
acq_to_trk_delay_samples = d_sample_counter - d_acq_sample_stamp;
|
||||||
// take into account the carrier cycles accumulated in the pull in signal alignment
|
acq_trk_shif_correction_samples = d_current_prn_length_samples - fmod(static_cast<float>(acq_to_trk_delay_samples), static_cast<float>(d_current_prn_length_samples));
|
||||||
d_acc_carrier_phase_rad -= d_carrier_phase_step_rad * samples_offset;
|
samples_offset = round(d_acq_code_phase_samples + acq_trk_shif_correction_samples);
|
||||||
|
current_synchro_data.Tracking_sample_counter = d_sample_counter + samples_offset;
|
||||||
|
d_sample_counter = d_sample_counter + samples_offset; // count for the processed samples
|
||||||
|
d_pull_in = false;
|
||||||
|
// take into account the carrier cycles accumulated in the pull in signal alignment
|
||||||
|
d_acc_carrier_phase_rad -= d_carrier_phase_step_rad * samples_offset;
|
||||||
|
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
||||||
|
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
||||||
|
current_synchro_data.fs = d_fs_in;
|
||||||
|
current_synchro_data.correlation_length_ms = 20;
|
||||||
|
*out[0] = current_synchro_data;
|
||||||
|
consume_each(samples_offset); // shift input to perform alignment with local replica
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ################# CARRIER WIPEOFF AND CORRELATORS ##############################
|
||||||
|
// perform carrier wipe-off and compute Early, Prompt and Late correlation
|
||||||
|
multicorrelator_cpu.set_input_output_vectors(d_correlator_outs, in);
|
||||||
|
multicorrelator_cpu.Carrier_wipeoff_multicorrelator_resampler(d_rem_carr_phase_rad,
|
||||||
|
d_carrier_phase_step_rad,
|
||||||
|
d_rem_code_phase_chips,
|
||||||
|
d_code_phase_step_chips,
|
||||||
|
d_current_prn_length_samples);
|
||||||
|
|
||||||
|
// ################## PLL ##########################################################
|
||||||
|
// PLL discriminator
|
||||||
|
// Update PLL discriminator [rads/Ti -> Secs/Ti]
|
||||||
|
carr_error_hz = pll_cloop_two_quadrant_atan(d_correlator_outs[1]) / GPS_L2_TWO_PI;
|
||||||
|
// Carrier discriminator filter
|
||||||
|
carr_error_filt_hz = d_carrier_loop_filter.get_carrier_nco(carr_error_hz);
|
||||||
|
// New carrier Doppler frequency estimation
|
||||||
|
d_carrier_doppler_hz = d_acq_carrier_doppler_hz + carr_error_filt_hz;
|
||||||
|
// New code Doppler frequency estimation
|
||||||
|
d_code_freq_chips = GPS_L2_M_CODE_RATE_HZ + ((d_carrier_doppler_hz * GPS_L2_M_CODE_RATE_HZ) / GPS_L2_FREQ_HZ);
|
||||||
|
|
||||||
|
// ################## DLL ##########################################################
|
||||||
|
// DLL discriminator
|
||||||
|
code_error_chips = dll_nc_e_minus_l_normalized(d_correlator_outs[0], d_correlator_outs[2]); // [chips/Ti]
|
||||||
|
// Code discriminator filter
|
||||||
|
code_error_filt_chips = d_code_loop_filter.get_code_nco(code_error_chips); //[chips/second]
|
||||||
|
double T_chip_seconds = 1.0 / static_cast<double>(d_code_freq_chips);
|
||||||
|
double T_prn_seconds = T_chip_seconds * GPS_L2_M_CODE_LENGTH_CHIPS;
|
||||||
|
double code_error_filt_secs = (T_prn_seconds * code_error_filt_chips*T_chip_seconds); //[seconds]
|
||||||
|
//double code_error_filt_secs = (GPS_L2_M_PERIOD * code_error_filt_chips) / GPS_L2_M_CODE_RATE_HZ; //[seconds]
|
||||||
|
|
||||||
|
// ################## CARRIER AND CODE NCO BUFFER ALIGNEMENT #######################
|
||||||
|
// keep alignment parameters for the next input buffer
|
||||||
|
// Compute the next buffer length based in the new period of the PRN sequence and the code phase error estimation
|
||||||
|
double T_prn_samples = T_prn_seconds * static_cast<double>(d_fs_in);
|
||||||
|
double K_blk_samples = T_prn_samples + d_rem_code_phase_samples + code_error_filt_secs * static_cast<double>(d_fs_in);
|
||||||
|
d_current_prn_length_samples = round(K_blk_samples); // round to a discrete number of samples
|
||||||
|
|
||||||
|
//################### PLL COMMANDS #################################################
|
||||||
|
// carrier phase step (NCO phase increment per sample) [rads/sample]
|
||||||
|
d_carrier_phase_step_rad = GPS_L2_TWO_PI * d_carrier_doppler_hz / static_cast<double>(d_fs_in);
|
||||||
|
// remnant carrier phase to prevent overflow in the code NCO
|
||||||
|
d_rem_carr_phase_rad = d_rem_carr_phase_rad + d_carrier_phase_step_rad * d_current_prn_length_samples;
|
||||||
|
d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, GPS_L2_TWO_PI);
|
||||||
|
// carrier phase accumulator
|
||||||
|
d_acc_carrier_phase_rad -= d_carrier_phase_step_rad * d_current_prn_length_samples;
|
||||||
|
|
||||||
|
//################### DLL COMMANDS #################################################
|
||||||
|
// code phase step (Code resampler phase increment per sample) [chips/sample]
|
||||||
|
d_code_phase_step_chips = d_code_freq_chips / static_cast<double>(d_fs_in);
|
||||||
|
// remnant code phase [chips]
|
||||||
|
d_rem_code_phase_samples = K_blk_samples - d_current_prn_length_samples; // rounding error < 1 sample
|
||||||
|
d_rem_code_phase_chips = d_code_freq_chips * (d_rem_code_phase_samples / static_cast<double>(d_fs_in));
|
||||||
|
|
||||||
|
// ####### CN0 ESTIMATION AND LOCK DETECTORS ######
|
||||||
|
if (d_cn0_estimation_counter < GPS_L2M_CN0_ESTIMATION_SAMPLES)
|
||||||
|
{
|
||||||
|
// fill buffer with prompt correlator output values
|
||||||
|
d_Prompt_buffer[d_cn0_estimation_counter] = d_correlator_outs[1];
|
||||||
|
d_cn0_estimation_counter++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
d_cn0_estimation_counter = 0;
|
||||||
|
// Code lock indicator
|
||||||
|
d_CN0_SNV_dB_Hz = cn0_svn_estimator(d_Prompt_buffer, GPS_L2M_CN0_ESTIMATION_SAMPLES, d_fs_in, GPS_L2_M_CODE_LENGTH_CHIPS);
|
||||||
|
// Carrier lock indicator
|
||||||
|
d_carrier_lock_test = carrier_lock_detector(d_Prompt_buffer, GPS_L2M_CN0_ESTIMATION_SAMPLES);
|
||||||
|
// Loss of lock detection
|
||||||
|
if (d_carrier_lock_test < d_carrier_lock_threshold or d_CN0_SNV_dB_Hz < GPS_L2M_MINIMUM_VALID_CN0)
|
||||||
|
{
|
||||||
|
d_carrier_lock_fail_counter++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (d_carrier_lock_fail_counter > 0) d_carrier_lock_fail_counter--;
|
||||||
|
}
|
||||||
|
if (d_carrier_lock_fail_counter > GPS_L2M_MAXIMUM_LOCK_FAIL_COUNTER)
|
||||||
|
{
|
||||||
|
std::cout << "Loss of lock in channel " << d_channel << "!" << std::endl;
|
||||||
|
LOG(INFO) << "Loss of lock in channel " << d_channel << "!";
|
||||||
|
this->message_port_pub(pmt::mp("events"), pmt::from_long(3));//3 -> loss of lock
|
||||||
|
d_carrier_lock_fail_counter = 0;
|
||||||
|
d_enable_tracking = false; // TODO: check if disabling tracking is consistent with the channel state machine
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ########### Output the tracking data to navigation and PVT ##########
|
||||||
|
current_synchro_data.Prompt_I = static_cast<double>(d_correlator_outs[1].real());
|
||||||
|
current_synchro_data.Prompt_Q = static_cast<double>(d_correlator_outs[1].imag());
|
||||||
|
current_synchro_data.Tracking_sample_counter = d_sample_counter + d_current_prn_length_samples;
|
||||||
|
current_synchro_data.Code_phase_samples = d_rem_code_phase_samples;
|
||||||
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
||||||
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
||||||
current_synchro_data.fs = d_fs_in;
|
current_synchro_data.CN0_dB_hz = d_CN0_SNV_dB_Hz;
|
||||||
|
current_synchro_data.Flag_valid_symbol_output = true;
|
||||||
current_synchro_data.correlation_length_ms = 20;
|
current_synchro_data.correlation_length_ms = 20;
|
||||||
*out[0] = current_synchro_data;
|
|
||||||
consume_each(samples_offset); // shift input to perform alignment with local replica
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ################# CARRIER WIPEOFF AND CORRELATORS ##############################
|
|
||||||
// perform carrier wipe-off and compute Early, Prompt and Late correlation
|
|
||||||
multicorrelator_cpu.set_input_output_vectors(d_correlator_outs, in);
|
|
||||||
multicorrelator_cpu.Carrier_wipeoff_multicorrelator_resampler(d_rem_carr_phase_rad,
|
|
||||||
d_carrier_phase_step_rad,
|
|
||||||
d_rem_code_phase_chips,
|
|
||||||
d_code_phase_step_chips,
|
|
||||||
d_current_prn_length_samples);
|
|
||||||
|
|
||||||
// ################## PLL ##########################################################
|
|
||||||
// PLL discriminator
|
|
||||||
// Update PLL discriminator [rads/Ti -> Secs/Ti]
|
|
||||||
carr_error_hz = pll_cloop_two_quadrant_atan(d_correlator_outs[1]) / GPS_L2_TWO_PI;
|
|
||||||
// Carrier discriminator filter
|
|
||||||
carr_error_filt_hz = d_carrier_loop_filter.get_carrier_nco(carr_error_hz);
|
|
||||||
// New carrier Doppler frequency estimation
|
|
||||||
d_carrier_doppler_hz = d_acq_carrier_doppler_hz + carr_error_filt_hz;
|
|
||||||
// New code Doppler frequency estimation
|
|
||||||
d_code_freq_chips = GPS_L2_M_CODE_RATE_HZ + ((d_carrier_doppler_hz * GPS_L2_M_CODE_RATE_HZ) / GPS_L2_FREQ_HZ);
|
|
||||||
|
|
||||||
// ################## DLL ##########################################################
|
|
||||||
// DLL discriminator
|
|
||||||
code_error_chips = dll_nc_e_minus_l_normalized(d_correlator_outs[0], d_correlator_outs[2]); // [chips/Ti]
|
|
||||||
// Code discriminator filter
|
|
||||||
code_error_filt_chips = d_code_loop_filter.get_code_nco(code_error_chips); //[chips/second]
|
|
||||||
double T_chip_seconds = 1.0 / static_cast<double>(d_code_freq_chips);
|
|
||||||
double T_prn_seconds = T_chip_seconds * GPS_L2_M_CODE_LENGTH_CHIPS;
|
|
||||||
double code_error_filt_secs = (T_prn_seconds * code_error_filt_chips*T_chip_seconds); //[seconds]
|
|
||||||
//double code_error_filt_secs = (GPS_L2_M_PERIOD * code_error_filt_chips) / GPS_L2_M_CODE_RATE_HZ; //[seconds]
|
|
||||||
|
|
||||||
// ################## CARRIER AND CODE NCO BUFFER ALIGNEMENT #######################
|
|
||||||
// keep alignment parameters for the next input buffer
|
|
||||||
// Compute the next buffer length based in the new period of the PRN sequence and the code phase error estimation
|
|
||||||
double T_prn_samples = T_prn_seconds * static_cast<double>(d_fs_in);
|
|
||||||
double K_blk_samples = T_prn_samples + d_rem_code_phase_samples + code_error_filt_secs * static_cast<double>(d_fs_in);
|
|
||||||
d_current_prn_length_samples = round(K_blk_samples); // round to a discrete number of samples
|
|
||||||
|
|
||||||
//################### PLL COMMANDS #################################################
|
|
||||||
// carrier phase step (NCO phase increment per sample) [rads/sample]
|
|
||||||
d_carrier_phase_step_rad = GPS_L2_TWO_PI * d_carrier_doppler_hz / static_cast<double>(d_fs_in);
|
|
||||||
// remnant carrier phase to prevent overflow in the code NCO
|
|
||||||
d_rem_carr_phase_rad = d_rem_carr_phase_rad + d_carrier_phase_step_rad * d_current_prn_length_samples;
|
|
||||||
d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, GPS_L2_TWO_PI);
|
|
||||||
// carrier phase accumulator
|
|
||||||
d_acc_carrier_phase_rad -= d_carrier_phase_step_rad * d_current_prn_length_samples;
|
|
||||||
|
|
||||||
//################### DLL COMMANDS #################################################
|
|
||||||
// code phase step (Code resampler phase increment per sample) [chips/sample]
|
|
||||||
d_code_phase_step_chips = d_code_freq_chips / static_cast<double>(d_fs_in);
|
|
||||||
// remnant code phase [chips]
|
|
||||||
d_rem_code_phase_samples = K_blk_samples - d_current_prn_length_samples; // rounding error < 1 sample
|
|
||||||
d_rem_code_phase_chips = d_code_freq_chips * (d_rem_code_phase_samples / static_cast<double>(d_fs_in));
|
|
||||||
|
|
||||||
// ####### CN0 ESTIMATION AND LOCK DETECTORS ######
|
|
||||||
if (d_cn0_estimation_counter < GPS_L2M_CN0_ESTIMATION_SAMPLES)
|
|
||||||
{
|
|
||||||
// fill buffer with prompt correlator output values
|
|
||||||
d_Prompt_buffer[d_cn0_estimation_counter] = d_correlator_outs[1];
|
|
||||||
d_cn0_estimation_counter++;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
d_cn0_estimation_counter = 0;
|
|
||||||
// Code lock indicator
|
|
||||||
d_CN0_SNV_dB_Hz = cn0_svn_estimator(d_Prompt_buffer, GPS_L2M_CN0_ESTIMATION_SAMPLES, d_fs_in, GPS_L2_M_CODE_LENGTH_CHIPS);
|
|
||||||
// Carrier lock indicator
|
|
||||||
d_carrier_lock_test = carrier_lock_detector(d_Prompt_buffer, GPS_L2M_CN0_ESTIMATION_SAMPLES);
|
|
||||||
// Loss of lock detection
|
|
||||||
if (d_carrier_lock_test < d_carrier_lock_threshold or d_CN0_SNV_dB_Hz < GPS_L2M_MINIMUM_VALID_CN0)
|
|
||||||
{
|
|
||||||
d_carrier_lock_fail_counter++;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (d_carrier_lock_fail_counter > 0) d_carrier_lock_fail_counter--;
|
|
||||||
}
|
|
||||||
if (d_carrier_lock_fail_counter > GPS_L2M_MAXIMUM_LOCK_FAIL_COUNTER)
|
|
||||||
{
|
|
||||||
std::cout << "Loss of lock in channel " << d_channel << "!" << std::endl;
|
|
||||||
LOG(INFO) << "Loss of lock in channel " << d_channel << "!";
|
|
||||||
this->message_port_pub(pmt::mp("events"), pmt::from_long(3));//3 -> loss of lock
|
|
||||||
d_carrier_lock_fail_counter = 0;
|
|
||||||
d_enable_tracking = false; // TODO: check if disabling tracking is consistent with the channel state machine
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// ########### Output the tracking data to navigation and PVT ##########
|
|
||||||
current_synchro_data.Prompt_I = static_cast<double>(d_correlator_outs[1].real());
|
|
||||||
current_synchro_data.Prompt_Q = static_cast<double>(d_correlator_outs[1].imag());
|
|
||||||
current_synchro_data.Tracking_sample_counter = d_sample_counter + d_current_prn_length_samples;
|
|
||||||
current_synchro_data.Code_phase_samples = d_rem_code_phase_samples;
|
|
||||||
current_synchro_data.Carrier_phase_rads = d_acc_carrier_phase_rad;
|
|
||||||
current_synchro_data.Carrier_Doppler_hz = d_carrier_doppler_hz;
|
|
||||||
current_synchro_data.CN0_dB_hz = d_CN0_SNV_dB_Hz;
|
|
||||||
current_synchro_data.Flag_valid_symbol_output = true;
|
|
||||||
current_synchro_data.correlation_length_ms = 20;
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
|
||||||
for (int n = 0; n < d_n_correlator_taps; n++)
|
|
||||||
{
|
{
|
||||||
d_correlator_outs[n] = gr_complex(0,0);
|
for (int n = 0; n < d_n_correlator_taps; n++)
|
||||||
|
{
|
||||||
|
d_correlator_outs[n] = gr_complex(0,0);
|
||||||
|
}
|
||||||
|
current_synchro_data.Tracking_sample_counter = d_sample_counter + d_current_prn_length_samples;
|
||||||
|
current_synchro_data.correlation_length_ms = 20;
|
||||||
}
|
}
|
||||||
current_synchro_data.Tracking_sample_counter = d_sample_counter + d_current_prn_length_samples;
|
|
||||||
current_synchro_data.correlation_length_ms = 20;
|
|
||||||
}
|
|
||||||
//assign the GNURadio block output data
|
//assign the GNURadio block output data
|
||||||
current_synchro_data.fs = d_fs_in;
|
current_synchro_data.fs = d_fs_in;
|
||||||
*out[0] = current_synchro_data;
|
*out[0] = current_synchro_data;
|
||||||
|
|
||||||
if(d_dump)
|
if(d_dump)
|
||||||
{
|
|
||||||
// MULTIPLEXED FILE RECORDING - Record results to file
|
|
||||||
float prompt_I;
|
|
||||||
float prompt_Q;
|
|
||||||
float tmp_E, tmp_P, tmp_L;
|
|
||||||
double tmp_double;
|
|
||||||
prompt_I = d_correlator_outs[1].real();
|
|
||||||
prompt_Q = d_correlator_outs[1].imag();
|
|
||||||
tmp_E = std::abs<float>(d_correlator_outs[0]);
|
|
||||||
tmp_P = std::abs<float>(d_correlator_outs[1]);
|
|
||||||
tmp_L = std::abs<float>(d_correlator_outs[2]);
|
|
||||||
try
|
|
||||||
{
|
{
|
||||||
// EPR
|
// MULTIPLEXED FILE RECORDING - Record results to file
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_E), sizeof(float));
|
float prompt_I;
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_P), sizeof(float));
|
float prompt_Q;
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_L), sizeof(float));
|
float tmp_E, tmp_P, tmp_L;
|
||||||
// PROMPT I and Q (to analyze navigation symbols)
|
double tmp_double;
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&prompt_I), sizeof(float));
|
prompt_I = d_correlator_outs[1].real();
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&prompt_Q), sizeof(float));
|
prompt_Q = d_correlator_outs[1].imag();
|
||||||
// PRN start sample stamp
|
tmp_E = std::abs<float>(d_correlator_outs[0]);
|
||||||
//tmp_float=(float)d_sample_counter;
|
tmp_P = std::abs<float>(d_correlator_outs[1]);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_sample_counter), sizeof(unsigned long int));
|
tmp_L = std::abs<float>(d_correlator_outs[2]);
|
||||||
// accumulated carrier phase
|
try
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_acc_carrier_phase_rad), sizeof(double));
|
{
|
||||||
|
// EPR
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_E), sizeof(float));
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_P), sizeof(float));
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_L), sizeof(float));
|
||||||
|
// PROMPT I and Q (to analyze navigation symbols)
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prompt_I), sizeof(float));
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prompt_Q), sizeof(float));
|
||||||
|
// PRN start sample stamp
|
||||||
|
//tmp_float=(float)d_sample_counter;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&d_sample_counter), sizeof(unsigned long int));
|
||||||
|
// accumulated carrier phase
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&d_acc_carrier_phase_rad), sizeof(double));
|
||||||
|
|
||||||
// carrier and code frequency
|
// carrier and code frequency
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_doppler_hz), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_doppler_hz), sizeof(double));
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_code_freq_chips), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&d_code_freq_chips), sizeof(double));
|
||||||
|
|
||||||
//PLL commands
|
//PLL commands
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&carr_error_hz), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&carr_error_hz), sizeof(double));
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_doppler_hz), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_doppler_hz), sizeof(double));
|
||||||
|
|
||||||
//DLL commands
|
//DLL commands
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&code_error_chips), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&code_error_chips), sizeof(double));
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&code_error_filt_chips), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&code_error_filt_chips), sizeof(double));
|
||||||
|
|
||||||
// CN0 and carrier lock test
|
// CN0 and carrier lock test
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_CN0_SNV_dB_Hz), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&d_CN0_SNV_dB_Hz), sizeof(double));
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_lock_test), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&d_carrier_lock_test), sizeof(double));
|
||||||
|
|
||||||
// AUX vars (for debug purposes)
|
// AUX vars (for debug purposes)
|
||||||
tmp_double = d_rem_code_phase_samples;
|
tmp_double = d_rem_code_phase_samples;
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
tmp_double = static_cast<double>(d_sample_counter + d_current_prn_length_samples);
|
||||||
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
d_dump_file.write(reinterpret_cast<char*>(&tmp_double), sizeof(double));
|
||||||
|
|
||||||
|
// PRN
|
||||||
|
unsigned int prn_ = d_acquisition_gnss_synchro->PRN;
|
||||||
|
d_dump_file.write(reinterpret_cast<char*>(&prn_), sizeof(unsigned int));
|
||||||
|
}
|
||||||
|
catch (std::ifstream::failure& e)
|
||||||
|
{
|
||||||
|
LOG(WARNING) << "Exception writing trk dump file " << e.what();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
catch (std::ifstream::failure& e)
|
|
||||||
{
|
|
||||||
LOG(WARNING) << "Exception writing trk dump file " << e.what();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
consume_each(d_current_prn_length_samples); // this is necessary in gr::block derivates
|
consume_each(d_current_prn_length_samples); // this is necessary in gr::block derivates
|
||||||
d_sample_counter += d_current_prn_length_samples; // count for the processed samples
|
d_sample_counter += d_current_prn_length_samples; // count for the processed samples
|
||||||
return 1; // output tracking result ALWAYS even in the case of d_enable_tracking==false
|
return 1; // output tracking result ALWAYS even in the case of d_enable_tracking==false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void gps_l2_m_dll_pll_tracking_cc::set_channel(unsigned int channel)
|
void gps_l2_m_dll_pll_tracking_cc::set_channel(unsigned int channel)
|
||||||
{
|
{
|
||||||
d_channel = channel;
|
d_channel = channel;
|
||||||
LOG(INFO) << "Tracking Channel set to " << d_channel;
|
LOG(INFO) << "Tracking Channel set to " << d_channel;
|
||||||
// ############# ENABLE DATA FILE LOG #################
|
// ############# ENABLE DATA FILE LOG #################
|
||||||
if (d_dump == true)
|
if (d_dump == true)
|
||||||
{
|
|
||||||
if (d_dump_file.is_open() == false)
|
|
||||||
{
|
{
|
||||||
try
|
if (d_dump_file.is_open() == false)
|
||||||
{
|
{
|
||||||
d_dump_filename.append(boost::lexical_cast<std::string>(d_channel));
|
try
|
||||||
d_dump_filename.append(".dat");
|
{
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit);
|
d_dump_filename.append(boost::lexical_cast<std::string>(d_channel));
|
||||||
d_dump_file.open(d_dump_filename.c_str(), std::ios::out | std::ios::binary);
|
d_dump_filename.append(".dat");
|
||||||
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
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);
|
||||||
catch (std::ifstream::failure& e)
|
LOG(INFO) << "Tracking dump enabled on channel " << d_channel << " Log file: " << d_dump_filename.c_str();
|
||||||
{
|
}
|
||||||
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
catch (std::ifstream::failure& e)
|
||||||
}
|
{
|
||||||
|
LOG(WARNING) << "channel " << d_channel << " Exception opening trk dump file " << e.what();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void gps_l2_m_dll_pll_tracking_cc::set_gnss_synchro(Gnss_Synchro* p_gnss_synchro)
|
void gps_l2_m_dll_pll_tracking_cc::set_gnss_synchro(Gnss_Synchro* p_gnss_synchro)
|
||||||
{
|
{
|
||||||
d_acquisition_gnss_synchro = p_gnss_synchro;
|
d_acquisition_gnss_synchro = p_gnss_synchro;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* \file gps_l2_m_dll_pll_tracking_cc.h
|
* \file gps_l2_m_dll_pll_tracking_cc.h
|
||||||
* \brief Interface of a code DLL + carrier PLL tracking block
|
* \brief Interface of a code DLL + carrier PLL tracking block for GPS L2C
|
||||||
* \author Javier Arribas, 2015. jarribas(at)cttc.es
|
* \author Javier Arribas, 2015. jarribas(at)cttc.es
|
||||||
*
|
*
|
||||||
* Code DLL + carrier PLL according to the algorithms described in:
|
* Code DLL + carrier PLL according to the algorithms described in:
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
% /*!
|
% /*!
|
||||||
% * \file galileo_l1_ca_dll_pll_vml_plot_sample_64bits.m
|
% * \file galileo_l1_ca_dll_pll_vml_plot_sample.m
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
||||||
% function and plot some internal variables
|
% function and plot some internal variables
|
||||||
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
||||||
@ -29,26 +29,28 @@
|
|||||||
% */
|
% */
|
||||||
close all;
|
close all;
|
||||||
clear all;
|
clear all;
|
||||||
samplingFreq = 20480000/4; %[Hz]
|
samplingFreq = 5000000; %[Hz]
|
||||||
channels=8;
|
channels = 7;
|
||||||
|
first_channel = 0;
|
||||||
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
||||||
path='/home/gnss/workspace/gnss-sdr/trunk/data/';
|
%path='/home/luis/dev/gnss-sdr/trunk/data/';
|
||||||
clear PRN_absolute_sample_start;
|
path = '/Users/carlesfernandez/git/cttc/build/';
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
tracking_log_path=[path 'veml_tracking_ch_' num2str(N-1) '.dat'];
|
tracking_log_path = [path 'track_ch' num2str(N+first_channel-1) '.dat'];
|
||||||
GNSS_tracking(N)= galileo_e1_dll_pll_veml_read_tracking_dump_32bits(tracking_log_path);
|
GNSS_tracking(N)= galileo_e1_dll_pll_veml_read_tracking_dump(tracking_log_path);
|
||||||
end
|
end
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
% GNSS-SDR format conversion to MATLAB GPS receiver
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
trackResults(N).status = 'T'; %fake track
|
trackResults(N).status = 'T'; %fake track
|
||||||
trackResults(N).codeFreq = GNSS_tracking(N).code_freq_hz.';
|
trackResults(N).codeFreq = GNSS_tracking(N).code_freq_hz.';
|
||||||
trackResults(N).carrFreq = GNSS_tracking(N).carrier_doppler_hz.';
|
trackResults(N).carrFreq = GNSS_tracking(N).carrier_doppler_hz.';
|
||||||
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
||||||
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
||||||
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
||||||
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
||||||
|
|
||||||
trackResults(N).I_P = GNSS_tracking(N).prompt_I.';
|
trackResults(N).I_P = GNSS_tracking(N).prompt_I.';
|
||||||
trackResults(N).Q_P = GNSS_tracking(N).prompt_Q.';
|
trackResults(N).Q_P = GNSS_tracking(N).prompt_Q.';
|
||||||
@ -61,7 +63,7 @@ for N=1:1:channels
|
|||||||
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
||||||
trackResults(N).Q_L = zeros(1,length(GNSS_tracking(N).L));
|
trackResults(N).Q_L = zeros(1,length(GNSS_tracking(N).L));
|
||||||
trackResults(N).Q_VL = zeros(1,length(GNSS_tracking(N).VL));
|
trackResults(N).Q_VL = zeros(1,length(GNSS_tracking(N).VL));
|
||||||
trackResults(N).PRN = N; %fake PRN
|
trackResults(N).PRN = GNSS_tracking(N).PRN.';
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
% Use original MATLAB tracking plot function
|
||||||
settings.numberOfChannels = channels;
|
settings.numberOfChannels = channels;
|
||||||
@ -69,25 +71,5 @@ for N=1:1:channels
|
|||||||
plotVEMLTracking(N,trackResults,settings)
|
plotVEMLTracking(N,trackResults,settings)
|
||||||
end
|
end
|
||||||
|
|
||||||
% for N=1:1:channels
|
|
||||||
% % figure;
|
|
||||||
% % plot([GNSS_tracking(N).E,GNSS_tracking(N).P,GNSS_tracking(N).L],'-*');
|
|
||||||
% % title(['Early, Prompt, and Late correlator absolute value output for channel ' num2str(N)']);
|
|
||||||
% % figure;
|
|
||||||
% % plot(GNSS_tracking(N).prompt_I,GNSS_tracking(N).prompt_Q,'+');
|
|
||||||
% % title(['Navigation constellation plot for channel ' num2str(N)]);
|
|
||||||
% % figure;
|
|
||||||
% %
|
|
||||||
% % plot(GNSS_tracking(N).prompt_Q,'r');
|
|
||||||
% % hold on;
|
|
||||||
% % plot(GNSS_tracking(N).prompt_I);
|
|
||||||
% % title(['Navigation symbols I(red) Q(blue) for channel ' num2str(N)]);
|
|
||||||
% %
|
|
||||||
% figure;
|
|
||||||
% t=0:4:length(GNSS_tracking(N).carrier_doppler_hz)*4-1;
|
|
||||||
% t=t/1000;
|
|
||||||
% plot(t,GNSS_tracking(N).carrier_doppler_hz/1000);
|
|
||||||
% xlabel('Time(s)');ylabel('Doppler(KHz)');title(['Doppler frequency channel ' num2str(N)]);
|
|
||||||
% end
|
|
||||||
|
|
||||||
|
|
@ -1,93 +0,0 @@
|
|||||||
% /*!
|
|
||||||
% * \file galileo_l1_ca_dll_pll_vml_plot_sample_64bits.m
|
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
|
||||||
% function and plot some internal variables
|
|
||||||
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% *
|
|
||||||
% * Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is a software defined Global Navigation
|
|
||||||
% * Satellite Systems receiver
|
|
||||||
% *
|
|
||||||
% * This file is part of GNSS-SDR.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is free software: you can redistribute it and/or modify
|
|
||||||
% * it under the terms of the GNU General Public License as published by
|
|
||||||
% * the Free Software Foundation, either version 3 of the License, or
|
|
||||||
% * at your option) any later version.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is distributed in the hope that it will be useful,
|
|
||||||
% * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
% * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
% * GNU General Public License for more details.
|
|
||||||
% *
|
|
||||||
% * You should have received a copy of the GNU General Public License
|
|
||||||
% * along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
% *
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% */
|
|
||||||
close all;
|
|
||||||
clear all;
|
|
||||||
samplingFreq = 64e6/8; %[Hz]
|
|
||||||
channels=1;
|
|
||||||
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
|
||||||
path='/home/luis/dev/gnss-sdr/trunk/data/';
|
|
||||||
clear PRN_absolute_sample_start;
|
|
||||||
for N=1:1:channels
|
|
||||||
tracking_log_path=[path 'veml_tracking_ch_' num2str(N-1) '.dat'];
|
|
||||||
GNSS_tracking(N)= galileo_e1_dll_pll_veml_read_tracking_dump(tracking_log_path);
|
|
||||||
end
|
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
|
||||||
|
|
||||||
for N=1:1:channels
|
|
||||||
trackResults(N).status='T'; %fake track
|
|
||||||
trackResults(N).codeFreq=GNSS_tracking(N).code_freq_hz.';
|
|
||||||
trackResults(N).carrFreq=GNSS_tracking(N).carrier_doppler_hz.';
|
|
||||||
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
|
||||||
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
|
||||||
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
|
||||||
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
|
||||||
|
|
||||||
trackResults(N).I_P=GNSS_tracking(N).prompt_I.';
|
|
||||||
trackResults(N).Q_P=GNSS_tracking(N).prompt_Q.';
|
|
||||||
|
|
||||||
trackResults(N).I_VE= GNSS_tracking(N).VE.';
|
|
||||||
trackResults(N).I_E= GNSS_tracking(N).E.';
|
|
||||||
trackResults(N).I_L = GNSS_tracking(N).L.';
|
|
||||||
trackResults(N).I_VL = GNSS_tracking(N).VL.';
|
|
||||||
trackResults(N).Q_VE = zeros(1,length(GNSS_tracking(N).VE));
|
|
||||||
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
|
||||||
trackResults(N).Q_L =zeros(1,length(GNSS_tracking(N).L));
|
|
||||||
trackResults(N).Q_VL =zeros(1,length(GNSS_tracking(N).VL));
|
|
||||||
trackResults(N).PRN=N; %fake PRN
|
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
|
||||||
settings.numberOfChannels=channels;
|
|
||||||
settings.msToProcess=length(GNSS_tracking(N).E)*4;
|
|
||||||
plotVEMLTracking(N,trackResults,settings)
|
|
||||||
end
|
|
||||||
|
|
||||||
% for N=1:1:channels
|
|
||||||
% % figure;
|
|
||||||
% % plot([GNSS_tracking(N).E,GNSS_tracking(N).P,GNSS_tracking(N).L],'-*');
|
|
||||||
% % title(['Early, Prompt, and Late correlator absolute value output for channel ' num2str(N)']);
|
|
||||||
% % figure;
|
|
||||||
% % plot(GNSS_tracking(N).prompt_I,GNSS_tracking(N).prompt_Q,'+');
|
|
||||||
% % title(['Navigation constellation plot for channel ' num2str(N)]);
|
|
||||||
% % figure;
|
|
||||||
% %
|
|
||||||
% % plot(GNSS_tracking(N).prompt_Q,'r');
|
|
||||||
% % hold on;
|
|
||||||
% % plot(GNSS_tracking(N).prompt_I);
|
|
||||||
% % title(['Navigation symbols I(red) Q(blue) for channel ' num2str(N)]);
|
|
||||||
% %
|
|
||||||
% figure;
|
|
||||||
% t=0:4:length(GNSS_tracking(N).carrier_doppler_hz)*4-1;
|
|
||||||
% t=t/1000;
|
|
||||||
% plot(t,GNSS_tracking(N).carrier_doppler_hz/1000);
|
|
||||||
% xlabel('Time(s)');ylabel('Doppler(KHz)');title(['Doppler frequency channel ' num2str(N)]);
|
|
||||||
% end
|
|
||||||
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
% /*!
|
% /*!
|
||||||
% * \file galileo_e5a_dll_pll_plot_sample_64bits.m
|
% * \file galileo_e5a_dll_pll_plot_sample.m
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
||||||
% function and plot some internal variables
|
% function and plot some internal variables
|
||||||
% * \author Javier Arribas, Marc Sales 2014. jarribas(at)cttc.es
|
% * \author Javier Arribas, Marc Sales 2014. jarribas(at)cttc.es
|
||||||
@ -30,41 +30,43 @@
|
|||||||
% */
|
% */
|
||||||
close all;
|
close all;
|
||||||
clear all;
|
clear all;
|
||||||
samplingFreq = 64e6/32; %[Hz]
|
samplingFreq = 5000000; %[Hz]
|
||||||
channels=1;
|
channels = 1;
|
||||||
|
first_channel = 30;
|
||||||
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
||||||
path='/home/marc/git/gnss-sdr/data/';
|
%path='/home/marc/git/gnss-sdr/data/';
|
||||||
clear PRN_absolute_sample_start;
|
path = '/Users/carlesfernandez/git/cttc/build/';
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
tracking_log_path=[path 'e5a_tracking_ch_' num2str(N-1) '.dat'];
|
tracking_log_path = [path 'tracking_ch_' num2str(N+first_channel-1) '.dat'];
|
||||||
GNSS_tracking(N)= gps_l1_ca_dll_pll_read_tracking_dump_64bits(tracking_log_path);
|
GNSS_tracking(N)= gps_l1_ca_dll_pll_read_tracking_dump(tracking_log_path);
|
||||||
end
|
end
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
% GNSS-SDR format conversion to MATLAB GPS receiver
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
trackResults(N).status='T'; %fake track
|
trackResults(N).status = 'T'; %fake track
|
||||||
trackResults(N).codeFreq=GNSS_tracking(N).code_freq_hz.';
|
trackResults(N).codeFreq = GNSS_tracking(N).code_freq_hz.';
|
||||||
trackResults(N).carrFreq=GNSS_tracking(N).carrier_doppler_hz.';
|
trackResults(N).carrFreq = GNSS_tracking(N).carrier_doppler_hz.';
|
||||||
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
||||||
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
||||||
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
||||||
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
||||||
|
|
||||||
trackResults(N).I_PN=GNSS_tracking(N).prompt_I.';
|
trackResults(N).I_PN = GNSS_tracking(N).prompt_I.';
|
||||||
trackResults(N).Q_PN=GNSS_tracking(N).prompt_Q.';
|
trackResults(N).Q_PN = GNSS_tracking(N).prompt_Q.';
|
||||||
trackResults(N).Q_P=zeros(1,length(GNSS_tracking(N).P));
|
trackResults(N).Q_P = zeros(1,length(GNSS_tracking(N).P));
|
||||||
trackResults(N).I_P=GNSS_tracking(N).P.';
|
trackResults(N).I_P = GNSS_tracking(N).P.';
|
||||||
|
|
||||||
trackResults(N).I_E= GNSS_tracking(N).E.';
|
trackResults(N).I_E = GNSS_tracking(N).E.';
|
||||||
trackResults(N).I_L = GNSS_tracking(N).L.';
|
trackResults(N).I_L = GNSS_tracking(N).L.';
|
||||||
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
||||||
trackResults(N).Q_L =zeros(1,length(GNSS_tracking(N).E));
|
trackResults(N).Q_L = zeros(1,length(GNSS_tracking(N).E));
|
||||||
trackResults(N).PRN=N; %fake PRN
|
trackResults(N).PRN = GNSS_tracking(N).PRN.';
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
% Use original MATLAB tracking plot function
|
||||||
settings.numberOfChannels=channels;
|
settings.numberOfChannels = channels;
|
||||||
settings.msToProcess=length(GNSS_tracking(N).E);
|
settings.msToProcess = length(GNSS_tracking(N).E);
|
||||||
plotTrackingE5a(N,trackResults,settings)
|
plotTrackingE5a(N,trackResults,settings)
|
||||||
end
|
end
|
||||||
|
|
@ -1,88 +0,0 @@
|
|||||||
% /*!
|
|
||||||
% * \file gps_l1_ca_dll_fll_pll_plot_sample.m
|
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
|
||||||
% function and plot some internal variables
|
|
||||||
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% *
|
|
||||||
% * Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is a software defined Global Navigation
|
|
||||||
% * Satellite Systems receiver
|
|
||||||
% *
|
|
||||||
% * This file is part of GNSS-SDR.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is free software: you can redistribute it and/or modify
|
|
||||||
% * it under the terms of the GNU General Public License as published by
|
|
||||||
% * the Free Software Foundation, either version 3 of the License, or
|
|
||||||
% * at your option) any later version.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is distributed in the hope that it will be useful,
|
|
||||||
% * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
% * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
% * GNU General Public License for more details.
|
|
||||||
% *
|
|
||||||
% * You should have received a copy of the GNU General Public License
|
|
||||||
% * along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
% *
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% */
|
|
||||||
%close all;
|
|
||||||
%clear all;
|
|
||||||
samplingFreq = 64e6/16; %[Hz]
|
|
||||||
channels=4;
|
|
||||||
path='/home/javier/workspace/gnss-sdr-ref/trunk/install/';
|
|
||||||
for N=1:1:channels
|
|
||||||
tracking_log_path=[path 'tracking_ch_' num2str(N-1) '.dat'];
|
|
||||||
GNSS_tracking(N)= gps_l1_ca_dll_fll_pll_read_tracking_dump(tracking_log_path,samplingFreq);
|
|
||||||
end
|
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
|
||||||
channel_PRN_ID=[32,14,20,11];
|
|
||||||
tracking_loop_start=1;%10001;
|
|
||||||
tracking_loop_end=70000;
|
|
||||||
for N=1:1:channels
|
|
||||||
trackResults_sdr(N).status='T'; %fake track
|
|
||||||
trackResults_sdr(N).codeFreq=GNSS_tracking(N).code_freq_hz(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).carrFreq=GNSS_tracking(N).carrier_doppler_hz(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).dllDiscr = GNSS_tracking(N).code_error_chips(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).dllDiscrFilt = GNSS_tracking(N).code_phase_samples(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).pllDiscr = GNSS_tracking(N).PLL_discriminator_hz(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).pllDiscrFilt = GNSS_tracking(N).carr_nco(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).absoluteSample = (GNSS_tracking(N).var2(tracking_loop_start:tracking_loop_end)+GNSS_tracking(N).var1(tracking_loop_start:tracking_loop_end)).';
|
|
||||||
|
|
||||||
trackResults_sdr(N).prn_delay_ms = 1000*trackResults_sdr(N).absoluteSample/samplingFreq;
|
|
||||||
%trackResults_sdr(N).absoluteSample = (GNSS_tracking(N).PRN_start_sample(tracking_loop_start:tracking_loop_end)+GNSS_tracking(N).var1(tracking_loop_start:tracking_loop_end)).';
|
|
||||||
|
|
||||||
trackResults_sdr(N).I_P=GNSS_tracking(N).prompt_I(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).Q_P=GNSS_tracking(N).prompt_Q(tracking_loop_start:tracking_loop_end).';
|
|
||||||
|
|
||||||
trackResults_sdr(N).I_E= GNSS_tracking(N).E(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).I_L = GNSS_tracking(N).L(tracking_loop_start:tracking_loop_end).';
|
|
||||||
trackResults_sdr(N).Q_E = zeros(1,tracking_loop_end-tracking_loop_start+1);
|
|
||||||
trackResults_sdr(N).Q_L =zeros(1,tracking_loop_end-tracking_loop_start+1);
|
|
||||||
trackResults_sdr(N).PRN=channel_PRN_ID(N);
|
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
|
||||||
settings.numberOfChannels=channels;
|
|
||||||
settings.msToProcess=tracking_loop_end-tracking_loop_start+1;
|
|
||||||
%plotTracking(N,trackResults_sdr,settings)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
% for N=1:1:channels
|
|
||||||
% figure;
|
|
||||||
% plot([GNSS_tracking(N).E,GNSS_tracking(N).P,GNSS_tracking(N).L],'-*');
|
|
||||||
% title(['Early, Prompt, and Late correlator absolute value output for channel ' num2str(N)']);
|
|
||||||
% figure;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I,GNSS_tracking(N).prompt_Q,'+');
|
|
||||||
% title(['Navigation constellation plot for channel ' num2str(N)]);
|
|
||||||
% figure;
|
|
||||||
%
|
|
||||||
% plot(GNSS_tracking(N).prompt_Q,'r');
|
|
||||||
% hold on;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I);
|
|
||||||
% title(['Navigation symbols I(red) Q(blue) for channel ' num2str(N)]);
|
|
||||||
% end
|
|
||||||
|
|
||||||
|
|
@ -29,54 +29,42 @@
|
|||||||
% */
|
% */
|
||||||
close all;
|
close all;
|
||||||
clear all;
|
clear all;
|
||||||
samplingFreq = 64e6/16; %[Hz]
|
samplingFreq = 5000000; %[Hz]
|
||||||
channels=4;
|
channels = 7;
|
||||||
path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
first_channel = 0;
|
||||||
clear PRN_absolute_sample_start;
|
|
||||||
|
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
||||||
|
path = '/Users/carlesfernandez/git/cttc/build/';
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
tracking_log_path=[path 'tracking_ch_' num2str(N-1) '.dat'];
|
tracking_log_path = [path 'epl_tracking_ch_' num2str(N+first_channel-1) '.dat'];
|
||||||
GNSS_tracking(N)= gps_l1_ca_dll_pll_read_tracking_dump(tracking_log_path);
|
GNSS_tracking(N)= gps_l1_ca_dll_pll_read_tracking_dump(tracking_log_path);
|
||||||
end
|
end
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
% GNSS-SDR format conversion to MATLAB GPS receiver
|
||||||
|
|
||||||
for N=1:1:channels
|
for N=1:1:channels
|
||||||
trackResults(N).status='T'; %fake track
|
trackResults(N).status = 'T'; %fake track
|
||||||
trackResults(N).codeFreq=GNSS_tracking(N).code_freq_hz.';
|
trackResults(N).codeFreq = GNSS_tracking(N).code_freq_hz.';
|
||||||
trackResults(N).carrFreq=GNSS_tracking(N).carrier_doppler_hz.';
|
trackResults(N).carrFreq = GNSS_tracking(N).carrier_doppler_hz.';
|
||||||
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
||||||
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
||||||
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
||||||
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
||||||
|
|
||||||
trackResults(N).I_P=GNSS_tracking(N).prompt_I.';
|
trackResults(N).I_P = GNSS_tracking(N).prompt_I.';
|
||||||
trackResults(N).Q_P=GNSS_tracking(N).prompt_Q.';
|
trackResults(N).Q_P = GNSS_tracking(N).prompt_Q.';
|
||||||
|
|
||||||
trackResults(N).I_E= GNSS_tracking(N).E.';
|
trackResults(N).I_E = GNSS_tracking(N).E.';
|
||||||
trackResults(N).I_L = GNSS_tracking(N).L.';
|
trackResults(N).I_L = GNSS_tracking(N).L.';
|
||||||
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
||||||
trackResults(N).Q_L =zeros(1,length(GNSS_tracking(N).E));
|
trackResults(N).Q_L = zeros(1,length(GNSS_tracking(N).E));
|
||||||
trackResults(N).PRN=N; %fake PRN
|
trackResults(N).PRN = GNSS_tracking(N).PRN.';
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
% Use original MATLAB tracking plot function
|
||||||
settings.numberOfChannels=channels;
|
settings.numberOfChannels = channels;
|
||||||
settings.msToProcess=length(GNSS_tracking(N).E);
|
settings.msToProcess = length(GNSS_tracking(N).E);
|
||||||
plotTracking(N,trackResults,settings)
|
plotTracking(N,trackResults,settings)
|
||||||
end
|
end
|
||||||
|
|
||||||
% for N=1:1:channels
|
|
||||||
% figure;
|
|
||||||
% plot([GNSS_tracking(N).E,GNSS_tracking(N).P,GNSS_tracking(N).L],'-*');
|
|
||||||
% title(['Early, Prompt, and Late correlator absolute value output for channel ' num2str(N)']);
|
|
||||||
% figure;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I,GNSS_tracking(N).prompt_Q,'+');
|
|
||||||
% title(['Navigation constellation plot for channel ' num2str(N)]);
|
|
||||||
% figure;
|
|
||||||
%
|
|
||||||
% plot(GNSS_tracking(N).prompt_Q,'r');
|
|
||||||
% hold on;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I);
|
|
||||||
% title(['Navigation symbols I(red) Q(blue) for channel ' num2str(N)]);
|
|
||||||
% end
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,89 +0,0 @@
|
|||||||
% /*!
|
|
||||||
% * \file gps_l1_ca_dll_pll_plot_sample_64bits.m
|
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file using the provided
|
|
||||||
% function and plot some internal variables
|
|
||||||
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% *
|
|
||||||
% * Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is a software defined Global Navigation
|
|
||||||
% * Satellite Systems receiver
|
|
||||||
% *
|
|
||||||
% * This file is part of GNSS-SDR.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is free software: you can redistribute it and/or modify
|
|
||||||
% * it under the terms of the GNU General Public License as published by
|
|
||||||
% * the Free Software Foundation, either version 3 of the License, or
|
|
||||||
% * at your option) any later version.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is distributed in the hope that it will be useful,
|
|
||||||
% * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
% * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
% * GNU General Public License for more details.
|
|
||||||
% *
|
|
||||||
% * You should have received a copy of the GNU General Public License
|
|
||||||
% * along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
% *
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% */
|
|
||||||
close all;
|
|
||||||
clear all;
|
|
||||||
samplingFreq = 64e6/32; %[Hz]
|
|
||||||
channels=1;
|
|
||||||
%path='/home/javier/workspace/gnss-sdr/trunk/install/';
|
|
||||||
path='/home/luis/dev/gnss-sdr/trunk/data/';
|
|
||||||
clear PRN_absolute_sample_start;
|
|
||||||
for N=1:1:channels
|
|
||||||
tracking_log_path=[path 'tracking_ch_' num2str(N-1) '.dat'];
|
|
||||||
GNSS_tracking(N)= gps_l1_ca_dll_pll_read_tracking_dump_64bits(tracking_log_path);
|
|
||||||
end
|
|
||||||
|
|
||||||
% GNSS-SDR format conversion to MATLAB GPS receiver
|
|
||||||
|
|
||||||
for N=1:1:channels
|
|
||||||
trackResults(N).status='T'; %fake track
|
|
||||||
trackResults(N).codeFreq=GNSS_tracking(N).code_freq_hz.';
|
|
||||||
trackResults(N).carrFreq=GNSS_tracking(N).carrier_doppler_hz.';
|
|
||||||
trackResults(N).dllDiscr = GNSS_tracking(N).code_error.';
|
|
||||||
trackResults(N).dllDiscrFilt = GNSS_tracking(N).code_nco.';
|
|
||||||
trackResults(N).pllDiscr = GNSS_tracking(N).carr_error.';
|
|
||||||
trackResults(N).pllDiscrFilt = GNSS_tracking(N).carr_nco.';
|
|
||||||
|
|
||||||
trackResults(N).I_P=GNSS_tracking(N).prompt_I.';
|
|
||||||
trackResults(N).Q_P=GNSS_tracking(N).prompt_Q.';
|
|
||||||
|
|
||||||
trackResults(N).I_E= GNSS_tracking(N).E.';
|
|
||||||
trackResults(N).I_L = GNSS_tracking(N).L.';
|
|
||||||
trackResults(N).Q_E = zeros(1,length(GNSS_tracking(N).E));
|
|
||||||
trackResults(N).Q_L =zeros(1,length(GNSS_tracking(N).E));
|
|
||||||
trackResults(N).PRN=N; %fake PRN
|
|
||||||
|
|
||||||
% Use original MATLAB tracking plot function
|
|
||||||
settings.numberOfChannels=channels;
|
|
||||||
settings.msToProcess=length(GNSS_tracking(N).E);
|
|
||||||
plotTracking(N,trackResults,settings)
|
|
||||||
end
|
|
||||||
|
|
||||||
for N=1:1:channels
|
|
||||||
% figure;
|
|
||||||
% plot([GNSS_tracking(N).E,GNSS_tracking(N).P,GNSS_tracking(N).L],'-*');
|
|
||||||
% title(['Early, Prompt, and Late correlator absolute value output for channel ' num2str(N)']);
|
|
||||||
% figure;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I,GNSS_tracking(N).prompt_Q,'+');
|
|
||||||
% title(['Navigation constellation plot for channel ' num2str(N)]);
|
|
||||||
% figure;
|
|
||||||
%
|
|
||||||
% plot(GNSS_tracking(N).prompt_Q,'r');
|
|
||||||
% hold on;
|
|
||||||
% plot(GNSS_tracking(N).prompt_I);
|
|
||||||
% title(['Navigation symbols I(red) Q(blue) for channel ' num2str(N)]);
|
|
||||||
%
|
|
||||||
figure;
|
|
||||||
t=0:length(GNSS_tracking(N).carrier_doppler_hz)-1;
|
|
||||||
t=t/1000;
|
|
||||||
plot(t,GNSS_tracking(N).carrier_doppler_hz/1000);
|
|
||||||
xlabel('Time(s)');ylabel('Doppler(KHz)');title(['Doppler frequency channel ' num2str(N)]);
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
@ -26,22 +26,38 @@
|
|||||||
% *
|
% *
|
||||||
% * -------------------------------------------------------------------------
|
% * -------------------------------------------------------------------------
|
||||||
% */
|
% */
|
||||||
function [GNSS_tracking] = galileo_e1_dll_pll_veml_read_tracking_dump (filename, count)
|
|
||||||
|
|
||||||
|
function [GNSS_tracking] = galileo_e1_dll_pll_veml_read_tracking_dump (filename, count)
|
||||||
%% usage: galileo_e1_dll_pll_veml_read_tracking_dump (filename, [count])
|
%% usage: galileo_e1_dll_pll_veml_read_tracking_dump (filename, [count])
|
||||||
%%
|
%%
|
||||||
%% open GNSS-SDR tracking binary log file .dat and return the contents
|
%% open GNSS-SDR tracking binary log file .dat and return the contents
|
||||||
%%
|
%%
|
||||||
|
|
||||||
m = nargchk (1,2,nargin);
|
m = nargchk (1,2,nargin);
|
||||||
num_float_vars=17;
|
|
||||||
num_unsigned_long_int_vars=1;
|
num_float_vars = 17;
|
||||||
num_double_vars=1;
|
num_unsigned_long_int_vars = 1;
|
||||||
double_size_bytes=8;
|
num_double_vars = 1;
|
||||||
unsigned_long_int_size_bytes=8;
|
num_unsigned_int_vars = 1;
|
||||||
float_size_bytes=4;
|
|
||||||
skip_bytes_each_read=float_size_bytes*num_float_vars+unsigned_long_int_size_bytes*num_unsigned_long_int_vars+double_size_bytes*num_double_vars;
|
if(~isempty(strfind(computer('arch'), '64')))
|
||||||
bytes_shift=0;
|
% 64-bit computer
|
||||||
|
double_size_bytes = 8;
|
||||||
|
unsigned_long_int_size_bytes = 8;
|
||||||
|
float_size_bytes = 4;
|
||||||
|
unsigned_int_size_bytes = 4;
|
||||||
|
else
|
||||||
|
double_size_bytes = 8;
|
||||||
|
unsigned_long_int_size_bytes = 4;
|
||||||
|
float_size_bytes = 4;
|
||||||
|
unsigned_int_size_bytes = 4;
|
||||||
|
end
|
||||||
|
|
||||||
|
skip_bytes_each_read = float_size_bytes * num_float_vars + unsigned_long_int_size_bytes * num_unsigned_long_int_vars + ...
|
||||||
|
double_size_bytes * num_double_vars + num_unsigned_int_vars*unsigned_int_size_bytes;
|
||||||
|
|
||||||
|
bytes_shift = 0;
|
||||||
|
|
||||||
if (m)
|
if (m)
|
||||||
usage (m);
|
usage (m);
|
||||||
end
|
end
|
||||||
@ -53,140 +69,85 @@ function [GNSS_tracking] = galileo_e1_dll_pll_veml_read_tracking_dump (filename,
|
|||||||
f = fopen (filename, 'rb');
|
f = fopen (filename, 'rb');
|
||||||
if (f < 0)
|
if (f < 0)
|
||||||
else
|
else
|
||||||
v1 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v1 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v2 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v3 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v4 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v5 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v6 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v7 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
||||||
v2 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v8 = fread (f, count, 'long', skip_bytes_each_read - unsigned_long_int_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift = bytes_shift + unsigned_long_int_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v9 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v10 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v11 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v12 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v13 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v14 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v15 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
|
v16 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
||||||
v3 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v17 = fread (f, count, 'float', skip_bytes_each_read - float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v4 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v18 = fread (f, count, 'float', skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift = bytes_shift + float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next double
|
||||||
v5 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v19 = fread (f, count, 'double', skip_bytes_each_read - double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift = bytes_shift + double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next unsigned int
|
||||||
v6 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v20 = fread (f, count, 'uint', skip_bytes_each_read - unsigned_int_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v7 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v8 = fread (f, count, 'uint64',skip_bytes_each_read-unsigned_long_int_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+unsigned_long_int_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v9 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v10 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v11 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v12 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v13 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v14 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v15 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v16 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v17 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v18 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v19 = fread (f, count, 'float64',skip_bytes_each_read-double_size_bytes);
|
|
||||||
fclose (f);
|
fclose (f);
|
||||||
|
|
||||||
%%%%%%%% output vars %%%%%%%%
|
GNSS_tracking.VE = v1;
|
||||||
|
GNSS_tracking.E = v2;
|
||||||
% // EPR
|
GNSS_tracking.P = v3;
|
||||||
% d_dump_file.write((char*)&tmp_VE, sizeof(float));
|
GNSS_tracking.L = v4;
|
||||||
% d_dump_file.write((char*)&tmp_E, sizeof(float));
|
GNSS_tracking.VL = v5;
|
||||||
% d_dump_file.write((char*)&tmp_P, sizeof(float));
|
GNSS_tracking.prompt_I = v6;
|
||||||
% d_dump_file.write((char*)&tmp_L, sizeof(float));
|
GNSS_tracking.prompt_Q = v7;
|
||||||
% d_dump_file.write((char*)&tmp_VL, sizeof(float));
|
GNSS_tracking.PRN_start_sample = v8;
|
||||||
% // PROMPT I and Q (to analyze navigation symbols)
|
GNSS_tracking.acc_carrier_phase_rad = v9;
|
||||||
% d_dump_file.write((char*)&prompt_I, sizeof(float));
|
GNSS_tracking.carrier_doppler_hz = v10;
|
||||||
% d_dump_file.write((char*)&prompt_Q, sizeof(float));
|
GNSS_tracking.code_freq_hz = v11;
|
||||||
% // PRN start sample stamp
|
GNSS_tracking.carr_error = v12;
|
||||||
% //tmp_float=(float)d_sample_counter;
|
GNSS_tracking.carr_nco = v13;
|
||||||
% d_dump_file.write((char*)&d_sample_counter, sizeof(unsigned long int));
|
GNSS_tracking.code_error = v14;
|
||||||
% // accumulated carrier phase
|
GNSS_tracking.code_nco = v15;
|
||||||
% d_dump_file.write((char*)&d_acc_carrier_phase_rad, sizeof(float));
|
GNSS_tracking.CN0_SNV_dB_Hz = v16;
|
||||||
%
|
GNSS_tracking.carrier_lock_test = v17;
|
||||||
% // carrier and code frequency
|
GNSS_tracking.var1 = v18;
|
||||||
% d_dump_file.write((char*)&d_carrier_doppler_hz, sizeof(float));
|
GNSS_tracking.var2 = v19;
|
||||||
% d_dump_file.write((char*)&d_code_freq_hz, sizeof(float));
|
GNSS_tracking.PRN = v20;
|
||||||
%
|
|
||||||
% //PLL commands
|
|
||||||
% d_dump_file.write((char*)&carr_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&carr_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% //DLL commands
|
|
||||||
% d_dump_file.write((char*)&code_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&code_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% // CN0 and carrier lock test
|
|
||||||
% d_dump_file.write((char*)&d_CN0_SNV_dB_Hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_carrier_lock_test, sizeof(float));
|
|
||||||
%
|
|
||||||
% // AUX vars (for debug purposes)
|
|
||||||
% tmp_float = d_rem_code_phase_samples;
|
|
||||||
% d_dump_file.write((char*)&tmp_float, sizeof(float));
|
|
||||||
% tmp_double=(double)(d_sample_counter+d_current_prn_length_samples);
|
|
||||||
% d_dump_file.write((char*)&tmp_double, sizeof(double));
|
|
||||||
|
|
||||||
VE=v1;
|
|
||||||
E=v2;
|
|
||||||
P=v3;
|
|
||||||
L=v4;
|
|
||||||
VL=v5;
|
|
||||||
prompt_I=v6;
|
|
||||||
prompt_Q=v7;
|
|
||||||
PRN_start_sample=v8;
|
|
||||||
acc_carrier_phase_rad=v9;
|
|
||||||
carrier_doppler_hz=v10;
|
|
||||||
code_freq_hz=v11;
|
|
||||||
carr_error=v12;
|
|
||||||
carr_nco=v13;
|
|
||||||
code_error=v14;
|
|
||||||
code_nco=v15;
|
|
||||||
CN0_SNV_dB_Hz=v16;
|
|
||||||
carrier_lock_test=v17;
|
|
||||||
var1=v18;
|
|
||||||
var2=v19;
|
|
||||||
|
|
||||||
GNSS_tracking.VE=VE;
|
|
||||||
GNSS_tracking.E=E;
|
|
||||||
GNSS_tracking.P=P;
|
|
||||||
GNSS_tracking.L=L;
|
|
||||||
GNSS_tracking.VL=VL;
|
|
||||||
GNSS_tracking.prompt_I=prompt_I;
|
|
||||||
GNSS_tracking.prompt_Q=prompt_Q;
|
|
||||||
GNSS_tracking.PRN_start_sample=PRN_start_sample;
|
|
||||||
GNSS_tracking.acc_carrier_phase_rad=acc_carrier_phase_rad;
|
|
||||||
GNSS_tracking.carrier_doppler_hz=carrier_doppler_hz;
|
|
||||||
GNSS_tracking.code_freq_hz=code_freq_hz;
|
|
||||||
GNSS_tracking.carr_error=carr_error;
|
|
||||||
GNSS_tracking.carr_nco=carr_nco;
|
|
||||||
GNSS_tracking.code_error=code_error;
|
|
||||||
GNSS_tracking.code_nco=code_nco;
|
|
||||||
GNSS_tracking.CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
|
||||||
GNSS_tracking.carrier_lock_test=carrier_lock_test;
|
|
||||||
GNSS_tracking.var1=var1;
|
|
||||||
GNSS_tracking.var2=var2;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1,192 +0,0 @@
|
|||||||
% /*!
|
|
||||||
% * \file galileo_e1_dll_pll_veml_read_tracking_dump.m
|
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file into MATLAB.
|
|
||||||
% * \author Luis Esteve, 2012. luis(at)epsilon-formacion.com
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% *
|
|
||||||
% * Copyright (C) 2010-2012 (see AUTHORS file for a list of contributors)
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is a software defined Global Navigation
|
|
||||||
% * Satellite Systems receiver
|
|
||||||
% *
|
|
||||||
% * This file is part of GNSS-SDR.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is free software: you can redistribute it and/or modify
|
|
||||||
% * it under the terms of the GNU General Public License as published by
|
|
||||||
% * the Free Software Foundation, either version 3 of the License, or
|
|
||||||
% * at your option) any later version.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is distributed in the hope that it will be useful,
|
|
||||||
% * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
% * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
% * GNU General Public License for more details.
|
|
||||||
% *
|
|
||||||
% * You should have received a copy of the GNU General Public License
|
|
||||||
% * along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
% *
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% */
|
|
||||||
function [GNSS_tracking] = galileo_e1_dll_pll_veml_read_tracking_dump_32bits (filename, count)
|
|
||||||
|
|
||||||
%% usage: galileo_e1_dll_pll_veml_read_tracking_dump (filename, [count])
|
|
||||||
%%
|
|
||||||
%% open GNSS-SDR tracking binary log file .dat and return the contents
|
|
||||||
%%
|
|
||||||
|
|
||||||
m = nargchk (1,2,nargin);
|
|
||||||
num_float_vars=17;
|
|
||||||
num_unsigned_long_int_vars=1;
|
|
||||||
num_double_vars=1;
|
|
||||||
double_size_bytes=8;
|
|
||||||
unsigned_long_int_size_bytes=4;
|
|
||||||
float_size_bytes=4;
|
|
||||||
skip_bytes_each_read=float_size_bytes*num_float_vars+unsigned_long_int_size_bytes*num_unsigned_long_int_vars+double_size_bytes*num_double_vars;
|
|
||||||
bytes_shift=0;
|
|
||||||
if (m)
|
|
||||||
usage (m);
|
|
||||||
end
|
|
||||||
|
|
||||||
if (nargin < 2)
|
|
||||||
count = Inf;
|
|
||||||
end
|
|
||||||
%loops_counter = fread (f, count, 'uint32',4*12);
|
|
||||||
f = fopen (filename, 'rb');
|
|
||||||
if (f < 0)
|
|
||||||
else
|
|
||||||
v1 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v2 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v3 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v4 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v5 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v6 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v7 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v8 = fread (f, count, 'uint32',skip_bytes_each_read-unsigned_long_int_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+unsigned_long_int_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v9 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v10 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v11 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v12 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v13 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v14 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v15 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v16 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v17 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v18 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v19 = fread (f, count, 'float64',skip_bytes_each_read-double_size_bytes);
|
|
||||||
fclose (f);
|
|
||||||
|
|
||||||
%%%%%%%% output vars %%%%%%%%
|
|
||||||
|
|
||||||
% // EPR
|
|
||||||
% d_dump_file.write((char*)&tmp_VE, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_E, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_P, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_L, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_VL, sizeof(float));
|
|
||||||
% // PROMPT I and Q (to analyze navigation symbols)
|
|
||||||
% d_dump_file.write((char*)&prompt_I, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&prompt_Q, sizeof(float));
|
|
||||||
% // PRN start sample stamp
|
|
||||||
% //tmp_float=(float)d_sample_counter;
|
|
||||||
% d_dump_file.write((char*)&d_sample_counter, sizeof(unsigned long int));
|
|
||||||
% // accumulated carrier phase
|
|
||||||
% d_dump_file.write((char*)&d_acc_carrier_phase_rad, sizeof(float));
|
|
||||||
%
|
|
||||||
% // carrier and code frequency
|
|
||||||
% d_dump_file.write((char*)&d_carrier_doppler_hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_code_freq_hz, sizeof(float));
|
|
||||||
%
|
|
||||||
% //PLL commands
|
|
||||||
% d_dump_file.write((char*)&carr_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&carr_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% //DLL commands
|
|
||||||
% d_dump_file.write((char*)&code_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&code_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% // CN0 and carrier lock test
|
|
||||||
% d_dump_file.write((char*)&d_CN0_SNV_dB_Hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_carrier_lock_test, sizeof(float));
|
|
||||||
%
|
|
||||||
% // AUX vars (for debug purposes)
|
|
||||||
% tmp_float = d_rem_code_phase_samples;
|
|
||||||
% d_dump_file.write((char*)&tmp_float, sizeof(float));
|
|
||||||
% tmp_double=(double)(d_sample_counter+d_current_prn_length_samples);
|
|
||||||
% d_dump_file.write((char*)&tmp_double, sizeof(double));
|
|
||||||
|
|
||||||
VE=v1;
|
|
||||||
E=v2;
|
|
||||||
P=v3;
|
|
||||||
L=v4;
|
|
||||||
VL=v5;
|
|
||||||
prompt_I=v6;
|
|
||||||
prompt_Q=v7;
|
|
||||||
PRN_start_sample=v8;
|
|
||||||
acc_carrier_phase_rad=v9;
|
|
||||||
carrier_doppler_hz=v10;
|
|
||||||
code_freq_hz=v11;
|
|
||||||
carr_error=v12;
|
|
||||||
carr_nco=v13;
|
|
||||||
code_error=v14;
|
|
||||||
code_nco=v15;
|
|
||||||
CN0_SNV_dB_Hz=v16;
|
|
||||||
carrier_lock_test=v17;
|
|
||||||
var1=v18;
|
|
||||||
var2=v19;
|
|
||||||
|
|
||||||
GNSS_tracking.VE=VE;
|
|
||||||
GNSS_tracking.E=E;
|
|
||||||
GNSS_tracking.P=P;
|
|
||||||
GNSS_tracking.L=L;
|
|
||||||
GNSS_tracking.VL=VL;
|
|
||||||
GNSS_tracking.prompt_I=prompt_I;
|
|
||||||
GNSS_tracking.prompt_Q=prompt_Q;
|
|
||||||
GNSS_tracking.PRN_start_sample=PRN_start_sample;
|
|
||||||
GNSS_tracking.acc_carrier_phase_rad=acc_carrier_phase_rad;
|
|
||||||
GNSS_tracking.carrier_doppler_hz=carrier_doppler_hz;
|
|
||||||
GNSS_tracking.code_freq_hz=code_freq_hz;
|
|
||||||
GNSS_tracking.carr_error=carr_error;
|
|
||||||
GNSS_tracking.carr_nco=carr_nco;
|
|
||||||
GNSS_tracking.code_error=code_error;
|
|
||||||
GNSS_tracking.code_nco=code_nco;
|
|
||||||
GNSS_tracking.CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
|
||||||
GNSS_tracking.carrier_lock_test=carrier_lock_test;
|
|
||||||
GNSS_tracking.var1=var1;
|
|
||||||
GNSS_tracking.var2=var2;
|
|
||||||
end
|
|
||||||
|
|
@ -34,12 +34,26 @@ function [GNSS_tracking] = gps_l1_ca_dll_pll_read_tracking_dump (filename, count
|
|||||||
%%
|
%%
|
||||||
|
|
||||||
m = nargchk (1,2,nargin);
|
m = nargchk (1,2,nargin);
|
||||||
num_float_vars=16;
|
num_float_vars = 5;
|
||||||
num_double_vars=2;
|
num_double_vars = 11;
|
||||||
double_size_bytes=8;
|
num_ulong_vars = 1;
|
||||||
float_size_bytes=4;
|
num_uint_vars = 1;
|
||||||
skip_bytes_each_read=float_size_bytes*num_float_vars+double_size_bytes*num_double_vars;
|
|
||||||
bytes_shift=0;
|
if(~isempty(strfind(computer('arch'), '64')))
|
||||||
|
% 64-bit computer
|
||||||
|
double_size_bytes = 8;
|
||||||
|
unsigned_long_int_size_bytes = 8;
|
||||||
|
float_size_bytes = 4;
|
||||||
|
unsigned_int_size_bytes = 4;
|
||||||
|
else
|
||||||
|
double_size_bytes = 8;
|
||||||
|
unsigned_long_int_size_bytes = 4;
|
||||||
|
float_size_bytes = 4;
|
||||||
|
unsigned_int_size_bytes = 4;
|
||||||
|
end
|
||||||
|
|
||||||
|
skip_bytes_each_read = float_size_bytes*num_float_vars + double_size_bytes*num_double_vars + unsigned_int_size_bytes*num_uint_vars + unsigned_long_int_size_bytes*num_ulong_vars;
|
||||||
|
bytes_shift = 0;
|
||||||
if (m)
|
if (m)
|
||||||
usage (m);
|
usage (m);
|
||||||
end
|
end
|
||||||
@ -53,130 +67,76 @@ function [GNSS_tracking] = gps_l1_ca_dll_pll_read_tracking_dump (filename, count
|
|||||||
else
|
else
|
||||||
v1 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v1 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v2 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v2 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v3 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v3 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v4 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v4 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v5 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v5 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+float_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next unsigned long int
|
||||||
v6 = fread (f, count, 'uint32',skip_bytes_each_read-float_size_bytes);
|
v6 = fread (f, count, 'long',skip_bytes_each_read-unsigned_long_int_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+unsigned_long_int_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v7 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v7 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v8 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v8 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v9 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v9 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v10 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v10 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v11 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v11 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v12 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v12 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v13 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v13 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v14 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v14 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v15 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
v15 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v16 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v17 = fread (f, count, 'float64',skip_bytes_each_read-double_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+double_size_bytes;
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
fseek(f,bytes_shift,'bof'); % move to next float
|
||||||
v18 = fread (f, count, 'float64',skip_bytes_each_read-double_size_bytes);
|
v16 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next double
|
||||||
|
v17 = fread (f, count, 'double',skip_bytes_each_read-double_size_bytes);
|
||||||
|
bytes_shift=bytes_shift+double_size_bytes;
|
||||||
|
fseek(f,bytes_shift,'bof'); % move to next double
|
||||||
|
v18 = fread (f, count, 'uint', skip_bytes_each_read - unsigned_int_size_bytes);
|
||||||
fclose (f);
|
fclose (f);
|
||||||
|
|
||||||
%%%%%%%% output vars %%%%%%%%
|
|
||||||
|
|
||||||
% // EPR
|
GNSS_tracking.E = v1;
|
||||||
% d_dump_file.write((char*)&tmp_E, sizeof(float));
|
GNSS_tracking.P = v2;
|
||||||
% d_dump_file.write((char*)&tmp_P, sizeof(float));
|
GNSS_tracking.L = v3;
|
||||||
% d_dump_file.write((char*)&tmp_L, sizeof(float));
|
GNSS_tracking.prompt_I = v4;
|
||||||
% // PROMPT I and Q (to analyze navigation symbols)
|
GNSS_tracking.prompt_Q = v5;
|
||||||
% d_dump_file.write((char*)&prompt_I, sizeof(float));
|
GNSS_tracking.PRN_start_sample = v6;
|
||||||
% d_dump_file.write((char*)&prompt_Q, sizeof(float));
|
GNSS_tracking.acc_carrier_phase_rad = v7;
|
||||||
% // PRN start sample stamp
|
GNSS_tracking.carrier_doppler_hz = v8;
|
||||||
% //tmp_float=(float)d_sample_counter;
|
GNSS_tracking.code_freq_hz = v9;
|
||||||
% d_dump_file.write((char*)&d_sample_counter, sizeof(unsigned long int));
|
GNSS_tracking.carr_error = v10;
|
||||||
% // accumulated carrier phase
|
GNSS_tracking.carr_nco = v11;
|
||||||
% d_dump_file.write((char*)&d_acc_carrier_phase_rad, sizeof(float));
|
GNSS_tracking.code_error = v12;
|
||||||
%
|
GNSS_tracking.code_nco = v13;
|
||||||
% // carrier and code frequency
|
GNSS_tracking.CN0_SNV_dB_Hz = v14;
|
||||||
% d_dump_file.write((char*)&d_carrier_doppler_hz, sizeof(float));
|
GNSS_tracking.carrier_lock_test = v15;
|
||||||
% d_dump_file.write((char*)&d_code_freq_hz, sizeof(float));
|
GNSS_tracking.var1 = v16;
|
||||||
%
|
GNSS_tracking.var2 = v17;
|
||||||
% //PLL commands
|
GNSS_tracking.PRN = v18;
|
||||||
% d_dump_file.write((char*)&carr_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&carr_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% //DLL commands
|
|
||||||
% d_dump_file.write((char*)&code_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&code_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% // CN0 and carrier lock test
|
|
||||||
% d_dump_file.write((char*)&d_CN0_SNV_dB_Hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_carrier_lock_test, sizeof(float));
|
|
||||||
%
|
|
||||||
% // AUX vars (for debug purposes)
|
|
||||||
% tmp_float=0;
|
|
||||||
% d_dump_file.write((char*)&tmp_float, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_sample_counter_seconds, sizeof(double));
|
|
||||||
|
|
||||||
E=v1;
|
|
||||||
P=v2;
|
|
||||||
L=v3;
|
|
||||||
prompt_I=v4;
|
|
||||||
prompt_Q=v5;
|
|
||||||
PRN_start_sample=v6;
|
|
||||||
acc_carrier_phase_rad=v7;
|
|
||||||
carrier_doppler_hz=v8;
|
|
||||||
code_freq_hz=v9;
|
|
||||||
carr_error=v10;
|
|
||||||
carr_nco=v11;
|
|
||||||
code_error=v12;
|
|
||||||
code_nco=v13;
|
|
||||||
CN0_SNV_dB_Hz=v14;
|
|
||||||
carrier_lock_test=v15;
|
|
||||||
var1=v16;
|
|
||||||
var2=v17;
|
|
||||||
var3=v18;
|
|
||||||
|
|
||||||
GNSS_tracking.E=E;
|
|
||||||
GNSS_tracking.P=P;
|
|
||||||
GNSS_tracking.L=L;
|
|
||||||
GNSS_tracking.prompt_I=prompt_I;
|
|
||||||
GNSS_tracking.prompt_Q=prompt_Q;
|
|
||||||
GNSS_tracking.PRN_start_sample=PRN_start_sample;
|
|
||||||
GNSS_tracking.acc_carrier_phase_rad=acc_carrier_phase_rad;
|
|
||||||
GNSS_tracking.carrier_doppler_hz=carrier_doppler_hz;
|
|
||||||
GNSS_tracking.code_freq_hz=code_freq_hz;
|
|
||||||
GNSS_tracking.carr_error=carr_error;
|
|
||||||
GNSS_tracking.carr_nco=carr_nco;
|
|
||||||
GNSS_tracking.code_error=code_error;
|
|
||||||
GNSS_tracking.code_nco=code_nco;
|
|
||||||
GNSS_tracking.CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
|
||||||
GNSS_tracking.carrier_lock_test=carrier_lock_test;
|
|
||||||
GNSS_tracking.var1=var1;
|
|
||||||
GNSS_tracking.var2=var2;
|
|
||||||
GNSS_tracking.var3=var3;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -1,179 +0,0 @@
|
|||||||
% /*!
|
|
||||||
% * \file gps_l1_ca_dll_pll_read_tracking_dump.m
|
|
||||||
% * \brief Read GNSS-SDR Tracking dump binary file into MATLAB.
|
|
||||||
% * \author Javier Arribas, 2011. jarribas(at)cttc.es
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% *
|
|
||||||
% * Copyright (C) 2010-2011 (see AUTHORS file for a list of contributors)
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is a software defined Global Navigation
|
|
||||||
% * Satellite Systems receiver
|
|
||||||
% *
|
|
||||||
% * This file is part of GNSS-SDR.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is free software: you can redistribute it and/or modify
|
|
||||||
% * it under the terms of the GNU General Public License as published by
|
|
||||||
% * the Free Software Foundation, either version 3 of the License, or
|
|
||||||
% * at your option) any later version.
|
|
||||||
% *
|
|
||||||
% * GNSS-SDR is distributed in the hope that it will be useful,
|
|
||||||
% * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
% * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
% * GNU General Public License for more details.
|
|
||||||
% *
|
|
||||||
% * You should have received a copy of the GNU General Public License
|
|
||||||
% * along with GNSS-SDR. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
% *
|
|
||||||
% * -------------------------------------------------------------------------
|
|
||||||
% */
|
|
||||||
function [GNSS_tracking] = gps_l1_ca_dll_pll_read_tracking_dump_64bits (filename, count)
|
|
||||||
|
|
||||||
%% usage: gps_l1_ca_dll_pll_read_tracking_dump_64bits (filename, [count])
|
|
||||||
%%
|
|
||||||
%% open GNSS-SDR tracking binary log file .dat and return the contents
|
|
||||||
%%
|
|
||||||
|
|
||||||
m = nargchk (1,2,nargin);
|
|
||||||
num_float_vars=15;
|
|
||||||
num_unsigned_long_int_vars=1;
|
|
||||||
num_double_vars=1;
|
|
||||||
double_size_bytes=8;
|
|
||||||
unsigned_long_int_size_bytes=8;
|
|
||||||
float_size_bytes=4;
|
|
||||||
skip_bytes_each_read=float_size_bytes*num_float_vars+unsigned_long_int_size_bytes*num_unsigned_long_int_vars+double_size_bytes*num_double_vars;
|
|
||||||
bytes_shift=0;
|
|
||||||
if (m)
|
|
||||||
usage (m);
|
|
||||||
end
|
|
||||||
|
|
||||||
if (nargin < 2)
|
|
||||||
count = Inf;
|
|
||||||
end
|
|
||||||
%loops_counter = fread (f, count, 'uint32',4*12);
|
|
||||||
f = fopen (filename, 'rb');
|
|
||||||
if (f < 0)
|
|
||||||
else
|
|
||||||
v1 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v2 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v3 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v4 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v5 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v6 = fread (f, count, 'uint64',skip_bytes_each_read-unsigned_long_int_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+unsigned_long_int_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v7 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v8 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v9 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v10 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v11 = fread (f, count, '*float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v12 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v13 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v14 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v15 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v16 = fread (f, count, 'float',skip_bytes_each_read-float_size_bytes);
|
|
||||||
bytes_shift=bytes_shift+float_size_bytes;
|
|
||||||
fseek(f,bytes_shift,'bof'); % move to next interleaved float
|
|
||||||
v17 = fread (f, count, 'float64',skip_bytes_each_read-double_size_bytes);
|
|
||||||
fclose (f);
|
|
||||||
|
|
||||||
%%%%%%%% output vars %%%%%%%%
|
|
||||||
|
|
||||||
% // EPR
|
|
||||||
% d_dump_file.write((char*)&tmp_E, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_P, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&tmp_L, sizeof(float));
|
|
||||||
% // PROMPT I and Q (to analyze navigation symbols)
|
|
||||||
% d_dump_file.write((char*)&prompt_I, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&prompt_Q, sizeof(float));
|
|
||||||
% // PRN start sample stamp
|
|
||||||
% //tmp_float=(float)d_sample_counter;
|
|
||||||
% d_dump_file.write((char*)&d_sample_counter, sizeof(unsigned long int));
|
|
||||||
% // accumulated carrier phase
|
|
||||||
% d_dump_file.write((char*)&d_acc_carrier_phase_rad, sizeof(float));
|
|
||||||
%
|
|
||||||
% // carrier and code frequency
|
|
||||||
% d_dump_file.write((char*)&d_carrier_doppler_hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_code_freq_hz, sizeof(float));
|
|
||||||
%
|
|
||||||
% //PLL commands
|
|
||||||
% d_dump_file.write((char*)&carr_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&carr_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% //DLL commands
|
|
||||||
% d_dump_file.write((char*)&code_error, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&code_nco, sizeof(float));
|
|
||||||
%
|
|
||||||
% // CN0 and carrier lock test
|
|
||||||
% d_dump_file.write((char*)&d_CN0_SNV_dB_Hz, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_carrier_lock_test, sizeof(float));
|
|
||||||
%
|
|
||||||
% // AUX vars (for debug purposes)
|
|
||||||
% tmp_float=0;
|
|
||||||
% d_dump_file.write((char*)&tmp_float, sizeof(float));
|
|
||||||
% d_dump_file.write((char*)&d_sample_counter_seconds, sizeof(double));
|
|
||||||
|
|
||||||
E=v1;
|
|
||||||
P=v2;
|
|
||||||
L=v3;
|
|
||||||
prompt_I=v4;
|
|
||||||
prompt_Q=v5;
|
|
||||||
PRN_start_sample=v6;
|
|
||||||
acc_carrier_phase_rad=v7;
|
|
||||||
carrier_doppler_hz=v8;
|
|
||||||
code_freq_hz=v9;
|
|
||||||
carr_error=v10;
|
|
||||||
carr_nco=v11;
|
|
||||||
code_error=v12;
|
|
||||||
code_nco=v13;
|
|
||||||
CN0_SNV_dB_Hz=v14;
|
|
||||||
carrier_lock_test=v15;
|
|
||||||
var1=v16;
|
|
||||||
var2=v17;
|
|
||||||
|
|
||||||
GNSS_tracking.E=E;
|
|
||||||
GNSS_tracking.P=P;
|
|
||||||
GNSS_tracking.L=L;
|
|
||||||
GNSS_tracking.prompt_I=prompt_I;
|
|
||||||
GNSS_tracking.prompt_Q=prompt_Q;
|
|
||||||
GNSS_tracking.PRN_start_sample=PRN_start_sample;
|
|
||||||
GNSS_tracking.acc_carrier_phase_rad=acc_carrier_phase_rad;
|
|
||||||
GNSS_tracking.carrier_doppler_hz=carrier_doppler_hz;
|
|
||||||
GNSS_tracking.code_freq_hz=code_freq_hz;
|
|
||||||
GNSS_tracking.carr_error=carr_error;
|
|
||||||
GNSS_tracking.carr_nco=carr_nco;
|
|
||||||
GNSS_tracking.code_error=code_error;
|
|
||||||
GNSS_tracking.code_nco=code_nco;
|
|
||||||
GNSS_tracking.CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
|
||||||
GNSS_tracking.carrier_lock_test=carrier_lock_test;
|
|
||||||
GNSS_tracking.var1=var1;
|
|
||||||
GNSS_tracking.var2=var2;
|
|
||||||
end
|
|
||||||
|
|
@ -49,7 +49,7 @@ for channelNr = channelList
|
|||||||
clf(channelNr +200);
|
clf(channelNr +200);
|
||||||
set(channelNr +200, 'Name', ['Channel ', num2str(channelNr), ...
|
set(channelNr +200, 'Name', ['Channel ', num2str(channelNr), ...
|
||||||
' (PRN ', ...
|
' (PRN ', ...
|
||||||
num2str(trackResults(channelNr).PRN), ...
|
num2str(trackResults(channelNr).PRN(end-1)), ...
|
||||||
') results']);
|
') results']);
|
||||||
|
|
||||||
%% Draw axes ==============================================================
|
%% Draw axes ==============================================================
|
||||||
@ -122,7 +122,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- PLL discriminator filtered----------------------------------
|
%----- PLL discriminator filtered----------------------------------
|
||||||
plot (handles(3, 1), timeAxisInSeconds, ...
|
plot (handles(3, 1), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).pllDiscrFilt, 'b');
|
trackResults(channelNr).pllDiscrFilt(1:settings.msToProcess), 'b');
|
||||||
|
|
||||||
grid (handles(3, 1));
|
grid (handles(3, 1));
|
||||||
axis (handles(3, 1), 'tight');
|
axis (handles(3, 1), 'tight');
|
||||||
|
@ -49,7 +49,7 @@ for channelNr = channelList
|
|||||||
clf(channelNr +200);
|
clf(channelNr +200);
|
||||||
set(channelNr +200, 'Name', ['Channel ', num2str(channelNr), ...
|
set(channelNr +200, 'Name', ['Channel ', num2str(channelNr), ...
|
||||||
' (PRN ', ...
|
' (PRN ', ...
|
||||||
num2str(trackResults(channelNr).PRN), ...
|
num2str(trackResults(channelNr).PRN(end-1)), ...
|
||||||
') results']);
|
') results']);
|
||||||
|
|
||||||
%% Draw axes ==============================================================
|
%% Draw axes ==============================================================
|
||||||
|
@ -66,7 +66,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%% Plot all figures =======================================================
|
%% Plot all figures =======================================================
|
||||||
|
|
||||||
timeAxisInSeconds = (1:settings.msToProcess)/1000;
|
timeAxisInSeconds = (1:settings.msToProcess-1)/1000;
|
||||||
|
|
||||||
%----- Discrete-Time Scatter Plot ---------------------------------
|
%----- Discrete-Time Scatter Plot ---------------------------------
|
||||||
plot(handles(1, 1), trackResults(channelNr).I_PN,...
|
plot(handles(1, 1), trackResults(channelNr).I_PN,...
|
||||||
@ -81,7 +81,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- Nav bits ---------------------------------------------------
|
%----- Nav bits ---------------------------------------------------
|
||||||
plot (handles(1, 2), timeAxisInSeconds, ...
|
plot (handles(1, 2), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).I_PN);
|
trackResults(channelNr).I_PN(1:settings.msToProcess-1));
|
||||||
|
|
||||||
grid (handles(1, 2));
|
grid (handles(1, 2));
|
||||||
title (handles(1, 2), 'Bits of the navigation message');
|
title (handles(1, 2), 'Bits of the navigation message');
|
||||||
@ -90,7 +90,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- PLL discriminator unfiltered--------------------------------
|
%----- PLL discriminator unfiltered--------------------------------
|
||||||
plot (handles(2, 1), timeAxisInSeconds, ...
|
plot (handles(2, 1), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).pllDiscr, 'r');
|
trackResults(channelNr).pllDiscr(1:settings.msToProcess-1), 'r');
|
||||||
|
|
||||||
grid (handles(2, 1));
|
grid (handles(2, 1));
|
||||||
axis (handles(2, 1), 'tight');
|
axis (handles(2, 1), 'tight');
|
||||||
@ -100,12 +100,12 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- Correlation ------------------------------------------------
|
%----- Correlation ------------------------------------------------
|
||||||
plot(handles(2, 2), timeAxisInSeconds, ...
|
plot(handles(2, 2), timeAxisInSeconds, ...
|
||||||
[sqrt(trackResults(channelNr).I_E.^2 + ...
|
[sqrt(trackResults(channelNr).I_E(1:settings.msToProcess-1).^2 + ...
|
||||||
trackResults(channelNr).Q_E.^2)', ...
|
trackResults(channelNr).Q_E(1:settings.msToProcess-1).^2)', ...
|
||||||
sqrt(trackResults(channelNr).I_P.^2 + ...
|
sqrt(trackResults(channelNr).I_P(1:settings.msToProcess-1).^2 + ...
|
||||||
trackResults(channelNr).Q_P.^2)', ...
|
trackResults(channelNr).Q_P(1:settings.msToProcess-1).^2)', ...
|
||||||
sqrt(trackResults(channelNr).I_L.^2 + ...
|
sqrt(trackResults(channelNr).I_L(1:settings.msToProcess-1).^2 + ...
|
||||||
trackResults(channelNr).Q_L.^2)'], ...
|
trackResults(channelNr).Q_L(1:settings.msToProcess-1).^2)'], ...
|
||||||
'-*');
|
'-*');
|
||||||
|
|
||||||
grid (handles(2, 2));
|
grid (handles(2, 2));
|
||||||
@ -122,7 +122,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- PLL discriminator filtered----------------------------------
|
%----- PLL discriminator filtered----------------------------------
|
||||||
plot (handles(3, 1), timeAxisInSeconds, ...
|
plot (handles(3, 1), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).pllDiscrFilt, 'b');
|
trackResults(channelNr).pllDiscrFilt(1:settings.msToProcess-1), 'b');
|
||||||
|
|
||||||
grid (handles(3, 1));
|
grid (handles(3, 1));
|
||||||
axis (handles(3, 1), 'tight');
|
axis (handles(3, 1), 'tight');
|
||||||
@ -132,7 +132,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- DLL discriminator unfiltered--------------------------------
|
%----- DLL discriminator unfiltered--------------------------------
|
||||||
plot (handles(3, 2), timeAxisInSeconds, ...
|
plot (handles(3, 2), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).dllDiscr, 'r');
|
trackResults(channelNr).dllDiscr(1:settings.msToProcess-1), 'r');
|
||||||
|
|
||||||
grid (handles(3, 2));
|
grid (handles(3, 2));
|
||||||
axis (handles(3, 2), 'tight');
|
axis (handles(3, 2), 'tight');
|
||||||
@ -142,7 +142,7 @@ for channelNr = channelList
|
|||||||
|
|
||||||
%----- DLL discriminator filtered----------------------------------
|
%----- DLL discriminator filtered----------------------------------
|
||||||
plot (handles(3, 3), timeAxisInSeconds, ...
|
plot (handles(3, 3), timeAxisInSeconds, ...
|
||||||
trackResults(channelNr).dllDiscrFilt, 'b');
|
trackResults(channelNr).dllDiscrFilt(1:settings.msToProcess-1), 'b');
|
||||||
|
|
||||||
grid (handles(3, 3));
|
grid (handles(3, 3));
|
||||||
axis (handles(3, 3), 'tight');
|
axis (handles(3, 3), 'tight');
|
||||||
|
Loading…
Reference in New Issue
Block a user