mirror of
				https://github.com/gnss-sdr/gnss-sdr
				synced 2025-10-22 19:17:40 +00:00 
			
		
		
		
	Change rem_carrier_phase_rad computation
This commit is contained in:
		| @@ -719,7 +719,7 @@ void dll_pll_veml_tracking::do_correlation_step(const gr_complex *input_samples) | |||||||
|     // ################# 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.set_input_output_vectors(d_correlator_outs, input_samples); |     multicorrelator_cpu.set_input_output_vectors(d_correlator_outs, input_samples); | ||||||
|     float tmp_f = d_rem_carr_phase_rad; |     //float tmp_f = d_rem_carr_phase_rad; | ||||||
|     multicorrelator_cpu.Carrier_wipeoff_multicorrelator_resampler( |     multicorrelator_cpu.Carrier_wipeoff_multicorrelator_resampler( | ||||||
|         d_rem_carr_phase_rad, |         d_rem_carr_phase_rad, | ||||||
|         d_carrier_phase_step_rad, d_carrier_phase_rate_step_rad, |         d_carrier_phase_step_rad, d_carrier_phase_rate_step_rad, | ||||||
| @@ -733,7 +733,7 @@ void dll_pll_veml_tracking::do_correlation_step(const gr_complex *input_samples) | |||||||
|         { |         { | ||||||
|             correlator_data_cpu.set_input_output_vectors(d_Prompt_Data, input_samples); |             correlator_data_cpu.set_input_output_vectors(d_Prompt_Data, input_samples); | ||||||
|             correlator_data_cpu.Carrier_wipeoff_multicorrelator_resampler( |             correlator_data_cpu.Carrier_wipeoff_multicorrelator_resampler( | ||||||
|                 tmp_f, |                 d_rem_carr_phase_rad, | ||||||
|                 d_carrier_phase_step_rad, d_carrier_phase_rate_step_rad, |                 d_carrier_phase_step_rad, d_carrier_phase_rate_step_rad, | ||||||
|                 static_cast<float>(d_rem_code_phase_chips) * static_cast<float>(d_code_samples_per_chip), |                 static_cast<float>(d_rem_code_phase_chips) * static_cast<float>(d_code_samples_per_chip), | ||||||
|                 static_cast<float>(d_code_phase_step_chips) * static_cast<float>(d_code_samples_per_chip), |                 static_cast<float>(d_code_phase_step_chips) * static_cast<float>(d_code_samples_per_chip), | ||||||
| @@ -793,6 +793,10 @@ void dll_pll_veml_tracking::clear_tracking_vars() | |||||||
|     d_current_symbol = 0; |     d_current_symbol = 0; | ||||||
|     d_Prompt_buffer_deque.clear(); |     d_Prompt_buffer_deque.clear(); | ||||||
|     d_last_prompt = gr_complex(0.0, 0.0); |     d_last_prompt = gr_complex(0.0, 0.0); | ||||||
|  |     d_carrier_phase_rate_step_rad = 0.0; | ||||||
|  |     d_code_phase_rate_step_chips = 0.0; | ||||||
|  |     d_carr_ph_history.clear(); | ||||||
|  |     d_code_ph_history.clear(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -811,19 +815,13 @@ void dll_pll_veml_tracking::update_tracking_vars() | |||||||
|  |  | ||||||
|     //################### PLL COMMANDS ################################################# |     //################### PLL COMMANDS ################################################# | ||||||
|     // carrier phase step (NCO phase increment per sample) [rads/sample] |     // carrier phase step (NCO phase increment per sample) [rads/sample] | ||||||
|     // carrier phase difference = carrier_phase(t2) - carrier_phase(t1) |  | ||||||
|     //double tmp_diff = -d_carrier_phase_step_rad;  // The previous cp value is stored in the variable |  | ||||||
|     d_carrier_phase_step_rad = PI_2 * d_carrier_doppler_hz / trk_parameters.fs_in; |     d_carrier_phase_step_rad = PI_2 * d_carrier_doppler_hz / trk_parameters.fs_in; | ||||||
|     //tmp_diff += d_carrier_phase_step_rad;  // The new cp value is added to the previous in order to obtain the difference |  | ||||||
|     // carrier phase rate step (NCO phase increment rate per sample) [rads/sample^2] |     // carrier phase rate step (NCO phase increment rate per sample) [rads/sample^2] | ||||||
|     //tmp_diff /= static_cast<double>(d_current_prn_length_samples); |  | ||||||
|     if (trk_parameters.high_dyn) |     if (trk_parameters.high_dyn) | ||||||
|         { |         { | ||||||
|             d_carr_ph_history.push_back(std::pair<double, double>(d_carrier_phase_step_rad, static_cast<double>(d_current_prn_length_samples))); |             d_carr_ph_history.push_back(std::pair<double, double>(d_carrier_phase_step_rad, static_cast<double>(d_current_prn_length_samples))); | ||||||
|             if (d_carr_ph_history.full()) |             if (d_carr_ph_history.full()) | ||||||
|                 { |                 { | ||||||
|                     //d_carr_ph_history.front().second = 0.0; |  | ||||||
|                     //d_carr_ph_history.at(trk_parameters.smoother_length).second = 0.0; |  | ||||||
|                     double tmp_cp1 = 0.0; |                     double tmp_cp1 = 0.0; | ||||||
|                     double tmp_cp2 = 0.0; |                     double tmp_cp2 = 0.0; | ||||||
|                     double tmp_samples = 0.0; |                     double tmp_samples = 0.0; | ||||||
| @@ -838,11 +836,9 @@ void dll_pll_veml_tracking::update_tracking_vars() | |||||||
|                     d_carrier_phase_rate_step_rad = (tmp_cp2 - tmp_cp1) / tmp_samples; |                     d_carrier_phase_rate_step_rad = (tmp_cp2 - tmp_cp1) / tmp_samples; | ||||||
|                 } |                 } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     // Now the remnant carrier phase is computed in the Carrier Wipeoff function |  | ||||||
|     // remnant 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_carrier_phase_step_rad * static_cast<double>(d_current_prn_length_samples) + 0.5 * d_carrier_phase_rate_step_rad * static_cast<double>(d_current_prn_length_samples) * static_cast<double>(d_current_prn_length_samples)); |     d_rem_carr_phase_rad += static_cast<float>(d_carrier_phase_step_rad * static_cast<double>(d_current_prn_length_samples) + 0.5 * d_carrier_phase_rate_step_rad * static_cast<double>(d_current_prn_length_samples) * static_cast<double>(d_current_prn_length_samples)); | ||||||
|     //d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, PI_2); |     d_rem_carr_phase_rad = fmod(d_rem_carr_phase_rad, PI_2); | ||||||
|  |  | ||||||
|  |  | ||||||
|     // carrier phase accumulator |     // carrier phase accumulator | ||||||
| @@ -850,17 +846,12 @@ void dll_pll_veml_tracking::update_tracking_vars() | |||||||
|  |  | ||||||
|     //################### DLL COMMANDS ################################################# |     //################### DLL COMMANDS ################################################# | ||||||
|     // code phase step (Code resampler phase increment per sample) [chips/sample] |     // code phase step (Code resampler phase increment per sample) [chips/sample] | ||||||
|     //tmp_diff = -d_code_phase_step_chips; |  | ||||||
|     d_code_phase_step_chips = d_code_freq_chips / trk_parameters.fs_in; |     d_code_phase_step_chips = d_code_freq_chips / trk_parameters.fs_in; | ||||||
|     //tmp_diff += d_code_phase_step_chips; |  | ||||||
|     //tmp_diff /= static_cast<double>(d_current_prn_length_samples); |  | ||||||
|     if (trk_parameters.high_dyn) |     if (trk_parameters.high_dyn) | ||||||
|         { |         { | ||||||
|             d_code_ph_history.push_back(std::pair<double, double>(d_code_phase_step_chips, static_cast<double>(d_current_prn_length_samples))); |             d_code_ph_history.push_back(std::pair<double, double>(d_code_phase_step_chips, static_cast<double>(d_current_prn_length_samples))); | ||||||
|             if (d_code_ph_history.full()) |             if (d_code_ph_history.full()) | ||||||
|                 { |                 { | ||||||
|                     //d_code_ph_history.front().second = 0.0; |  | ||||||
|                     //d_code_ph_history.at(trk_parameters.smoother_length).second = 0.0; |  | ||||||
|                     double tmp_cp1 = 0.0; |                     double tmp_cp1 = 0.0; | ||||||
|                     double tmp_cp2 = 0.0; |                     double tmp_cp2 = 0.0; | ||||||
|                     double tmp_samples = 0.0; |                     double tmp_samples = 0.0; | ||||||
|   | |||||||
| @@ -127,7 +127,7 @@ void cpu_multicorrelator_real_codes::update_local_code(int correlator_length_sam | |||||||
|  |  | ||||||
| // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility | // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility | ||||||
| bool cpu_multicorrelator_real_codes::Carrier_wipeoff_multicorrelator_resampler( | bool cpu_multicorrelator_real_codes::Carrier_wipeoff_multicorrelator_resampler( | ||||||
|     float& rem_carrier_phase_in_rad, |     float rem_carrier_phase_in_rad, | ||||||
|     float phase_step_rad, |     float phase_step_rad, | ||||||
|     float phase_rate_step_rad, |     float phase_rate_step_rad, | ||||||
|     float rem_code_phase_chips, |     float rem_code_phase_chips, | ||||||
| @@ -148,7 +148,7 @@ bool cpu_multicorrelator_real_codes::Carrier_wipeoff_multicorrelator_resampler( | |||||||
|         { |         { | ||||||
|             volk_gnsssdr_32fc_32f_rotator_dot_prod_32fc_xn(d_corr_out, d_sig_in, std::exp(lv_32fc_t(0.0, -phase_step_rad)), phase_offset_as_complex, const_cast<const float**>(d_local_codes_resampled), d_n_correlators, signal_length_samples); |             volk_gnsssdr_32fc_32f_rotator_dot_prod_32fc_xn(d_corr_out, d_sig_in, std::exp(lv_32fc_t(0.0, -phase_step_rad)), phase_offset_as_complex, const_cast<const float**>(d_local_codes_resampled), d_n_correlators, signal_length_samples); | ||||||
|         } |         } | ||||||
|     rem_carrier_phase_in_rad = std::arg(std::conj(phase_offset_as_complex[0])); |     //rem_carrier_phase_in_rad = std::arg(std::conj(phase_offset_as_complex[0])); | ||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility | // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ public: | |||||||
|     bool set_input_output_vectors(std::complex<float> *corr_out, const std::complex<float> *sig_in); |     bool set_input_output_vectors(std::complex<float> *corr_out, const std::complex<float> *sig_in); | ||||||
|     void update_local_code(int correlator_length_samples, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips = 0.0); |     void update_local_code(int correlator_length_samples, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips = 0.0); | ||||||
|     // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility |     // Overload Carrier_wipeoff_multicorrelator_resampler to ensure back compatibility | ||||||
|     bool Carrier_wipeoff_multicorrelator_resampler(float &rem_carrier_phase_in_rad, float phase_step_rad, float phase_rate_step_rad, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips, int signal_length_samples); |     bool Carrier_wipeoff_multicorrelator_resampler(float rem_carrier_phase_in_rad, float phase_step_rad, float phase_rate_step_rad, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips, int signal_length_samples); | ||||||
|     bool Carrier_wipeoff_multicorrelator_resampler(float rem_carrier_phase_in_rad, float phase_step_rad, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips, int signal_length_samples); |     bool Carrier_wipeoff_multicorrelator_resampler(float rem_carrier_phase_in_rad, float phase_step_rad, float rem_code_phase_chips, float code_phase_step_chips, float code_phase_rate_step_chips, int signal_length_samples); | ||||||
|     bool free(); |     bool free(); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Antonio Ramos
					Antonio Ramos