Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ieee-nitk/artbot

ROS2 package stack to simulate a swarm of robots that can replicate drawings
https://github.com/ieee-nitk/artbot

Last synced: 4 days ago
JSON representation

ROS2 package stack to simulate a swarm of robots that can replicate drawings

Awesome Lists containing this project

README

        

# ARTBot

[![GitHub issues](https://img.shields.io/github/issues/IEEE-NITK/ARTBot?color=red&label=Issues&style=flat)](https://github.com/IEEE-NITK/ARTBot/issues)
[![GitHub license](https://img.shields.io/github/license/IEEE-NITK/ARTBot?color=green&label=License&style=flat)](https://github.com/IEEE-NITK/ARTBot/blob/main/LICENSE)
![Ubuntu](https://img.shields.io/badge/Ubuntu%2022.04-%E2%9C%94-blue)
![ROS2 Iron](https://img.shields.io/badge/ROS2%20Iron-%E2%9C%94-blue)

![ARTBots in Action](assets/artbot_main.jpeg)

Table of Contents



  1. Introduction



  2. Literature Survey



  3. Getting Started



  4. User Guide



  5. Implementation



  6. Results


  7. References


  8. Project Mentors



  9. Project Members



  10. License



## Introduction

Swarm robotics, inspired by the collective behavior of social organisms, offers a unique avenue for creating dynamic and interactive art installations.

![Alt text](assets/swarm.jpg)


*Swarm of Robots*

This project seeks to develop an application of swarm robotics by creating a swarm of robots that can autonomously arrange themselves to replicate drawings made by a user. The proposed system leverages swarm intelligence to translate artistic expressions into a visually stunning and collaborative robotic display.

### Technologies Used
[![Tech_Used](https://skills.thijs.gg/icons?i=ros,py,cpp,opencv,qt&theme=dark)](https://skills.thijs.gg)

## Literature Survey

### Robot Operating System 2

ROS 2 (Robot Operating System 2) is the next-generation open-source robotics middleware framework that builds upon the success of the original ROS. It introduces significant improvements, including support for multiple programming languages, a more robust communication layer based on the Data Distribution Service (DDS) standard, enhanced real-time performance, built-in security features, better support for multi-robot systems and distributed systems, Quality of Service (QoS) policies for reliable communication, improved lifecycle management for nodes, and increased interoperability with other robotics frameworks. ROS 2 also introduces a new Robot Description Format (RDF) for describing robot models and provides tools for maintaining backward compatibility with existing ROS packages, enabling a smoother transition for developers.

### Basic Terminologies in ROS 2:

* Nodes: A node is an executable that uses ROS 2 to communicate with other nodes. A ROS 2 Node can be a Publisher or a Subscriber. A Publisher puts the messages of a standard message type to a particular topic. The Subscriber, on the other hand, subscribes to the topic and receives the messages that are published to the topic.
* Messages: ROS 2 data type used upon subscribing or publishing to a topic.
* Topics: Nodes can publish messages to a topic as well as subscribe to a topic to receive messages.

Client libraries needed for this project:
* rclpy: Python client library
* rclcpp: C++ client library

### Python Programming Language
Python is a high-level, general-purpose programming language. Its design philosophy emphasizes code readability with the use of significant indentation. It supports multiple programming paradigms, including structured, object-oriented, and functional programming.

### Swarm Robotics
Swarm robotics is an approach to coordinate multiple robots as a single system to achieve a particular goal. It is inspired by the emergent behavior observed in social insects.

## Getting Started

### Prerequisites

* Ubuntu 22.04
* ROS 2 Iron
> For installing ROS 2 refer to [ROS 2 Wiki](https://docs.ros.org/en/iron/Installation.html)

### Installation

Create a colcon workspace

```bash
mkdir ros_ws
cd ros_ws
mkdir src
colcon build
```
To automatically source this workspace every time a new shell is launched, run these commands

```bash
echo "source /install/setup.bash" >> ~/.bashrc
source ~/.bashrc
```

Clone the repository in the `src` folder in the catkin workspace.

```bash
cd ~/ros_ws/src
git clone https://github.com/IEEE-NITK/ARTBot
```

Navigate back to the workspace folder and build the packages.

```bash
cd ~/ros_ws
colcon build
```

## User Guide

### Launching ARTBot Simulation

To launch the ARTBot simulation use the command

```bash
ros2 launch artbotsim artbotsim.launch.py
```

![Alt text](assets/simulation.png)


*ARTBot Simulation*

To move each of the robot around, we will use teleop_twist_keyboard which is a package for moving the robot using the keyboard:

```bash
ros2 run teleop_twist_keyboard teleop_twist_keyboard --ros-args --remap cmd_vel:=//cmd_vel
```
## Implementation

### Swarm Algorithm: Flock Formation Algorithm

The algorithm operates within a simulation
environment where only the current position and orientation of the bots are sensed in real-time.

The algorithm involves a swarm of robotic agents, each equipped to navigate and coordinate with its peers autonomously. The swarm is divided into two groups:
- The target-seeking bots are assigned specific targets or coordinates to
move towards, simulating the behavior of birds homing in on particular locations within a flock.
- The integrating bots dynamically position themselves between pairs of "parent bots," facilitating cohesion and formation maintenance within the swarm.

Each "child bot" is assigned specific "parent bots," between which it positions itself. This
arrangement ensures that the "child bots" contribute to the overall shape formation by
maintaining optimal spacing and alignment within the swarm.

### Swarm Algorithm: Boid's Algorithm

![Boids Algorithm](assets/boids.jpg)


*Boids Algorithm*

Boids is an artificial life program that produces startlingly realistic simulations of flocking behavior. Each "boid" (which is an abbreviation of "bird-oid object") follows a very simple set of rules. These rules can be summarized as follows:

- Separation: boids move away from other boids that are too close
- Alignment: boids attempt to match the velocities of their neighbors
- Cohesion: boids move toward the center of mass of their neighbors

> This project has tried to use this algorithm but it is yet to be properly developed

### Canvas

The user interface for the project (the canvas) is made using a simple python3 script that uses opencv.

The drawing is made by handling mouse clicks and mouse movement events which can be done using the mouse event handling feature of opencv.

To process and transfer the image from the canvas to the artbot simulation, the user just needs to use the right mouse button. Once the right mouse button is pressed, targets are assigned in an equi distant manner for the drawing and is trnsferred to the bots.

![Canvas](assets/canvas.png)

### Simulation

The project uses a customized turtlesim environment that is built on Qt (a cross-platform software for creating GUI).

## Results

Here is a video of one of the runs.

https://github.com/IEEE-NITK/ARTBot/assets/97270737/5b0e4868-ec83-44af-998f-3ea33abb24d3

## References

1. [ROS 2 Wiki](https://docs.ros.org/en/iron/index.html)
2. [Boids Algorithms](https://vanhunteradams.com/Pico/Animal_Movement/Boids-algorithm.html)
3. [Swarm robotics: A Review from the Swarm Engineering Perspective
](https://link.springer.com/article/10.1007/s11721-012-0075-2)

## Project Mentors:

1. [Joel Jojo Painuthara](https://github.com/JoelJojoP)
2. [Rohan Bahri](https://github.com/rohanbahri)

## Project Members:

1. [Nallagatla Prudhvi](https://github.com/PrudhviNallagatla)
2. [Nishchay Pallav](https://github.com/Captaincool2017)
3. [Kovidh Singh](https://github.com/KoviSingh)

## License:

This repository is licensed under the [BSD-3-Clause License](https://github.com/IEEE-NITK/ARTBot/blob/main/LICENSE)