1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/examples/twr_aloha
2022-09-16 13:15:46 +02:00
..
tests-with-config examples/twr_aloha: add channel and txpower to ifconfig 2022-04-27 09:12:39 +02:00
app.config.test examples,tests: replace deprecated module names by new names 2022-09-16 13:15:46 +02:00
control.c examples/twr_aloha: default print rng result only on initiator 2022-04-27 09:12:39 +02:00
control.h examples/twr_aloha: default print rng result only on initiator 2022-04-27 09:12:39 +02:00
main.c sys/shell_commands: convert to SHELL_COMMAND() 2022-06-07 09:25:04 +02:00
Makefile examples,tests: replace deprecated module names by new names 2022-09-16 13:15:46 +02:00
Makefile.ci examples: add bluepill-stm32f030c8 to Makefile.ci 2021-02-02 23:47:40 +01:00
README.md examples/twr_aloha: change test to tests-with-config 2022-01-25 09:19:06 +01:00
twr_shell.c sys/shell_commands: convert to SHELL_COMMAND() 2022-06-07 09:25:04 +02:00
twr_shell.py examples/twr_aloha: add channel and txpower to ifconfig 2022-04-27 09:12:39 +02:00

Decawave TWR_ALOHA Example

This example allows testing different two-way ranging algorithms between two boards supporting a dw1000 device. This makes use of the uwb-core pkg.

IoT-LAB Setup

IoT-LAB can be used to test the application.

Prerequisites
  1. Install iotlab-cli tools

    • pip install iotlabcli
  2. Create an iotlab account

  3. Authenticate:

$ iotlab-auth --user <username> --password <password>
Launch an Experiment
  1. Submit a 60 minutes experiment with 2 dwm1001 boards:
$ iotlab-experiment submit -n "twr-aloha" -d 60 -l 2,archi=dwm1001:dw1000+site=saclay
  1. Wait for the experiment to be in the Running state:
$ iotlab-experiment wait --timeout 30 --cancel-on-timeout

Note: If the command above returns the message Timeout reached, cancelling experiment <exp_id>, try to re-submit your experiment later.

  1. Get the experiment nodes list:
$ iotlab-experiment  --jmespath="items[*].network_address | sort(@)" get --nodes
[
    "dwm1001-1.saclay.iot-lab.info",
    "dwm1001-10.saclay.iot-lab.info"
]

When flashing the devices set IOTLAB_NODE to one of the above values, e.g. for the firs node: IOTLAB_NODE=dwm1001-2.saclay.iot-lab.info.

Free up the resources

You are done with the experiment, so stop your experiment to free up the devices:

$ iotlab-experiment stop

Setup

  1. In two separate terminals flash two nodes and open a serial connection to the board, prefix with IOTLAB_NODE if using IoT-LAB
$ make -C examples/twr_aloha/ flash term -j
$ make -C examples/twr_aloha/ flash term -j
  1. On at least one node enable listening and get its short address
> twr lst on
[twr]: start listening
> ifconfig
Iface  3        HWaddr: C8:0C  NID: DE:CA

                Long HWaddr: 08:2B:31:07:CC:52:C8:0C
  1. On the second node send a request to neighbors short address:
>twr req C8:0C
[twr]: start ranging

Both nodes should show the ranging result:

> {"t": 55158, "src": "02:A1", "dst": "C8:0C", "d_cm": 39}

By default twr-ss (Single-Sided Two-Way-Ranging) is used, try using different protocols, check the ones available with help command:

> twr req --help
Usage:
        twr req <short_addr> [-p <proto>] [-c <count>] [-h][-i <ms interval>]
        - short_addr: short address of request destination
        - count: number of requests (default: 1)
        - ms interval: wait interval milliseconds between requests(default: 1000)
        - proto: twr protocol (ss|ss-ext|ss-ack|ds|ds-ext, default: ss)
        twr lst on: start listening for ranging requests
        twr lst off: stop listening for ranging requests
  1. Perform range requests with different intervals, protocols etc...
> twr req C8:0C -c 5 -i 10
[twr]: start ranging
{"t": 251588, "src": "02:A1", "dst": "C8:0C", "d_cm": 38}
{"t": 251600, "src": "02:A1", "dst": "C8:0C", "d_cm": 37}
{"t": 251610, "src": "02:A1", "dst": "C8:0C", "d_cm": 38}
{"t": 251620, "src": "02:A1", "dst": "C8:0C", "d_cm": 37}
> twr req C8:0C -c 5 -i 10 -p ds
[twr]: start ranging
{"t": 312513, "src": "C8:0C", "dst": "02:A1", "d_cm": 36}
{"t": 312525, "src": "C8:0C", "dst": "02:A1", "d_cm": 37}
{"t": 312535, "src": "C8:0C", "dst": "02:A1", "d_cm": 35}
{"t": 312545, "src": "C8:0C", "dst": "02:A1", "d_cm": 35}

Automatic Test

Pre-Requisites:

  • pip install rioctrl pyserial

A basic automatic test for the provided shell is included, run with:

$ make -C examples/twr_aloha flash test-with-config

The application provides a ShellInteraction that can be used for scripting UWB experiments or testing.