Skip to content

This project integrates computer vision and robotics to create an autonomous robot for navigation on streets using Python, C, OpenCV, Flask, and GPIO libraries for image processing, motor control, and web-based interaction, with a Raspberry Pi handling vision and logic, and an Arduino managing motor control.

Notifications You must be signed in to change notification settings

sofiasawczenko/autonomous_robot_computer_vision

Repository files navigation

Autonomous Robot with Computer Vision

image

This repository contains the source code and necessary resources for building an autonomous robot using Python, C, Raspberry Pi, and Arduino. The robot features a navigation system based on computer vision.

Overview

The goal of this project is to develop an autonomous robot capable of navigating independently in an environment using computer vision techniques to detect obstacles and make navigation decisions. The robot integrates hardware and software, with the Raspberry Pi handling image processing and decision-making, while the Arduino controls the motors and sensors.

Key Features

  • Computer Vision: Equipped with a camera, the robot captures images of its surroundings. The computer vision algorithm processes these images to identify obstacles, free paths, and other navigation-critical information.
  • Motor Control: The Arduino is responsible for motor control, allowing the robot to move forward, backward, turn, and perform other maneuvers to avoid obstacles and follow predefined paths.
  • Obstacle Detection: Using advanced computer vision techniques, the robot identifies obstacles and adjusts its movement to avoid collisions.
  • Autonomous Navigation: The navigation system on the Raspberry Pi uses input from computer vision and sensors to make real-time decisions, enabling the robot to move autonomously.

Hardware Requirements

  • Raspberry Pi: For image processing and navigation logic.
  • Arduino: To control motors and read sensor data.
  • Camera: For capturing real-time images for computer vision.
  • Motors and Wheels: For movement.
  • Sensors: Optional for additional obstacle detection.
  • Car configuration: image

Software Technologies

  • Programming Languages: Python, C
  • Libraries: OpenCV, Flask, NumPy, GPIO libraries (e.g., RPi.GPIO, gpiozero)
  • Frameworks: Flask for web-based robot control

Getting Started

1. Clone this repository:

   git clone https://github.com/sofiasawczenko/robot_using_computervision.git

2. Set up your Raspberry Pi and Arduino:

  • Flash the appropriate Arduino code for motor and sensor control.
  • Install the required Python libraries on the Raspberry Pi using pip:
pip install opencv-python flask numpy

3. Assemble the robot hardware, connecting the Raspberry Pi and Arduino as specified in the configuration.

4. Run the Flask server on the Raspberry Pi to control the robot:

python app.py

5. Code Snippets

1. Motor Control with Raspberry Pi

import RPi.GPIO as GPIO
import time

GPIO.setmode(GPIO.BOARD)
RF = 12  # Right Forward
RB = 32  # Right Backward
LF = 33  # Left Forward
LB = 35  # Left Backward

GPIO.setup(RF, GPIO.OUT)
GPIO.setup(RB, GPIO.OUT)
GPIO.setup(LF, GPIO.OUT)
GPIO.setup(LB, GPIO.OUT)

# Example movement: forward for 2 seconds
GPIO.output(RF, True)
GPIO.output(LF, True)
time.sleep(2)
GPIO.output(RF, False)
GPIO.output(LF, False)
GPIO.cleanup()

2. Computer Vision for Obstacle Detection

import cv2

cap = cv2.VideoCapture(0)
while True:
    _, frame = cap.read()
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    # Detect obstacles using a classifier
    obstacles = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
    detected = obstacles.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5)
    for (x, y, w, h) in detected:
        cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
    cv2.imshow("Obstacle Detection", frame)
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break
cap.release()
cv2.destroyAllWindows()

How to Contribute

Contributions are welcome! Follow these steps to contribute:

  • Fork this repository.
  • Clone the forked repository:
git clone https://github.com/YOUR_USERNAME/robot_using_computervision.git
Create a new branch:
```bash
git checkout -b feature-name
  • Make your changes and commit:
git add .
git commit -m "Description of changes"
  • Push your changes and open a pull request:
git push origin feature-name

Acknowledgments

This project was inspired by the potential of integrating computer vision with robotics to create efficient autonomous systems.

About

This project integrates computer vision and robotics to create an autonomous robot for navigation on streets using Python, C, OpenCV, Flask, and GPIO libraries for image processing, motor control, and web-based interaction, with a Raspberry Pi handling vision and logic, and an Arduino managing motor control.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published