Reinforcement Learning based routing protocol implementation for wireless ad hoc networks.
This is an implementation of ad hoc routing in wireless networks, based on one of the concepts of machine learning theory - Reinforcement Learning. The main idea of this approach is to make a decision about forwarding a packet with a certain destination address to a neighboring node based on current estimation values of a given set of neighbors. The estimation values are being dynamically changed by means of so-called "rewards", which represent feedback values for the chosen "action" - a packet forward event to a selected neighbor.
This routing protocol works on Linux-based machines with TCP/IP stack, and provides the routing functionality for any data packets with either IPv4 or IPv6 addressing. The other L3 protocols are unsupported for now. The routing process starts after initializing the routing daemon (adhocd), and runs on a created virtual tun-interface (adhoc0, by default), which is "tied up" with a real network interface of a node used for actual data transmission - e.g., wlan0, bt0, eth0, and so on.
The program works on Linux only, for now.
Clone the repository:
git clone <github repo url>
Rename the cloned directory to adhoc_routing
:
mv <cloned repo name> adhoc_routing
Copy the directory into /usr/share/
folder:
sudo cp -r adhoc_routing /usr/share/
Edit conf.py
file and set your wireless interface name and so on.
Now, you can run the routing daemon by directly executing adhocd
script:
sudo ./adhocd start|stop|restart
Optional: Add a daemon into linux services (for Ubuntu 16.04):
cd /etc/init.d/
sudo ln -s /usr/share/adhoc_routing/adhocd
sudo systemctl daemon-reload
Now, you can manage the daemon using service
command:
sudo service adhocd start|stop|restart|status
Log files default location: /var/log/adhoc_routing/
Let's say, there are two wireless nodes (node1 and node2) running in wifi ad-hoc mode, which should be connected to each other.
First, make sure that the wireless interface name, which is running in
wi-fi ad-hoc mode, is correctly set up in conf.py
file.
Second, run the routing daemon:
sudo service adhocd restart
In the network interfaces list, there should a virtual adhoc0
interface
appear.
Third, set up some IPv4 or IPv6 addressing on adhoc0
interface:
E.g., node1:
sudo ifconfig adhoc0 10.0.0.1/24
On node2:
sudo ifconfig adhoc0 10.0.0.2/24
Fourth, check the connectivity with ping
, ssh
or anything. E.g., from node1:
ping 10.0.0.2
And see the output.
Of course, this example is the most primitive one, which does not really show the routing process in full action. But this is the basis where a more complex wireless ad hoc networks can be built on, with tens or hundreds of such nodes.
Wi-fi ad-hoc mode has been chosen here as the most transparent example, since linux kernel has good support of wifi ad-hoc for many wi-fi chips, so the example above can be easily replicated. Certainly, there are other variants possible, such as: PLC, wired ethernet or 802.15.4 + 6LowPan.
The application is written on Python 2.7 without any usage of external libraries - so, the only thing which should be installed in order to run and develop the app - is Python with 2.7.x version with standard libraries set.
Some libraries which the app uses:
sys, os, socket, ctypes, struct, logging, threading, fcntl, Queue, hashlib
.
Dmitrii Dugaev – @linkedin – dugdmitry@gmail.com
Distributed under the Apache 2.0 license. See LICENSE
for more information.
https://github.com/dugdmitry/adhoc_routing
Doxygen code documentation: https://dugdmitry.github.io/adhoc_routing/