Skip to content

Bnjoroge1/leader_follower

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Leader-Follower Protocol (Patent-Pending)

This is a continuation of the Singing Boxes Project aiming to generalize the protocol and add the following features.

  • Test harness to traverse the protocol's state space and guide refactoring.
  • Digital simulation of distributed devices and communication channels.
  • User interface visualizing the protocol in real-time and allowing users to inject events into a device's protocol loop.
  • Robotics layer serving as an API between the generalized protocol and a physical application as a coordinated demo.

Singing Boxes: An Autonomous and Adaptive Leader-Follower Protocol for Collaborative Robotics

Demo Video

In this short demo, five devices communicate wirelessly to each play a different track of "Piano Man." The leader will assign a task to all connected devices as they join and transmit indicators to synchronize actions in real-time. When the leader (red) is manually disconnected, a follower (blue) seamlessly takes over as the new leader. When a follower is disconnected, its task becomes available to any new devices that join, as coordinated by the leader. You can hear the different tracks stop as I disconnect a device, and start in synchronization with the others as I reconnect it. The screen of each device details its leader/follower status, as well as the track it is currently playing.

The protocol uses a probabilistic framework and an object-oriented design to coordinate a mesh network of devices. One leader is selected and will add any other devices as followers, distribute tasks amongst them, and monitor their status. It is designed for resiliency, so that if any device disconnects, even the leader, the collective remains intact.

Protocol Block Diagram

The communication occurs over radio frequency at 433MHz using a CC1101 transceiver. The protocol is designed to be functional with other communication methods such as Wi-Fi or infrared, and generalizable to any number of devices or tasks.

The robustness of the control system's communication protocol also allows for follower-leader feedback, dynamic message payloads, and the prioritization of available roles. Alongside an increased number of devices, these features enable for the parallelization and execution of more complex tasks. The speed of this algorithm is only limited by the transmission and receiving capabilities of devices at 433MHz. In addition, time complexity of the check-in process scales linearly with the number of devices in the network. This protocol has applications for collaborative tasks in various industries, such as agriculture, construction, and defense -- really any sector that requires coordinated tasks to be completed simultaneously.

Simulation Plots

UI Demo

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 89.6%
  • JavaScript 5.4%
  • TLA 3.1%
  • CSS 1.7%
  • HTML 0.2%