Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/r0h1th-1dd4e2/gesture-control
This repository houses code for a versatile control system for a robotics project. It combines hand gesture recognition, keyboard control, and voice commands to operate a robot wirelessly. The system utilizes Python libraries like Torch, Transformers, OpenCV, MediaPipe, and more for seamless interaction and control.
https://github.com/r0h1th-1dd4e2/gesture-control
keyboard-control opencv-python python-library robotics-control voice-control
Last synced: 3 days ago
JSON representation
This repository houses code for a versatile control system for a robotics project. It combines hand gesture recognition, keyboard control, and voice commands to operate a robot wirelessly. The system utilizes Python libraries like Torch, Transformers, OpenCV, MediaPipe, and more for seamless interaction and control.
- Host: GitHub
- URL: https://github.com/r0h1th-1dd4e2/gesture-control
- Owner: R0h1th-1DD4E2
- Created: 2024-05-07T19:06:21.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-05-14T17:22:08.000Z (8 months ago)
- Last Synced: 2024-11-16T21:12:43.111Z (2 months ago)
- Topics: keyboard-control, opencv-python, python-library, robotics-control, voice-control
- Language: Python
- Homepage:
- Size: 3.93 MB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
🤖 Gesture Control
![](Assets/2.webp)
Gesture Control is a versatile Python application that enables real-time control of a robot using hand gestures or keyboard inputs. It offers an intuitive interface for users to interact with the robot effortlessly.
## Libraries Used
[![torch](https://img.shields.io/badge/torch-abd6fd?style=for-the-badge)](#) [![transformers](https://img.shields.io/badge/transformers-ffd7e1?style=for-the-badge)](#) [![sounddevice](https://img.shields.io/badge/sounddevice-ffd8b1?style=for-the-badge)](#) [![opencv-python](https://img.shields.io/badge/opencv--python-c7e3ff?style=for-the-badge)](#) [![mediapipe](https://img.shields.io/badge/mediapipe-ffb6c1?style=for-the-badge)](#) [![keyboard](https://img.shields.io/badge/keyboard-ffb347?style=for-the-badge)](#) [![websocket-client](https://img.shields.io/badge/websocket--client-c1ffc1?style=for-the-badge)](#) [![OS](https://img.shields.io/badge/OS-ffd7e7?style=for-the-badge)](#) [![Groq](https://img.shields.io/badge/groq-ffe347?style=for-the-badge)](#)
## What does the Bot Do?
Bot Control empowers users to control a robot's movements and actions through two primary methods:
1. **Hand Gesture Control:** Utilizing the webcam, the application detects and interprets hand gestures, translating them into commands for the robot. Users can navigate the robot's movements seamlessly by gesturing in front of the camera.
2. **Keyboard Control:** Alternatively, users can control the robot using keyboard inputs. This method offers precise control over the robot's actions, allowing users to issue specific commands with ease.
3. **Voice Control** `(Work In progress)` Bot Control also offers voice control functionality, allowing users to control the robot using spoken commands. By leveraging automatic speech recognition (ASR) technology, users can issue commands to the robot simply by speaking into a microphone.
## Key Features
- **Real-time Control:** Experience immediate responsiveness as you control the robot's movements and actions in real-time.
- **Intuitive Interface:** Choose between hand gesture or keyboard control based on your preference or convenience, with a user-friendly interface guiding you through the process.
- **Versatile Application:** Suitable for various robot applications, including remote-controlled vehicles, robotic arms, and more.
- **Voice Control:** Control the robot using natural language commands, thanks to built-in automatic speech recognition capabilities.## How it Works
Bot Control relies on the following components and technologies:
- **Python Programming:** The application is built using Python, a versatile and powerful programming language known for its simplicity and readability.
- **OpenCV Library:** OpenCV is used for computer vision tasks, enabling the detection and recognition of hand gestures from the webcam feed.
- **Keyboard Library:** The keyboard library facilitates keyboard input monitoring, allowing users to control the robot using key presses.
- **ESP8266 WebSocket Server:** The robot communicates with the application via a WebSocket server hosted on an ESP8266 microcontroller, enabling seamless interaction between the user and the robot.
- **Voice Control** The Robot utilizes automatic speech recognition (ASR) technology to enable voice control functionality. The voice module records audio input from a microphone, which is then processed by the ASR model to transcribe spoken commands into text. The transcribed commands are then interpreted and translated into corresponding robot actions.## Photos
![](Assets/3.webp)
![](Assets/1.webp)
![](Assets/4.webp)## Getting Started
To get started with Bot Control, follow these steps:
1. **Clone the Repository:** Clone the repository to your local machine using Git:
```bash
git clone https://github.com/R0h1th-1DD4E2/Gesture-Control.git
```2. **Install Dependencies:** Install the required Python libraries by running:
```bash
pip install -r requirements.txt
```
3. **Setup:** Store your `Groq` api key in an `.env` file.4. **Run the Application:** Launch the application by executing the main Python script:
```bash
python controller.py
```
The above command can also be given with an argument consisting of IP of the bot, only if the bot is connected to the other network other than your laptop's hotspot.5. **Choose Control Mode:** Follow the on-screen instructions to select your preferred control mode (hand gesture or keyboard control) and start controlling the robot.
6. **Voice Control:** Run `voiceController.py` with or without the the IP of the the bot as argument to cnnect the bot and control it.