1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2025-01-22 23:17:03 +00:00

Adding PVT flag to enable or disable the log INFO position geohash output

This commit is contained in:
Javier Arribas 2023-10-03 12:41:22 +02:00
parent 3474c9d8ac
commit 99952f6275
5 changed files with 17 additions and 7 deletions

View File

@ -15,7 +15,8 @@ All notable changes to GNSS-SDR will be documented in this file.
## [Unreleased](https://github.com/gnss-sdr/gnss-sdr/tree/next) ## [Unreleased](https://github.com/gnss-sdr/gnss-sdr/tree/next)
### Improvements in Interoperability: ### Improvements in Interoperability:
- Added a new PVT configuration boolean flag (`flag_geohash_log_out`) that enables or disables the
Position Geohash tag output in INFO log files. Set to `false` by default.
- New fields have been added to the custom output stream defined by - New fields have been added to the custom output stream defined by
`monitor_pvt.proto`: `utc_time` (a `monitor_pvt.proto`: `utc_time` (a
[RFC 3339](https://www.rfc-editor.org/rfc/rfc3339) datetime string), velocity [RFC 3339](https://www.rfc-editor.org/rfc/rfc3339) datetime string), velocity

View File

@ -74,6 +74,9 @@ Rtklib_Pvt::Rtklib_Pvt(const ConfigurationInterface* configuration,
// 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));
// log options
pvt_output_parameters.flag_geohash_log_out = configuration->property(role + ".flag_geohash_log_out", false);
// PVT KF settings // PVT KF settings
pvt_output_parameters.enable_pvt_kf = configuration->property(role + ".enable_pvt_kf", false); pvt_output_parameters.enable_pvt_kf = configuration->property(role + ".enable_pvt_kf", false);
pvt_output_parameters.measures_ecef_pos_sd_m = configuration->property(role + ".kf_measures_ecef_pos_sd_m", 1.0); pvt_output_parameters.measures_ecef_pos_sd_m = configuration->property(role + ".kf_measures_ecef_pos_sd_m", 1.0);

View File

@ -179,7 +179,8 @@ rtklib_pvt_gs::rtklib_pvt_gs(uint32_t nchannels,
d_an_printer_enabled(conf_.an_output_enabled), d_an_printer_enabled(conf_.an_output_enabled),
d_log_timetag(conf_.log_source_timetag), d_log_timetag(conf_.log_source_timetag),
d_use_has_corrections(conf_.use_has_corrections), d_use_has_corrections(conf_.use_has_corrections),
d_use_unhealthy_sats(conf_.use_unhealthy_sats) d_use_unhealthy_sats(conf_.use_unhealthy_sats),
d_flag_geohash_log_out(conf_.flag_geohash_log_out)
{ {
// Send feedback message to observables block with the receiver clock offset // Send feedback message to observables block with the receiver clock offset
this->message_port_register_out(pmt::mp("pvt_to_observables")); this->message_port_register_out(pmt::mp("pvt_to_observables"));
@ -2427,6 +2428,8 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
// p_time += boost::posix_time::microseconds(round(rtklib_utc_time.sec * 1e6)); // p_time += boost::posix_time::microseconds(round(rtklib_utc_time.sec * 1e6));
// std::cout << TEXT_MAGENTA << "Observable RX time (GPST) " << boost::posix_time::to_simple_string(p_time) << TEXT_RESET << '\n'; // std::cout << TEXT_MAGENTA << "Observable RX time (GPST) " << boost::posix_time::to_simple_string(p_time) << TEXT_RESET << '\n';
if (d_flag_geohash_log_out == true)
{
LOG(INFO) << "Position at " << boost::posix_time::to_simple_string(d_user_pvt_solver->get_position_UTC_time()) LOG(INFO) << "Position at " << boost::posix_time::to_simple_string(d_user_pvt_solver->get_position_UTC_time())
<< " UTC using " << d_user_pvt_solver->get_num_valid_observations() << " observations is Lat = " << d_user_pvt_solver->get_latitude() << " [deg], Long = " << d_user_pvt_solver->get_longitude() << " UTC using " << d_user_pvt_solver->get_num_valid_observations() << " observations is Lat = " << d_user_pvt_solver->get_latitude() << " [deg], Long = " << d_user_pvt_solver->get_longitude()
<< " [deg], Height = " << d_user_pvt_solver->get_height() << " [m]"; << " [deg], Height = " << d_user_pvt_solver->get_height() << " [m]";
@ -2436,6 +2439,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
<< d_user_pvt_solver->get_vdop() << d_user_pvt_solver->get_vdop()
<< " GDOP = " << d_user_pvt_solver->get_gdop() << '\n'; */ << " GDOP = " << d_user_pvt_solver->get_gdop() << '\n'; */
} }
}
// PVT MONITOR // PVT MONITOR
if (d_user_pvt_solver->is_valid_position() && flag_compute_pvt_output == true) if (d_user_pvt_solver->is_valid_position() && flag_compute_pvt_output == true)

View File

@ -278,6 +278,7 @@ private:
bool d_log_timetag; bool d_log_timetag;
bool d_use_has_corrections; bool d_use_has_corrections;
bool d_use_unhealthy_sats; bool d_use_unhealthy_sats;
bool d_flag_geohash_log_out;
}; };

View File

@ -70,6 +70,7 @@ public:
uint16_t rtcm_tcp_port = 0; uint16_t rtcm_tcp_port = 0;
uint16_t rtcm_station_id = 0; uint16_t rtcm_station_id = 0;
bool flag_geohash_log_out = false;
bool flag_nmea_tty_port = false; bool flag_nmea_tty_port = false;
bool flag_rtcm_server = false; bool flag_rtcm_server = false;
bool flag_rtcm_tty_port = false; bool flag_rtcm_tty_port = false;