USB GNSS RTK Receiver Setup

Helpful Resources

This setup provides a tutorial on how to use a GNSS RTK Receiver, a Linux Machine, and an RTK Correction Service (or Base Station) to access position data with centimeter-level precision. Many GNSS RTK Receivers will connect to an NTRIP Caster directly utilizing its on-board LoRa,WiFi, Bluetooth, or Cellular Modem. However this tutorial is geared towards using a Linux Machine to connect to an NTRIP Caster to receive the RTK Correction Data and then relay the data to the RTK Receiver via USB. This use case is more relevant to a robotic platform that already has access to the Internet or a Local Network with an NTRIP Caster/Server. Main reason to do it this way is because your Linux Machine may already be using a Cellular Modem or Long Distance Wireless Access Point. This would render the wireless capabilities of the RTK Receiver as redundant or less capable than what the Linux machine is using.

Basic Concepts

GNSS RTK Receiver (Rover)

These devices have recently became available in low-cost forms with comparable performance to higher end products. It is basically a micro-controller with a GNSS antenna and receiver with the capability to run complex calculations that enable it to resolve position data with centimeter precision under the right conditions. The micro-controller may be using a library like RTKLIB to perform the calculations. The most important condition for resolving centimeter-level precision is access to RTK corrections from a nearby (approximately 35 km) Base Station.

Base Station

The Base Station is basically a stationary GNSS RTK Receiver that is configured to stream out RTK correction data using a NTRIP Server (COTS products offer this as a single package). A Base Station and Reference Station are synonymous.

Continuously Operating Reference Stations (CORS) network

A CORS Network is a collection of GNSS Base stations combined in a single network to provide wider coverage of valid RTK correction data. Recall that RTK correction data is only valid within approximately a 35 km radius of the Base Station. A CORS network may provide convenient access to RTK correction data from the nearest base station. There also exist advance techniques to combine correction data from multiple base stations to provide correction data from a Virtual Reference Station (VRS) to further reduce location error. See VRS for details

NTRIP Client

RTKLIB provides a suite of CLIs and GUIs that simplify much of the work. In theory could configure your design to perform the RTK calculations on the Linux Machine. However in this tutorial, the Linux Machine is only used to relay the RTK correction data from the NTRIP Caster to the GNSS RTK Receiver. To do this we use the RTKLIB CLI str2str which enables us to connect to a NTRIP caster as a data input source and a GNSS RTK Receiver has a data output target. This employs our Linux machine as a NTRIP Client. Alternatively, instead of using the RTKLIB CLI, we can use the ROS package ntrip_client. See OpenMower’s ntrip_client launch file for further details.

https://software.rtcm-ntrip.org/wiki

GNSS RTK Receiver

Configure RTK device correction input and position out methods

This project is using the Emlid Reach RTK Module and following documentation. Once the device is connected to a local WiFi network device can be accessed via the web app http://reach.local

Emlid Reach

  • Raw data receiver: U-blox NEO-M8T – 72 channels, output rate is up to 18Hz, supports GPS L1, GLONASS G1, BeiDou B1, QZSS, SBAS, ready for Galileo E1
  • Processing unit: Intel Edison – dual-core 500 MHz
  • Connectivity: I2C, UART, GPIO, TimeStamp, OTG USB, Bluetooth, Wi-Fi
  • GNSS Antenna: external with MCX connector

Interface

Identifying serial port label

  1. Open a terminal and enter the following command to capture the serial port device label e.g. /dev/tty* More info
dmesg --follow
  1. Plugin in the USB RTK module and on the Linux terminal you should see this something like the following:
[604400.525618] cdc_acm 1-1.3:1.0: ttyACM0: USB ACM device
                                   ^^^^^^^ make note of this label

NOTE

If you’re using a terminal within a docker container you may need to try running the container in privileged mode using the --privileged flag. Privileged mode is not a secure solution but the alternative requires you to specify the exact device and grant access to the device group. The devcontainer.json with look something like the following:

"runArgs": [
  "--device=/dev/ttyUSB0:/dev/ttyUSB0",
   "--group-add=dialout",
]

Test GPS serial port

  1. Cancel the process from step 0. In the terminal, enter the following.
sudo screen /dev/ttyACM0 9600

or

sudo cutecom
  1. You should be able to observe NMEA strings streamed to the terminal. If not, your device may need to be manually configured to do so. One, alternative method is to configure the GNSS receiver to output data via TCP. Enter the either the following commands to observe the data stream.
