Skip to content

Latest commit

 

History

History
102 lines (69 loc) · 3.13 KB

README.md

File metadata and controls

102 lines (69 loc) · 3.13 KB

DeliveryGame

Requirements

Windows

  • Python 3.8 only
  • Download Python3.8 from Microsoft windows store.
  • Open windows powershell and run following line by line
git clone https://github.com/L2S-lab/DeliveryGame.git
cd DeliveryGame
python3.8 -m venv .venv 
.\.venv\Scripts\activate 
pip install -r requirements.txt
  • For error in activating venv, excecute the following
# Secure but annoying way, need to run on each terminal
Set-ExecutionPolicy Unrestricted -Scope Process

# Not so secure way but onnly need to run once for user
Set-ExecutionPolicy Unrestricted -Force -Scope CurrentUser

Linux

  • For Python 3 only,
sudo apt install python3-venv libopus-dev -y
git clone https://github.com/L2S-lab/DeliveryGame.git
cd DeliveryGame
python3 -m venv .venv
source .venv/bin/activate
pip install git+https://github.com/aarsht7/RoboMaster-SDK.git@master
pip install git+https://github.com/aarsht7/RoboMaster-SDK.git@libmedia_codec
pip install -r requirements.txt

MacOs

Haven't tried on MacOS but follow the linux version. It should be something similar.

If you try on Mac, please report any error or feedback.

Known issues

In some laptop we have noticed connections issues with the robot. If the code crashes without any error, re-run the task.

Goal of the game

This is a delivery game between a DJI ROBOMASTER EP robot controlled manually by a person (keyboard or joystick) and a DJI ROBOMASTER EP robot controlled automatically using a Python code. The aim is to retrieve two tennis balls and return them to a basket.

Setting up the game

The hardware required to set up the game is as follows:

  • 2 DJI ROBOMASTER EP
  • tennis balls
  • 2 baskets: cardboard boxes will do
  • DJI markers
  • two computers
  • controller 8-bitdo sn30 pro (or similar)

Each robot must face two tennis balls and behind the robot must be the cardboard box with the marker.

Diagram of how to set up the game :

Game Schema

To connect to the robots :

  • Turn on the robots, then set the connection switch to direct mode (icon with the telephone).
  • Connect to the robot's WIFI on your computer
  • The password can be found on the robot label

To operate the automatically controlled robot :

  • Open Terminal/PowerShell in the directory of the game.

  • Use the command .\.venv\Scripts\activate to activate virtual environment.

  • Use command python ui_tool.py to use UI.

  • Use the command python .\TheGame\main.py to start the game.

  • Use the command python .\TheGame\main.py --help to know the variables that can be set from terminal.

To run the manually controlled robot:

  • Connect the robot and game controller to your computer.
  • Run the python .\ControlRobot\control_manette.py to use the controller. (press esc on the image to exit)

Educational aspect of the game

The students can set the PID that allows the robot to move towards the marker.

To do this, they must :

  • Place the robot in front of the marker. It can be moved to the side.
  • Run the python ui_tool.py program.
  • Set the coefficients, press start and repeat ad infinitum until the PID is set correctly.