mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-21 22:47:09 +00:00
Code cleaning
git-svn-id: https://svn.code.sf.net/p/gnss-sdr/code/trunk@263 64b25241-fba3-4117-9849-534c7e92360d
This commit is contained in:
parent
ae4a867249
commit
9b62455366
@ -49,70 +49,70 @@ using google::LogMessage;
|
|||||||
gps_l1_ca_pvt_cc_sptr
|
gps_l1_ca_pvt_cc_sptr
|
||||||
gps_l1_ca_make_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname)
|
gps_l1_ca_make_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname)
|
||||||
{
|
{
|
||||||
return gps_l1_ca_pvt_cc_sptr(new gps_l1_ca_pvt_cc(nchannels, queue, dump, dump_filename, averaging_depth, flag_averaging, output_rate_ms, display_rate_ms, flag_nmea_tty_port, nmea_dump_filename, nmea_dump_devname));
|
return gps_l1_ca_pvt_cc_sptr(new gps_l1_ca_pvt_cc(nchannels, queue, dump, dump_filename, averaging_depth, flag_averaging, output_rate_ms, display_rate_ms, flag_nmea_tty_port, nmea_dump_filename, nmea_dump_devname));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
gps_l1_ca_pvt_cc::gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname) :
|
gps_l1_ca_pvt_cc::gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname) :
|
||||||
gr_block ("gps_l1_ca_pvt_cc", gr_make_io_signature (nchannels, nchannels, sizeof(Gnss_Synchro)),
|
gr_block ("gps_l1_ca_pvt_cc", gr_make_io_signature (nchannels, nchannels, sizeof(Gnss_Synchro)),
|
||||||
gr_make_io_signature(1, 1, sizeof(gr_complex)))
|
gr_make_io_signature(1, 1, sizeof(gr_complex)))
|
||||||
{
|
{
|
||||||
|
|
||||||
d_output_rate_ms = output_rate_ms;
|
d_output_rate_ms = output_rate_ms;
|
||||||
d_display_rate_ms = display_rate_ms;
|
d_display_rate_ms = display_rate_ms;
|
||||||
d_queue = queue;
|
d_queue = queue;
|
||||||
d_dump = dump;
|
d_dump = dump;
|
||||||
d_nchannels = nchannels;
|
d_nchannels = nchannels;
|
||||||
d_dump_filename = dump_filename;
|
d_dump_filename = dump_filename;
|
||||||
std::string dump_ls_pvt_filename = dump_filename;
|
std::string dump_ls_pvt_filename = dump_filename;
|
||||||
|
|
||||||
//initialize kml_printer
|
//initialize kml_printer
|
||||||
std::string kml_dump_filename;
|
std::string kml_dump_filename;
|
||||||
kml_dump_filename = d_dump_filename;
|
kml_dump_filename = d_dump_filename;
|
||||||
kml_dump_filename.append(".kml");
|
kml_dump_filename.append(".kml");
|
||||||
d_kml_dump.set_headers(kml_dump_filename);
|
d_kml_dump.set_headers(kml_dump_filename);
|
||||||
|
|
||||||
//initialize nmea_printer
|
//initialize nmea_printer
|
||||||
d_nmea_printer = new Nmea_Printer(nmea_dump_filename, flag_nmea_tty_port, nmea_dump_devname);
|
d_nmea_printer = new Nmea_Printer(nmea_dump_filename, flag_nmea_tty_port, nmea_dump_devname);
|
||||||
|
|
||||||
d_dump_filename.append("_raw.dat");
|
d_dump_filename.append("_raw.dat");
|
||||||
dump_ls_pvt_filename.append("_ls_pvt.dat");
|
dump_ls_pvt_filename.append("_ls_pvt.dat");
|
||||||
d_averaging_depth = averaging_depth;
|
d_averaging_depth = averaging_depth;
|
||||||
d_flag_averaging = flag_averaging;
|
d_flag_averaging = flag_averaging;
|
||||||
|
|
||||||
d_ls_pvt = new gps_l1_ca_ls_pvt(nchannels,dump_ls_pvt_filename,d_dump);
|
d_ls_pvt = new gps_l1_ca_ls_pvt(nchannels,dump_ls_pvt_filename,d_dump);
|
||||||
d_ls_pvt->set_averaging_depth(d_averaging_depth);
|
d_ls_pvt->set_averaging_depth(d_averaging_depth);
|
||||||
d_ephemeris_clock_s = 0.0;
|
d_ephemeris_clock_s = 0.0;
|
||||||
|
|
||||||
d_sample_counter = 0;
|
d_sample_counter = 0;
|
||||||
|
|
||||||
d_tx_time=0.0;
|
d_tx_time=0.0;
|
||||||
|
|
||||||
b_rinex_header_writen = false;
|
b_rinex_header_writen = false;
|
||||||
rp = new Rinex_Printer();
|
rp = new Rinex_Printer();
|
||||||
|
|
||||||
for (unsigned int i=0; i<nchannels; i++)
|
for (unsigned int i=0; i<nchannels; i++)
|
||||||
{
|
{
|
||||||
nav_data_map[i] = Gps_Navigation_Message();
|
nav_data_map[i] = Gps_Navigation_Message();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ############# ENABLE DATA FILE LOG #################
|
// ############# ENABLE DATA FILE LOG #################
|
||||||
if (d_dump == true)
|
if (d_dump == true)
|
||||||
{
|
{
|
||||||
if (d_dump_file.is_open() == false)
|
if (d_dump_file.is_open() == false)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit );
|
d_dump_file.exceptions (std::ifstream::failbit | std::ifstream::badbit );
|
||||||
d_dump_file.open(d_dump_filename.c_str(), std::ios::out | std::ios::binary);
|
d_dump_file.open(d_dump_filename.c_str(), std::ios::out | std::ios::binary);
|
||||||
std::cout << "PVT dump enabled Log file: " << d_dump_filename.c_str() << std::endl;
|
std::cout << "PVT dump enabled Log file: " << d_dump_filename.c_str() << std::endl;
|
||||||
}
|
}
|
||||||
catch (std::ifstream::failure e)
|
catch (std::ifstream::failure e)
|
||||||
{
|
{
|
||||||
std::cout << "Exception opening PVT dump file " << e.what() << std::endl;
|
std::cout << "Exception opening PVT dump file " << e.what() << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -120,148 +120,148 @@ gps_l1_ca_pvt_cc::gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr que
|
|||||||
|
|
||||||
gps_l1_ca_pvt_cc::~gps_l1_ca_pvt_cc()
|
gps_l1_ca_pvt_cc::~gps_l1_ca_pvt_cc()
|
||||||
{
|
{
|
||||||
d_kml_dump.close_file();
|
d_kml_dump.close_file();
|
||||||
delete d_ls_pvt;
|
delete d_ls_pvt;
|
||||||
delete rp;
|
delete rp;
|
||||||
delete d_nmea_printer;
|
delete d_nmea_printer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool pseudoranges_pairCompare_min( std::pair<int,Gnss_Synchro> a, std::pair<int,Gnss_Synchro> b)
|
bool pseudoranges_pairCompare_min( std::pair<int,Gnss_Synchro> a, std::pair<int,Gnss_Synchro> b)
|
||||||
{
|
{
|
||||||
return (a.second.Pseudorange_m) < (b.second.Pseudorange_m);
|
return (a.second.Pseudorange_m) < (b.second.Pseudorange_m);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int gps_l1_ca_pvt_cc::general_work (int noutput_items, gr_vector_int &ninput_items,
|
int gps_l1_ca_pvt_cc::general_work (int noutput_items, gr_vector_int &ninput_items,
|
||||||
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
|
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
|
||||||
{
|
{
|
||||||
d_sample_counter++;
|
d_sample_counter++;
|
||||||
|
|
||||||
std::map<int,Gnss_Synchro> gnss_pseudoranges_map;
|
std::map<int,Gnss_Synchro> gnss_pseudoranges_map;
|
||||||
std::map<int,double> pseudoranges;
|
std::map<int,double> pseudoranges;
|
||||||
std::map<int,Gnss_Synchro>::iterator gnss_pseudoranges_iter;
|
std::map<int,Gnss_Synchro>::iterator gnss_pseudoranges_iter;
|
||||||
|
|
||||||
Gnss_Synchro **in = (Gnss_Synchro **) &input_items[0]; //Get the input pointer
|
Gnss_Synchro **in = (Gnss_Synchro **) &input_items[0]; //Get the input pointer
|
||||||
|
|
||||||
for (unsigned int i=0; i<d_nchannels; i++)
|
for (unsigned int i=0; i<d_nchannels; i++)
|
||||||
{
|
{
|
||||||
if (in[i][0].Flag_valid_pseudorange == true)
|
if (in[i][0].Flag_valid_pseudorange == true)
|
||||||
{
|
{
|
||||||
gnss_pseudoranges_map.insert(std::pair<int,Gnss_Synchro>(in[i][0].PRN, in[i][0])); // store valid pseudoranges in a map
|
gnss_pseudoranges_map.insert(std::pair<int,Gnss_Synchro>(in[i][0].PRN, in[i][0])); // store valid pseudoranges in a map
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(gnss_pseudoranges_iter = gnss_pseudoranges_map.begin();
|
for(gnss_pseudoranges_iter = gnss_pseudoranges_map.begin();
|
||||||
gnss_pseudoranges_iter != gnss_pseudoranges_map.end();
|
gnss_pseudoranges_iter != gnss_pseudoranges_map.end();
|
||||||
gnss_pseudoranges_iter++)
|
gnss_pseudoranges_iter++)
|
||||||
{
|
{
|
||||||
double pr = gnss_pseudoranges_iter->second.Pseudorange_m;
|
double pr = gnss_pseudoranges_iter->second.Pseudorange_m;
|
||||||
pseudoranges[gnss_pseudoranges_iter->first] = pr;
|
pseudoranges[gnss_pseudoranges_iter->first] = pr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ############ 1. READ EPHEMERIS FROM QUEUE ######################
|
// ############ 1. READ EPHEMERIS FROM QUEUE ######################
|
||||||
// find the minimum index (nearest satellite, will be the reference)
|
// find the minimum index (nearest satellite, will be the reference)
|
||||||
gnss_pseudoranges_iter = std::min_element(gnss_pseudoranges_map.begin(), gnss_pseudoranges_map.end(), pseudoranges_pairCompare_min);
|
gnss_pseudoranges_iter = std::min_element(gnss_pseudoranges_map.begin(), gnss_pseudoranges_map.end(), pseudoranges_pairCompare_min);
|
||||||
|
|
||||||
Gps_Navigation_Message nav_msg;
|
Gps_Navigation_Message nav_msg;
|
||||||
while (d_nav_queue->try_pop(nav_msg) == true)
|
while (d_nav_queue->try_pop(nav_msg) == true)
|
||||||
{
|
{
|
||||||
std::cout << "New ephemeris record has arrived from SAT ID "
|
std::cout << "New ephemeris record has arrived from SAT ID "
|
||||||
<< nav_msg.i_satellite_PRN << " (Block "
|
<< nav_msg.i_satellite_PRN << " (Block "
|
||||||
<< nav_msg.satelliteBlock[nav_msg.i_satellite_PRN]
|
<< nav_msg.satelliteBlock[nav_msg.i_satellite_PRN]
|
||||||
<< ")" << std::endl;
|
<< ")" << std::endl;
|
||||||
d_last_nav_msg = nav_msg;
|
d_last_nav_msg = nav_msg;
|
||||||
if (nav_msg.b_valid_ephemeris_set_flag == true)
|
if (nav_msg.b_valid_ephemeris_set_flag == true)
|
||||||
{
|
{
|
||||||
d_ls_pvt->d_ephemeris[nav_msg.i_channel_ID] = nav_msg;
|
d_ls_pvt->d_ephemeris[nav_msg.i_channel_ID] = nav_msg;
|
||||||
nav_data_map[nav_msg.i_channel_ID] = nav_msg;
|
nav_data_map[nav_msg.i_channel_ID] = nav_msg;
|
||||||
}
|
}
|
||||||
// **** update pseudoranges clock ****
|
// **** update pseudoranges clock ****
|
||||||
if (nav_msg.i_satellite_PRN == gnss_pseudoranges_iter->second.PRN)
|
if (nav_msg.i_satellite_PRN == gnss_pseudoranges_iter->second.PRN)
|
||||||
{
|
{
|
||||||
d_ephemeris_clock_s = d_last_nav_msg.d_TOW;
|
d_ephemeris_clock_s = d_last_nav_msg.d_TOW;
|
||||||
d_ephemeris_timestamp_ms = d_last_nav_msg.d_subframe_timestamp_ms;
|
d_ephemeris_timestamp_ms = d_last_nav_msg.d_subframe_timestamp_ms;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ############ 2. COMPUTE THE PVT ################################
|
// ############ 2. COMPUTE THE PVT ################################
|
||||||
// write the pseudoranges to RINEX OBS file
|
// write the pseudoranges to RINEX OBS file
|
||||||
// 1- need a valid clock
|
// 1- need a valid clock
|
||||||
if (d_ephemeris_clock_s > 0 and d_last_nav_msg.i_satellite_PRN > 0 and d_last_nav_msg.b_valid_ephemeris_set_flag == true)
|
if (d_ephemeris_clock_s > 0 and d_last_nav_msg.i_satellite_PRN > 0 and d_last_nav_msg.b_valid_ephemeris_set_flag == true)
|
||||||
{
|
{
|
||||||
double clock_error;
|
double clock_error;
|
||||||
double satellite_tx_time_using_timestamps;
|
double satellite_tx_time_using_timestamps;
|
||||||
//for GPS L1 C/A: t_tx = TOW + N_symbols_from_TOW*T_symbol
|
//for GPS L1 C/A: t_tx = TOW + N_symbols_from_TOW*T_symbol
|
||||||
//Notice that the TOW is decoded AFTER processing the subframe -> we need to add ONE subframe duration to t_tx
|
//Notice that the TOW is decoded AFTER processing the subframe -> we need to add ONE subframe duration to t_tx
|
||||||
d_tx_time = d_ephemeris_clock_s + gnss_pseudoranges_iter->second.Pseudorange_symbol_shift/(double)GPS_CA_TELEMETRY_RATE_SYMBOLS_SECOND + GPS_SUBFRAME_SECONDS;
|
d_tx_time = d_ephemeris_clock_s + gnss_pseudoranges_iter->second.Pseudorange_symbol_shift/(double)GPS_CA_TELEMETRY_RATE_SYMBOLS_SECOND + GPS_SUBFRAME_SECONDS;
|
||||||
//Perform an extra check to verify the TOW update (the ephemeris queue is ASYNCHRONOUS to the GNU Radio Gnss_Synchro sample stream)
|
//Perform an extra check to verify the TOW update (the ephemeris queue is ASYNCHRONOUS to the GNU Radio Gnss_Synchro sample stream)
|
||||||
//-> compute the t_tx_timestamps using the symbols timestamp (it is affected by code Doppler, but it is not wrapped like N_symbols_from_TOW)
|
//-> compute the t_tx_timestamps using the symbols timestamp (it is affected by code Doppler, but it is not wrapped like N_symbols_from_TOW)
|
||||||
satellite_tx_time_using_timestamps = d_ephemeris_clock_s + (gnss_pseudoranges_iter->second.Pseudorange_timestamp_ms - d_ephemeris_timestamp_ms)/1000.0;
|
satellite_tx_time_using_timestamps = d_ephemeris_clock_s + (gnss_pseudoranges_iter->second.Pseudorange_timestamp_ms - d_ephemeris_timestamp_ms)/1000.0;
|
||||||
//->compute the absolute error between both T_tx
|
//->compute the absolute error between both T_tx
|
||||||
clock_error = std::abs(d_tx_time - satellite_tx_time_using_timestamps);
|
clock_error = std::abs(d_tx_time - satellite_tx_time_using_timestamps);
|
||||||
// -> The symbol counter N_symbols_from_TOW will be reset every new received telemetry word, if the TOW is not updated, both t_tx and t_tx_timestamps times will difer by more than 1 seconds.
|
// -> The symbol counter N_symbols_from_TOW will be reset every new received telemetry word, if the TOW is not updated, both t_tx and t_tx_timestamps times will difer by more than 1 seconds.
|
||||||
if (clock_error < 1)
|
if (clock_error < 1)
|
||||||
{
|
{
|
||||||
// compute on the fly PVT solution
|
// compute on the fly PVT solution
|
||||||
//mod 8/4/2012 Set the PVT computation rate in this block
|
//mod 8/4/2012 Set the PVT computation rate in this block
|
||||||
if ((d_sample_counter % d_output_rate_ms) == 0)
|
if ((d_sample_counter % d_output_rate_ms) == 0)
|
||||||
{
|
{
|
||||||
if (d_ls_pvt->get_PVT(gnss_pseudoranges_map,d_tx_time,d_flag_averaging) == true)
|
if (d_ls_pvt->get_PVT(gnss_pseudoranges_map,d_tx_time,d_flag_averaging) == true)
|
||||||
{
|
{
|
||||||
d_kml_dump.print_position(d_ls_pvt, d_flag_averaging);
|
d_kml_dump.print_position(d_ls_pvt, d_flag_averaging);
|
||||||
d_nmea_printer->Print_Nmea_Line(d_ls_pvt, d_flag_averaging);
|
d_nmea_printer->Print_Nmea_Line(d_ls_pvt, d_flag_averaging);
|
||||||
|
|
||||||
if (!b_rinex_header_writen) // & we have utc data in nav message!
|
if (!b_rinex_header_writen) // & we have utc data in nav message!
|
||||||
{
|
{
|
||||||
rp->rinex_nav_header(rp->navFile, d_last_nav_msg);
|
rp->rinex_nav_header(rp->navFile, d_last_nav_msg);
|
||||||
rp->rinex_obs_header(rp->obsFile, d_last_nav_msg);
|
rp->rinex_obs_header(rp->obsFile, d_last_nav_msg);
|
||||||
b_rinex_header_writen = true; // do not write header anymore
|
b_rinex_header_writen = true; // do not write header anymore
|
||||||
}
|
}
|
||||||
if(b_rinex_header_writen) // Put here another condition to separate annotations (e.g 30 s)
|
if(b_rinex_header_writen) // Put here another condition to separate annotations (e.g 30 s)
|
||||||
{
|
{
|
||||||
rp->log_rinex_nav(rp->navFile, nav_data_map);
|
rp->log_rinex_nav(rp->navFile, nav_data_map);
|
||||||
rp->log_rinex_obs(rp->obsFile, d_last_nav_msg, pseudoranges);
|
rp->log_rinex_obs(rp->obsFile, d_last_nav_msg, pseudoranges);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (((d_sample_counter % d_display_rate_ms) == 0) and d_ls_pvt->b_valid_position == true)
|
if (((d_sample_counter % d_display_rate_ms) == 0) and d_ls_pvt->b_valid_position == true)
|
||||||
{
|
{
|
||||||
std::cout << "Position at " << boost::posix_time::to_simple_string(d_ls_pvt->d_position_UTC_time)
|
std::cout << "Position at " << boost::posix_time::to_simple_string(d_ls_pvt->d_position_UTC_time)
|
||||||
<< " is Lat = " << d_ls_pvt->d_latitude_d << " [deg], Long = " << d_ls_pvt->d_longitude_d
|
<< " is Lat = " << d_ls_pvt->d_latitude_d << " [deg], Long = " << d_ls_pvt->d_longitude_d
|
||||||
<< " [deg], Height= " << d_ls_pvt->d_height_m << " [m]" << std::endl;
|
<< " [deg], Height= " << d_ls_pvt->d_height_m << " [m]" << std::endl;
|
||||||
|
|
||||||
std::cout << "Dilution of Precision at " << boost::posix_time::to_simple_string(d_ls_pvt->d_position_UTC_time)
|
std::cout << "Dilution of Precision at " << boost::posix_time::to_simple_string(d_ls_pvt->d_position_UTC_time)
|
||||||
<< " is HDOP = " << d_ls_pvt->d_HDOP << " and VDOP = " << d_ls_pvt->d_VDOP << std::endl;
|
<< " is HDOP = " << d_ls_pvt->d_HDOP << " and VDOP = " << d_ls_pvt->d_VDOP << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(d_dump == true)
|
if(d_dump == true)
|
||||||
{
|
{
|
||||||
// MULTIPLEXED FILE RECORDING - Record results to file
|
// MULTIPLEXED FILE RECORDING - Record results to file
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
double tmp_double;
|
double tmp_double;
|
||||||
for (unsigned int i=0; i<d_nchannels ; i++)
|
for (unsigned int i=0; i<d_nchannels ; i++)
|
||||||
{
|
{
|
||||||
tmp_double = in[i][0].Pseudorange_m;
|
tmp_double = in[i][0].Pseudorange_m;
|
||||||
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
||||||
tmp_double = in[i][0].Pseudorange_symbol_shift;
|
tmp_double = in[i][0].Pseudorange_symbol_shift;
|
||||||
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
d_dump_file.write((char*)&tmp_double, sizeof(double));
|
||||||
d_dump_file.write((char*)&d_tx_time, sizeof(double));
|
d_dump_file.write((char*)&d_tx_time, sizeof(double));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (std::ifstream::failure e)
|
catch (std::ifstream::failure e)
|
||||||
{
|
{
|
||||||
std::cout << "Exception writing observables dump file " << e.what() << std::endl;
|
std::cout << "Exception writing observables dump file " << e.what() << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
consume_each(1); //one by one
|
consume_each(1); //one by one
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -56,55 +56,40 @@ gps_l1_ca_make_pvt_cc(unsigned int n_channels, gr_msg_queue_sptr queue, bool dum
|
|||||||
*/
|
*/
|
||||||
class gps_l1_ca_pvt_cc : public gr_block
|
class gps_l1_ca_pvt_cc : public gr_block
|
||||||
{
|
{
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
friend gps_l1_ca_pvt_cc_sptr
|
||||||
friend gps_l1_ca_pvt_cc_sptr
|
gps_l1_ca_make_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname);
|
||||||
gps_l1_ca_make_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname);
|
gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname);
|
||||||
|
gr_msg_queue_sptr d_queue;
|
||||||
gps_l1_ca_pvt_cc(unsigned int nchannels, gr_msg_queue_sptr queue, bool dump, std::string dump_filename, int averaging_depth, bool flag_averaging, int output_rate_ms, int display_rate_ms, bool flag_nmea_tty_port, std::string nmea_dump_filename, std::string nmea_dump_devname);
|
bool d_dump;
|
||||||
|
bool b_rinex_header_writen;
|
||||||
gr_msg_queue_sptr d_queue;
|
Rinex_Printer *rp;
|
||||||
bool d_dump;
|
unsigned int d_nchannels;
|
||||||
bool b_rinex_header_writen;
|
std::string d_dump_filename;
|
||||||
Rinex_Printer *rp;
|
std::ofstream d_dump_file;
|
||||||
|
int d_averaging_depth;
|
||||||
unsigned int d_nchannels;
|
bool d_flag_averaging;
|
||||||
|
int d_output_rate_ms;
|
||||||
std::string d_dump_filename;
|
int d_display_rate_ms;
|
||||||
std::ofstream d_dump_file;
|
long unsigned int d_sample_counter;
|
||||||
|
Kml_Printer d_kml_dump;
|
||||||
int d_averaging_depth;
|
Nmea_Printer *d_nmea_printer;
|
||||||
bool d_flag_averaging;
|
concurrent_queue<Gps_Navigation_Message> *d_nav_queue; // Navigation ephemeris queue
|
||||||
int d_output_rate_ms;
|
Gps_Navigation_Message d_last_nav_msg; // Last navigation message
|
||||||
int d_display_rate_ms;
|
double d_ephemeris_clock_s;
|
||||||
long unsigned int d_sample_counter;
|
double d_ephemeris_timestamp_ms;
|
||||||
|
double d_tx_time;
|
||||||
Kml_Printer d_kml_dump;
|
gps_l1_ca_ls_pvt *d_ls_pvt;
|
||||||
|
std::map<int,Gps_Navigation_Message> nav_data_map;
|
||||||
Nmea_Printer *d_nmea_printer;
|
|
||||||
|
|
||||||
concurrent_queue<Gps_Navigation_Message> *d_nav_queue; // Navigation ephemeris queue
|
|
||||||
Gps_Navigation_Message d_last_nav_msg; // Last navigation message
|
|
||||||
|
|
||||||
double d_ephemeris_clock_s;
|
|
||||||
double d_ephemeris_timestamp_ms;
|
|
||||||
double d_tx_time;
|
|
||||||
gps_l1_ca_ls_pvt *d_ls_pvt;
|
|
||||||
|
|
||||||
std::map<int,Gps_Navigation_Message> nav_data_map;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
~gps_l1_ca_pvt_cc (); //!< Default destructor
|
||||||
~gps_l1_ca_pvt_cc (); //!< Default destructor
|
/*!
|
||||||
|
* \brief Set the queue for getting navigation messages from the GpsL1CaTelemetryDecoder
|
||||||
/*!
|
*/
|
||||||
* \brief Set the queue for getting navigation messages from the GpsL1CaTelemetryDecoder
|
void set_navigation_queue(concurrent_queue<Gps_Navigation_Message> *nav_queue){d_nav_queue=nav_queue;}
|
||||||
*/
|
int general_work (int noutput_items, gr_vector_int &ninput_items,
|
||||||
void set_navigation_queue(concurrent_queue<Gps_Navigation_Message> *nav_queue){d_nav_queue=nav_queue;}
|
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items); //!< PVT Signal Processing
|
||||||
|
|
||||||
int general_work (int noutput_items, gr_vector_int &ninput_items,
|
|
||||||
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items); //!< PVT Signal Processing
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -64,10 +64,10 @@ public:
|
|||||||
int d_nchannels; //! Number of available channels for positioning
|
int d_nchannels; //! Number of available channels for positioning
|
||||||
int d_valid_observations; //! Number of valid pseudorange observations (valid satellites)
|
int d_valid_observations; //! Number of valid pseudorange observations (valid satellites)
|
||||||
int d_visible_satellites_IDs[PVT_MAX_CHANNELS]; //! Array with the IDs of the valid satellites
|
int d_visible_satellites_IDs[PVT_MAX_CHANNELS]; //! Array with the IDs of the valid satellites
|
||||||
double d_visible_satellites_El[PVT_MAX_CHANNELS]; //! Array with the LOS Elevation of the valid satellites
|
double d_visible_satellites_El[PVT_MAX_CHANNELS]; //! Array with the LOS Elevation of the valid satellites
|
||||||
double d_visible_satellites_Az[PVT_MAX_CHANNELS]; //! Array with the LOS Azimuth of the valid satellites
|
double d_visible_satellites_Az[PVT_MAX_CHANNELS]; //! Array with the LOS Azimuth of the valid satellites
|
||||||
double d_visible_satellites_Distance[PVT_MAX_CHANNELS]; //! Array with the LOS Distance of the valid satellites
|
double d_visible_satellites_Distance[PVT_MAX_CHANNELS]; //! Array with the LOS Distance of the valid satellites
|
||||||
double d_visible_satellites_CN0_dB[PVT_MAX_CHANNELS]; //! Array with the IDs of the valid satellites
|
double d_visible_satellites_CN0_dB[PVT_MAX_CHANNELS]; //! Array with the IDs of the valid satellites
|
||||||
|
|
||||||
Gps_Navigation_Message* d_ephemeris;
|
Gps_Navigation_Message* d_ephemeris;
|
||||||
double d_GPS_current_time;
|
double d_GPS_current_time;
|
||||||
|
@ -38,18 +38,15 @@ bool Kml_Printer::set_headers(std::string filename)
|
|||||||
{
|
{
|
||||||
time_t rawtime;
|
time_t rawtime;
|
||||||
struct tm * timeinfo;
|
struct tm * timeinfo;
|
||||||
|
|
||||||
time ( &rawtime );
|
time ( &rawtime );
|
||||||
timeinfo = localtime ( &rawtime );
|
timeinfo = localtime ( &rawtime );
|
||||||
kml_file.open(filename.c_str());
|
kml_file.open(filename.c_str());
|
||||||
if (kml_file.is_open())
|
if (kml_file.is_open())
|
||||||
{
|
{
|
||||||
DLOG(INFO) << "KML printer writing on " << filename.c_str();
|
DLOG(INFO) << "KML printer writing on " << filename.c_str();
|
||||||
|
|
||||||
// Set iostream numeric format and precision
|
// Set iostream numeric format and precision
|
||||||
kml_file.setf(kml_file.fixed,kml_file.floatfield);
|
kml_file.setf(kml_file.fixed,kml_file.floatfield);
|
||||||
kml_file<<std::setprecision(14);
|
kml_file << std::setprecision(14);
|
||||||
|
|
||||||
kml_file << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" << std::endl
|
kml_file << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" << std::endl
|
||||||
<< "<kml xmlns=\"http://www.opengis.net/kml/2.2\">" << std::endl
|
<< "<kml xmlns=\"http://www.opengis.net/kml/2.2\">" << std::endl
|
||||||
<< " <Document>" << std::endl
|
<< " <Document>" << std::endl
|
||||||
@ -83,6 +80,7 @@ bool Kml_Printer::set_headers(std::string filename)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool Kml_Printer::print_position(gps_l1_ca_ls_pvt* position,bool print_average_values)
|
bool Kml_Printer::print_position(gps_l1_ca_ls_pvt* position,bool print_average_values)
|
||||||
{
|
{
|
||||||
double latitude;
|
double latitude;
|
||||||
@ -90,15 +88,15 @@ bool Kml_Printer::print_position(gps_l1_ca_ls_pvt* position,bool print_average_v
|
|||||||
double height;
|
double height;
|
||||||
if (print_average_values == false)
|
if (print_average_values == false)
|
||||||
{
|
{
|
||||||
latitude=position->d_latitude_d;
|
latitude = position->d_latitude_d;
|
||||||
longitude=position->d_longitude_d;
|
longitude = position->d_longitude_d;
|
||||||
height=position->d_height_m;
|
height = position->d_height_m;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
latitude=position->d_avg_latitude_d;
|
latitude = position->d_avg_latitude_d;
|
||||||
longitude=position->d_avg_longitude_d;
|
longitude = position->d_avg_longitude_d;
|
||||||
height=position->d_avg_height_m;
|
height = position->d_avg_height_m;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (kml_file.is_open())
|
if (kml_file.is_open())
|
||||||
@ -118,11 +116,11 @@ bool Kml_Printer::close_file()
|
|||||||
{
|
{
|
||||||
if (kml_file.is_open())
|
if (kml_file.is_open())
|
||||||
{
|
{
|
||||||
kml_file<<"</coordinates>" << std::endl
|
kml_file << "</coordinates>" << std::endl
|
||||||
<<"</LineString>" << std::endl
|
<< "</LineString>" << std::endl
|
||||||
<<"</Placemark>" << std::endl
|
<< "</Placemark>" << std::endl
|
||||||
<<"</Document>" << std::endl
|
<< "</Document>" << std::endl
|
||||||
<<"</kml>";
|
<< "</kml>";
|
||||||
kml_file.close();
|
kml_file.close();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -46,19 +46,13 @@
|
|||||||
class Kml_Printer
|
class Kml_Printer
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
|
std::ofstream kml_file;
|
||||||
std::ofstream kml_file;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
bool set_headers(std::string filename);
|
||||||
bool set_headers(std::string filename);
|
bool print_position(gps_l1_ca_ls_pvt* position, bool print_average_values);
|
||||||
|
bool close_file();
|
||||||
bool print_position(gps_l1_ca_ls_pvt* position, bool print_average_values);
|
Kml_Printer();
|
||||||
|
~Kml_Printer();
|
||||||
bool close_file();
|
|
||||||
|
|
||||||
Kml_Printer();
|
|
||||||
~Kml_Printer();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -34,7 +34,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef GNSS_SDR_NMEA_PRINTER_H_
|
#ifndef GNSS_SDR_NMEA_PRINTER_H_
|
||||||
#define GNSS_SDR_NMEA_PRINTER_H_
|
#define GNSS_SDR_NMEA_PRINTER_H_
|
||||||
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
@ -59,18 +59,14 @@ public:
|
|||||||
*/
|
*/
|
||||||
~Nmea_Printer();
|
~Nmea_Printer();
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string nmea_filename ; //<! String with the NMEA log filename
|
std::string nmea_filename ; //<! String with the NMEA log filename
|
||||||
std::ofstream nmea_file_descriptor ; //<! Output file stream for NMEA log file
|
std::ofstream nmea_file_descriptor ; //<! Output file stream for NMEA log file
|
||||||
std::string nmea_devname;
|
std::string nmea_devname;
|
||||||
int nmea_dev_descriptor ; //<! NMEA serial device descriptor (i.e. COM port)
|
int nmea_dev_descriptor ; //<! NMEA serial device descriptor (i.e. COM port)
|
||||||
|
|
||||||
gps_l1_ca_ls_pvt* d_PVT_data;
|
gps_l1_ca_ls_pvt* d_PVT_data;
|
||||||
|
|
||||||
int init_serial (std::string serial_device); //serial port control
|
int init_serial (std::string serial_device); //serial port control
|
||||||
void close_serial ();
|
void close_serial ();
|
||||||
|
|
||||||
std::string get_GPGGA();
|
std::string get_GPGGA();
|
||||||
std::string get_GPGSV();
|
std::string get_GPGSV();
|
||||||
std::string get_GPGSA();
|
std::string get_GPGSA();
|
||||||
@ -79,7 +75,6 @@ private:
|
|||||||
std::string longitude_to_hm(double longitude);
|
std::string longitude_to_hm(double longitude);
|
||||||
std::string latitude_to_hm(double lat);
|
std::string latitude_to_hm(double lat);
|
||||||
char checkSum(std::string sentence);
|
char checkSum(std::string sentence);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
* 1) The carrier-phase measurement at one or both carriers (actually being a
|
* 1) The carrier-phase measurement at one or both carriers (actually being a
|
||||||
* measurement on the beat frequency between the received carrier of the
|
* measurement on the beat frequency between the received carrier of the
|
||||||
* satellite signal and a receiver-generated reference frequency).
|
* satellite signal and a receiver-generated reference frequency).
|
||||||
* 2) The pseudorange (code) measuremen , equivalent to the difference
|
* 2) The pseudorange (code) measurement , equivalent to the difference
|
||||||
* of the time of reception (expressed in the time frame of the receiver)
|
* of the time of reception (expressed in the time frame of the receiver)
|
||||||
* and the time of transmission (expressed in the time frame of the satellite)
|
* and the time of transmission (expressed in the time frame of the satellite)
|
||||||
* of a distinct satellite signal.
|
* of a distinct satellite signal.
|
||||||
@ -66,8 +66,6 @@
|
|||||||
*/
|
*/
|
||||||
class Rinex_Printer
|
class Rinex_Printer
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/*!
|
/*!
|
||||||
* \brief Default constructor. Creates GPS Navigation and Observables RINEX files and their headers
|
* \brief Default constructor. Creates GPS Navigation and Observables RINEX files and their headers
|
||||||
@ -106,30 +104,19 @@ public:
|
|||||||
* \brief Writes observables into the RINEX file
|
* \brief Writes observables into the RINEX file
|
||||||
*/
|
*/
|
||||||
void log_rinex_obs(std::ofstream& out, Gps_Navigation_Message nav_msg, std::map<int,double> pseudoranges);
|
void log_rinex_obs(std::ofstream& out, Gps_Navigation_Message nav_msg, std::map<int,double> pseudoranges);
|
||||||
|
|
||||||
std::map<std::string,std::string> satelliteSystem; //<! GPS, GLONASS, SBAS payload, Galileo or Compass
|
std::map<std::string,std::string> satelliteSystem; //<! GPS, GLONASS, SBAS payload, Galileo or Compass
|
||||||
std::map<std::string,std::string> observationType; //<! PSEUDORANGE, CARRIER_PHASE, DOPPLER, SIGNAL_STRENGTH
|
std::map<std::string,std::string> observationType; //<! PSEUDORANGE, CARRIER_PHASE, DOPPLER, SIGNAL_STRENGTH
|
||||||
std::map<std::string,std::string> observationCode; //<! GNSS observation descriptors
|
std::map<std::string,std::string> observationCode; //<! GNSS observation descriptors
|
||||||
|
|
||||||
|
|
||||||
std::string stringVersion; //<! RINEX version (2.10/2.11 or 3.01)
|
std::string stringVersion; //<! RINEX version (2.10/2.11 or 3.01)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
int version ; // RINEX version (2 for 2.10/2.11 and 3 for 3.01)
|
int version ; // RINEX version (2 for 2.10/2.11 and 3 for 3.01)
|
||||||
|
|
||||||
int numberTypesObservations; // Number of available types of observable in the system. Should be public?
|
int numberTypesObservations; // Number of available types of observable in the system. Should be public?
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Generation of RINEX signal strength indicators
|
* Generation of RINEX signal strength indicators
|
||||||
*/
|
*/
|
||||||
int signalStrength(double snr);
|
int signalStrength(double snr);
|
||||||
|
|
||||||
|
|
||||||
/* Creates RINEX file names according to the naming convention
|
/* Creates RINEX file names according to the naming convention
|
||||||
*
|
*
|
||||||
* See http://igscb.jpl.nasa.gov/igscb/data/format/rinex301.pdf
|
* See http://igscb.jpl.nasa.gov/igscb/data/format/rinex301.pdf
|
||||||
@ -426,7 +413,6 @@ inline std::string& Rinex_Printer::sci2for(std::string& aStr,
|
|||||||
const std::string::size_type expLen,
|
const std::string::size_type expLen,
|
||||||
const bool checkSwitch)
|
const bool checkSwitch)
|
||||||
{
|
{
|
||||||
|
|
||||||
std::string::size_type idx = aStr.find('.', startPos);
|
std::string::size_type idx = aStr.find('.', startPos);
|
||||||
int expAdd = 0;
|
int expAdd = 0;
|
||||||
std::string exp;
|
std::string exp;
|
||||||
@ -505,19 +491,17 @@ inline std::string& Rinex_Printer::sci2for(std::string& aStr,
|
|||||||
aStr.insert((std::string::size_type)1, 1, '0');
|
aStr.insert((std::string::size_type)1, 1, '0');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return aStr;
|
return aStr;
|
||||||
|
|
||||||
} // end sci2for
|
} // end sci2for
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
inline std::string asString(const long double x, const std::string::size_type precision)
|
inline std::string asString(const long double x, const std::string::size_type precision)
|
||||||
{
|
{
|
||||||
std::ostringstream ss;
|
std::ostringstream ss;
|
||||||
ss << std::fixed << std::setprecision(precision) << x ;
|
ss << std::fixed << std::setprecision(precision) << x ;
|
||||||
return ss.str();
|
return ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user