mirror of
				https://github.com/gnss-sdr/gnss-sdr
				synced 2025-10-25 04:27:39 +00:00 
			
		
		
		
	Merge branch 'obs-interval' into next
This commit is contained in:
		| @@ -103,6 +103,9 @@ All notable changes to GNSS-SDR will be documented in this file. | |||||||
|   https://github.com/analogdevicesinc/gr-iio. If the GNU Radio module is found, |   https://github.com/analogdevicesinc/gr-iio. If the GNU Radio module is found, | ||||||
|   the other one is ignored. |   the other one is ignored. | ||||||
| - File `changelog.md` renamed to the more usual `CHANGELOG.md` uppercase name. | - File `changelog.md` renamed to the more usual `CHANGELOG.md` uppercase name. | ||||||
|  | - New global configuration parameter `GNSS-SDR.observable_interval_ms`, set by | ||||||
|  |   default to 20 [ms], allows to control the internal rate at which computed | ||||||
|  |   observables sets are processed (50 observables sets per second by default). | ||||||
|  |  | ||||||
| See the definitions of concepts and metrics at | See the definitions of concepts and metrics at | ||||||
| https://gnss-sdr.org/design-forces/ | https://gnss-sdr.org/design-forces/ | ||||||
|   | |||||||
| @@ -58,7 +58,9 @@ Rtklib_Pvt::Rtklib_Pvt(const ConfigurationInterface* configuration, | |||||||
|     pvt_output_parameters.pre_2009_file = configuration->property("GNSS-SDR.pre_2009_file", false); |     pvt_output_parameters.pre_2009_file = configuration->property("GNSS-SDR.pre_2009_file", false); | ||||||
|  |  | ||||||
|     // output rate |     // output rate | ||||||
|     pvt_output_parameters.output_rate_ms = bc::lcm(20, configuration->property(role + ".output_rate_ms", 500)); |     pvt_output_parameters.observable_interval_ms = configuration->property("GNSS-SDR.observable_interval_ms", pvt_output_parameters.observable_interval_ms); | ||||||
|  |  | ||||||
|  |     pvt_output_parameters.output_rate_ms = bc::lcm(static_cast<int>(pvt_output_parameters.observable_interval_ms), configuration->property(role + ".output_rate_ms", 500)); | ||||||
|  |  | ||||||
|     // display rate |     // display rate | ||||||
|     pvt_output_parameters.display_rate_ms = bc::lcm(pvt_output_parameters.output_rate_ms, configuration->property(role + ".display_rate_ms", 500)); |     pvt_output_parameters.display_rate_ms = bc::lcm(pvt_output_parameters.output_rate_ms, configuration->property(role + ".display_rate_ms", 500)); | ||||||
|   | |||||||
| @@ -173,6 +173,7 @@ rtklib_pvt_gs::rtklib_pvt_gs(uint32_t nchannels, | |||||||
|     d_nchannels = nchannels; |     d_nchannels = nchannels; | ||||||
|  |  | ||||||
|     d_type_of_rx = conf_.type_of_receiver; |     d_type_of_rx = conf_.type_of_receiver; | ||||||
|  |     d_observable_interval_ms = conf_.observable_interval_ms; | ||||||
|  |  | ||||||
|     // GPS Ephemeris data message port in |     // GPS Ephemeris data message port in | ||||||
|     this->message_port_register_in(pmt::mp("telemetry")); |     this->message_port_register_in(pmt::mp("telemetry")); | ||||||
| @@ -2003,8 +2004,8 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item | |||||||
|                                             if (!d_gnss_observables_map_t0.empty()) |                                             if (!d_gnss_observables_map_t0.empty()) | ||||||
|                                                 { |                                                 { | ||||||
|                                                     const auto t0_int_ms = static_cast<uint32_t>(d_gnss_observables_map_t0.cbegin()->second.RX_time * 1000.0); |                                                     const auto t0_int_ms = static_cast<uint32_t>(d_gnss_observables_map_t0.cbegin()->second.RX_time * 1000.0); | ||||||
|                                                     const uint32_t adjust_next_20ms = 20 - t0_int_ms % 20; |                                                     const uint32_t adjust_next_obs_interval_ms = d_observable_interval_ms - t0_int_ms % d_observable_interval_ms; | ||||||
|                                                     current_RX_time_ms = t0_int_ms + adjust_next_20ms; |                                                     current_RX_time_ms = t0_int_ms + adjust_next_obs_interval_ms; | ||||||
|  |  | ||||||
|                                                     if (current_RX_time_ms % d_output_rate_ms == 0) |                                                     if (current_RX_time_ms % d_output_rate_ms == 0) | ||||||
|                                                         { |                                                         { | ||||||
|   | |||||||
| @@ -254,6 +254,7 @@ private: | |||||||
|  |  | ||||||
|     uint32_t d_nchannels; |     uint32_t d_nchannels; | ||||||
|     uint32_t d_type_of_rx; |     uint32_t d_type_of_rx; | ||||||
|  |     uint32_t d_observable_interval_ms; | ||||||
|  |  | ||||||
|     bool d_dump; |     bool d_dump; | ||||||
|     bool d_dump_mat; |     bool d_dump_mat; | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| Pvt_Conf::Pvt_Conf() | Pvt_Conf::Pvt_Conf() | ||||||
| { | { | ||||||
|     type_of_receiver = 0U; |     type_of_receiver = 0U; | ||||||
|  |     observable_interval_ms = 20U; | ||||||
|     output_rate_ms = 0; |     output_rate_ms = 0; | ||||||
|     display_rate_ms = 0; |     display_rate_ms = 0; | ||||||
|     kml_rate_ms = 1000; |     kml_rate_ms = 1000; | ||||||
|   | |||||||
| @@ -51,6 +51,8 @@ public: | |||||||
|     std::string udp_eph_addresses; |     std::string udp_eph_addresses; | ||||||
|  |  | ||||||
|     uint32_t type_of_receiver; |     uint32_t type_of_receiver; | ||||||
|  |     uint32_t observable_interval_ms; | ||||||
|  |  | ||||||
|     int32_t output_rate_ms; |     int32_t output_rate_ms; | ||||||
|     int32_t display_rate_ms; |     int32_t display_rate_ms; | ||||||
|     int32_t kml_rate_ms; |     int32_t kml_rate_ms; | ||||||
|   | |||||||
| @@ -31,13 +31,14 @@ HybridObservables::HybridObservables(const ConfigurationInterface* configuration | |||||||
|     dump_mat_ = configuration->property(role + ".dump_mat", true); |     dump_mat_ = configuration->property(role + ".dump_mat", true); | ||||||
|     dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename); |     dump_filename_ = configuration->property(role + ".dump_filename", default_dump_filename); | ||||||
|  |  | ||||||
|     Obs_Conf conf; |     Obs_Conf conf{}; | ||||||
|  |  | ||||||
|     conf.dump = dump_; |     conf.dump = dump_; | ||||||
|     conf.dump_mat = dump_mat_; |     conf.dump_mat = dump_mat_; | ||||||
|     conf.dump_filename = dump_filename_; |     conf.dump_filename = dump_filename_; | ||||||
|     conf.nchannels_in = in_streams_; |     conf.nchannels_in = in_streams_; | ||||||
|     conf.nchannels_out = out_streams_; |     conf.nchannels_out = out_streams_; | ||||||
|  |     conf.observable_interval_ms = configuration->property("GNSS-SDR.observable_interval_ms", conf.observable_interval_ms); | ||||||
|     conf.enable_carrier_smoothing = configuration->property(role + ".enable_carrier_smoothing", conf.enable_carrier_smoothing); |     conf.enable_carrier_smoothing = configuration->property(role + ".enable_carrier_smoothing", conf.enable_carrier_smoothing); | ||||||
|  |  | ||||||
|     if (FLAGS_carrier_smoothing_factor == DEFAULT_CARRIER_SMOOTHING_FACTOR) |     if (FLAGS_carrier_smoothing_factor == DEFAULT_CARRIER_SMOOTHING_FACTOR) | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ | |||||||
| #include <glog/logging.h> | #include <glog/logging.h> | ||||||
| #include <gnuradio/io_signature.h> | #include <gnuradio/io_signature.h> | ||||||
| #include <matio.h> | #include <matio.h> | ||||||
|  | #include <algorithm>  // for std::min | ||||||
| #include <array> | #include <array> | ||||||
| #include <cmath>      // for round | #include <cmath>      // for round | ||||||
| #include <cstdlib>    // for size_t, llabs | #include <cstdlib>    // for size_t, llabs | ||||||
| @@ -117,12 +118,11 @@ hybrid_observables_gs::hybrid_observables_gs(const Obs_Conf &conf_) : gr::block( | |||||||
|                 } |                 } | ||||||
|         } |         } | ||||||
|     d_T_rx_TOW_ms = 0U; |     d_T_rx_TOW_ms = 0U; | ||||||
|     d_T_rx_step_ms = 20;  // read from config at the adapter GNSS-SDR.observable_interval_ms!! |     d_T_rx_step_ms = conf_.observable_interval_ms; | ||||||
|     d_T_rx_TOW_set = false; |     d_T_rx_TOW_set = false; | ||||||
|     d_T_status_report_timer_ms = 0; |     d_T_status_report_timer_ms = 0; | ||||||
|     // rework |     d_Rx_clock_buffer.set_capacity(std::min(std::max(200U / d_T_rx_step_ms, 3U), 10U)); | ||||||
|     d_Rx_clock_buffer.set_capacity(10);  // 10*20 ms = 200 ms of data in buffer |     d_Rx_clock_buffer.clear(); | ||||||
|     d_Rx_clock_buffer.clear();           // Clear all the elements in the buffer |  | ||||||
|  |  | ||||||
|     d_channel_last_pll_lock = std::vector<bool>(d_nchannels_out, false); |     d_channel_last_pll_lock = std::vector<bool>(d_nchannels_out, false); | ||||||
|     d_channel_last_pseudorange_smooth = std::vector<double>(d_nchannels_out, 0.0); |     d_channel_last_pseudorange_smooth = std::vector<double>(d_nchannels_out, 0.0); | ||||||
| @@ -191,10 +191,10 @@ void hybrid_observables_gs::msg_handler_pvt_to_observables(const pmt::pmt_t &msg | |||||||
|                 { |                 { | ||||||
|                     const auto new_rx_clock_offset_s = boost::any_cast<double>(pmt::any_ref(msg)); |                     const auto new_rx_clock_offset_s = boost::any_cast<double>(pmt::any_ref(msg)); | ||||||
|                     d_T_rx_TOW_ms = d_T_rx_TOW_ms - static_cast<int>(round(new_rx_clock_offset_s * 1000.0)); |                     d_T_rx_TOW_ms = d_T_rx_TOW_ms - static_cast<int>(round(new_rx_clock_offset_s * 1000.0)); | ||||||
|                     // align the receiver clock to integer multiple of 20 ms |                     // align the receiver clock to integer multiple of d_T_rx_step_ms | ||||||
|                     if (d_T_rx_TOW_ms % 20) |                     if (d_T_rx_TOW_ms % d_T_rx_step_ms) | ||||||
|                         { |                         { | ||||||
|                             d_T_rx_TOW_ms += 20 - d_T_rx_TOW_ms % 20; |                             d_T_rx_TOW_ms += d_T_rx_step_ms - d_T_rx_TOW_ms % d_T_rx_step_ms; | ||||||
|                         } |                         } | ||||||
|                     // d_Rx_clock_buffer.clear();  // Clear all the elements in the buffer |                     // d_Rx_clock_buffer.clear();  // Clear all the elements in the buffer | ||||||
|                     for (uint32_t n = 0; n < d_nchannels_out; n++) |                     for (uint32_t n = 0; n < d_nchannels_out; n++) | ||||||
| @@ -371,7 +371,7 @@ bool hybrid_observables_gs::interp_trk_obs(Gnss_Synchro &interpolated_obs, uint3 | |||||||
|  |  | ||||||
|     if (nearest_element != -1 and nearest_element != static_cast<int32_t>(d_gnss_synchro_history->size(ch))) |     if (nearest_element != -1 and nearest_element != static_cast<int32_t>(d_gnss_synchro_history->size(ch))) | ||||||
|         { |         { | ||||||
|             if ((static_cast<double>(old_abs_diff) / static_cast<double>(d_gnss_synchro_history->get(ch, nearest_element).fs)) < 0.02) |             if ((static_cast<double>(old_abs_diff) / static_cast<double>(d_gnss_synchro_history->get(ch, nearest_element).fs)) < static_cast<double>(d_T_rx_step_ms) / 1000.0) | ||||||
|                 { |                 { | ||||||
|                     int32_t neighbor_element; |                     int32_t neighbor_element; | ||||||
|                     if (rx_clock > d_gnss_synchro_history->get(ch, nearest_element).Tracking_sample_counter) |                     if (rx_clock > d_gnss_synchro_history->get(ch, nearest_element).Tracking_sample_counter) | ||||||
| @@ -483,10 +483,10 @@ void hybrid_observables_gs::update_TOW(const std::vector<Gnss_Synchro> &data) | |||||||
|                         } |                         } | ||||||
|                 } |                 } | ||||||
|             d_T_rx_TOW_ms = TOW_ref; |             d_T_rx_TOW_ms = TOW_ref; | ||||||
|             // align the receiver clock to integer multiple of 20 ms |             // align the receiver clock to integer multiple of d_T_rx_step_ms | ||||||
|             if (d_T_rx_TOW_ms % 20) |             if (d_T_rx_TOW_ms % d_T_rx_step_ms) | ||||||
|                 { |                 { | ||||||
|                     d_T_rx_TOW_ms += 20 - d_T_rx_TOW_ms % 20; |                     d_T_rx_TOW_ms += d_T_rx_step_ms - d_T_rx_TOW_ms % d_T_rx_step_ms; | ||||||
|                 } |                 } | ||||||
|         } |         } | ||||||
|     else |     else | ||||||
|   | |||||||
| @@ -22,8 +22,9 @@ Obs_Conf::Obs_Conf() | |||||||
| { | { | ||||||
|     dump_filename = std::string("obs_dump.dat"); |     dump_filename = std::string("obs_dump.dat"); | ||||||
|     smoothing_factor = FLAGS_carrier_smoothing_factor; |     smoothing_factor = FLAGS_carrier_smoothing_factor; | ||||||
|     nchannels_in = 0; |     nchannels_in = 0U; | ||||||
|     nchannels_out = 0; |     nchannels_out = 0U; | ||||||
|  |     observable_interval_ms = 20U; | ||||||
|     enable_carrier_smoothing = false; |     enable_carrier_smoothing = false; | ||||||
|     dump = false; |     dump = false; | ||||||
|     dump_mat = false; |     dump_mat = false; | ||||||
|   | |||||||
| @@ -36,6 +36,7 @@ public: | |||||||
|     int32_t smoothing_factor; |     int32_t smoothing_factor; | ||||||
|     uint32_t nchannels_in; |     uint32_t nchannels_in; | ||||||
|     uint32_t nchannels_out; |     uint32_t nchannels_out; | ||||||
|  |     uint32_t observable_interval_ms; | ||||||
|     bool enable_carrier_smoothing; |     bool enable_carrier_smoothing; | ||||||
|     bool dump; |     bool dump; | ||||||
|     bool dump_mat; |     bool dump_mat; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Carles Fernandez
					Carles Fernandez