-
Notifications
You must be signed in to change notification settings - Fork 35
Low Bandwidth Devices
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).
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 --build-id
7.135.494 7997d2bc (development)
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.
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.
$ git rev-parse --short HEAD
b717b2b3
Master (8.0.0) as of 2024-05-14
Visually timed from clicking icon until icon becomes sensitive again, took 101 seconds.
Visually timed from clicking icon until icon becomes sensitive again, took 44 seconds.
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).
A c. 2016 vintage small form factor / low bandwidth data radio.
Tested with a CP2102 USB to UART Bridge at 9600 baud.
$ mwp --version --build-id
7.135.494 7997d2bc (development)
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.
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.
$ git rev-parse --short HEAD
b717b2b3
Master (8.0.0) as of 2024-05-14
Visually timed from clicking icon until icon becomes sensitive again, took 38 seconds.
Visually timed from clicking icon until icon becomes sensitive again, took 39 seconds.
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 --build-id
7.140.407 752b6ad7
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.
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.
$ git rev-parse --short HEAD
71817afc
Master (8.0.0) as of 2024-05-19
Visually timed from clicking icon until icon becomes sensitive again, took 142 seconds.
Visually timed from clicking icon until icon becomes sensitive again, took 141 seconds.
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.
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.
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.
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.
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.