This repository contains the source code for the paper "DisruptaBLE: Opportunistic BLE Networking". DisruptaBLE is based on µD3TN and adds Zephyr RTOS with BLE support as well as a BLE simulation environment using BabbleSim.
Disclaimer: DisruptaBLE was partially derived from µD3TN. See ./LICENSE.txt
and ./LICENSE-3RD-PARTY.txt
for legal information.
With Zephyr RTOS support, DisruptaBLE supports (in theory) numerous boards: List of Supported Boards in Zephyr
To cite this, please cite the publication:
@INPROCEEDINGS{9843509, author={Rathje, Patrick and Landsiedel, Olaf}, booktitle={2022 IEEE 47th Conference on Local Computer Networks (LCN)}, title={DisruptaBLE: Opportunistic BLE Networking}, year={2022}, volume={}, number={}, pages={165-172}, doi={10.1109/LCN53696.2022.9843509}}
For a quick start, simply run the provided docker image and mount your current directory in it. We provide a preliminary Docker Image to build and run DisruptaBLE under Zephyr RTOS. Currently, only the nRF52 platform is tested. This also includes the BLE simulation of multiple devices using BabbleSim. First, start the corresponding container and mount the current working direction (the git project root) to /app:
docker run --rm -it -v ${PWD}:/app prathje/disruptable:latest@sha256:ba202790c45f44792a9aed3de31ce898b184ba34c505f3ff7af3510260afebc2 /bin/bash
You can then execute the example with 25 devices in a random walk environment as follows:
git submodule init && git submodule update
cd sim
python3 run.py envs/test.env
This example spawns 24 proxy nodes and a single central node. Simulation settings are merged using the config file in sim/.env
as well as the ones specified in envs/test.env
.
The events are written into a logfile in logs/sqlite.db
Script to run the experiments as in the paper (from inside the sim directory):
GROUP_NUM_EXECUTIONS=5 GROUP_PARALLEL_RUNS=5 python3 run_group.py "" envs/experiments/kth_walkers_broadcast/ &
GROUP_NUM_EXECUTIONS=5 GROUP_PARALLEL_RUNS=5 python3 run_group.py "" envs/experiments/kth_walkers_unicast/ &
wait
echo "All done"
In addition, you may checkout the bsim/test.sh to see how the basic simulation works and devices are spawned.
We modified the original 2G4 positional channel to extend positioning. The modified code is available at: https://github.com/prathje/ext_2G4_channel_positional.git
cd /bsim
git clone https://github.com/prathje/ext_2G4_channel_positional.git ./components/ext_2G4_channel_positional
make all
We further added static background noise to the BLE modem in components/ext_2G4_modem_BLE_simple/src/modem_BLE_simple.c (look for TotalInterfmW):
cd /bsim
nano components/ext_2G4_modem_BLE_simple/src/modem_BLE_simple.c
double TotalInterfmW = pow(10.0, -96.42/10.0);
make all
Running large simulations requires additional parameters (at least for the execution via docker):
--net=host --cap-add=SYS_PTRACE --security-opt seccomp=unconfined --ulimit nofile=1000000:1000000 --pids-limit -1
Or increase container process limits to run large simulations
ulimit -n 1000000 && ulimit -s 256 && ulimit -i 120000 && echo 120000 > /proc/sys/kernel/threads-max && echo 600000 > /proc/sys/vm/max_map_count && echo 200000 > /proc/sys/kernel/pid_max
Script to run the experiments as in the paper the KTH walkers dataset is required, please write [email protected] to get access. With the files in place, the experiments can get executed via:
GROUP_NUM_EXECUTIONS=5 GROUP_PARALLEL_RUNS=5 python3 run_group.py "" envs/experiments/kth_walkers_broadcast/ &
GROUP_NUM_EXECUTIONS=5 GROUP_PARALLEL_RUNS=5 python3 run_group.py "" envs/experiments/kth_walkers_unicast/ &
wait
echo "All done"
Or execute the bsim test simulation:
/app/bsim/test.sh
To run with gdb support:
/app/bsim/test_gdb.sh
Workaround: When Ninja ends in a segmentation fault, restart the container...
Manually Build it (e.g. without the provided docker image, note that you will need the mentioned BabbleSim Modifications):
cd $ZEPHYR_BASE && west update && sudo apt-get install -y gdb valgrind libc6-dbg:i386 mysql-client && cd /bsim && git clone https://github.com/prathje/ext_2G4_channel_positional.git ./components/ext_2G4_channel_positional && make all && sudo apt-get remove cmake && sudo -H pip3 install cmake && pip3 install python-dotenv pydal progressbar2 matplotlib pymysql scipy seaborn
west build -b nrf52840dk_nrf52840 --pristine auto /app/zephyr/
west build -b native_posix --pristine auto /app/zephyr/
west build -b nrf52_bsim --pristine auto /app/zephyr/
To build inside but flash outside the container:
west build -b nrf52840dk_nrf52840 /app/zephyr/ --pristine auto --build-dir /app/build/zephyr/build_source -- -DOVERLAY_CONFIG=source.conf
west build -b nrf52840dk_nrf52840 /app/zephyr/ --pristine auto --build-dir /app/build/zephyr/build_proxy -- -DOVERLAY_CONFIG=proxy.conf
To flash it:
nrfjprog -f nrf52 --program build/zephyr/build_source/zephyr/zephyr.hex --sectorerase --reset
nrfjprog -f nrf52 --program build/zephyr/build_proxy/zephyr/zephyr.hex --sectorerase --reset
Build, flash and debug proxy using west directly:
west build -b nrf52840dk_nrf52840 zephyr/ --pristine auto --build-dir build_proxy -- -DOVERLAY_CONFIG=proxy.conf
west flash --build-dir build_proxy
west debug --build-dir build_proxy
If you use the provided container, you might need to upgrade cmake:
sudo apt-get remove cmake && sudo -H pip3 install cmake
Running and analyzing simulations:
pip3 install python-dotenv pydal progressbar2 matplotlib pymysql scipy seaborn
cd /app/sim/
python3 run.py
python3 eval.py
The core part of µD3TN is located in ./components/ud3tn/
.
The starting point of the program can be found in
./components/daemon/main.c
, calling init located in
./components/ud3tn/init.c
.
This file is the best place to familiarize with the implementation.
./components/cla/zephyr
contains the BLE specific adapters and neighbor detection.
./components/platform/zephyr
contains platform specific code for Zephyr adapters.
./components/routing/epidemic
contains code for broadcast and spray-and-wait routing.
License
The code in ./components
, ./include
, ./pyd3tn
, ./python-ud3tn-utils
,
./test
, and ./tools
has been developed specifically for µD3TN and is
released under a BSD 3-clause license. The license can be found in
./LICENSE.txt
, ./pyd3tn/LICENSE
, and ./python-ud3tn-utils/LICENSE
.
As an early starting point for the STM32F4 project structure, we have used the project https://github.com/elliottt/stm32f4/ as a general basis.
All further code taken from third parties is documented in
./LICENSE-3RD-PARTY.txt
, as well as in the source files, along with the
respective original URLs and associated licenses. Generally, third-party code
is found in ./external
and uses Git submodules referencing the original
repositories where applicable.