This example demonstrates how to configure the navigation filter with GNSS velocity and magnetometer as the heading source to stream filter data on a MicroStrain 5-series GNSS/INS device with the MIP SDK using the C++ API.
The example showcases the basic setup and operation of a 5-series GNSS/INS device, including:
- Device initialization and communication
- Filter and GNSS message format configuration
- Gyro bias capture
- Antenna offset configuration
- Filter initialization and heading source configuration
- Real-time data streaming and display
The example uses the following default settings, which should be adjusted based on application requirements:
| Setting | Value | Description |
|---|---|---|
PORT_NAME |
"COM1" (Windows)"/dev/ttyACM0" (Unix) |
Serial port for device communication |
BAUDRATE |
115200 |
Communication baud rate |
SAMPLE_RATE_HZ |
1 |
Data output rate in Hz |
RUN_TIME_SECONDS |
30 |
Example runtime duration |
Please consult the device's user manual for more information on proper configuration of the antenna
This example requires a connected antenna with proper configuration and a clear sky view.
The example configures antenna GNSS setup for enhanced navigation accuracy:
| Translation | Description |
|---|---|
| [-0.25, 0, 0] m | GNSS receiver positioned 0.25m behind the device center |
- Connect your 5-series GNSS/INS device to the specified serial port
- Update the configuration options and the antenna offset based on your application needs
- Compile and run the example
- Follow the gyro bias capture prompt (keep the device stationary)
- The program will:
- Initialize the device
- Configure data streaming
- Wait for the filter to initialize
- Stream data for the specified runtime
- Display filter state and GNSS fix transitions
- Display real-time filter data
- Clean up and exit
The project can be configured on its own using the supplied CMakeLists.txt.
The file is configured to work directly in the MIP SDK project or as a standalone project.
If building outside the MIP SDK project, all that's needed is to define MIP_SDK_ROOT_DIR.
When building within the MIP SDK project, make sure to enable the examples using the MICROSTRAIN_BUILD_EXAMPLES
CMake option.
mkdir build
cd build
cmake .. -DMIP_SDK_ROOT_DIR:PATH=<path_to_mip_sdk>If the project cannot be configured using CMake, then the following project configurations are required:
Link against these libraries:
mip- Core MIP SDK librarymicrostrain- Core MicroStrain SDK librarymicrostrain_serial- MicroStrain serial communication library
Make sure to include those library paths as additional link directories if needed
Add these include directories:
[path_to_mip_sdk_include]/c[path_to_mip_sdk_include]/cpp[path_to_project_root]
path_to_mip_sdk_include can be installed paths or source paths:
- Unix -
/usr/include/microstrain - Windows -
C:/Program Files/MIP_SDK/include/microstrain - Source:
[mip_sdk_project_root]/src
Add these compiler definitions:
MICROSTRAIN_LOGGING_MAX_LEVEL=MICROSTRAIN_LOGGING_LEVEL_INFO_Sets the logging level to info which is the minimum required for this example
initializeDevice()- Establishes communication, validates device connection, and loads defaultscaptureGyroBias()- Captures and applies gyroscope bias compensationconfigureAntennaOffset()- Sets GNSS antenna position relative to the deviceinitializeFilter()- Initializes the navigation filter with GNSS velocity and magnetometer as the heading source
configureFilterMessageFormat()- Configures filter/navigation data output including:- Filter timestamp
- Filter status
- LLH position coordinates
- NED velocity vectors
- Euler angles (roll, pitch, yaw)
configureGnssMessageFormat()- Configures GNSS data output including:- Fix info
displayFilterState()- Displays navigation filter operating mode changesdisplayGnssFixState()- Shows current GNSS fix status and quality
- Uses the
mip::Interfaceclass for device communication - Serial connection handled by
microstrain::connections::SerialConnection
This example uses modern C++ features including:
- Data Extractors: Automatic parsing of incoming data fields
- Type Safety: Strongly typed data structures for each message type
- Callbacks: Automatic data callbacks for registered message types
- String Handling: Safe C++ string operations
This example demonstrates:
- MIP Interface: Modern C++ interface for device communication (
mip::Interface) - Modern C++ Connection Management: RAII-based resource handling
- Type-Safe MIP Command Interfaces: Compile-time type checking
- Exception Safety: Proper error handling and resource cleanup
- STL Integration: Use of standard library containers and algorithms
- Portability: Cross-platform compatibility (Windows/Unix)
This example uses modern C++ connection handling:
- SerialConnection: RAII-based serial connection management
- Automatic Cleanup: Connection automatically closed when the object goes out of scope
The example streams the following filter data:
- Units: seconds
- Description: Time of Week - GPS time reference
- Format: Floating-point timestamp value
- Units:
- Latitude: degrees
- Longitude: degrees
- Ellipsoid Height: meters
- Description: Position in Latitude, Longitude, Height coordinate system
- Format: [Latitude, Longitude, Height] vector
- Units: m/s (meters per second)
- Description: Velocity in North, East, Down coordinate frame
- Format: [North, East, Down] velocity vector
- Units: radians
- Description: Orientation expressed as Euler angles
- Format: [Roll, Pitch, Yaw] angle vector
The example displays filter data in the following format:
TOW = 123456.789 Position LLH = [ 4.123456, -83.54321, 123.4567] Velocity NED = [ 1.234567, -0.987654, 0.123456] Euler Angles = [ 0.012345, -0.067890, 1.234567]
The example monitors and displays filter state transitions:
- Startup - Filter startup
- Initialization - Filter initialization
- Run Solution Valid - Valid filter solution
- Run Solution Invalid - Invalid filter solution
The example monitors and displays GNSS fix state transitions:
- No Fix - Initial state with no satellite positioning
- Invalid - Fix data is present but flagged as unreliable or corrupted
- Time Only - Time synchronization established but no positioning
- 2D Fix - Horizontal positioning available (latitude/longitude)
- 3D Fix - Full positioning with altitude information
The example includes comprehensive error handling with:
- Command result checking using
mip::CmdResult - Connection failure detection and recovery
- Graceful termination functions for different error types
- Detailed error messages with context using built-in documentation strings
This example demonstrates:
- Modern C++ connection management
- Type-safe MIP command interfaces
- Automatic data field extraction
- RAII resource management
- Standard library integration
This example provides additional C++ benefits:
- Built-in Documentation: Data structures include
DOC_NAMEconstants for easy reference - Strongly Typed Enums: C++ enum classes prevent accidental misuse
- Automatic Descriptors:
DESCRIPTORconstants eliminate magic numbers
- MicroStrain 5-series GNSS/INS device (3DM-CX5-GNSS/INS, or 3DM-GX5-GNSS/INS)
- Serial connection (USB or RS-232)
- MIP SDK library with C++ support
- C++11 or later compiler
- C version:
5_series_gnss_ins_example.c - Other examples in the
examples/directory - MIP SDK documentation