Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

The radar acts as a TCP/IP server and therefore listens for connections once started. The server will support up to 3 concurrent client connections, therefore the first 3 clients attempting to connect will succeed, but subsequent attempts from other clients will fail. The radar supports a primary IP address and streams data over a single port, which, by default, is the IANA allocated port of TCP 6317. The IP addresses and the port are all configurable via the radar management software. Please refer to reference Vertex documentation for more information. Note that the radar TCP server maintains state on the client connections therefore message start / stop requests, such as FFT Data, are applied on a per client basis.

TCP Message Structure

Each message includes a header of 22 bytes followed by a variable length payload. The header includes the message type and payload size enabling the client software to reliably decode the payload data as required.


Typically there are 2 types of payloads;

  • Byte array representing a structure made up from standard C++ data types
  • Byte array representing a serialised Protocol Buffer message
  • Byte arrays that represent both of the above

For more information on Google Protocol Buffers please see reference [https://developers.google.com/protocol-buffers]. Navtech can provide Protobuf message files on request.

Info

All network data is sent in Network Order i.e. big-endian.

The Complete TCP Message Structure

The TCP Message Header

This is the first part of every message sent using this protocol. The header serves 2 purposes; the first is to provide a byte sequence for synchronisation purposes and secondly to provide information about the body of the message.

TCP Message Header Structure

FieldType [Size]Description
Signatureuint8_t [16]Unique synchronisation byte sequence
Versionuint8_t [1]Protocol version – indicates the revision of the protocol messages
Message Iduint8_t [1]Message type – indicates the type of the payload
Payload Sizeuint32_t [4]The size, in bytes, of the main body of the message
Panel
borderColorsilver
borderWidth1

On this page:

Table of Contents
maxLevel3
indent10px

TCP Message Types

Message NameMessage IdDirectionDescription
Configuration10From RadarSends all the radar configuration properties required to configure the client software to correctly receive data
Configuration Request20To RadarRequests a configuration message from the radar
Start FFT Data21To RadarInstructs the radar to start sending FFT data until told to stop
Stop FFT Data22To RadarInstructs the radar to stop sending FFT data
Start Health Msgs23To RadarInstructs the radar to start sending regular health messages until told to stop
Stop Health Msgs24To RadarInstructs the radar to stop sending health messages
Reset RF Health25To RadarInstructs the radar to reset RF Health check system
FFT Data30From RadarAn azimuth of raw radar data
High Precision FFT Data31From RadarAn azimuth of high precision radar data
Health40From RadarSends a radar health status message
Contour Update50To RadarEnables the client to update the contour map on the radar
System Restart76To RadarRequest system reboot
Logging Levels90To/From RadarA list of logging levels
Logging Levels Request100To RadarRequest a list of logging levels
Set Auto Tune110To RadarSet beam splitter auto tune value
Start Nav Data120To RadarRequest system to start sending navigation data
Stop Nav Data121To RadarRequest system to stop sending navigation data
Set Nav Threshold122To RadarSet navigation threshold
Navigation Data123From RadarNavigation data records
Set Nav Range Gain and Offset124To RadarSet navigation threshold

Signature

The 16 byte signature differs very slightly from the older Navtech RMB protocol. This does enable existing software to differentiate between the two protocols if required.

The new signature is as follows:

The TCP Message Body

This payload will be variable length, the size being specified in the message header. The rest of this document describes the message types.

Configuration Message

The configuration message contains all the relevant information a client application needs to process raw data from the radar. The message provides all critical data in fixed length fields at the beginning of the message. These values are the minimum required in order to successfully configure a client. These fields can be accessed using the normal process of decoding a byte stream coming across the network. The remainder of the message is made up from a variable length Protocol Buffer message which contains additional information about the radar, such as serial numbers and service dates. Advanced customer applications would be expected to decode this message data however the information is optional.

The size of this message body is specified by the payload size field in the header. The size of the Protocol Buffer message can be calculated by subtracting the size of the fixed length fields from the payload size (i.e. Payload Size – 22 bytes). A configuration message is always sent when a client first connects and is also sent in response to a request from the client.

Configuration Message Structure

FieldType [Size]Description
Azimuth Samplesuint16_t [2]Number of azimuth samples taken per rotation
Bin Size / Resolutionuint16_t [2]The range resolution per bin. In tenths of millimetres. For example 0.2997m would be 2997.
Range In Binsuint16_t [2]Configured detection range, in bins
Encoder Sizeuint16_t [2]The total number of available steps on the encoder wheel
Rotation Speeduint16_t [2]The configured rotation speed for the radar. In milliHertz
Packet Rateuint16_t [2]Expected packet rate based on sample time and rotation speed
Range Gainfloat [4]Gain applied to calculated ranges based on radar calibration
Range Offsetfloat [4]Fixed offset in metres, applied to calculated ranges based on radar calibration

Note: Floats transmitted over the network are IEEE 754 compatible values converted to 32 bit unsigned integers in network order. They will need to be reverted to host order and then cast back to floats on the client.

Configuration Protocol Buffer Payload

FIeldType [Size]Description
ModelstringCustomer friendly model name
MAC AddressstringNetworking MAC Address
Service Dateuint32_t [4]The date the last service was completed
Software Version NumbersSoftwareVersion PB MessageCollection of software version numbers
NVRAM ContentsNVRAM PB MessageContents if NVRAM
Range Resolution HzfloatResolution of each bin in Hz
Module Serial NumberstringProcessing Module Serial Number
Auto Tune Valueint16_t [2]Current Auto Tune Value
Radar Unique Idstring (Guid)Radar's Unique Id
Data Widthint321 for 8-bit 2 for 16-bit
Range Resolution MetresfloatRange of each bin in metres
Radar Feature Flaguint32Feature Flag bit field 1 = AutoTune, 2 = Secondary Processing Module Present

Configuration Request Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will respond by sending a single configuration message.

Start FFT Data Request Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will respond by starting the raw radar data stream.

Stop FFT Data Request Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will respond by stopping the raw radar data stream.

Start Health Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will start sending regular health messages. By default the interval is every 5
seconds.

Stop Health Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will stop sending regular health messages.

Reset RF Health Check System

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will reset the long term health check system.

System Restart Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will reboot.

Start Navigation Data Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will start sending navigation data messages.

Stop Navigation Data Message

This message contains no body / payload. The message is sent just as a header. On receiving this
message the radar will stop sending navigation data messages.

Set Navigation Threshold

This message is used to set the threshold for the navigation system

Set Navigation Threshold Message Structure

FieldType [Size]Description
Thresholduint16_t [2]Threshold to use for navigation data

Set Navigation Gain and Offset

This message is used to set a gain and offset that is used when by the onboard navigation system, this gain and offset are applied to the ranges found using the formula [(Target Range * Range Gain * Range Resolution) + Offset]

Set Navigation Gain and Offset Message Structure

FieldType [Size]Description
Gainuint32_t [4]Gain multiplied by 1000000
Offsetuint32_t [4]Offset multiplied by 1000000

FFT/High Precision Data Message

The FFT Data message contains all the necessary information to process the amplitude data for a specific azimuth. The packet consists of 4 fixed length fields and a variable length byte array of amplitude data. Each byte of amplitude data represents a range bin. The total number of reported range bins can varying per packet depending on the radar configuration. The size of this message body is specified by the payload size field in the header. The FTT Data length can be calculated by subtracting the fixed length field sizes from the overall payload size (i.e. Payload Size – 14 bytes). FFT Data messages need to be switched on before they are sent. Once activated, FFT Data messages will be sent continuously for each sampled azimuth. FFT data will continue to be sent until the radar receives a message to stop. Clients should honour this mechanism and, where possible, send the radar a stop message before disconnecting.

FFT/High Precision Data Message Structure

FieldType [Size]Description
FFT Data Offsetuint16_t [2]The offset from the start of the payload where the FTT data starts. In this version the value will be 14 – the FFT starts at the 15th byte
Sweep Counteruint16_t [2]A counter that increments on each packet sent from the radar. The value will rollover once the maximum type size has been reached
Azimuthuint16_t [2]The azimuth at which this sample of FFT data was taken
Secondsuint32_t [4]Total number of seconds since the synchronised Epoch
Split Secondsuint32_t [4]Part seconds. This value rolls over each second
FFT Datauint8_t [n]Variable length byte array of amplitude data per range bin (If high precision then two bytes represent one bin)

Health Message

The health message includes critical health information about the radar. The payload consists of a number of health status structures, each one provides data on a specific metric, for example temperature, and includes details on the current measurement and whether the metric is within expected bounds or not. The health message payload is a Protocol Buffer serialised byte array. In order to de-serialise the message the client will need to use the Google library as described in reference [2]. Metrics may be added or changed within the content of the Protocol Buffer message. This would not result in a new protocol version for this message. Client applications consuming this message will need the latest Protobuf definition file from Navtech. These are available on request. Health messages need to be switched on before they are transmitted. Once active, health messages will be sent every 5 seconds. Messages will continue to be sent until the radar receives a message to stop. Clients should honour this mechanism and, where possible, send the radar a stop message before disconnecting.

Health Message Structure

FieldType [Size]Description
TemperatureHealthInfo PB MessageTemperature health information including current operating temperature
RotationHealthInfo PB MessageRotation health information including current speed
Packet RateHealthInfo PB MessageNetwork health information including current packet rate
RF Health CheckHealthInfo PB MessageRF health information including current noise deviation from the norm
Motor CurrentHealthInfo PB MessageMotor health information including current draw

Contour Update Message

The Contour Update message controls the contour mode and contour map. The contour map is held on the radar and provides a mechanism to restrict the radar detection area. The map consists of a variable range per degree (i.e. 360). When a contour map is active, data is sent out from the radar for each degree up to the range specified. If the range is zero then no data is sent for that bearing. If the contour map is disabled or in its default configuration then the full range of data is sent for every azimuth (i.e. all data). There is also a test mode which can be set on the radar – this activates a pre-configured map which exhibits a distinctive data pattern. To disable the contour map the client should send an empty update message (just header). This will leave the contour configuration intact but tell the radar to stop using it. Alternatively the client can send a full contour map, in other words a maximum range value for each azimuth. This will have the same effect. The contour map, once active, restricts the amount of data sent over the network. The more restrictive the contour map, the less data that is sent.

Contour Update Message Structure

Log Levels Get/Set Messages

The log levels get and get messages enable a user to get the logging levels and set the logging levels of the radar software. The LoggingLevelRequest message is an empty payload message, the radar will respond with a LoggingLevel message that contains a Protocol Buffer object which is a list of Log Levels. The get log levels payload is a Protocol Buffer serialised byte array. In order to de-serialise the message the client will need to use the Google library as described in reference [https://developers.google.com/protocol-buffers].

Log Levels Structure

Log Levels Buffer Payload

FieldType [Size]Description
ItemsList of LogLevel PB MessagesA list of Log Level Items

Set Auto Tune

Set Auto Tune Message Structure

FieldType [Size]Description
Autp Tune Valueint16_t [2]The delta to increment/decrement the auto tune parameter by

Related information

Filter by label (Content by label)
showLabelsfalse
cqllabel in ("colossus","vertex")