nc 192.168.0.20:9002

or

socat - TCP4:192.168.0.20:9002
  1. The str2str rtklib CLI application is use to connect to a NTRIP Caster and receive correction data.
$ sudo ./str2str -in ntrip://username:password@hostname:port/mountpoint -out serial://ttyACM0:115200#52001 -b 1

Creating a persistent label for the RTK GNSS USB device

To use the serial device as non-root user, udev rules must be installed.

CAUTION

This serial interface label e.g. ttyACM0 is liable to change depending on various reasons. The following commands will be used create a persistent label for serial port device and enable use by a non-root user.

  1. Open a terminal and enter the following follow commands.
lsusb
  1. You should see this something like the following:
Bus 003 Device 063: ID 3032:0014 Emlid Reach
                       ^^^^ ^^^^
                    vendor  product
  1. Identify the the serial port label Identifying serial port label
  2. Run the udev management tool udevadmn to capture additional info.
udevadm info -q all -n /dev/ttyACM0
P: /devices/pci0000:00/0000:00:14.0/usb3/3-1/3-1:1.2/tty/ttyACM0
N: ttyACM0
....
E: DEVPATH=/devices/pci0000:00/0000:00:14.0/usb3/3-1/3-1:1.2/tty/ttyACM0
E: DEVNAME=/dev/ttyACM0
E: MAJOR=166
E: MINOR=0
E: SUBSYSTEM=tty       <----------- make note of this label
E: USEC_INITIALIZED=166592821213
E: ID_BUS=usb
E: ID_VENDOR_ID=3032   <------------
E: ID_MODEL_ID=0014    <------------
E: ID_PCI_CLASS_FROM_DATABASE=Serial bus controller
....
  1. Next we need to provide the system instructions on how to treat our GNSS USB device. Here our goal is to create a persistent name for a device node by creating a symbolic link to the default device node.
cd /etc/udev/rules.d/;
sudo vim 51-emlid.rules
# Copy this udev with "sudo cp 51-emlid.rules /etc/udev/rules.d/"
# When done, do "sudo udevadm control --reload && sudo udevadm trigger"
# Edit it to suit your type of Linux. It's currently set up for modern Ubuntu
ATTRS{idProduct}=="0014", ATTRS{idVendor}=="3032", MODE:="666", GROUP="plugdev", SUBSYSTEM=="tty", SYMLINK+="emlid_rtk"

Explanation

  1. ATTRS{idProduct}=="0014", ATTRS{idVendor}=="3032":
  • This helps identify a particular type or brand of device.
  1. MODE:="666"
  • β€œ666” corresponds to read (4), write (2), and execute (1) permissions for the owner, group, and others, respectively. In this context, β€œ666” means read and write permissions for everyone.
  1. GROUP="plugdev":
    • This specifies the group ownership of the device node. The device will be assigned to the β€œplugdev” group. The β€œplugedev” group is primarilty associated with serial commuication devices such as UART ports.
  2. SUBSYSTEM=="tty":
    • This condition narrows down the rule to devices in the β€œtty” (terminal) subsystem. It’s often used for serial port devices.
  3. SYMLINK+="emlid_rtk":
    • This creates a symbolic link named β€œemlid_rtk” pointing to the device node. Symbolic links provide an additional name for the device, making it more user-friendly or predictable.
  1. Next we must reload udev rules and then trigger udev to reevaluate devices based on those updated rules. This enables our recent changes to take effect without requiring a system restart.
sudo udevadm control --reload && sudo udevadm trigger

Re-plug in USB GNSS receiver and verify NMEA strings streamed to the terminal

ls -l /dev/emlid*
sudo screen /dev/emlid_rtk

Transclude of note.c

RTKLIB str2str

NOTE

Access RTK correction service and RTK correction data

  • If your using a RTK correction service then we need a convenient way to store the login credentials securely. This is can be done with Environment Variables
  • Alternatively you can set up your own base station (this requires an additional Receiver that can stream out RTK corrections).
  • Each method will perform similarly. The limitations of each will be based on the following:
MethodBase Station CoverageCost
RTK ServiceTypically StatewideFree or Subscription (depending on state)
RTK Base station6 mi (single band) 36 mi (multi-band)+$300 for additional receiver and antenna

Installing RTKLIB

  1. In the terminal install the rtklib
