The demand for real-time decision-making, propelled by diverse data sources, is increasingly significant across various industry sectors. Conventional applications typically entail collecting data from an array of widely distributed sensors, transmitting it to a centralized access point for informed decision-making. The resultant decisions are then communicated to remote actuators, enabling devices to perform tasks based on the outcomes.
In response to this imperative, we researched and constructed a testbed for real-time decision-making over wireless networks. This involved utilizing multiple Intel Galileo embedded microcontrollers and implementing a novel protocol that exemplified the principles of sensing, communication, actuation, and coordination.
The project and its noteworthy findings were documented and published in the 2014 Insight Research Center for Data Analytics Annual Conference. Supported by Science Foundation Ireland (SFI) Grant SFI/12/RC/2289.
Research Paper | Research Poster | Project Report
Real-time decision-making with diverse data is increasingly vital across industries, typically involving data collection from various sensors, centralized processing, and subsequent actions by remote actuators. However, the conventional centralized communication process proves sluggish for real-time decisions. To address this, the project aimed to establish a decentralized communication system, allowing devices to transmit data directly to every connected device for decision-making, eliminating the need for a central access point.
The project involved building a wireless testbed using Intel Galileo microcontrollers, extending them with breadboard, sensors, and LEDs. The developed demonstration application showcased the platform's capabilities in decentralized data processing. Initial research included studying ad-hoc wireless networks through literature, online articles, and presentations, providing valuable insights into project concepts.
-
Decentralized Communication: The project focuses on eliminating the bottleneck of centralized communication in real-time decision-making by implementing a decentralized communication model. Devices transmit data directly to every connected device, allowing for quicker decision-making without relying on a central access point.
-
Intel Galileo Wireless Test Bed: Successful construction of a wireless test bed using multiple Intel Galileo microcontrollers. Integration of Intel Centrino N-135 Wi-Fi cards to enable wireless communication among the Galileo boards. Extended the microcontrollers with bread boards, sensors and LED's.
-
Ad-Hoc Wireless Network: Manual configuration of ad-hoc wireless networks on Galileo devices, enabling direct communication among connected devices. Script automation for ad-hoc setup, streamlining the process for efficiency and ease of use.
-
Demonstration Application: Construction of a demonstration application showcasing the capabilities of the wireless test bed. Extension of Galileo microcontrollers with sensors and LEDs, enabling data gathering, wireless transmission, decision-making, and visual representation of results.
-
Coordinated Sequenced Protocol: Development of a coordinated sequence protocol for multi-agent decision-making. Implementation of a sound-based protocol where devices communicate, share sound levels, and collectively determine the closest sound source.
Python programming language is used for developing the coordinated sequence protocol client. Python scripts are executed on the Galileo boards to facilitate communication, decision-making, and LED control.
The project is built around five Intel Galileo Gen 2 development boards, which are Arduino-certified and run a Yocto Linux image as the operating system.
Bash scripts are used for automating the setup of ad-hoc wireless networks on the Galileo devices, streamlining the configuration process.
The Arduino IDE is utilized for upgrading the firmware on the Intel Galileo boards. It enables users to write programs (sketches) for the Galileo and upload them using the serial port.
Ad-hoc networking is configured manually using Linux commands to set up wireless communication among the Galileo devices. The coordinated sequence protocol is designed for multi-agent decision-making.
The Yocto Linux operating system is used as the primary OS on the Intel Galileo boards. It provides the basic functionality of a standard Linux OS and is tailored for embedded systems.
└── multi_agent_decision_making_over_wireless_networks
├── docs
├── multi_agent_decision_making_over_wireless_networks_paper.pdf
├── multi_agent_decision_making_over_wireless_networks_poster.pdf
├── multi_agent_decision_making_over_wireless_networks_project_report.pdf
├── libs
├── pygalileo
├── examples
├── __init__.py
├── analog_input.py
├── array.py
├── blink.py
├── button.py
├── digital_read_serial.py
├── digital_read_speed.py
├── fade.py
├── fast.py
├── __init__.py
├── constants.py
├── galileo_pins.py
├── how_to_develop.txt
├── README.md
├── scripts
├── ad_hoc_1.sh
├── ad_hoc_2.sh
├── ad_hoc_3.sh
├── ad_hoc_4.sh
├── ad_hoc_5.sh
├── src
├── client_1.py
├── client_2.py
├── client_3.py
├── client_4.py
├── client_5.py
Before you begin, ensure that you have the following:
-
Intel Galileo Development Boards (5x): Donated by Intel for this project.
-
Intel Centrino N-135 Wi-Fi Cards (5x) and Antennas (5x): Provided along with the Galileo boards.
-
Micro SD Cards (5x): Required for booting the Galileo boards with the Yocto Linux image.
-
Sound Sensors (5x), LEDs (5x Red & 5x Green), Breadboard (5x), Resistors, Jumper Cables: Refer to the hardware components section in the documentation for a detailed list.
- Clone the repository to your local machine:
git clone https://github.com/Martin-Bullman/multi-agenda-decision-making-over-wireless-networks.git
- Navigate to the project directory:
cd multi-agenda-decision-making-over-wireless-networks
-
Installing Wi-Fi Cards: Attach the provided expansion plate to the Intel Centrino Wi-Fi card, connect the Wi-Fi antenna, and install the Wi-Fi card onto the Galileo board.
-
Upgrading Firmware: Download and install the Arduino IDE. Connect the Galileo board to your computer, launch the IDE, select the Galileo board, and upgrade the firmware following the provided steps.
-
Booting from SD Card: Download the Linux image from the provided link, extract files to the micro SD card, and boot the Galileo board with the new Linux OS.
-
Remote Login via SSH: Find the IP address of the Galileo board using an IP scanner. Use PuTTY to SSH into the board with the default username 'root' and no password.
-
Setting Up Ad-Hoc Wireless Network: Manually configure ad-hoc networking using Linux commands. Repeat the process for all Galileo devices. Bash scripts are provided for automation.
-
Connecting Your Computer: Locate the GalileoAD-HOC network on your computer and connect using the provided WEP security key.
-
Assembling Hardware Components: Connect power and ground cables, sound sensor analog output, install sound sensors, and set up LEDs. Refer to the hardware assembly section in the documentation for detailed instructions.
-
Running the Coordinated Protocol Client: Run the coordinated sequence protocol client by typing the appropriate Python command in the terminal for each device.
-
Node Discovery: The coordinated protocol initiates with node discovery. Nodes broadcast "Who's There" messages to dynamically locate and identify nearby nodes.
-
Hash Table Usage: Hash tables are utilized during the decision-making process to store and manage sound levels from each device.
-
Resending Mechanism: A resending mechanism is implemented to ensure reliable data transmission in case of packet loss or out-of-sequence reception.
Contributions are welcome! Here are several ways you can contribute:
- Submit Pull Requests: Review open PRs, and submit your own PRs.
- Join the Discussions: Share your insights, provide feedback, or ask questions.
- Report Issues: Submit bugs found or log feature requests for Interoperability-of-cloud-monitoring-data.
Contributing Guidelines
- Fork the Repository: Start by forking the project repository to your GitHub account.
- Clone Locally: Clone the forked repository to your local machine using a
Git client.
git clone https://github.com/Martin-Bullman/multi-agenda-decision-making-over-wireless-networks.git
- Create a New Branch: Always work on a new branch, giving it a descriptive
name.
git checkout -b new-feature-x
- Make Your Changes: Develop and test your changes locally.
- Commit Your Changes: Commit with a clear message describing your updates.
git commit -m 'Implemented new feature x.'
- Push to GitHub: Push the changes to your forked repository.
git push origin new-feature-x
- Submit a Pull Request: Create a PR against the original project repository. Clearly describe the changes and their motivations.
Once your PR is reviewed and approved, it will be merged into the main branch.
This project is licensed under the MIT License - see the LICENSE file for details.
I would like to express my sincere gratitude to the following individuals and organizations for their invaluable contributions and support throughout the duration of this project:
A special thank you to UCC for providing a conducive environment for research and learning. The academic resources and facilities at UCC have been instrumental in the successful completion of this project.
I am deeply grateful to the Insight Centre for Data Analytics at UCC for hosting and supporting my summer internship. The collaborative and innovative atmosphere at Insight has significantly enriched my learning experience.
My sincere appreciation goes to Kenneth Brown for serving as my supervisor during this internship. His guidance, expertise, and constructive feedback have been crucial in shaping the project and enhancing its quality.
I would like to extend my thanks to Mohamed Wahbi for being a dedicated mentor throughout this internship. His insights, encouragement, and technical assistance have played a vital role in the successful execution of the "Multi-Agent Decision Making over Wireless Networks" project.
This project would not have been possible without the collective support and encouragement from these individuals and organizations. Their commitment to fostering a collaborative and intellectually stimulating environment has left a lasting impact on my professional and academic journey.
Thank you for the opportunity and guidance.