Skip to content

Latest commit

 

History

History
716 lines (570 loc) · 21.2 KB

README.rst

File metadata and controls

716 lines (570 loc) · 21.2 KB

Beluga 2.0

Decawave DWM1001-DEV board firmware for building ad-hoc distance measurement network

Uses BLE to discover and UWB to measure distance between nodes

Overview

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.

Project Structure

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

Setup and Building

It is recommended to use the nRF Connect extension in Visual Studio Code to build.

Option 1: Setup (VS code, All platforms)

  1. Download and install nRF Connect for Desktop
  2. Download and install VS Code
  3. Download and install nRF Command Line Tools
  4. Open nRF Connect
  5. Install the toolchain manager
  6. Open the toolchain manager
  7. Install nRF Connect SDK v2.9.0
  8. Open VS code and install the nRF Connect extension pack
  9. Open Beluga-2.0/Beluga in VS Code

For additional help, refer to Nordic's nRF Connect installation guide

Option 2: Setup (Command line, Linux Only, Not recommended)

Run the following command:

./setup.sh

Build Configurations

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

decawave_dwm1000_dev

  • 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

Beluga

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

Building and Flashing

  1. Select the nRF Connect Icon in the side bar
  2. Select the build configuration you want to build.
  3. Press the build button under Actions. If a clean build is desired, press the redo icon when hovering over build (pristine build)
  4. Press the flash button under Actions. If multiple targets are connected, select the desired target from the dropdown list.

AT Commands

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:

  1. ID
  2. STARTBLE
  3. STOPBLE
  4. STARTUWB
  5. STOPUWB
  6. BOOTMODE
  7. RATE
  8. CHANNEL
  9. RESET
  10. TIMEOUT
  11. TXPOWER
  12. STREAMMODE
  13. TWRMODE
  14. LEDMODE
  15. REBOOT
  16. PWRAMP
  17. ANTENNA
  18. TIME
  19. FORMAT
  20. DEEPSLEEP
  21. PHR
  22. DATARATE
  23. PULSERATE
  24. PREAMBLE
  25. PAC
  26. SFD

ID

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.

STARTBLE

AT+STARTBLE

Starts BLE broadcating/retrieving.

STOPBLE

AT+STOPBLE

Stops BLE broadcating/retrieving.

STARTUWB

AT+STARTUWB

Starts UWB initiator/responder.

STOPUWB

AT+STOPUWB

Stops UWB initiator/responder.

BOOTMODE

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.

RATE

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)

CHANNEL

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)

TXPOWER

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.

TIMEOUT

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

STREAMMODE

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

TWRMODE

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.

LEDMODE

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.

RESET

AT+RESET

Clear flash memory configuration. This command will reset all user configuration.

REBOOT

AT+REBOOT

Reboots Beluga. All internal states will be reset.

PWRAMP

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

ANTENNA

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

TIME

AT+TIME

Retrieves the current Beluga timestamp (ms since boot).

FORMAT

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"

DEEPSLEEP

AT+DEEPSLEEP

Places Beluga into deep sleep, only allowing for a movement to wake Beluga.

PHR

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

DATARATE

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.

PULSERATE

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.

PREAMBLE

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.

PAC

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

SFD

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

PANID

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

Appendix

Adding Board Roots

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

Setup/Building/Flashing Troubleshooting

Unable to flash DW1001

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:

  1. Open the toolchain manager, click on the dropdown arrow, and select "Generate environment script." Save the script to a location of your choice.
  2. Open a terminal and source the environment script that you just generated (i.e source env.sh)
  3. Find where the nordic toolchain is installed and navigate to it in the terminal (example path: ~/ncs/toolchains/2be090971e)
  4. Run "./usr/local/bin/pip install pylink"
  5. 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.