From 047807ba0ca115d754632f75fa6121002d9639b4 Mon Sep 17 00:00:00 2001 From: Marc Majoral Date: Thu, 8 Nov 2018 19:19:39 +0100 Subject: [PATCH] solved a bug that caused the tracking pull-in test in the FPGA not to work when using the downsampling filter in the acquisition. --- .../gnuradio_blocks/pcps_acquisition_fpga.cc | 44 +++- .../tracking/tracking_pull-in_test_fpga.cc | 221 +++++++++++++----- 2 files changed, 206 insertions(+), 59 deletions(-) diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fpga.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fpga.cc index 3cef0d117..45e093a0f 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fpga.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fpga.cc @@ -369,7 +369,7 @@ void pcps_acquisition_fpga::set_active(bool active) //printf("yes here\n"); d_gnss_synchro->Acq_delay_samples = static_cast(d_downsampling_factor*(indext % acq_parameters.samples_per_code)); //d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 81*0.25*d_downsampling_factor; // delay due to the downsampling filter in the acquisition - d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 33; //41; //+ 81*0.5; // delay due to the downsampling filter in the acquisition + d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 44; //33; //41; //+ 81*0.5; // delay due to the downsampling filter in the acquisition //d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 81/d_downsampling_factor; // delay due to the downsampling filter in the acquisition //d_gnss_synchro->Acq_delay_samples = static_cast(2*(indext % acq_parameters.samples_per_code)); //d_gnss_synchro->Acq_delay_samples = static_cast(2*(indext)); @@ -438,10 +438,10 @@ void pcps_acquisition_fpga::set_active(bool active) send_positive_acquisition(); d_state = 0; // Positive acquisition - //printf("acq d_gnss_synchro->Acq_delay_samples = %f\n: ",d_gnss_synchro->Acq_delay_samples); - //printf("acq d_gnss_synchro->Acq_samplestamp_samples = %d\n", (unsigned int) d_gnss_synchro->Acq_samplestamp_samples); - //printf("acq d_gnss_synchro->Acq_doppler_hz = %f\n", d_gnss_synchro->Acq_doppler_hz); - //printf("acq d_gnss_synchro->PRN = %d\n", (int) d_gnss_synchro->PRN); + // printf("acq d_gnss_synchro->Acq_delay_samples = %f\n: ",d_gnss_synchro->Acq_delay_samples); + // printf("acq d_gnss_synchro->Acq_samplestamp_samples = %d\n", (unsigned int) d_gnss_synchro->Acq_samplestamp_samples); + // printf("acq d_gnss_synchro->Acq_doppler_hz = %f\n", d_gnss_synchro->Acq_doppler_hz); + // printf("acq d_gnss_synchro->PRN = %d\n", (int) d_gnss_synchro->PRN); } else { @@ -480,6 +480,40 @@ void pcps_acquisition_fpga::read_acquisition_results(uint32_t *max_index, acquisition_fpga->read_acquisition_results(max_index, max_magnitude, second_magnitude, initial_sample, &input_power, doppler_index, total_fft_scaling_factor); + if (d_select_queue_Fpga == 0) + { + if (d_downsampling_factor > 1) + { + //printf("yes here\n"); + *max_index = static_cast(d_downsampling_factor*(*max_index)); + //d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 81*0.25*d_downsampling_factor; // delay due to the downsampling filter in the acquisition + *initial_sample = d_downsampling_factor*(*initial_sample) - 44; //33; //41; //+ 81*0.5; // delay due to the downsampling filter in the acquisition + //d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 81/d_downsampling_factor; // delay due to the downsampling filter in the acquisition + //d_gnss_synchro->Acq_delay_samples = static_cast(2*(indext % acq_parameters.samples_per_code)); + //d_gnss_synchro->Acq_delay_samples = static_cast(2*(indext)); + //d_gnss_synchro->Acq_samplestamp_samples = d_sample_counter*2 - 81; + //d_gnss_synchro->Acq_delay_samples = static_cast(indext % acq_parameters.samples_per_code); + //d_gnss_synchro->Acq_samplestamp_samples = d_sample_counter; + + } + else + { + //printf("xxxxxxxxxxxxxxxx no here\n"); + //max_index = static_cast(indext % acq_parameters.samples_per_code); + //initial_sample = d_sample_counter; // delay due to the downsampling filter in the acquisition + //d_gnss_synchro->Acq_samplestamp_samples = d_sample_counter - 40; // delay due to the downsampling filter in the acquisition + //d_gnss_synchro->Acq_samplestamp_samples = d_downsampling_factor*d_sample_counter - 81*0.5*d_downsampling_factor; + } + } +// else +// { +// d_gnss_synchro->Acq_delay_samples = static_cast(indext % acq_parameters.samples_per_code); +// d_gnss_synchro->Acq_samplestamp_samples = d_sample_counter; // delay due to the downsampling filter in the acquisition +// } + + + + // acquisition_fpga->read_acquisition_results(max_index, max_magnitude, // initial_sample, power_sum, doppler_index); } diff --git a/src/tests/unit-tests/signal-processing-blocks/tracking/tracking_pull-in_test_fpga.cc b/src/tests/unit-tests/signal-processing-blocks/tracking/tracking_pull-in_test_fpga.cc index cd8198527..99f5f50b6 100644 --- a/src/tests/unit-tests/signal-processing-blocks/tracking/tracking_pull-in_test_fpga.cc +++ b/src/tests/unit-tests/signal-processing-blocks/tracking/tracking_pull-in_test_fpga.cc @@ -73,7 +73,9 @@ #define NSAMPLES_TRACKING 200000000 // number of samples during which we test the tracking module #define NSAMPLES_FINAL 50000 // number of samples sent after running tracking to unblock the SW if it is waiting for an interrupt of the tracking module #define NSAMPLES_ACQ_DOPPLER_SWEEP 50000000 // number of samples sent to the acquisition module when running acquisition when the HW controls the doppler loop -#define DOWNAMPLING_FILTER_INIT_SAMPLES 2000 // some samples to initialize the state of the downsampling filter +#define DOWNAMPLING_FILTER_INIT_SAMPLES 100 // some samples to initialize the state of the downsampling filter +#define DOWNSAMPLING_FILTER_DELAY 11 + // HW related options bool doppler_control_in_sw = 1; // 1 => doppler sweep controlled by the SW test code , 0 => doppler sweep controlled by the HW bool show_results_table = 0; // 1 => show matrix of (doppler, (max value, power sum)) results (only if doppler_control_in_sw = 1), 0=> do not show it @@ -1030,12 +1032,12 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) } else if (implementation.compare("Galileo_E5a_DLL_PLL_Tracking_Fpga") == 0) { - code_length = static_cast(std::round(static_cast(baseband_sampling_freq_acquisition) / Galileo_E5a_CODE_CHIP_RATE_HZ * static_cast(Galileo_E5a_CODE_LENGTH_CHIPS))); + code_length = static_cast(std::round(static_cast(baseband_sampling_freq) / Galileo_E5a_CODE_CHIP_RATE_HZ * static_cast(Galileo_E5a_CODE_LENGTH_CHIPS))); nsamples_to_transfer = static_cast(std::round(static_cast(baseband_sampling_freq) / (GPS_L1_CA_CODE_RATE_HZ / GPS_L1_CA_CODE_LENGTH_CHIPS))); } else if (implementation.compare("GPS_L5_DLL_PLL_Tracking_Fpga") == 0) { - code_length = static_cast(std::round(static_cast(baseband_sampling_freq_acquisition) / (GPS_L5i_CODE_RATE_HZ / static_cast(GPS_L5i_CODE_LENGTH_CHIPS)))); + code_length = static_cast(std::round(static_cast(baseband_sampling_freq) / (GPS_L5i_CODE_RATE_HZ / static_cast(GPS_L5i_CODE_LENGTH_CHIPS)))); nsamples_to_transfer = static_cast(std::round(static_cast(baseband_sampling_freq) / (GPS_L1_CA_CODE_RATE_HZ / GPS_L1_CA_CODE_LENGTH_CHIPS))); } @@ -1069,6 +1071,7 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) float result_table[MAX_PRN_IDX][num_doppler_steps][3]; for (unsigned int PRN = 1; PRN < MAX_PRN_IDX; PRN++) + //for (unsigned int PRN = 13; PRN < 15; PRN++) { uint32_t max_index = 0; @@ -1149,42 +1152,62 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) args.file = file; - - // send the previous samples to set the downsampling filter in a good condition -// send_samples_start = 0; -// if (skip_samples_already_used == 1) -// { -// args.skip_used_samples = (PRN -1)*fft_size - DOWNAMPLING_FILTER_INIT_SAMPLES; // set the counter 2000 samples before -// } -// else -// { -// args.skip_used_samples = - DOWNAMPLING_FILTER_INIT_SAMPLES; // set the counter 2000 samples before -// } -// args.nsamples_tx = DOWNAMPLING_FILTER_INIT_SAMPLES; //50000; // max size of the FFT -// if (pthread_create(&thread_DMA, NULL, handler_DMA, (void *)&args) < 0) -// { -// printf("ERROR cannot create DMA Process\n"); -// } -// pthread_mutex_lock(&mutex); -// send_samples_start = 1; -// pthread_mutex_unlock(&mutex); -// pthread_join(thread_DMA, NULL); -// send_samples_start = 0; -// printf("finished sending samples init filter status\n"); - - // debug - args.nsamples_tx = nsamples_to_transfer; //fft_size; //50000; // max size of the FFT - - if (skip_samples_already_used == 1) + if ((implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) or (implementation.compare("Galileo_E1_DLL_PLL_VEML_Tracking_Fpga"))) { - args.skip_used_samples = (PRN -1)*fft_size; + //---------------------------------------------------------------------------------- + // send the previous samples to set the downsampling filter in a good condition + send_samples_start = 0; + if (skip_samples_already_used == 1) + { + args.skip_used_samples = (PRN -1)*fft_size - DOWNAMPLING_FILTER_INIT_SAMPLES; // set the counter 2000 samples before + } + else + { + args.skip_used_samples = - DOWNAMPLING_FILTER_INIT_SAMPLES; // set the counter 2000 samples before + } + args.nsamples_tx = DOWNAMPLING_FILTER_INIT_SAMPLES + DOWNSAMPLING_FILTER_DELAY; //50000; // max size of the FFT + if (pthread_create(&thread_DMA, NULL, handler_DMA, (void *)&args) < 0) + { + printf("ERROR cannot create DMA Process\n"); + } + pthread_mutex_lock(&mutex); + send_samples_start = 1; + pthread_mutex_unlock(&mutex); + pthread_join(thread_DMA, NULL); + send_samples_start = 0; + //printf("finished sending samples init filter status\n"); + //----------------------------------------------------------------------------------- + + // debug + args.nsamples_tx = nsamples_to_transfer; //fft_size; //50000; // max size of the FFT + + if (skip_samples_already_used == 1) + { + args.skip_used_samples = (PRN -1)*fft_size + DOWNSAMPLING_FILTER_DELAY; + } + else + { + args.skip_used_samples = DOWNSAMPLING_FILTER_DELAY; + } } else { - args.skip_used_samples = 0; + // debug + args.nsamples_tx = nsamples_to_transfer; //fft_size; //50000; // max size of the FFT + + if (skip_samples_already_used == 1) + { + args.skip_used_samples = (PRN -1)*fft_size; + } + else + { + args.skip_used_samples = 0; + } } + + // create DMA child process //printf("||||||||1 args freq_band = %d\n", args.freq_band); if (pthread_create(&thread_DMA, NULL, handler_DMA, (void *)&args) < 0) @@ -1268,14 +1291,29 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) //printf("max_magnitude_iteration = %f\n", max_magnitude_iteration); //printf("second_magnitude_iteration = %f\n", second_magnitude_iteration); - if (max_magnitude_iteration > max_magnitude) + if ((implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) or (implementation.compare("Galileo_E1_DLL_PLL_VEML_Tracking_Fpga"))) + { + if (max_magnitude_iteration > max_magnitude) + { + max_index = max_index_iteration; + max_magnitude = max_magnitude_iteration; + second_magnitude = second_magnitude_iteration; + initial_sample = initial_sample_iteration; + doppler_index = doppler_index_iteration; + doppler_shift_selected = doppler_shift; + } + } + else { - max_index = max_index_iteration; - max_magnitude = max_magnitude_iteration; - second_magnitude = second_magnitude_iteration; - initial_sample = initial_sample_iteration; - doppler_index = doppler_index_iteration; - doppler_shift_selected = doppler_shift; + if (max_magnitude_iteration > max_magnitude) + { + max_index = max_index_iteration; + max_magnitude = max_magnitude_iteration; + second_magnitude = second_magnitude_iteration; + initial_sample = initial_sample_iteration - (DOWNAMPLING_FILTER_INIT_SAMPLES + DOWNSAMPLING_FILTER_DELAY); + doppler_index = doppler_index_iteration; + doppler_shift_selected = doppler_shift; + } } top_block->stop(); } @@ -1286,9 +1324,11 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) float threshold = config->property("Acquisition.threshold", FLAGS_external_signal_acquisition_threshold); if (test_statistics > threshold) { + //printf("XXXXXXXXXXXXXXXXXXXXXXXXXXX max index = %d = %d \n", max_index, max_index % nsamples_total); std::cout << " " << PRN << " "; doppler_measurements_map.insert(std::pair(PRN, static_cast(doppler_shift_selected))); code_delay_measurements_map.insert(std::pair(PRN, static_cast(max_index % nsamples_total))); + code_delay_measurements_map.insert(std::pair(PRN, static_cast(max_index))); acq_samplestamp_map.insert(std::pair(PRN, initial_sample)); // should be 0 (first sample upon which acq starts is always 0 in this case) } else @@ -1361,6 +1401,7 @@ bool TrackingPullInTestFpga::acquire_signal(int SV_ID) TEST_F(TrackingPullInTestFpga, ValidationOfResults) { + // pointer to the DMA thread that sends the samples to the acquisition engine pthread_t thread_DMA; @@ -1368,6 +1409,17 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) struct DMA_handler_args args; + int interpolation_factor; + if (implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) + { + interpolation_factor = 4; // downsampling filter in L1/E1 + } + else if (implementation.compare("Galileo_E1_DLL_PLL_VEML_Tracking_Fpga") == 0) + { + interpolation_factor = 4; // downsampling filter in L1/E1 + } + + // // step 0 determine the sampling frequency // if (implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) // { @@ -1451,7 +1503,7 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) } } - + //printf("#################################### CONFIGURE \n"); configure_receiver(FLAGS_PLL_bw_hz_start, FLAGS_DLL_bw_hz_start, FLAGS_PLL_narrow_bw_hz, @@ -1468,6 +1520,7 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) double true_acq_delay_samples = 0.0; uint64_t acq_samplestamp_samples = 0; + //printf("#################################### NEXT\n"); tracking_true_obs_reader true_obs_data; if (!FLAGS_enable_external_signal_file) { @@ -1524,7 +1577,7 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) unsigned int fft_size = pow(2, nbits); - + printf("####################################\n"); for (unsigned int current_cn0_idx = 0; current_cn0_idx < generator_CN0_values.size(); current_cn0_idx++) { std::vector pull_in_results_v; @@ -1548,10 +1601,18 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) // true_acq_doppler_hz = -2500; // true_acq_delay_samples = 5353; -// acq_samplestamp_samples = 523050976; -// true_acq_doppler_hz = 3500; -// true_acq_delay_samples = 932; + //acq_samplestamp_samples = 79470544; + //true_acq_doppler_hz = -4000; + //true_acq_delay_samples = 1292; + if ((implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) or (implementation.compare("Galileo_E1_DLL_PLL_VEML_Tracking_Fpga"))) + { + acq_samplestamp_samples = 0; + + true_acq_delay_samples = true_acq_delay_samples - interpolation_factor*DOWNSAMPLING_FILTER_DELAY; + printf("acq_samplestamp_samples = %d\n", (int)acq_samplestamp_samples); + printf("true_acq_delay_samples = %d\n", (int)true_acq_delay_samples); + } gnss_synchro.Acq_samplestamp_samples = acq_samplestamp_samples; //simulate a Doppler error in acquisition gnss_synchro.Acq_doppler_hz = true_acq_doppler_hz + acq_doppler_error_hz_values.at(current_acq_doppler_error_idx); @@ -1618,24 +1679,76 @@ TEST_F(TrackingPullInTestFpga, ValidationOfResults) }) << "Failure connecting the blocks of tracking test."; + std::string file = FLAGS_signal_file; + + args.file = file; + +// if ((implementation.compare("GPS_L1_CA_DLL_PLL_Tracking_Fpga") == 0) or (implementation.compare("Galileo_E1_DLL_PLL_VEML_Tracking_Fpga"))) +// { +// //---------------------------------------------------------------------------------- +// // send the previous samples to set the downsampling filter in a good condition +// send_samples_start = 0; +// if (skip_samples_already_used == 1 && doppler_control_in_sw == 1) +// { +// args.skip_used_samples = (gnss_synchro.PRN - 1)*fft_size; +// } +// else +// { +// args.skip_used_samples = 0; +// } +// args.nsamples_tx = DOWNSAMPLING_FILTER_DELAY; //50000; // max size of the FFT +// if (pthread_create(&thread_DMA, NULL, handler_DMA, (void *)&args) < 0) +// { +// printf("ERROR cannot create DMA Process\n"); +// } +// pthread_mutex_lock(&mutex); +// send_samples_start = 1; +// pthread_mutex_unlock(&mutex); +// pthread_join(thread_DMA, NULL); +// send_samples_start = 0; +// //printf("finished sending samples init filter status\n"); +// //----------------------------------------------------------------------------------- +// if (skip_samples_already_used == 1 && doppler_control_in_sw == 1) +// { +// args.skip_used_samples = (gnss_synchro.PRN - 1)*fft_size + DOWNSAMPLING_FILTER_DELAY; +// } +// else +// { +// args.skip_used_samples = DOWNSAMPLING_FILTER_DELAY; +// } +// +// } +// else +// { + if (skip_samples_already_used == 1 && doppler_control_in_sw == 1) + { + args.skip_used_samples = (gnss_synchro.PRN - 1)*fft_size; + } + else + { + args.skip_used_samples = 0; + } + // } + + //******************************************************************** //***** STEP 5: Perform the signal tracking and read the results ***** //******************************************************************** - std::string file = FLAGS_signal_file; + //std::string file = FLAGS_signal_file; - args.file = file; + //args.file = file; args.nsamples_tx = NSAMPLES_TRACKING; // number of samples to transfer - if (skip_samples_already_used == 1 && doppler_control_in_sw == 1) - { - args.skip_used_samples = (gnss_synchro.PRN - 1)*fft_size; - } - else - { - args.skip_used_samples = 0; - } +// if (skip_samples_already_used == 1 && doppler_control_in_sw == 1) +// { +// args.skip_used_samples = (gnss_synchro.PRN - 1)*fft_size; +// } +// else +// { +// args.skip_used_samples = 0; +// } //args.skip_used_samples = 0; //printf("||||||||1 args freq_band = %d\n", args.freq_band);