mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-10-24 03:57:39 +00:00
TCP port and RTCM Station ID config can be done now by the Rtcm_Printer
This commit is contained in:
@@ -39,25 +39,30 @@
|
||||
#include <boost/crc.hpp>
|
||||
#include <boost/date_time/gregorian/gregorian.hpp>
|
||||
#include <boost/dynamic_bitset.hpp>
|
||||
#include <gflags/gflags.h>
|
||||
#include <glog/logging.h>
|
||||
#include "Galileo_E1.h"
|
||||
|
||||
|
||||
using google::LogMessage;
|
||||
|
||||
DEFINE_int32(RTCM_Ref_Station_ID, 1234, "Reference Station ID in RTCM messages");
|
||||
DEFINE_int32(RTCM_Port, 2101 , "TCP port of the RTCM message server");
|
||||
// 2101 is the standard RTCM port according to the Internet Assigned Numbers Authority (IANA)
|
||||
// https://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xml
|
||||
|
||||
|
||||
Rtcm::Rtcm()
|
||||
{
|
||||
// 2101 is the standard RTCM port according to the Internet Assigned Numbers Authority (IANA)
|
||||
// https://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xml
|
||||
unsigned short _default_port = 2101;
|
||||
unsigned short _default_station_id = 1234;
|
||||
Rtcm::Rtcm(_default_port, _default_station_id);
|
||||
}
|
||||
|
||||
|
||||
Rtcm::Rtcm(unsigned short port, unsigned short station_id)
|
||||
{
|
||||
RTCM_port = port;
|
||||
RTCM_Station_ID = station_id;
|
||||
preamble = std::bitset<8>("11010011");
|
||||
reserved_field = std::bitset<6>("000000");
|
||||
rtcm_message_queue = std::make_shared< concurrent_queue<std::string> >();
|
||||
boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), FLAGS_RTCM_Port);
|
||||
boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), RTCM_port);
|
||||
servers.emplace_back(io_service, endpoint);
|
||||
server_is_running = false;
|
||||
}
|
||||
@@ -80,10 +85,10 @@ Rtcm::~Rtcm()
|
||||
// *****************************************************************************************************
|
||||
void Rtcm::run_server()
|
||||
{
|
||||
std::cout << "Starting a TCP Server on port " << FLAGS_RTCM_Port << std::endl;
|
||||
std::cout << "Starting a TCP Server on port " << RTCM_port << std::endl;
|
||||
try
|
||||
{
|
||||
std::thread tq([&]{ std::make_shared<Queue_Reader>(io_service, rtcm_message_queue, FLAGS_RTCM_Port)->do_read_queue(); });
|
||||
std::thread tq([&]{ std::make_shared<Queue_Reader>(io_service, rtcm_message_queue, RTCM_port)->do_read_queue(); });
|
||||
tq.detach();
|
||||
|
||||
std::thread t([&]{ io_service.run(); });
|
||||
@@ -105,7 +110,7 @@ void Rtcm::stop_service()
|
||||
|
||||
void Rtcm::stop_server()
|
||||
{
|
||||
std::cout << "Stopping TCP Server on port " << FLAGS_RTCM_Port << std::endl;
|
||||
std::cout << "Stopping TCP Server on port " << RTCM_port << std::endl;
|
||||
rtcm_message_queue->push("Goodbye"); // this terminates tq
|
||||
Rtcm::stop_service();
|
||||
servers.front().close_server();
|
||||
@@ -448,7 +453,7 @@ std::bitset<58> Rtcm::get_MT1001_sat_content(const Gps_Ephemeris & eph, double o
|
||||
|
||||
std::string Rtcm::print_MT1001(const Gps_Ephemeris & gps_eph, double obs_time, const std::map<int, Gnss_Synchro> & pseudoranges)
|
||||
{
|
||||
unsigned int ref_id = static_cast<unsigned int>(FLAGS_RTCM_Ref_Station_ID);
|
||||
unsigned int ref_id = static_cast<unsigned int>(RTCM_Station_ID);
|
||||
unsigned int smooth_int = 0;
|
||||
bool sync_flag = false;
|
||||
bool divergence_free = false;
|
||||
@@ -498,7 +503,7 @@ std::string Rtcm::print_MT1001(const Gps_Ephemeris & gps_eph, double obs_time, c
|
||||
|
||||
std::string Rtcm::print_MT1002(const Gps_Ephemeris & gps_eph, double obs_time, const std::map<int, Gnss_Synchro> & pseudoranges)
|
||||
{
|
||||
unsigned int ref_id = static_cast<unsigned int>(FLAGS_RTCM_Ref_Station_ID);
|
||||
unsigned int ref_id = static_cast<unsigned int>(RTCM_Station_ID);
|
||||
unsigned int smooth_int = 0;
|
||||
bool sync_flag = false;
|
||||
bool divergence_free = false;
|
||||
@@ -570,7 +575,7 @@ std::bitset<74> Rtcm::get_MT1002_sat_content(const Gps_Ephemeris & eph, double o
|
||||
|
||||
std::string Rtcm::print_MT1003(const Gps_Ephemeris & ephL1, const Gps_CNAV_Ephemeris & ephL2, double obs_time, const std::map<int, Gnss_Synchro> & pseudoranges)
|
||||
{
|
||||
unsigned int ref_id = static_cast<unsigned int>(FLAGS_RTCM_Ref_Station_ID);
|
||||
unsigned int ref_id = static_cast<unsigned int>(RTCM_Station_ID);
|
||||
unsigned int smooth_int = 0;
|
||||
bool sync_flag = false;
|
||||
bool divergence_free = false;
|
||||
@@ -680,7 +685,7 @@ std::bitset<101> Rtcm::get_MT1003_sat_content(const Gps_Ephemeris & ephL1, const
|
||||
|
||||
std::string Rtcm::print_MT1004(const Gps_Ephemeris & ephL1, const Gps_CNAV_Ephemeris & ephL2, double obs_time, const std::map<int, Gnss_Synchro> & pseudoranges)
|
||||
{
|
||||
unsigned int ref_id = static_cast<unsigned int>(FLAGS_RTCM_Ref_Station_ID);
|
||||
unsigned int ref_id = static_cast<unsigned int>(RTCM_Station_ID);
|
||||
unsigned int smooth_int = 0;
|
||||
bool sync_flag = false;
|
||||
bool divergence_free = false;
|
||||
|
@@ -84,6 +84,7 @@ class Rtcm
|
||||
{
|
||||
public:
|
||||
Rtcm(); //<! Default constructor
|
||||
Rtcm(unsigned short port, unsigned short station_id); //<! Constructor that sets non-default TCP port of the RTCM message server and RTCM Station ID
|
||||
~Rtcm();
|
||||
|
||||
/*!
|
||||
@@ -346,6 +347,8 @@ private:
|
||||
//
|
||||
// Classes for TCP communication
|
||||
//
|
||||
unsigned short RTCM_port;
|
||||
unsigned short RTCM_Station_ID;
|
||||
class Rtcm_Message
|
||||
{
|
||||
public:
|
||||
|
Reference in New Issue
Block a user