mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-20 14:13:01 +00:00
Add RINEX validations
This commit is contained in:
parent
7f9d3c385d
commit
2c393af75a
@ -1,8 +1,11 @@
|
||||
|
||||
#include <iostream>
|
||||
#include <unistd.h>
|
||||
#include <sys/wait.h>
|
||||
#include <exception>
|
||||
#include <iostream>
|
||||
#include <cstring>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sys/wait.h>
|
||||
#include <unistd.h>
|
||||
#include <gflags/gflags.h>
|
||||
#include <glog/logging.h>
|
||||
#include <gtest/gtest.h>
|
||||
@ -12,7 +15,12 @@
|
||||
#include "concurrent_queue.h"
|
||||
#include "in_memory_configuration.h"
|
||||
|
||||
|
||||
DEFINE_string(generator_binary, std::string(SW_GENERATOR_BIN), "Path of Software Geenrator binary");
|
||||
DEFINE_string(rinex_nav_file, std::string(DEFAULT_RINEX_NAV), "Input RINEX navigation file");
|
||||
DEFINE_int32(duration, 100, "Duration of the experiment [in seconds]");
|
||||
DEFINE_string(static_position, "30.286502,120.032669,100", "Static receiver position [log,lat,height]");
|
||||
DEFINE_string(filename_rinex_obs, "sim.16o", "Filename of output RINEX navigation file");
|
||||
DEFINE_string(filename_raw_data, "signal_out.bin", "Filename of output raw data file");
|
||||
|
||||
// For GPS NAVIGATION (L1)
|
||||
concurrent_queue<Gps_Acq_Assist> global_gps_acq_assist_queue;
|
||||
@ -31,18 +39,19 @@ public:
|
||||
|
||||
const int baseband_sampling_freq = 2.6e6;
|
||||
|
||||
std::string filename_rinex_obs = "sim.16o";
|
||||
std::string filename_raw_data = "signal_out.bin";
|
||||
std::string filename_rinex_obs = FLAGS_filename_rinex_obs;
|
||||
std::string filename_raw_data = FLAGS_filename_raw_data;
|
||||
|
||||
int configure_generator();
|
||||
int generate_signal();
|
||||
int configure_receiver();
|
||||
int run_receiver();
|
||||
int check_results();
|
||||
void check_results();
|
||||
bool check_valid_rinex_nav(std::string filename); // return true if the file is a valid Rinex navigation file.
|
||||
bool check_valid_rinex_obs(std::string filename); // return true if the file is a valid Rinex observation file.
|
||||
|
||||
std::shared_ptr<InMemoryConfiguration> config;
|
||||
std::string generated_rinex_obs;
|
||||
};
|
||||
|
||||
|
||||
@ -64,16 +73,14 @@ bool Trk_System_Test::check_valid_rinex_obs(std::string filename)
|
||||
|
||||
int Trk_System_Test::configure_generator()
|
||||
{
|
||||
// Configure signal
|
||||
generator_binary = std::string(SW_GENERATOR_BIN);
|
||||
// Configure signal generator
|
||||
generator_binary = FLAGS_generator_binary;
|
||||
|
||||
EXPECT_EQ(true, check_valid_rinex_nav(std::string(DEFAULT_RINEX_NAV)));
|
||||
|
||||
p1 = std::string("-rinex_nav_file=") + std::string(DEFAULT_RINEX_NAV);
|
||||
p2_static = std::string("-static_position=30.286502,120.032669,100,1000");
|
||||
p1 = std::string("-rinex_nav_file=") + FLAGS_rinex_nav_file;
|
||||
p2_static = std::string("-static_position=") + FLAGS_static_position + std::string(",") + std::to_string(FLAGS_duration * 10);
|
||||
p2_dynamic = std::string("-obs_pos_file=") + std::string(DEFAULT_POSITION_FILE); // Observer positions file, in .csv or .nmea format"
|
||||
p3 = std::string("-rinex_obs_file=") + filename_rinex_obs; // RINEX 2.10 observation file output
|
||||
p4 = std::string("-sig_out_file=") + filename_raw_data; // Baseband signal output file. Will be stored in int8_t IQ multiplexed samples
|
||||
p3 = std::string("-rinex_obs_file=") + FLAGS_filename_rinex_obs; // RINEX 2.10 observation file output
|
||||
p4 = std::string("-sig_out_file=") + FLAGS_filename_raw_data; // Baseband signal output file. Will be stored in int8_t IQ multiplexed samples
|
||||
p5 = std::string("-sampling_freq=") + std::to_string(baseband_sampling_freq); //Baseband sampling frequency [MSps]
|
||||
return 0;
|
||||
}
|
||||
@ -277,16 +284,79 @@ int Trk_System_Test::run_receiver()
|
||||
{
|
||||
std::cout << "STD exception: " << ex.what();
|
||||
}
|
||||
|
||||
// Get the name of the RINEX obs file generated by the receiver
|
||||
FILE *fp;
|
||||
std::string argum2 = std::string("/bin/ls *O | tail -1");
|
||||
char buffer[1035];
|
||||
fp = popen(&argum2[0], "r");
|
||||
if (fp == NULL)
|
||||
{
|
||||
printf("Failed to run command\n" );
|
||||
}
|
||||
char * without_trailing;
|
||||
while (fgets(buffer, sizeof(buffer), fp) != NULL)
|
||||
{
|
||||
std::string aux = std::string(buffer);
|
||||
without_trailing = strtok(&aux[0], "\n");
|
||||
}
|
||||
generated_rinex_obs = std::string(without_trailing);
|
||||
pclose(fp);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int Trk_System_Test::check_results()
|
||||
void Trk_System_Test::check_results()
|
||||
{
|
||||
// Open reference RINEX observables file
|
||||
pid_t wait_result;
|
||||
int child_status;
|
||||
std::string RinDump = std::string("RinDump");
|
||||
std::string path_RinDump = std::string(GPSTK_BINDIR) + RinDump;
|
||||
std::string arg1 = std::string("--obs");
|
||||
std::string arg2 = std::string("./") + FLAGS_filename_rinex_obs;
|
||||
std::string arg3 = std::string("9");
|
||||
std::string arg4 = std::string("C1C");
|
||||
std::string arg5 = std::string("--headless");
|
||||
|
||||
FILE *fp;
|
||||
FILE *fp2;
|
||||
int status;
|
||||
char buffer[1035];
|
||||
|
||||
/* Open the command for reading. */
|
||||
std::string argum = path_RinDump + " " + arg1 + " " + arg2 + " " + arg3 + " " + arg4 + " " + arg5;
|
||||
|
||||
fp = popen(&argum[0], "r");
|
||||
if (fp == NULL)
|
||||
{
|
||||
printf("Failed to run command\n" );
|
||||
}
|
||||
|
||||
/* Read the output a line at a time - output it. */
|
||||
while (fgets(buffer, sizeof(buffer), fp) != NULL)
|
||||
{
|
||||
printf("Reading line: %s", buffer);
|
||||
}
|
||||
pclose(fp);
|
||||
|
||||
// Open generated RINEX observables file
|
||||
std::string arg2_gen = "./" + generated_rinex_obs;
|
||||
std::string argum2 = path_RinDump + " " + arg1 + " " + arg2_gen + " " + arg3 + " " + arg4 + " " + arg5;
|
||||
|
||||
fp2 = popen(&argum2[0], "r");
|
||||
if (fp2 == NULL)
|
||||
{
|
||||
printf("Failed to run command\n" );
|
||||
}
|
||||
|
||||
/* Read the output a line at a time - output it. */
|
||||
while (fgets(buffer, sizeof(buffer), fp2) != NULL)
|
||||
{
|
||||
printf("Reading generated line: %s", buffer);
|
||||
}
|
||||
|
||||
pclose(fp2);
|
||||
// Time alignment!
|
||||
|
||||
// Read reference pseudoranges from a given satellite
|
||||
@ -300,24 +370,39 @@ int Trk_System_Test::check_results()
|
||||
// Read obtained carrier phase from a given satellite
|
||||
|
||||
// Compute carrier phase error
|
||||
return 0;
|
||||
//return 0;
|
||||
}
|
||||
|
||||
|
||||
TEST_F(Trk_System_Test, Tracking_system_test)
|
||||
{
|
||||
std::cout << "Validating input RINEX nav file: " << FLAGS_rinex_nav_file << " ..." << std::endl;
|
||||
bool is_rinex_nav_valid = check_valid_rinex_nav(FLAGS_rinex_nav_file);
|
||||
ASSERT_EQ(true, is_rinex_nav_valid);
|
||||
std::cout << "The file is valid." << std::endl;
|
||||
|
||||
// Configure the signal generator
|
||||
configure_generator();
|
||||
|
||||
// Generate signal raw signal samples and observations RINEX file
|
||||
generate_signal();
|
||||
|
||||
std::cout << "Validating generated reference RINEX obs file: " << FLAGS_filename_rinex_obs << " ..." << std::endl;
|
||||
bool is_gen_rinex_obs_valid = check_valid_rinex_obs( "./" + FLAGS_filename_rinex_obs);
|
||||
ASSERT_EQ(true, is_gen_rinex_obs_valid);
|
||||
std::cout << "The file is valid." << std::endl;
|
||||
|
||||
// Configure receiver
|
||||
configure_receiver();
|
||||
|
||||
// Run the receiver
|
||||
run_receiver();
|
||||
|
||||
std::cout << "Validating RINEX obs file obtained by GNSS-SDR: " << generated_rinex_obs << " ..." << std::endl;
|
||||
is_gen_rinex_obs_valid = check_valid_rinex_obs( "./" + generated_rinex_obs);
|
||||
ASSERT_EQ(true, is_gen_rinex_obs_valid);
|
||||
std::cout << "The file is valid." << std::endl;
|
||||
|
||||
// Check results
|
||||
check_results();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user