mirror of
				https://github.com/gnss-sdr/gnss-sdr
				synced 2025-10-25 20:47:39 +00:00 
			
		
		
		
	Use unique_ptr instead of shared_ptr for d_gnss_synchro_history, and code cleaning
This commit is contained in:
		| @@ -23,6 +23,7 @@ | ||||
| #include "MATH_CONSTANTS.h"  // for SPEED_OF_LIGHT | ||||
| #include "gnss_circular_deque.h" | ||||
| #include "gnss_sdr_create_directory.h" | ||||
| #include "gnss_sdr_make_unique.h" | ||||
| #include "gnss_synchro.h" | ||||
| #include <glog/logging.h> | ||||
| #include <gnuradio/io_signature.h> | ||||
| @@ -90,7 +91,7 @@ hybrid_observables_gs::hybrid_observables_gs(const Obs_Conf &conf_) : gr::block( | ||||
|     d_dump_filename = conf_.dump_filename; | ||||
|     d_nchannels_out = conf_.nchannels_out; | ||||
|     d_nchannels_in = conf_.nchannels_in; | ||||
|     d_gnss_synchro_history = std::make_shared<Gnss_circular_deque<Gnss_Synchro>>(1000, d_nchannels_out); | ||||
|     d_gnss_synchro_history = std::make_unique<Gnss_circular_deque<Gnss_Synchro>>(1000, d_nchannels_out); | ||||
|  | ||||
|     // ############# ENABLE DATA FILE LOG ################# | ||||
|     if (d_dump) | ||||
| @@ -136,10 +137,10 @@ hybrid_observables_gs::hybrid_observables_gs(const Obs_Conf &conf_) : gr::block( | ||||
|                     d_dump = false; | ||||
|                 } | ||||
|         } | ||||
|     T_rx_TOW_ms = 0U; | ||||
|     T_rx_step_ms = 20;  // read from config at the adapter GNSS-SDR.observable_interval_ms!! | ||||
|     T_rx_TOW_set = false; | ||||
|     T_status_report_timer_ms = 0; | ||||
|     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_TOW_set = false; | ||||
|     d_T_status_report_timer_ms = 0; | ||||
|     // rework | ||||
|     d_Rx_clock_buffer.set_capacity(10);  // 10*20 ms = 200 ms of data in buffer | ||||
|     d_Rx_clock_buffer.clear();           // Clear all the elements in the buffer | ||||
| @@ -198,11 +199,11 @@ void hybrid_observables_gs::msg_handler_pvt_to_observables(const pmt::pmt_t &msg | ||||
|                 { | ||||
|                     double new_rx_clock_offset_s; | ||||
|                     new_rx_clock_offset_s = boost::any_cast<double>(pmt::any_ref(msg)); | ||||
|                     T_rx_TOW_ms = 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 | ||||
|                     if (T_rx_TOW_ms % 20) | ||||
|                     if (d_T_rx_TOW_ms % 20) | ||||
|                         { | ||||
|                             T_rx_TOW_ms += 20 - T_rx_TOW_ms % 20; | ||||
|                             d_T_rx_TOW_ms += 20 - d_T_rx_TOW_ms % 20; | ||||
|                         } | ||||
|                     // d_Rx_clock_buffer.clear();  // Clear all the elements in the buffer | ||||
|                     for (uint32_t n = 0; n < d_nchannels_out; n++) | ||||
| @@ -220,7 +221,7 @@ void hybrid_observables_gs::msg_handler_pvt_to_observables(const pmt::pmt_t &msg | ||||
| } | ||||
|  | ||||
|  | ||||
| int32_t hybrid_observables_gs::save_matfile() | ||||
| int32_t hybrid_observables_gs::save_matfile() const | ||||
| { | ||||
|     // READ DUMP FILE | ||||
|     std::string dump_filename = d_dump_filename; | ||||
| @@ -357,13 +358,13 @@ int32_t hybrid_observables_gs::save_matfile() | ||||
| } | ||||
|  | ||||
|  | ||||
| double hybrid_observables_gs::compute_T_rx_s(const Gnss_Synchro &a) | ||||
| double hybrid_observables_gs::compute_T_rx_s(const Gnss_Synchro &a) const | ||||
| { | ||||
|     return ((static_cast<double>(a.Tracking_sample_counter) + a.Code_phase_samples) / static_cast<double>(a.fs)); | ||||
| } | ||||
|  | ||||
|  | ||||
| bool hybrid_observables_gs::interp_trk_obs(Gnss_Synchro &interpolated_obs, const uint32_t &ch, const uint64_t &rx_clock) | ||||
| bool hybrid_observables_gs::interp_trk_obs(Gnss_Synchro &interpolated_obs, uint32_t ch, uint64_t rx_clock) const | ||||
| { | ||||
|     int32_t nearest_element = -1; | ||||
|     int64_t abs_diff; | ||||
| @@ -476,7 +477,7 @@ void hybrid_observables_gs::update_TOW(const std::vector<Gnss_Synchro> &data) | ||||
|     // 2. If the TOW is set, it must be incremented by the desired receiver time step. | ||||
|     //    the time step must match the observables timer block (connected to the las input channel) | ||||
|     std::vector<Gnss_Synchro>::const_iterator it; | ||||
|     if (!T_rx_TOW_set) | ||||
|     if (!d_T_rx_TOW_set) | ||||
|         { | ||||
|             // int32_t TOW_ref = std::numeric_limits<uint32_t>::max(); | ||||
|             uint32_t TOW_ref = 0U; | ||||
| @@ -487,35 +488,35 @@ void hybrid_observables_gs::update_TOW(const std::vector<Gnss_Synchro> &data) | ||||
|                             if (it->TOW_at_current_symbol_ms > TOW_ref) | ||||
|                                 { | ||||
|                                     TOW_ref = it->TOW_at_current_symbol_ms; | ||||
|                                     T_rx_TOW_set = true; | ||||
|                                     d_T_rx_TOW_set = true; | ||||
|                                 } | ||||
|                         } | ||||
|                 } | ||||
|             T_rx_TOW_ms = TOW_ref; | ||||
|             d_T_rx_TOW_ms = TOW_ref; | ||||
|             // align the receiver clock to integer multiple of 20 ms | ||||
|             if (T_rx_TOW_ms % 20) | ||||
|             if (d_T_rx_TOW_ms % 20) | ||||
|                 { | ||||
|                     T_rx_TOW_ms += 20 - T_rx_TOW_ms % 20; | ||||
|                     d_T_rx_TOW_ms += 20 - d_T_rx_TOW_ms % 20; | ||||
|                 } | ||||
|         } | ||||
|     else | ||||
|         { | ||||
|             T_rx_TOW_ms += T_rx_step_ms;  // the tow time step increment must match the ref time channel step | ||||
|             if (T_rx_TOW_ms >= 604800000) | ||||
|             d_T_rx_TOW_ms += d_T_rx_step_ms;  // the tow time step increment must match the ref time channel step | ||||
|             if (d_T_rx_TOW_ms >= 604800000) | ||||
|                 { | ||||
|                     DLOG(INFO) << "TOW RX TIME rollover!"; | ||||
|                     T_rx_TOW_ms = T_rx_TOW_ms % 604800000; | ||||
|                     d_T_rx_TOW_ms = d_T_rx_TOW_ms % 604800000; | ||||
|                 } | ||||
|         } | ||||
| } | ||||
|  | ||||
|  | ||||
| void hybrid_observables_gs::compute_pranges(std::vector<Gnss_Synchro> &data) | ||||
| void hybrid_observables_gs::compute_pranges(std::vector<Gnss_Synchro> &data) const | ||||
| { | ||||
|     // std::cout.precision(17); | ||||
|     // std::cout << " T_rx_TOW_ms: " << static_cast<double>(T_rx_TOW_ms) << std::endl; | ||||
|     // std::cout << " d_T_rx_TOW_ms: " << static_cast<double>(d_T_rx_TOW_ms) << std::endl; | ||||
|     std::vector<Gnss_Synchro>::iterator it; | ||||
|     auto current_T_rx_TOW_ms = static_cast<double>(T_rx_TOW_ms); | ||||
|     auto current_T_rx_TOW_ms = static_cast<double>(d_T_rx_TOW_ms); | ||||
|     double current_T_rx_TOW_s = current_T_rx_TOW_ms / 1000.0; | ||||
|     for (it = data.begin(); it != data.end(); it++) | ||||
|         { | ||||
| @@ -531,7 +532,7 @@ void hybrid_observables_gs::compute_pranges(std::vector<Gnss_Synchro> &data) | ||||
|                     it->Flag_valid_pseudorange = true; | ||||
|                     // debug code | ||||
|                     // std::cout << "[" << it->Channel_ID << "] interp_TOW_ms: " << it->interp_TOW_ms << std::endl; | ||||
|                     // std::cout << "[" << it->Channel_ID << "] Diff T_rx_TOW_ms - interp_TOW_ms: " << static_cast<double>(T_rx_TOW_ms) - it->interp_TOW_ms << std::endl; | ||||
|                     // std::cout << "[" << it->Channel_ID << "] Diff d_T_rx_TOW_ms - interp_TOW_ms: " << static_cast<double>(d_T_rx_TOW_ms) - it->interp_TOW_ms << std::endl; | ||||
|                 } | ||||
|             else | ||||
|                 { | ||||
| @@ -550,7 +551,7 @@ void hybrid_observables_gs::smooth_pseudoranges(std::vector<Gnss_Synchro> &data) | ||||
|                 { | ||||
|                     // 0. get wavelength for the current signal | ||||
|                     double wavelength_m = 0; | ||||
|                     switch (mapStringValues_[it->Signal]) | ||||
|                     switch (d_mapStringValues[it->Signal]) | ||||
|                         { | ||||
|                         case evGPS_1C: | ||||
|                             wavelength_m = SPEED_OF_LIGHT / FREQ1; | ||||
| @@ -591,21 +592,21 @@ void hybrid_observables_gs::smooth_pseudoranges(std::vector<Gnss_Synchro> &data) | ||||
|  | ||||
|                     // todo: propagate the PLL lock status in Gnss_Synchro | ||||
|                     // 1. check if last PLL lock status was false and initialize last d_channel_last_pseudorange_smooth | ||||
|                     if (d_channel_last_pll_lock.at(it->Channel_ID) == true) | ||||
|                     if (d_channel_last_pll_lock[it->Channel_ID] == true) | ||||
|                         { | ||||
|                             // 2. Compute the smoothed pseudorange for this channel | ||||
|                             // Hatch filter algorithm (https://insidegnss.com/can-you-list-all-the-properties-of-the-carrier-smoothing-filter/) | ||||
|                             double r_sm = d_channel_last_pseudorange_smooth.at(it->Channel_ID); | ||||
|                             double r_sm = d_channel_last_pseudorange_smooth[it->Channel_ID]; | ||||
|                             double factor = ((d_smooth_filter_M - 1.0) / d_smooth_filter_M); | ||||
|                             it->Pseudorange_m = factor * r_sm + (1.0 / d_smooth_filter_M) * it->Pseudorange_m + wavelength_m * (factor / PI_2) * (it->Carrier_phase_rads - d_channel_last_carrier_phase_rads.at(it->Channel_ID)); | ||||
|                             it->Pseudorange_m = factor * r_sm + (1.0 / d_smooth_filter_M) * it->Pseudorange_m + wavelength_m * (factor / PI_2) * (it->Carrier_phase_rads - d_channel_last_carrier_phase_rads[it->Channel_ID]); | ||||
|                         } | ||||
|                     d_channel_last_pseudorange_smooth.at(it->Channel_ID) = it->Pseudorange_m; | ||||
|                     d_channel_last_carrier_phase_rads.at(it->Channel_ID) = it->Carrier_phase_rads; | ||||
|                     d_channel_last_pll_lock.at(it->Channel_ID) = it->Flag_valid_pseudorange; | ||||
|                     d_channel_last_pseudorange_smooth[it->Channel_ID] = it->Pseudorange_m; | ||||
|                     d_channel_last_carrier_phase_rads[it->Channel_ID] = it->Carrier_phase_rads; | ||||
|                     d_channel_last_pll_lock[it->Channel_ID] = it->Flag_valid_pseudorange; | ||||
|                 } | ||||
|             else | ||||
|                 { | ||||
|                     d_channel_last_pll_lock.at(it->Channel_ID) = false; | ||||
|                     d_channel_last_pll_lock[it->Channel_ID] = false; | ||||
|                 } | ||||
|         } | ||||
| } | ||||
| @@ -675,7 +676,7 @@ int hybrid_observables_gs::general_work(int noutput_items __attribute__((unused) | ||||
|                     epoch_data[n] = interpolated_gnss_synchro; | ||||
|                 } | ||||
|  | ||||
|             if (T_rx_TOW_set) | ||||
|             if (d_T_rx_TOW_set) | ||||
|                 { | ||||
|                     update_TOW(epoch_data); | ||||
|                 } | ||||
| @@ -703,8 +704,8 @@ int hybrid_observables_gs::general_work(int noutput_items __attribute__((unused) | ||||
|                     out[n][0] = epoch_data[n]; | ||||
|                 } | ||||
|             // report channel status every second | ||||
|             T_status_report_timer_ms += T_rx_step_ms; | ||||
|             if (T_status_report_timer_ms >= 1000) | ||||
|             d_T_status_report_timer_ms += d_T_rx_step_ms; | ||||
|             if (d_T_status_report_timer_ms >= 1000) | ||||
|                 { | ||||
|                     for (uint32_t n = 0; n < d_nchannels_out; n++) | ||||
|                         { | ||||
| @@ -712,7 +713,7 @@ int hybrid_observables_gs::general_work(int noutput_items __attribute__((unused) | ||||
|                             // publish valid gnss_synchro to the gnss_flowgraph channel status monitor | ||||
|                             this->message_port_pub(pmt::mp("status"), pmt::make_any(gnss_synchro_sptr)); | ||||
|                         } | ||||
|                     T_status_report_timer_ms = 0; | ||||
|                     d_T_status_report_timer_ms = 0; | ||||
|                 } | ||||
|  | ||||
|             if (d_dump) | ||||
|   | ||||
| @@ -30,11 +30,10 @@ | ||||
| #include <cstdint>                    // for int32_t | ||||
| #include <fstream>                    // for std::ofstream | ||||
| #include <map>                        // for std::map | ||||
| #include <memory>                     // for std:shared_ptr | ||||
| #include <memory>                     // for std::shared, std:unique_ptr | ||||
| #include <string>                     // for std::string | ||||
| #include <vector>                     // for std::vector | ||||
| #if GNURADIO_USES_STD_POINTERS | ||||
| #include <memory> | ||||
| #else | ||||
| #include <boost/shared_ptr.hpp> | ||||
| #endif | ||||
| @@ -71,7 +70,7 @@ private: | ||||
|  | ||||
|     Obs_Conf d_conf; | ||||
|  | ||||
|     enum StringValue | ||||
|     enum StringValue_ | ||||
|     { | ||||
|         evGPS_1C, | ||||
|         evGPS_2S, | ||||
| @@ -86,31 +85,32 @@ private: | ||||
|         evBDS_B3 | ||||
|     }; | ||||
|  | ||||
|     std::map<std::string, StringValue> mapStringValues_; | ||||
|     bool d_T_rx_TOW_set;  // rx time follow GPST | ||||
|     bool d_dump; | ||||
|     bool d_dump_mat; | ||||
|     uint32_t d_T_rx_TOW_ms; | ||||
|     uint32_t d_T_rx_step_ms; | ||||
|     uint32_t d_T_status_report_timer_ms; | ||||
|     uint32_t d_nchannels_in; | ||||
|     uint32_t d_nchannels_out; | ||||
|     double d_smooth_filter_M; | ||||
|  | ||||
|     std::map<std::string, StringValue_> d_mapStringValues; | ||||
|     std::vector<bool> d_channel_last_pll_lock; | ||||
|     std::vector<double> d_channel_last_pseudorange_smooth; | ||||
|     std::vector<double> d_channel_last_carrier_phase_rads; | ||||
|     double d_smooth_filter_M; | ||||
|     void smooth_pseudoranges(std::vector<Gnss_Synchro>& data); | ||||
|  | ||||
|     bool T_rx_TOW_set;  // rx time follow GPST | ||||
|     bool d_dump; | ||||
|     bool d_dump_mat; | ||||
|     uint32_t T_rx_TOW_ms; | ||||
|     uint32_t T_rx_step_ms; | ||||
|     uint32_t T_status_report_timer_ms; | ||||
|     uint32_t d_nchannels_in; | ||||
|     uint32_t d_nchannels_out; | ||||
|     std::string d_dump_filename; | ||||
|     std::ofstream d_dump_file; | ||||
|     std::unique_ptr<Gnss_circular_deque<Gnss_Synchro>> d_gnss_synchro_history;  // Tracking observable history | ||||
|     boost::circular_buffer<uint64_t> d_Rx_clock_buffer;                         // time history | ||||
|     std::shared_ptr<Gnss_circular_deque<Gnss_Synchro>> d_gnss_synchro_history;  // Tracking observable history | ||||
|  | ||||
|     void msg_handler_pvt_to_observables(const pmt::pmt_t& msg); | ||||
|     double compute_T_rx_s(const Gnss_Synchro& a); | ||||
|     bool interp_trk_obs(Gnss_Synchro& interpolated_obs, const uint32_t& ch, const uint64_t& rx_clock); | ||||
|     double compute_T_rx_s(const Gnss_Synchro& a) const; | ||||
|     bool interp_trk_obs(Gnss_Synchro& interpolated_obs, uint32_t ch, uint64_t rx_clock) const; | ||||
|     void update_TOW(const std::vector<Gnss_Synchro>& data); | ||||
|     void compute_pranges(std::vector<Gnss_Synchro>& data); | ||||
|     int32_t save_matfile(); | ||||
|     void compute_pranges(std::vector<Gnss_Synchro>& data) const; | ||||
|     void smooth_pseudoranges(std::vector<Gnss_Synchro>& data); | ||||
|     int32_t save_matfile() const; | ||||
| }; | ||||
|  | ||||
| #endif  // GNSS_SDR_HYBRID_OBSERVABLES_GS_H | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Carles Fernandez
					Carles Fernandez