59class dll_pll_veml_tracking_fpga :
public gr::block
70 void set_channel(uint32_t channel,
const std::string &device_io_name);
96 gr_vector_const_void_star &input_items, gr_vector_void_star &output_items);
104 friend dll_pll_veml_tracking_fpga_sptr dll_pll_veml_make_tracking_fpga(
const Dll_Pll_Conf_Fpga &conf_);
107 void msg_handler_telemetry_to_trk(
const pmt::pmt_t &msg);
108 bool cn0_and_tracking_lock_status(
double coh_integration_time_s);
109 bool acquire_secondary();
110 void do_correlation_step();
112 void check_carrier_phase_coherent_initialization();
113 void update_tracking_vars();
114 void clear_tracking_vars();
115 void save_correlation_results();
117 void configure_bit_synchronizer();
118 int32_t save_matfile()
const;
131 volk_gnsssdr::vector<float> d_local_code_shift_chips;
132 volk_gnsssdr::vector<gr_complex> d_correlator_outs;
133 volk_gnsssdr::vector<gr_complex> d_Prompt_Data;
134 volk_gnsssdr::vector<gr_complex> d_Prompt_buffer;
136 boost::circular_buffer<float> d_dll_filt_history;
137 boost::circular_buffer<std::pair<double, double>> d_code_ph_history;
138 boost::circular_buffer<std::pair<double, double>> d_carr_ph_history;
139 boost::circular_buffer<gr_complex> d_Prompt_circular_buffer;
141 std::string d_systemName;
142 std::string d_signal_type;
143 std::string d_secondary_code_string;
144 std::string d_data_secondary_code_string;
145 std::string d_signal_pretty_name;
146 std::string d_dump_filename;
148 std::ofstream d_dump_file;
150 std::shared_ptr<Fpga_Multicorrelator_8sc> d_multicorrelator_fpga;
152 boost::condition_variable d_m_condition;
154 boost::mutex d_mutex;
156 const size_t int_type_hash_code =
typeid(int).hash_code();
158 double d_signal_carrier_freq;
159 double d_code_period;
160 double d_code_chip_rate;
161 double d_code_phase_step_chips;
162 double d_code_phase_rate_step_chips;
163 double d_carrier_phase_step_rad;
164 double d_carrier_phase_rate_step_rad;
165 double d_acq_code_phase_samples;
166 double d_acq_carrier_doppler_hz;
167 double d_rem_code_phase_samples;
168 double d_rem_code_phase_samples_prev;
169 double d_current_correlation_time_s;
170 double d_carr_phase_error_hz;
171 double d_carr_freq_error_hz;
172 double d_carr_error_filt_hz;
173 double d_code_error_chips;
174 double d_code_error_filt_chips;
175 double d_code_freq_chips;
176 double d_carrier_doppler_hz;
177 double d_acc_carrier_phase_rad;
178 double d_rem_code_phase_chips;
179 double d_T_chip_seconds;
180 double d_T_prn_seconds;
181 double d_T_prn_samples;
182 double d_K_blk_samples;
183 double d_carrier_lock_test;
184 double d_CN0_SNV_dB_Hz;
185 double d_carrier_lock_threshold;
187 gr_complex *d_Very_Early;
189 gr_complex *d_Prompt;
191 gr_complex *d_Very_Late;
193 gr_complex d_VE_accu;
196 gr_complex d_P_accu_old;
198 gr_complex d_VL_accu;
199 gr_complex d_P_data_accu;
201 uint64_t d_sample_counter;
202 uint64_t d_acq_sample_stamp;
203 uint64_t d_sample_counter_next;
204 int64_t d_bit_sync_target_epoch{};
206 float *d_prompt_data_shift;
207 float d_rem_carr_phase_rad;
209 int32_t d_symbols_per_bit;
211 int32_t d_extend_correlation_symbols_count;
212 int32_t d_current_symbol;
213 int32_t d_current_data_symbol;
214 int32_t d_current_integration_length_samples;
215 int32_t d_cn0_estimation_counter;
216 int32_t d_carrier_lock_fail_counter;
217 int32_t d_code_lock_fail_counter;
218 int32_t d_correlation_length_ms;
219 int32_t d_n_correlator_taps;
220 int32_t d_next_integration_length_samples;
221 int32_t d_extend_fpga_integration_periods;
224 uint32_t d_secondary_code_length;
225 uint32_t d_data_secondary_code_length;
226 uint32_t d_code_length_chips;
227 uint32_t d_code_samples_per_chip;
228 uint32_t d_fpga_integration_period;
229 uint32_t d_current_fpga_integration_period;
234 bool d_enable_extended_integration;
237 bool d_pull_in_transitory;
238 bool d_corrected_doppler;
239 bool d_interchange_iq;
240 bool d_acc_carrier_phase_initialized;
241 bool d_worker_is_done;
242 bool d_extended_correlation_in_fpga;
243 bool d_current_extended_correlation_in_fpga;
244 bool d_stop_tracking;
245 bool d_sc_demodulate_enabled;
246 bool d_Flag_PLL_180_deg_phase_locked;
247 bool d_use_histogram_bit_sync;
248 bool d_wait_for_bit_edge{
false};