Skip to content

Extended Telemetry

Overview

This is the structure and behavior of Extended Telemetry

The goal was to define an enhancement to the Basic Telemetry scheme by:

  • Retaining full backward-compatibility
  • Clearly defining new features and implementation specifics
  • Creating a code implementation meant to be used across trackers for common data encoding
  • Being open to community development and shared investment

Improvements with the Extended Telemetry scheme

  • 16 New Telemetry Message Types
    • Including User-Defined
    • Future growth path beyond 16 messages
  • Send up to 5 Extended Telemetry messages per 10-min window
    • Use of Regular message optional
    • Use of Basic Telemetry message optional
    • No rigid send sequence
    • No clash potential with other senders
  • Wider support of field ranges via use of single big number
    • Single field size max of 29.180 bits (608,212,404 values)
  • Defined clamping behavior
  • Defined rounding behavior
  • Extensible already-defined message types

Improvements

16 New Telemetry Message Types

Types

  • 14 Enumerated types, to be defined and standardized
    • eg a GPS stats message
  • 1 User-Defined type, for testing and experimentation
  • 1 Vendor-Defined type

See Message Fields (Per-Type) for more details

Send up to 5 Extended Telemetry messages per 10-min window

Use of Basic Telemetry and even Regular Type 1 message optional

Extended Telemetry can be sent during the time slots the Basic Telemetry and Regular Type 1 are currently sent in.

This allows for a maximum of 5 Extended Telemetry messages to be sent during a given 10-min window.

See Time Slot Behavior for more details

No rigid send sequence

There are different types of Extended Telemetry messages. They can be sent in any order, at *any time.

See Time Slot Behavior for more details

No clash potential with other senders

Additional data in each Extended Telemetry message identifies the message as being yours.

See HdrSlot for more more details

See Time Slot Behavior for more details

Wider support of field ranges via use of single big number

Basic Telemetry segments its big number encoding process into two operations, targeting specific fields in the WSPR message.

Extended Telemetry uses a different encoding algorithm that ultimately allows encoded fields to span all the fields of the WSPR message, up to and including a single encoded field of size 29.180 bits (608,212,404 values).

See Additional Encoding Details for more details

Defined Clamping Behavior

No Rollover. All values clamped before encoding.

Defined Rounding Behavior

Field values shall be rounded to the closest multiple of step size within range when being encoded.

Extensible Message Types

If a message can support 5 fields, but you define 1, you can add 4 additional fields later on and the values in the 1st field remain readable in historical data.

See Additional Encoding Details for more details.

Message Structure

The structure of Extended Telemetry messages falls into two categories

  • Header fields (common structure to all Extended Telemetry messages)
  • Message fields (distinct structure to each HdrType of Extended Telemetry message)

Header Fields (Common)

Header fields specified in unpack order (ie, unpack from big number order).

Header Fields common to all Extended Telemetry message types

FieldName Unit LowValue HighValue StepSize # Values
HdrTelemetryType Enum 0 1 1 2
HdrRESERVED Enum 0 3 1 4
HdrType Enum 0 15 1 16
HdrSlot Enum 0 4 1 5

HdrTelemetryType

HdrTelemetryType

Defined as 0 = Extended Telemetry.

HdrRESERVED

HdrRESERVED

Must be set to 0b00.

Consumers must ignore any received message with non-zero HdrRESERVED value

This field is the means of extension of the protocol in the future.

Any future change may not be compatible with the rest of this spec as-is.

Therefore consumers must ignore any HdrRESERVED field which is non-zero if they want to automatically survive a future enhancement.

HdrType

Set default value to be 0b0000.

This field is set to the value of the enumerated type of Extended Telemetry message.

Extended Telemetry messages need to be defined and assigned a number to be used in this field in order for receivers to know how to decode the telemetry within.

HdrType Type Notes
0 User-Defined No defined structure beyond header.
Useful for experimenting, testing, one-offs, etc.
1-14 ... (Not yet defined)
15 Vendor-Defined No defined structure beyond header.
Vendor decides structure and send schedule, possibly with end-user input.

HdrSlot

HdrSlot

Set default value to be 0b00.

Used to identify this Extended Telemetry message as belonging to a particular sender.

This field can take 4 possible values 0-4.

These values correspond to the 5 2-minute time slots within a given 10-min window.

In accordance with the start minute defined by Band and Channel selection, the slots are defined as:

When Slot
start minute slot 0
+ 2 min slot 1
+ 4 min slot 2
+ 6 min slot 3
+ 8 min slot 4

It is valid to send Extended Telemetry in any slot, with or without a Regular message or Basic Telemetry message having ever been sent within that 10-minute window.

Specifically, Extended Telemetry:

  • Can be sent in any slot, regardless of when/if it was sent in a prior 10-min window
  • Can replace Regular Type 1 sometimes and other times not
  • Can replace Basic Telemetry sometimes and other times not

See Time Slot Behavior for more details

Message Fields (Per-Type)

The goal is to have an enumerated list of well-defined Extended Telemetry messages which can be implemented consistently across trackers.

For each Enumerated Extended Telemetry message type, there would be a set of defined Message Fields specific to that message.

Example Enumerated Message Types

Here is a hypothetical example of how a list of enumerated types could be captured and grown.

