Skip to content
Andrey Voroshkov edited this page May 17, 2018 · 39 revisions

Welcome to the Chorus-RF-Laptimer wiki!

Device communication protocol

Each Solo device Receives and Transmits data. Here's how the communication flow is organized from a Solo device standpoint.

Basic concepts:

  1. Each Solo device connected into a Chorus has its ID (order number), which is assigned dynamically upon initialization of the Chorus device from a communicating application. Normally enumeration starts with 0.
  2. Each data chunk is a plain string terminated with "\n" character (ASCII=10) and having a predefined structure.
  3. There are 3 types of data chunks:
  • Requests
  • Responses
  • Pass-through data
  1. Almost each Request produces a Response
  2. Pass-through data is either a request to a different Solo device, or response which needs to pass through current device to reach the Bluetooth dongle and be transmitted to App.

Requests

There are 3 types of requests:

  1. Device enumeration: (3 characters) "N" + <first_ID> + "\n". Example: "N0\n"
  2. Command/Request: (4 characters) "R" + <device_ID> + <command> + "\n". Example: "R1T\n"
  3. Calibration: (11 characters) "C" + <device_ID> + <time_long_HEX_value> + "\n". Example: "C00000010A\n"

In any "R" request: <device_ID> may be set to "*", which means the request is addressed to all devices (broadcast), and each should provide a response. Example: "R*A\n"

Note: for broadcast requests the order of responses from different devices is not defined. Example: "S1R1\nS0R1\nS2R1\n"

Responses

Response structure: "S" + <device_ID> + <response_type> + <data> + "\n" Each response type has its own predefined length depending on size of data to be transmitted.

Correspondence of Requests to Responses (API)

The most recent version of the API is in the docs folder (MS Excel format).

High-level communication process

NOTE: In commands I use below I omit the trailing "/n" character for simplicity, but this character is mandatory in each command!

  1. Run "Enumerate Devices" command ("N0") to enumerate modules (REQUIRED!). Read the response to find out the number of modules in the device. Modules numbering will start from zero. (Hint: you may send "N1" to start numbering from 1 if it's more convenient to you).

  2. Set the "Minimal Lap Time", which must be less than the fastest possible lap time during the upcoming race. This will make sure that Chorus won't report false laps if accidentally catches VTX RSSI peak from a nearby drone before the latter crosses the finish line. Also you should plan the track to avoid situations when drones fly in close proximity to the Chorus before the end of a lap.

  3. Set Frequency into each node using either "Set Frequency" command or "Set Channel" + "Set Band" (2 commands). Note: it's the responsibility of the race control software to remember which node is monitoring which frequency to further match Chorus responses to pilots in each heat.

  4. Calibrate Arduino Timers (optional step, but increases accuracy of measured lap times during the race across nodes). The calibration process is as follows:

    1. Send "Start Calibration" command to all nodes: "R*I"
    2. Wait for some time (I use about 10 seconds). Let's note this time in milliseconds as "tc".
    3. Send "End Calibration" command to all nodes: "R*i". Chorus will respond with measured times from each node:  S1I00002710, S0I00002715 ... Let's note a time from any node as "tn"
    4. Perform the following calculation for each node: cc = tc/(tc - tn), if tc - tn = 0, then set cc = 0 Here "cc" would mean something like "what time measured by this arduino should be increased/decreased by 1ms". E.g. cc=1000 means that each second measured by arduino gives an error of -1 millisecond, so this millisecond should be added by arduino to compensate the error.
    5. Send calculated cc values to each corresponding node (note it must be a signed 32bit value).
    6. You're done. Alternatively you may perform all adjustments (steps 4 - 5) in the race control software.
  5. Set threshold for each pilot. You may use one of the following:

    1. "Set Threshold Value" command - to set already known threshold value (e.g. if you stored one from previous setting attempt).
    2. Set threshold values to zero using "Set Threshold Value" command: "R*S0000"; then use "Set/Clear Threshold" command to start the threshold setting algorithm in Chorus, which will eventually reply with threshold values for the specified node(s). Here you should carefully monitor if threshold values are returned for all pilots that take part in the procedure, otherwise some pilot(s) might be not tracked at all during the heat.
  6. Start race using one of 2 possible commands. Choose whatever is convenient to you: a) Start race with relative lap times: "R*R", - once the race is started, lap times will be calculated based on a previous lap end: e.g. lap #1: 0:30.500, lap #2: 0:28.240, ... b) Start race with absolute lap times: "R*P", - once the race is started, lap times will represent a time passed since the race start: e.g. lap #1: 0:30.500, lap #2: 0:58.740 (time of lap 1 + time of lap 2), ...

  7. Stop the race when it's over using "End Race" command: "R*r". (REQUIRED!).

  8. Repeat from step 5 or 6 for each subsequent heat.

Clone this wiki locally