How to interface a GPS/GNSS module with Ouster Lidar
This article provides instructions on setting up, wiring, and synchronizing with a GPS/GNSS device (NEO-M9N) and Ouster lidar sensor.
Required Items
Hardware Needed
Ouster Sensor: OSx-[32, 64, 128] with included Interface Box (IBOX)
GPS Board: SparkFun GPS Breakout - https://www.sparkfun.com/products/15712 (1) and applicable antenna
PC: Windows machine recommended for this exercise in order to utilize https://www.u-blox.com/en/product/u-center configuration software. Ensure the PC has 1000Base-T (Gigabit Ethernet) capability (via ethernet port on PC or separate USB-Ethernet converter).
Miscellaneous:
Required: Ethernet cable, USB-C cable, M3 torx screwdriver, jumper wires (male and female)
Optional: Breadboard (or plugblock), oscilloscope
Note: This specific SparkFun product requires an antenna (sold separately). Be sure to pick a suitable antenna with U.FL connector for this exercise.
Software Needed
u-center GNSS evaluation software for Windows [freeware]
The u-center version utilized for the creation of this article: u-center, v22.07
Sensor and GPS/GNSS Configuration
Ouster Sensor Configuration via Web Interface
The Ouster sensor must be configured to accept externally generated, electrical signals as ‘inputs’ for both PPS and NMEA. There are many ways to configure the sensor (e.g. via TCP/HTTP api), however the Ouster Web Interface is probably the most simple and effective method.
See our documentation on Web Interface for further details.
Tip: to access the web interface, enter one of the following arguments into a web browser url bar.
http://os-991234567890.local/
where 991234567890 represents the unique serial number of your device.
This can be found on the sensor label or GET /api/v1/sensor/metadata/sensor_info
http://169.254.1.100/
where 169.254.1.100 represents the set IPv4 address of the sensor
Sensor IPv4: GET /api/v1/system/network/ipv4
From the Configuration tab, ensure the following items are configured as described. All other fields can remain as the default values.
Sensor configuration via Web UI | |
---|---|
1 | Timestamp Mode: |
2 | Multipurpose IO Mode: |
3 | NMEA In Polarity: |
4 | NMEA Baud Rate: |
5 | NMEA Leap Seconds: |
6 | Sync Pulse In Polarity: |
7 | Click |
8 | Click |
GPS/GNSS Configuration with u-center
NEO-M9N Configuration Settings for use with Ouster sensor
It is important to ensure you have configured the GPS/GNSS device to be compatible with the Ouster sensor. For details on initial installation of https://www.u-blox.com/en/product/u-center, connecting the GPS receiver, and other introductory features, please refer to the user guide by visiting the manufacturer site.
Getting started:
Open the
Configuration View
(Ctrl+F9)
List of configuration topics to be changed:
Save (BBR/Flash)
NMEA Protocol
UART Out
PPS Out
NMEA Message Types
1. Save (BBR/Flash) | |
---|---|
1 | Highlight |
2 | Select |
3 | Send the message to the receiver |
2. Configure NMEA Protocol | |
---|---|
1 | Highlight |
2 | Select |
3 | Number used for SV’s not supported by NMEA: |
4 | Main Talker ID: |
5 | Send the message to the receiver |
3. Configure UART Out | |
---|---|
1 | Highlight |
2 | Target: |
3 | Baudrate: |
4 | Send the message to the receiver |
| |
---|---|
1 | Highlight |
2 | Timepulse Settings: |
3 | Check the radio button: |
4 | Frequency: |
5 | Length: |
6 | Length Locked: |
7 | Select |
8 | Send the message to the receiver |
| |
---|---|
1 | Highlight |
2 | Timepulse Settings: |
3 | For each message type below, uncheck the box (OFF) for UART1 only.
|
4 | Ensure that UART1 checkbox is selected (ON) for the RMC message type:
|
5 | Send the message to the receiver after each step 3a, 3b, ….4a. |
Hardware Interface and Connections
Component connections
Connect the Ouster sensor to the Interface Box (provided in the box with the sensor). The IBOX comes in a kit which includes the IBOX unit, sensor cable, Ethernet cable ,and a AC-to-DC power supply.
Plug the ethernet cable into the designated port on the IBOX. Connect the other end to your PC (or USB-Ethernet converter). Provide power to the IBOX via the DC jack.
Power the SparkFun NEO-M9N board with a USB-C cable as shown and connect the other end to your PC.
Attach the antenna with U.FL connector to the GPS board where indicated (not shown). Place the antenna module outdoors, or near a window for a sufficient view of the sky.
NEO-M9N + IBOX connections
Remove the clear, plastic cover from the IBOX using the torx screwdriver.
Using jumper wires, connect the PPS, GND and TX/MISO pin on the GPS board to the designated pins on the IBOX as shown in the table/figure below.
GPS Board pin | IBOX Pin |
---|---|
PPS | SYNC_PULSE_IN |
TX/MISO | MULTIPURPOSE_IO |
GND | GND |
Verification of Success
Once all prior steps are complete, follow the instructions below to check if the sensor is synchronized properly and reporting the expected values.
Query the status via Ouster API
HTTP: GET /api/v1/time/sensor
The sensor can be queried and configured using HTTP GET requests. This can be done using several different tools such as HTTPie, cURL, Advanced REST Client, etc. You can execute these queries from a command line application (e.g. Windows CMD, macOS & Linux Terminal)
Here are two examples using a curl command:
curl -i http://os-991234567890/api/v1/time/sensor
where 991234567890 represents the unique serial number of your device. This can be found on the sensor label as a reference.
curl -i http://169.254.1.100/api/v1/time/sensor
where 169.254.1.100 represents the set IPv4 address of the sensor
Response from API Query
From the outputted response below:
Verify the following:
The sensor is locked on to the PPS signal
"sync_pulse_in"
(line 32)"locked": 1
(line 38).
The sensor is locked on the NMEA signal
"nmea"
(line 4)"locked": 1
(line 22)
The last read message looks like a valid GPRMC sentence
"last_read_message" (line 9)
"GPRMC,164853.00,A,4102.23151,N,08141.59407,W,0.052,,080823,,,D,V*16"
The timestamp time has updated to a reasonable GPS time
“timestamp” (line 41)
"time": 1691513333.6113698
(line 43)
Related articles