sudo apt install rtklib
  1. Attempt to receive RTK corrections. Note the placeholders for the required parameters are environment variables. Environment Variables discusses details on how to set these up so you don’t have to remember them.
  • Single Site
str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_SINGLE/$NT_ENDPOINT_SINGLE#rtcm3
  • Automatic Site

IMPORTANT

Automatic site requires communication with a GNSS RTK Receiver in order to automatically send you correction data from the nearest site (mount point) or if caster is using VRS. Since there is NO target -out parameter provided in the example below str2str will timeout as it waits to receive GNSS coordinate data. In this case the -in -out semantics might be confusing since the data is being exchanged in both directions between server and client.

It is important to understand that if you are using Automatic Cells or VRS (see this) then a target -out parameter specifying a GNSS receiver and the -b 1 arguments must be passed with str2str or the NTRIP caster will time out.

For additional details see [[#explanation-of-str2str-parameters|Explanation of str2str parameters]]

str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_AUTO/$NT_ENDPOINT_AUTO

str2str Testing

  1. Run the str2str rtklib CLI application

To receive Single site corrections via NTRIP and relay to USB GNSS receiver via serial

str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_SINGLE/$NT_ENDPOINT_SINGLE#rtcm3 -out serial://emlid_rtk:115200#52001

To Receive Automatic cell corrections via NTRIP and relay to USB GNSS receiver via serial

IMPORTANT

For VRS or Automatic Cell sites, just be sure to include -b 1 with your output stream.

str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_AUTO/$NT_ENDPOINT_AUTO -out serial://emlid_rtk:115200 -b 1

Note

STR2STR also implements β€œOutput Received Stream to TCP Port” option like STRSVR 2.4.3 b34 https://github.com/tomojitakasu/RTKLIB/issues/573#issuecomment-760017844

  • Alt. to Receive Automatic cell corrections via NTRIP and stream RTCM sentences via serial port. Stream reciever NMEA sentences via serial and TCP port 52001.
str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_AUTO/$NT_ENDPOINT_AUTO -out serial://emlid_rtk:115200#52001 -b 1
  1. Listen
nc localhost 52001

Explanation of str2str parameters

Running str2str

todo

  • -in ntrip://username:password@host:port/mount#format
    • username:
    • password:
    • host: IP address of
    • port:
    • mount:
    • format:
  • -out serial://device_port:bitrate:parity:stopbit:fctr#output_tcp_port
    • device_port:
    • bitrate:
    • parity:
    • stopbit:
    • fctr:
    • output_tcp_port:
  • -b 1: The -b 1 indicates we want to use the 1st of many output streams (if multiple outputs streams are used) as the source to send NMEA GGA messages to the corrections provider (required for VRS or Automatic Cells) background

Environment Variables

There are multiple ways to do this. The most important point is to choose the way that offers the least risk from developers accidentally committing passwords or secrets to your public git repo.

https://www.linode.com/docs/guides/how-to-set-linux-environment-variables/

  1. Open new terminal, and append the .bashrc file with the following template and overwriting the characters with ...
sudo vim ~/.bashrc

WARNING

Note login credentials environment variables have been omitted. Use this snippet as a template. Be careful NOT to upload theses to the internet. This should pasted at the bottom of the .bashrc file of the Linux machine. This will create permanent environment variables to store RTK correction service login credentials. This template has two separate ports and endpoints for connecting to a network that automatically selects a reference station and one for connecting a specific reference station.

Info

If you prefer not to store secrets as environment variables OWSAP recommends using secrets-manager such as:

AWS Secret Manager,Β Azure Key Vault,Β Google Secret Manager), or other third-party facilities (Hashicorp Vault,Β Conjur,Β Keeper,Β Confidant)

Other secret managers are:

# InCORS RTK correction service credentials https://incors.in.gov/
#########################################################
# DO NOT commit to source control unless encrypted      #
#########################################################
export NT_HOSTNAME='...'
# Automatic cells
export NT_PORT_AUTO='9000'
export NT_ENDPOINT_AUTO='RTCM3_MAX'
# single site
export NT_PORT_SINGLE='...'
export NT_ENDPOINT_SINGLE='...'
# secret
export NT_USER='...'
export NT_PASSWORD='...'
  1. After saving edits, close the terminal then run source ~/.bahsrc
  2. Verify environment variables
echo -e '\n'\
'ntrip hostname:        ' $NT_HOSTNAME'\n'\
'ntrip port_auto:       ' $NT_PORT_AUTO'\n'\
'ntrip endpoint_auto:   ' $NT_ENDPOINT_AUTO'\n'\
'ntrip port_sigle:      ' $NT_PORT_SINGLE'\n'\
'ntrip endpoint_single: ' $NT_ENDPOINT_SINGLE'\n'\
'ntrip user:            ' $NT_USER'\n'\
'nitrip password:       ' $NT_PASSWORD

NOTE

Alternatively, you can save the environment variables to a standalone file such as .env.dev and then encrypt the value of the key-value pair with dontenvx. Just don’t commit your .env.keys πŸ˜‰

The main risk is are the following:

  1. You main accidentally commit .env.dev file decrypted.
  2. You may accidentally commit the .env.keys file.
  3. Not post-quantum safe.

Extras

  • Set trace level with -t 3 and you can read logs with cat str2str.trace
str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_SINGLE/$NT_ENDPOINT_SINGLE#rtcm3 -t 3
cat str2str.trace

ROS2 Demo

Initial Testing

  • Configure the Emlid Reach device β€œCorrection input” settings to connect to an NTRIP server via the webapp. Note this ideally should be done via str2str because such method would used the rpi’s network connection instead of the WiFi module on-board the Reach device itself. The main hurdle with using str2str is that the command typically connects to the serial interface of the GPS device and most ROS2 packages will only connect to a GPS devices’ serial interface. This is OK because we could provide a second serial interface via the UART interface on-board the Reach device and connect the GPIO/UART pins on to the rpi. However this demo section is simply exploring the several ways of getting RTK correction data to our GPS device and then connecting the NEMA sentences to a ROS2 node that can then publish NavSatFix messages.
  • Install the nmea_serial_driver ROS2 package
sudo apt update
sudo apt install ros-humble-nmea-navsat-driver
ros2 run nmea_navsat_driver nmea_serial_driver --ros-args --params-file ./config/nmea_serial_driver.yaml
  • Echo the ROS2 topic /fix which contains the sensor_msgs/msg/NavSatFix messages
ros2 topic info /fix
  • Observe the NavSatFix messages with covariance data.
header:
  stamp:
    sec: 1705213614
    nanosec: 891449711
  frame_id: gps
status:
  status: 2
  service: 1
latitude: omitted
longitude: omitted
altitude: omitted
position_covariance:
- 0.000144
- 0.0
- 0.0
- 0.0
- 0.000144
- 0.0
- 0.0
- 0.0
- 0.0144
position_covariance_type: 1
  • Takeaway: This initial test verifies the principles, but one draw back is that the RTCM messages are streamed to the Reach module via it’s onboard WiFi connection from the local network. Ideally I would prefer the RTCM messages were streamed to the Reach Module via the Raspberry Pis’ in a β€œPC-to-USB” fashion. The main hurdle with this is we will need to use the UART ports on the the Reach module and Raspberry Pi to receive NMEA sentences. Using a single serial port for transmitting correction data to GNSS receiver and reading the NMEA sentences (using two separate processes) doesn’t seem possible or is error prone at this time so two serial port may be necessary.

My current understanding of possible configurations at this moment are:

  1. Utilize Reach Modules’ on-board WiFi and NTRIP client software to receive RTCM and stream the receiver β€œPosition Output” to the Raspberry Pi in a β€œSerial-To-PC” fashion and utilize nmea_navsat_diver (Initial Testing Config)
  2. Utilize str2str and nmea_navsat_driver and UART as a second channel for receiving NMEA sentences while PC-to-Serial is used for streaming RTCM Messages to the Reach Module.
  3. Utilize str2str and nmea_tcp_driver (Only after nmea_tcp_driver is rewritten for ROS2 support πŸ’€) Currently started on a emlid_reach_ros2 but I’m not sure how much work is required.
  4. Utilize str2str and gpsd_client

Test 2 - gpsd

Connect emlid device with correction service via str2str and Output Received Stream to TCP Port 52001.

str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_SINGLE/$NT_ENDPOINT_SINGLE#rtcm3 -out serial://emlid_rtk:115200#52001

Verify NMEA stream is present on port 52001 with nc.

nc localhost 52001

Launch gpsd with the following options. This program parses the NMEA stream on the TCP port.

  • -N: don’t go into background
  • -p: do not reconfigure the receiver automatically
  • -d: set debug level, default 0
  • -S: set port for daemon, default 2947
  • tcp://host[:port]
 sudo gpsd -N -p -D 5 -S 10002 tcp://localhost:52001

Run cgps to verify that gpsd can relay the GPS data.

cgps localhost:10002

or

gpsmon localhost:10002

Output from cgps. Notice we have a fix status.

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€Seen  0/Used  0┐
β”‚ Time:          n/a (0)                    β”‚β”‚GNSS   PRN  Elev   Azim   SNR Useβ”‚
β”‚ Latitude:         <omitted>   N           β”‚β”‚                                 β”‚
β”‚ Longitude:        <omitted>   W           β”‚β”‚                                 β”‚
β”‚ Alt (HAE, MSL):   <omitted>, <omitted> ft β”‚β”‚                                 β”‚
β”‚ Speed:           n/a                      β”‚β”‚                                 β”‚
β”‚ Track (true, var):                n/a deg β”‚β”‚                                 β”‚
β”‚ Climb:           n/a                      β”‚β”‚                                 β”‚
β”‚ Status:         3D RTK FIX (161 secs)     β”‚β”‚                                 β”‚
β”‚ Long Err  (XDOP, EPX):  n/a ,  n/a        β”‚β”‚                                 β”‚
β”‚ Lat Err   (YDOP, EPY):  n/a ,  n/a        β”‚β”‚                                 β”‚
β”‚ Alt Err   (VDOP, EPV):  n/a , +/-  150 ft β”‚β”‚                                 β”‚
β”‚ 2D Err    (HDOP, CEP):  n/a , +/- 81.0 ft β”‚β”‚                                 β”‚
β”‚ 3D Err    (PDOP, SEP):  n/a , +/-  149 ft β”‚β”‚                                 β”‚
β”‚ Time Err  (TDOP):       n/a               β”‚β”‚                                 β”‚
β”‚ Geo Err   (GDOP):       n/a               β”‚β”‚                                 β”‚
β”‚ ECEF X, VX:              n/a    n/a       β”‚β”‚                                 β”‚
β”‚ ECEF Y, VY:              n/a    n/a       β”‚β”‚                                 
β”‚ ECEF Z, VZ:              n/a    n/a       β”‚β”‚                                 β”‚
β”‚ Speed Err (EPS):        n/a               β”‚β”‚                                 β”‚
β”‚ Track Err (EPD):        n/a               β”‚β”‚                                 β”‚
β”‚ Time offset:            n/a               β”‚β”‚                                 β”‚
β”‚ Grid Square:            <omitted>         β”‚β”‚                                 β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Test 2 Results

We demonstrated that a single connection (USB) to the emlid GPS device running the programs str2str and gpsd on the rpi prepare us to utilize the ROS2 package gpsd_clientto offer NavSatFix messages.

Test 2 - gpsd_client

NOTE

These commands quickly become cumbersome to wrangle with. A more practical solution will use a single command that essentially calls the following commands sequentially. These commands are provided as an educational guide and demonstrate principles. Here is a ROS2 python launch file that streamlines the process. gpsd-client-test.py

Connect emlid device with correction service via str2str and Output Received Stream to TCP Port 9123.

str2str -in ntrip://$NT_USER:$NT_PASSWORD@$NT_HOSTNAME:$NT_PORT_AUTO/$NT_ENDPOINT_AUTO -out serial://emlid_rtk:115200#9123 -b 1

Start the gspd server in the foreground (-N) on port 9234 (-S) and connect to the previously instantiated TCP stream on port 9123 (tcp://localhost:9123).

gpsd -N -S 9234 tcp://localhost:9123

Start the gpsd_client ROS2 node and connect client to the previously started gpsd server

IMPORTANT

No nodes (executables) are compiled for gpsd_client. You’ll have to load it as a component, gpsd_client::GPSDClientComponent. And the ros2 component standalone command doesn’t support --ros-args directly. Instead, you must use the ros2 component load command in conjunction with ros2 run to achieve a similar effect.

Start the component container.

ros2 run rclcpp_components component_container

In a new terminal, load the component into the container with the specified parameters.

ros2 component load /ComponentManager gpsd_client gpsd_client::GPSDClientComponent --node-name gpsd_client_composed_node --param host:=localhost --param port:=9234 --param use_gps_time:=false --param check_fix_by_variance:=false --param frame_id:=gps --param publish_rate:=1

Print the ROS sensor_msgs/msg/NavSatFix topic to the terminal.

ros2 echo /fix

Observe, GNSS data with a valid fix is available in our ROS topic πŸ₯³

header:
  stamp:
    sec: 1721540846
    nanosec: 346349874
  frame_id: gps
status:
  status: 0 <--- `STATUS_FIX`, indicating that a valid fix has been obtained.
  service: 1
latitude: <omitted>
longitude: <omitted>
altitude:  <omitted>
position_covariance:
- 10.632
- 0.0
- 0.0
- 0.0
- 24.189
- 0.0
- 0.0
- 0.0
- 42.55
position_covariance_type: 2
---

Test 3 - ROS2 reach_ros_node

Pretesting Note: Recently a ROS1 package (reach_ros_node) became available for ROS2 for the Emlid Reach RTK Module. If this works the way I expect it, I would only need to run the str2str command with the TCP output and the node from this package.

Test 3 Results

I encountered issues with the ros2 branch of reach_ros_node. It seems that it is not fully developed for ROS2 yet.

Testing Summary

The python ros2 launch file examples below, will perform following:

  1. Use dotenx to decrypt str2str login parameters
  2. Utilize str2str to receive correction data
    1. inputs:
      1. Location Data from GNSS device
      2. Correction data from CORS Network
    2. outputs:
      1. Location data to CORS Network
      2. Location data to local Network tcp://localhost:9123
  3. Utilize a gpsd server to republished the data as JSON objects
    1. Inputs:
      1. Location data from local Network tcp://localhost:9123
    2. Outputs:
      1. JSON formatted location data to local network tcp://localhost:9234
  4. Utilize gpsd_client::GPSDClientComponent to republish data as a ROS topic
    1. input:
      1. JSON formatted location data from local network tcp://localhost:9234
    2. Outputs:
      1. Location data as a ROS topic sensor_msgs/msg/NavSatFix messages

gpsd-client-test.py

PATH: https://raw.githubusercontent.com/digitalhabitat/bot2_ros2_workspace/humble/launch/gpsd-client-test.py

Questions

Q1. How do you find the NTRIP Mount point for Automatic Cells or Single Sites?

  1. The service provider may have a number of resources such as a table specifying the connection details or an interactive map of Sites a part of the CORs Network.
  2. With a given IP address and Port you can use str2str -in ntrip://<ip>:<port> to return a Source Table with the 2nd data field specifying the mount point. For more info see
  3. There are also several tools that enable you browse the available mount points on such as http://monitor.use-snip.com/ or srctblbrows.exe

Nomenclature

todo

Source Table: Represents contents list of provided data by NTRIP servers

  1. RTK (Real-Time Kinematic): A technique used to improve the precision of GNSS data.
  2. GNSS (Global Navigation Satellite System): A generic term used for satellite navigation systems including GPS, GLONASS, Galileo, and BeiDou.
  3. PPP (Precise Point Positioning):
  4. Base Station: A stationary GNSS receiver used as a reference point for RTK corrections.
  5. Rover Station: A mobile GNSS receiver that receives corrections from a base station.
  6. NMEA message/string:todo
  7. NTRIP (Networked Transport of RTCM via Internet Protocol): A communication protocol to streaming RTCM correction data over the internet.
  8. RTCM (Radio Technical Commission for Maritime Services): An international standards body that defines standards such as, RTCM SC-104, which specifies a set of binary messages (aka RTCM messages) containing GNSS correction data.
  9. Observation Data: Raw GNSS measurements collected by a receiver, including pseudoranges and carrier phase information.
  10. Solution: The final output of the positioning process, providing accurate coordinates for a specific location.
  11. Float Solution: A position solution with a lower level of accuracy, often used in standard GPS positioning.
  12. Fix Solution: A high-precision position solution achieved through RTK techniques, providing centimeter-level accuracy.
  13. DGNSS (Differential GNSS): A technique that improves GNSS accuracy by using correction data from a reference station.
  14. Cycle Slip:
  15. ION (Institute of Navigation): A professional organization that focuses on the science and art of navigation.
  16. Tropospheric Delay: The slowing of GNSS signals as they pass through the Earth’s atmosphere, affecting accuracy.
  17. Receiver Firmware: . Embedded software of GNSS receievers.
  18. RINEX (Receiver Independent Exchange Format): A standard format for exchanging GNSS data between different software.
  19. Solution Status: Information indicating the quality and reliability of the position solution, such as β€˜FIXED’ or β€˜FLOAT.’
  20. Ambiguity Resolution: The process of determining the integer values in carrier phase measurements to improve positioning accuracy in RTK.