HdrType Type Notes
0 User-Defined No defined structure beyond header.
Useful for experimenting, testing, one-offs, etc.
1 Basic Telemetry 2 Extended ranges and higher-res version of Basic Telemetry.
2 GPS Stats Capture stats about GPS behavior or conditions.
...
15 Vendor-Defined No defined structure beyond header.
Vendor decides structure and send schedule, possibly with end-user input.

Example Message - GPS Stats

This is just a hypothetical example for illustration purposes.

GPS Stats Extended Telemetry Message Definition.

Field Unit LowValue HighValue StepSize # Values
SatsUSA Count 0 128 4 33
SatsChina Count 0 128 4 33
SatsRussia Count 0 128 4 33
SatsEU Count 0 128 4 33
SatsIndia Count 0 128 4 33
hdop Value 0 10 2 6

Analysis.

Encodable Bits Available: 29.180
Encodable Bits Used     : 27.807 ( 95.29 %) 
Encodable Bits Remaining:  1.373 (  4.71 %)

Field         # Values    # Bits    % Used
------------------------------------------
SatsUSA             33     5.044     17.29
SatsChina           33     5.044     17.29
SatsRussia          33     5.044     17.29
SatsEU              33     5.044     17.29
SatsIndia           33     5.044     17.29
hdop                 6     2.585      8.86

Defining New Extended Telemetry Message Types

Use the Extended Telemetry playground to try new message structures.

Additional Encoding Details

Packing big number

Messages are packed into the big number in reverse order from their definition. Header fields are packed in reverse order from their description above.

Illustration using the GPS Stats message above

The GPS Stats message defines:

  • SatsUSA
  • SatsChina
  • SatsRussia
  • SatsEU
  • SatsIndia
  • hdop

The header fields are:

  • HdrTelemetryType
  • HdrRESERVED
  • HdrType
  • HdrSlot

The packing into big number is in this order:

  • hdop
  • SatsIndia
  • SatsEU
  • SatsRussia
  • SatsChina
  • SatsUSA
  • HdrSlot
  • HdrType
  • HdrRESERVED
  • HdrTelemetryType

Callsign Characters 1 and 3

Callsign characters 1 and 3 are not used for data encoding

Extended Telemetry is encoded into the Type 1 Message Format, except for the Callsign characters 1 and 3.

See Channels for details on use of characters 1 and 3.

Time Slot Behavior

Extended Telemetry operates within the established 10-min window.

Below is a description of how the Extended Telemetry changes the message types sent within the 10-min window in a backward-compatible way.

10-Minute Schedule Framework

This is the current pattern for when to send the Type 1 message in a repeating 10-min window.

start minute + 2 min + 4 min + 6 min + 8 min
Regular Type 1 - - - -

Including Basic Telemetry

This is the current pattern for when to send the Basic Telemetry message in relation to the Type 1 message in a repeating 10-min window.

start minute + 2 min + 4 min + 6 min + 8 min
Regular Type 1 Basic Telemetry - - -

Including Basic and/or Extended Telemetry

The [Ext Telemetry] notation means that an Extended Telemetry message can be sent in that slot, but is not required to be.

Any HdrType type of Extended Telemetry can be sent at any time [Ext Telemetry] is specified.

Including Basic and Extended Telemetry

start minute + 2 min + 4 min + 6 min + 8 min
Regular Type 1 Basic Telemetry [Ext Telemetry] [Ext Telemetry] [Ext Telemetry]

Replacing Basic with Extended Telemetry

start minute + 2 min + 4 min + 6 min + 8 min
Regular Type 1 [Ext Telemetry] [Ext Telemetry] [Ext Telemetry] [Ext Telemetry]

Replacing Everything with Extended Telemetry

start minute + 2 min + 4 min + 6 min + 8 min
[Ext Telemetry] [Ext Telemetry] [Ext Telemetry] [Ext Telemetry] [Ext Telemetry]

Extended Telemetry Schedule Specifics

Example Send Sequences

These are all valid send sequences in a 10-min window (not exhaustive)

start minute + 2 min + 4 min + 6 min + 8 min
Regular Type 1 - - - -
Regular Type 1 Basic Telemetry - - -
Regular Type 1 Basic Telemetry Ext Telemetry - -
Regular Type 1 Basic Telemetry - Ext Telemetry -
Regular Type 1 Basic Telemetry Ext Telemetry Ext Telemetry Ext Telemetry
Regular Type 1 Ext Telemetry - - -
Regular Type 1 Ext Telemetry - Ext Telemetry -
Regular Type 1 - - Ext Telemetry -
Regular Type 1 Ext Telemetry Ext Telemetry Ext Telemetry Ext Telemetry
Ext Telemetry - - - -
- Ext Telemetry - - -
Ext Telemetry Basic Telemetry - - -
Ext Telemetry Ext Telemetry - - -
Ext Telemetry Ext Telemetry - Ext Telemetry -

Fingerprinting

Fingerprinting logic

In any given 10-minute window, to find telemetry, when using fingerprinting:

  • Scanners would have to look for both Regular and Extended in slot 0
  • If you find only Regular, that is your reference freq for finding remaining telemetry
  • If you find only Extended, that is your reference freq for finding remaining telemetry
  • If you find both Regular and Extended, prefer Regular

Code

See Programming Library for implementation.

Changelog

Date Change
2025-01-15 Vendor-Defined message added.
2024-12-29 Correct max bits from 29.178 to 29.180.
2024-12-13 Ratification.
2024-12-06 HdrSlot change from 4 slots to 5.
2024-12-03 Initial proposal.