Decawave DWM1001-DEV board firmware for building ad-hoc distance measurement network
Uses BLE to discover and UWB to measure distance between nodes
Beluga makes it more convenient for users to create an ad-hoc distance measurement network. Users can enter different types of AT commands through serial monitor to configure the properties of the DWM1001-DEV board. For example, change the channel of the UWB signal and polling frequency. These features enable users to customize their own network setup and meet the requirements. Beluga can be applied in the area of localization, robotics, and infrastructure sensing.
Beluga-2.0
├── Beluga
│ ├── CMakeLists.txt
│ ├── config
│ ├── DecaDriver
│ │ ├── include
│ │ └── src
│ ├── dts
│ │ └── bindings
│ ├── images
│ │ └── decawave_dwm1001_dev
│ ├── include
│ ├── Kconfig
│ ├── Kconfig.sysbuild
│ ├── Makefile
│ ├── overlay
│ ├── prj.conf
│ ├── src
│ └── VERSION
├── boards
│ └── arm
│ └── Beluga
├── DW1000_docs
├── JLink
│ └── JLink_Linux_V798a_x86_64.deb
├── Makefile
├── README.rst
├── ROS
│ └── src
│ ├── beluga
│ ├── beluga_messages
│ └── example_beluga_client
└── setup.sh
It is recommended to use the nRF Connect extension in Visual Studio Code to build.
- Download and install nRF Connect for Desktop
- Download and install VS Code
- Download and install nRF Command Line Tools
- Open nRF Connect
- Install the toolchain manager
- Open the toolchain manager
- Install nRF Connect SDK v2.9.0
- Open VS code and install the nRF Connect extension pack
- Open Beluga-2.0/Beluga in VS Code
For additional help, refer to Nordic's nRF Connect installation guide
Run the following command:
./setup.sh
Before building your application, you need to set up your build configurations. There are two important build configurations: Beluga and decawave_dwm1001_dev. The build configurations are listed below. To create these build configurations, open the nRF Connect Extension in VS code by pressing the icon or using the shortcut CTRL+ALT+N
- Board Target: decawave_dwm1001_dev
- Base configuration file: prj.conf
- Base device tree overlay: overlay/decawave_dwm1001_dev.overlay
- Optimization level: Os (Optimize for size)
- Sysbuild: No sysbuild
See Adding Board Roots for finding custom boards.
- Board Target: Beluga
- Base configuration file: prj.conf
- Extra Kconfig fragments: config/beluga.conf and config/usb.conf
- Base Device tree overlay: overlay/beluga.overlay
- Optimization level: Anything works
- Sysbuild: No sysbuild
- Select the nRF Connect Icon in the side bar
- Select the build configuration you want to build.
- Press the build button under Actions. If a clean build is desired, press the redo icon when hovering over build (pristine build)
- Press the flash button under Actions. If multiple targets are connected, select the desired target from the dropdown list.
The following AT commands can help users to access and modify DWM1001-DEV firmware to meet specific need. There are a total of 26 commands, and certain configurations will be saved in flash memory to restore user settings after the system reboots.
Commands:
- ID
- STARTBLE
- STOPBLE
- STARTUWB
- STOPUWB
- BOOTMODE
- RATE
- CHANNEL
- RESET
- TIMEOUT
- TXPOWER
- STREAMMODE
- TWRMODE
- LEDMODE
- REBOOT
- PWRAMP
- ANTENNA
- TIME
- FORMAT
- DEEPSLEEP
- PHR
- DATARATE
- PULSERATE
- PREAMBLE
- PAC
- SFD
AT+ID <number>
AT+ID
Determines the ID number of the number. No argument will return the current setting. This setting is saved in flash.
Note
<number> should be a positive, non-zero integer, and each node should have a unique ID.
AT+STARTBLE
Starts BLE broadcating/retrieving.
AT+STOPBLE
Stops BLE broadcating/retrieving.
AT+STARTUWB
Starts UWB initiator/responder.
AT+STOPUWB
Stops UWB initiator/responder.
AT+BOOTMODE <mode>
AT+BOOTMODE
Determines how the node should behave when reset/powered on. No argument will return the current boot mode. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | Do nothing on startup (BLE and UWB off) |
1 | Start BLE broadcasting/receiving on startup |
2 | Start BLE and UWB on startup, full functionality. |
Note
For BOOTMODEs 1 and 2, the AT+ID command must have been previously ran, the last set ID will be used on startup.
AT+RATE <period>
AT+RATE
Determines the frequency that the node send poll messages. No argument will return the current polling period. This setting is saved in flash.
Parameter | Input | Units | Default |
period | 0-500 | ms | 250 |
Note
When the frequency is 0, the node is in listening mode (It only responds to ranging requests)
AT+CHANNEL <channel>
AT+CHANNEL
Determines the UWB signal's channel. No argument will return the current UWB channel. This setting is saved in flash.
Parameter | Valid Options | Default |
channel | 1, 2, 3, 4, 5, 7 | 5 |
Note
The corresponding centre frequency and bandwidth of each channel please reference DW1000 User Manual (Section 10.5)
AT+TXPOWER <mode>
AT+TXPOWER <stage> <coarse gain> <fine gain>
AT+TXPOWER
Determines the UWB transmitter power setting. No argument will return the current UWB transmitter power setting. This setting is saved in flash.
One argument will set the power level to either the default power level or maximum power level.
mode | Description |
---|---|
0 (Default) | Default power supply |
1 | Maximum power supply |
Three arguments allow for total control over the power setting. For example, if coarse gain is 2 and fine gain is 2, then the TX power will be 2.5 dB + 1.0 dB = 3.5 dB.
Parameter | Value | Description |
---|---|---|
stage | 0 | BOOSTNORM |
1 | BOOSTP500 | |
2 | BOOSTP250 | |
3 | BOOSTP125 | |
coarse gain | 0 | Off (No output) |
1 | 0 dB Gain | |
2 | 2.5 dB Gain | |
⋮ | 2.5 dB Gain Steps | |
7 | 15 dB Gain | |
fine gain | 0 | 0.0 dB Gain |
1 | 0.5 dB Gain | |
2 | 1.0 dB Gain | |
⋮ | 0.5 dB Gain Steps | |
31 | 15.5 dB gain |
Note
Increasing transmitter power supply can help UWB to maximum range, but the maximum power supply exceeds restricted transmit power level regulation.
AT+TIMEOUT <elapsed time>
AT+TIMEOUT
Determines the timeout parameter to evict nearby nodes. No argument will return the current timeout setting. This setting is saved in flash.
Parameter | Input | Units | Default |
period | 0-9000 | ms | 9000 |
AT+STREAMMODE <mode>
AT+STREAMMODE
Determines the neighbors list display mode. No argument will return the current stream mode. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | Displays all neighbors, even those who have not been updated |
1 | Only display neighbors that have been updated |
AT+TWRMODE <mode>
AT+TWRMODE
Determines the UWB ranging scheme. No argument will return the current ranging scheme. This setting is saved in flash.
mode | Description |
---|---|
0 | Single-sided ranging (SS-TWR) |
1 (Default) | Double-sided ranging (DS-TWR) |
Note
DS-TWR is more accurate and can reduce clock drift effect. SS-TWR can be used for a network that needs faster transmission.
Determines the LED display mode. No argument will return the current LED mode. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | LED support mode (All LEDs) |
1 | No LEDSs support mode (turn off all LEDs) |
Note
LEDs support mode can be used for debugging, and another mode can be used for saving power.
AT+RESET
Clear flash memory configuration. This command will reset all user configuration.
AT+REBOOT
Reboots Beluga. All internal states will be reset.
AT+PWRAMP <mode> AT+PWRMAP
Determines if the BLE and UWB signals are amplified. No argument will return the current amplifier setting. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | External amplifiers are inactive |
1 | External amplifiers are active |
Note
This command is not supported on the decawave_dwm1001_dev board
AT+ANTENNA <antenna> AT+ANTENNA
Determines which antenna is used for neighbor discovery. No argument will return the current antenna setting
Parameter | Valid Options | Default |
antenna | 1, 2 | 1 |
Note
This command is not supported on the decawave_dwm1001_dev board
Warning
This setting is not saved in flash
AT+TIME
Retrieves the current Beluga timestamp (ms since boot).
AT+FORMAT <mode> AT+FORMAT
Determines the formatting of the neighborhood list. No argument will return the current format setting. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | CSV Format |
1 | JSON Format
Removed neighbors are
indicated by rm "ID" |
AT+DEEPSLEEP
Places Beluga into deep sleep, only allowing for a movement to wake Beluga.
AT+PHR <mode> AT+PHR
Determines the PHR mode used for UWB. No argument will return the current PHR mode. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | Standard PHR Mode |
1 | DW proprietary extended frames PHR mode |
Note
Refer to the DW1000 documents on how to best use this parameter
AT+DATARATE <data rate> AT+DATARATE
Determines the data rate of the DW1000. No argument will return the current data rate. This setting is saved in flash.
data rate | Description |
---|---|
0 (Default) | 6.8 MHz |
1 | 850 kHz |
2 | 110 kHz |
Note
Faster data rates mean faster transmission, but lower range. Refer to the DW1000 for appropriate use.
AT+PULSERATE <rate> AT+PULSERATE
Determines the pulse rate of the DW1000. No arguments will return the current pulse rate. This setting is saved in flash.
rate | Description |
---|---|
0 | 64 Mhz |
1 (Default) | 16 MHz |
Note
Refer to the DW1000 docs for appropriate use of this parameter.
AT+PREAMBLE <preamble> AT+PREAMBLE
Determines the preamble length of the DW1000. No arguments will return the current preamble length. This setting is saved in flash.
Parameter | Valid Options | Default |
preamble | 64, 128, 256, 512, 1024, 1536, 2048, 4096 | 128 |
Note
A longer preamble length will increase range. Refer to the DW1000 docs for appropriate use.
AT+PAC <pac> AT+PAC
Determines the PAC size of the DW1000. No arguments will return the current Preamble Acquisition Chunk (PAC) size. This setting is saved in flash.
pac | Description |
---|---|
0 (Default) | 8 bytes (recommended for RX of preamble length 128 and below) |
1 | 16 bytes (recommended for RX of preamble length 256) |
2 | 32 bytes (recommended for RX of preamble length 512) |
3 | 64 bytes (recommended for RX of preamble length 1024 and up) |
Note
Refer to the DW1000 docs for more information
AT+SFD <mode> AT+SFD
Determines what SFD length to use for the DW1000. No arguments will return the current SFD setting. This setting is saved in flash.
mode | Description |
---|---|
0 (Default) | Standard SFD length as defined in the IEEE802.15.4 standard |
1 | DW proprietary SFD (varies the length based on the data rate) |
Note
Refer to the DW1000 docs for more information
AT+PANID <id> AT+PANID
Determines the Personal Area Network (PAN) ID for the DW1000. No argument will return the current PAN ID setting. This setting is saved in flash.
Parameter | Input | Default |
id | 0-65535 | 57034 |
In order for Zephyr to find Beluga, you need to specify a Board Root. In VS Code, this is
done by navigating to File->Preferences->Settings or by just pressing CTRL+,.
Then under Extensions, find nRF Connect navigate to Board Roots. Add the absolute
path to the Beluga-2.0 repository to the board roots.
If you are using the command line, run make beluga
If you are seeing the following error "FATAL ERROR: one or more Python dependencies were missing; see the getting started guide for details on how to fix," it means that a python dependency is missing from the environment. This will require an update to the environment. Run the following steps to fix the environment:
- Open the toolchain manager, click on the dropdown arrow, and select "Generate environment script." Save the script to a location of your choice.
- Open a terminal and source the environment script that you just generated (i.e source env.sh)
- Find where the nordic toolchain is installed and navigate to it in the terminal (example path: ~/ncs/toolchains/2be090971e)
- Run "./usr/local/bin/pip install pylink"
- Open environment.json inside the toolchain directory, under the "LD_LIBRARY_PATH" key, add the following value to the list: "opt/nanopb/generator-bin/"
See VS Code Extension - west flash fails from missing python dependencies for more details.