Skip to content

Low Bandwidth Devices

Jonathan Hudson edited this page May 22, 2024 · 16 revisions

mwp and Configurator low bandwidth device performance evaluation.

Documented / instrumented tests of mwp and the INAV Configurator against low bandwidth devices. Tested with a F405 flight controller, hosted on Arch Linux x86_64.

The test mission comprises 120 points, and the test simply involves:

  • Upload the mission to the flight controller
  • Download the mission from the flight controller
  • Verify that the mission had been correctly "round-tripped"
  • Record the times taken (and any errors).

Test 1 CC2451 BLE

Probably the worst serial device I own. Ridiculously small h/w buffers, very slow. Tests are performed using mwp-ble-bridge -t to generate a TCP server, as the Configurator appears not to recognise BLE devices on Linux. This means all applications are using the same infrastructure to access the device (mwp can access the BLE device directly; using the bridge just makes it the same everywhere, including WSL access to the device).

mwp

Version ID

$ mwp --version --build-id
7.135.494 7997d2bc (development)

Upload to FC

14:35:54.078829 Start mission upload for 120 points
14:36:30.068279 mission uploaded for 120 points

So c. 36 seconds to upload the mission.

Download from FC

14:37:02.154259 Received nav_wp_multi_mission_index: 1
14:37:21.466484 Download completed #120 (0)

So c. 18 seconds to download the mission.

Configurator

Version ID

$ git rev-parse --short HEAD
b717b2b3

Master (8.0.0) as of 2024-05-14

Upload to FC

Visually timed from clicking icon until icon becomes sensitive again, took 101 seconds.

Download from FC

Visually timed from clicking icon until icon becomes sensitive again, took 44 seconds.

Summary

Both applications coped with the very weak CC2451 device.

Application Upload Download
mwp linux 36s 18s
mwp WSL 37s 20s
Configurator (Linux) 101s 44s

The Configurator is consistently slower and both applications take longer to upload that download. The WSL overhead is insignificant, particularly considering that there is double virtualisation (Win11 in Linux KVM host running the WSL VM for Ubuntu 22.04).

Test 2 HC-12 Radio

A c. 2016 vintage small form factor / low bandwidth data radio.

Tested with a CP2102 USB to UART Bridge at 9600 baud.

mwp

Version ID

$ mwp --version --build-id
7.135.494 7997d2bc (development)

Upload to FC

15:21:04.409928 Start mission upload for 120 points
15:21:19.521475 mission uploaded for 120 points

So c. 15 seconds to upload the mission.

Download from FC

15:21:40.003163 Received nav_wp_multi_mission_index: 1
15:21:55.023486 Download completed #120 (0)

So c. 15 seconds to download the mission.

Configurator

Version ID

$ git rev-parse --short HEAD
b717b2b3

Master (8.0.0) as of 2024-05-14

Upload to FC

Visually timed from clicking icon until icon becomes sensitive again, took 38 seconds.

Download from FC

Visually timed from clicking icon until icon becomes sensitive again, took 39 seconds.

Test 3 E45-TTL-100 LoRa

A c. 2017 vintage LoRa transparent serial radio. One of the earlier small factor commercial LoRa radios, so probbaly not as efficient as more modern examples.

Tested via a CP2102 USB to UART Bridge at 9600 baud (9600 airspeed).

mwp

Version ID

mwp --version --build-id
7.140.407 752b6ad7

Upload to FC

15:50:18.048333 Start mission upload for 120 points
15:50:53.106723 mission uploaded for 120 points

So c. 35 seconds to upload the mission.

Download from FC

16:16:32.215014 Start download for 120 WP
16:16:32.215035 Received nav_wp_multi_mission_index: 1
16:17:07.119474 Download completed #120 (0)

So c. 35 seconds to download the mission.

Configurator

Version ID

$ git rev-parse --short HEAD
71817afc

Master (8.0.0) as of 2024-05-19

Upload to FC

Visually timed from clicking icon until icon becomes sensitive again, took 142 seconds.

Download from FC

Visually timed from clicking icon until icon becomes sensitive again, took 141 seconds.

Summary

Both applications coped with the old LoRa ET45-TTL-100.

Application Upload Download
mwp Linux 35s 35s
Configurator (Linux) 142s 141s

The Configurator is again consistently slower. WSL was not tested, but based on earlier results, I would expect mwp / WSL to be similar to the Linux performance.

Test 4 E220-900T22D LoRa

A more recent LoRa transparent serial radio.

Tested via a CP2102 USB to UART Bridge at 9600 baud (9600 airspeed).

Only mwp was tested, requiring 30s for both upload and download, an improvement over the older LoRa device.

Test 5 SiK / 3DR

The old faithfully. Rock solid, well buffered. 64k air speed / 115k ground speed via HC05 Bluetooth (legacy RFCOMM)/

mwp was tested, requiring 15s for both upload and download.

The INAV Configurator was also tested, requiring 160s seconds for both upload and download.

Still the short range wireless champion, at least for mwp.

Test 6 pl2303 USB-TTL at 2400 baud

To establish some ground truth; a wired device using 2400 baud.

mwp was tested, requiring 20s for both upload and download.

The INAV Configurator was also tested, requiring 75s seconds for both upload and download.

So wired is faster at 2400 baud that many wireless options at notionally faster speeds.

Overall impression

Device Application Upload (s) Download (s)
CC2541 mwp 36s 18s
CC2541 mwp (WSL) 37s 20s
CC2541 Configurator 101s 44s
HC-12 mwp 15s 15s
HC-12 Configurator 39s 38s
E45-TTL-100 mwp 35s 35s
E45-TTL-100 Configurator 142s 141s
E220-900T22D mwp 30s 30s
E220-900T22D Configurator - -
SiK (3DR) mwp 15s 15s
SiK (3DR) Configurator 161s 160s
pl2303 (2400) mwp 20s 20s
pl2303 (2400) Configurator 76s 75s
  • Both applications work with low bandwidth / inadequately buffered devices.
  • No errors / timeouts / retries were shown in any test or application
  • WSL performs acceptably. Little impact from either double virtualisation or ser2udp serial bridge.

In all cases, the mission was correctly "round-tripped" through the FC.

To my surprise, Configurator 7.1.1 was able to complete the HC-12 test as well (only devices not tested on 7.1.1):

Device Applciation Upload (s) Download (s)
HC-12 Configurator 7.1.1 35s 35s

Faster than Configurator 8.0.0, slower than mwp.

Clone this wiki locally