mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-07 16:00:35 +00:00
Clean TTFF test
This commit is contained in:
parent
cd0cec131b
commit
7624c461f2
@ -56,8 +56,7 @@ DEFINE_int32(max_measurement_duration, 90, "Maximum time waiting for a position
|
|||||||
DEFINE_int32(num_measurements, 2, "Number of measurements");
|
DEFINE_int32(num_measurements, 2, "Number of measurements");
|
||||||
DEFINE_string(device_address, "192.168.40.2", "USRP device IP address");
|
DEFINE_string(device_address, "192.168.40.2", "USRP device IP address");
|
||||||
DEFINE_string(subdevice, "A:0", "USRP subdevice");
|
DEFINE_string(subdevice, "A:0", "USRP subdevice");
|
||||||
DEFINE_int32(output_rate_ms, 100, "Rate at which PVT solutions will be computed, in ms.");
|
|
||||||
DEFINE_int32(averaging_depth, 10, "size of the buffer performing a moving average");
|
|
||||||
|
|
||||||
// For GPS NAVIGATION (L1)
|
// For GPS NAVIGATION (L1)
|
||||||
concurrent_queue<Gps_Acq_Assist> global_gps_acq_assist_queue;
|
concurrent_queue<Gps_Acq_Assist> global_gps_acq_assist_queue;
|
||||||
@ -70,13 +69,15 @@ typedef struct {
|
|||||||
double ttff;
|
double ttff;
|
||||||
} ttff_msgbuf;
|
} ttff_msgbuf;
|
||||||
|
|
||||||
|
const int decimation_factor = 1;
|
||||||
|
|
||||||
class TTFF_GPS_L1_CA_Test: public ::testing::Test
|
class TTFF_GPS_L1_CA_Test: public ::testing::Test
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
void config_1();
|
void config_1();
|
||||||
void config_2();
|
void config_2();
|
||||||
|
void print_TTFF_report(const std::vector<double> & ttff_v);
|
||||||
|
|
||||||
std::shared_ptr<InMemoryConfiguration> config;
|
std::shared_ptr<InMemoryConfiguration> config;
|
||||||
std::shared_ptr<FileConfiguration> config2;
|
std::shared_ptr<FileConfiguration> config2;
|
||||||
|
|
||||||
@ -114,6 +115,8 @@ public:
|
|||||||
const float early_late_space_chips = 0.5;
|
const float early_late_space_chips = 0.5;
|
||||||
|
|
||||||
const int display_rate_ms = 500;
|
const int display_rate_ms = 500;
|
||||||
|
const int output_rate_ms = 100;
|
||||||
|
const int averaging_depth = 10;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -194,7 +197,7 @@ void TTFF_GPS_L1_CA_Test::config_1()
|
|||||||
// Set Telemetry
|
// Set Telemetry
|
||||||
config->set_property("TelemetryDecoder_1C.implementation", "GPS_L1_CA_Telemetry_Decoder");
|
config->set_property("TelemetryDecoder_1C.implementation", "GPS_L1_CA_Telemetry_Decoder");
|
||||||
config->set_property("TelemetryDecoder_1C.dump", "false");
|
config->set_property("TelemetryDecoder_1C.dump", "false");
|
||||||
config->set_property("TelemetryDecoder_1C.decimation_factor", std::to_string(1));
|
config->set_property("TelemetryDecoder_1C.decimation_factor", std::to_string(decimation_factor));
|
||||||
|
|
||||||
// Set Observables
|
// Set Observables
|
||||||
config->set_property("Observables.implementation", "GPS_L1_CA_Observables");
|
config->set_property("Observables.implementation", "GPS_L1_CA_Observables");
|
||||||
@ -203,9 +206,9 @@ void TTFF_GPS_L1_CA_Test::config_1()
|
|||||||
|
|
||||||
// Set PVT
|
// Set PVT
|
||||||
config->set_property("PVT.implementation", "GPS_L1_CA_PVT");
|
config->set_property("PVT.implementation", "GPS_L1_CA_PVT");
|
||||||
config->set_property("PVT.averaging_depth", std::to_string(FLAGS_averaging_depth));
|
config->set_property("PVT.averaging_depth", std::to_string(averaging_depth));
|
||||||
config->set_property("PVT.flag_averaging", "true");
|
config->set_property("PVT.flag_averaging", "true");
|
||||||
config->set_property("PVT.output_rate_ms", std::to_string(FLAGS_output_rate_ms));
|
config->set_property("PVT.output_rate_ms", std::to_string(output_rate_ms));
|
||||||
config->set_property("PVT.display_rate_ms", std::to_string(display_rate_ms));
|
config->set_property("PVT.display_rate_ms", std::to_string(display_rate_ms));
|
||||||
config->set_property("PVT.dump_filename", "./PVT");
|
config->set_property("PVT.dump_filename", "./PVT");
|
||||||
config->set_property("PVT.nmea_dump_filename", "./gnss_sdr_pvt.nmea");
|
config->set_property("PVT.nmea_dump_filename", "./gnss_sdr_pvt.nmea");
|
||||||
@ -247,8 +250,8 @@ void receive_msg()
|
|||||||
ttff_msg = msg.ttff;
|
ttff_msg = msg.ttff;
|
||||||
if( (ttff_msg != 0) && (ttff_msg != -1))
|
if( (ttff_msg != 0) && (ttff_msg != -1))
|
||||||
{
|
{
|
||||||
TTFF_v.push_back(ttff_msg / static_cast<double>(FLAGS_output_rate_ms * FLAGS_averaging_depth));
|
TTFF_v.push_back(ttff_msg / (1000.0 / decimation_factor) );
|
||||||
LOG(INFO) << "Valid Time-To-First-Fix: " << ttff_msg / static_cast<double>(FLAGS_output_rate_ms * FLAGS_averaging_depth) << "[s]";
|
LOG(INFO) << "Valid Time-To-First-Fix: " << ttff_msg / (1000.0 / decimation_factor ) << "[s]";
|
||||||
// Stop the receiver
|
// Stop the receiver
|
||||||
while((msqid_stop = msgget(key_stop, 0644)) == -1){}
|
while((msqid_stop = msgget(key_stop, 0644)) == -1){}
|
||||||
double msgsend_size = sizeof(msg_stop.ttff);
|
double msgsend_size = sizeof(msg_stop.ttff);
|
||||||
@ -264,7 +267,7 @@ void receive_msg()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void print_TTFF_report(const std::vector<double> & ttff_v)
|
void TTFF_GPS_L1_CA_Test::print_TTFF_report(const std::vector<double> & ttff_v)
|
||||||
{
|
{
|
||||||
std::vector<double> ttff = ttff_v;
|
std::vector<double> ttff = ttff_v;
|
||||||
double sum = std::accumulate(ttff.begin(), ttff.end(), 0.0);
|
double sum = std::accumulate(ttff.begin(), ttff.end(), 0.0);
|
||||||
@ -315,7 +318,7 @@ TEST_F(TTFF_GPS_L1_CA_Test, ColdStart)
|
|||||||
gettimeofday(&tv, NULL);
|
gettimeofday(&tv, NULL);
|
||||||
long long int begin = tv.tv_sec * 1000000 + tv.tv_usec;
|
long long int begin = tv.tv_sec * 1000000 + tv.tv_usec;
|
||||||
|
|
||||||
std::cout << "Starting measurement " << num_measurements << std::endl;
|
std::cout << "Starting measurement " << num_measurements + 1 << " / " << FLAGS_num_measurements << std::endl;
|
||||||
|
|
||||||
// start receiver
|
// start receiver
|
||||||
try
|
try
|
||||||
@ -349,7 +352,7 @@ TEST_F(TTFF_GPS_L1_CA_Test, ColdStart)
|
|||||||
int random_delay_s = static_cast<int>(random_variable_0_1 * 25.0);
|
int random_delay_s = static_cast<int>(random_variable_0_1 * 25.0);
|
||||||
std::cout << "Waiting a random amount of time (from 5 to 30 s) to start new measurement... " << std::endl;
|
std::cout << "Waiting a random amount of time (from 5 to 30 s) to start new measurement... " << std::endl;
|
||||||
std::cout << "This time will wait " << random_delay_s + 5 << " s." << std::endl << std::endl;
|
std::cout << "This time will wait " << random_delay_s + 5 << " s." << std::endl << std::endl;
|
||||||
std::this_thread::sleep_until(std::chrono::system_clock::now() + std::chrono::seconds(5) + std::chrono::seconds(random_delay_s)); // add random waiting!
|
std::this_thread::sleep_until(std::chrono::system_clock::now() + std::chrono::seconds(5) + std::chrono::seconds(random_delay_s));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user