Detect Motion and Destroy Target! Autonomous DIY Project

by MertArduino in Circuits > Microcontrollers

2935 Views, 34 Favorites, 0 Comments

Detect Motion and Destroy Target! Autonomous DIY Project

cover-01.png

Detect Motion and Destroy Target!

In this video I show you how to build a DIY motion tracking project with a Raspberry Pi 3. The project is autonomous so it moves and fires the gun when it detects motion. I used laser module for this project, but you can easily change modify this build to use a Nerf instead.

This project allows you to detect and track a person with OpenCV and then trigger a device (such as a laser or gun).

Video Tutorial - Step by Step

Detect Motion and Destroy Target! Amazing Autonomous DIY Idea - OpenCV

Circuit Diagram

devre2.png

You can complete your connections according to the circuit above. GPIO22 pin is used for relay control within the code.

RELAY_PIN = 22

Install Guide - OpenCV and Pip

vlcsnap-2019-10-23-10h26m48s603.png

1. Make sure pip is installed

sudo apt-get install python pip

https://www.pyimagesearch.com/2018/09/19/pip-install-opencv/

2. Install OpenCV 3. Follow all steps for python 3 instructions

https://www.pyimagesearch.com/2016/04/18/install-guide-raspberry-pi-3-raspbian-jessie-opencv-3/

3. Setup I2C on your Raspberry Pi

https://learn.adafruit.com/adafruits-raspberry-pi-lesson-4-gpio-setup/configuring-i2c

4. Install the Adafruit stepper motor HAT library

sudo pip install git+https://github.com/adafruit/Adafruit-Motor-HAT-Python-Library

5. I2C Address

If you are using a Raspberry Pi Stepper Motor Expansion Board other than the Adafruit Stepper Motor HAT (just like in the video), then update the I2C address or frequency value with the following. (This address is only compatible with the board in the video, default value is blank for Adafruit Stepper Motor HAT)

self.mh = Adafruit_MotorHAT()

to

self.mh = Adafruit_MotorHAT(0x6F)

in the source code (mertracking.py)

for mor details: http://www.raspberrypiwiki.com/index.php/Robot_Expansion_Board

6. Make sure to create your virtual environment with the extra flag

mkvirtualenv cv --system-site-packages -p python3

7. Open Terminal and Activate your virtual environment

workon cv

8. Clone this repository

git clone git@github.com:MertArduino/RaspberryPi-Mertracking.git

9. Navigate to the directory

cd RaspberryPi-Mertracking

10. Install dependencies to your virtual environment

pip install imutils RPi.GPIO

11. Run the Code

python mertracking.py

Setting Parameters

vlcsnap-2019-10-23-10h52m47s970.png

mertracking.py has a couple parameters that you can set:

MOTOR_X_REVERSED = False
MOTOR_Y_REVERSED = False 
MAX_STEPS_X = 20
MAX_STEPS_Y = 10
RELAY_PIN = 22

I2C Address or Frequency

self.mh = Adafruit_MotorHAT(0x6f)

Speed of the Stepper Motors

self.sm_x.setSpeed(5)
self.sm_y.setSpeed(5)

Steps/Rev of the Stepper Motors

self.sm_x = self.mh.getStepper(200, 1)
self.sm_y = self.mh.getStepper(200, 1)

Delay Time for the Relay Trigger

time.sleep(1)

You can change the step type with the following commands

Adafruit_MotorHAT.MICROSTEP

MICROSTEP - SINGLE - DOUBLE - INTERLEAVE

Source Code

vlcsnap-2019-10-23-10h51m55s371.png

Get the Code from GitHub - https://github.com/MertArduino/RaspberryPi-Mertracking

Clone this repository:

git clone git@github.com:MertArduino/RaspberryPi-Mertracking.git