/ai-and-lego

Some code to demonstrate how to use Lego to learn the basics of AI (work in progress)

Primary LanguageJupyter NotebookGNU General Public License v3.0GPL-3.0

Introduction

This repository contains code to control a Lego Mindstorms Robot and to capture images from a webcam that is on the robot.

In a next step, these images will be used to train a neural network to detect objects.

The repository is split into two parts:

  • The hub folder contains the code that will ron on the Lego Mindstorms Robot.
  • The client folder contains the code that will run on your computer. This is itself split into two parts:
    • The control folder contains code for a simple program to control the robot.
    • The capture has code to capture images (using a GoPro).

Initial

First install Python 3.

Create and activate a virtual environment

python -m venv venv
.\venv\Scripts\activate

Now install the requirements:

pip install -r requirements.txt

Mindstorms Robot Inventor

The code consists of two parts:

  • The hub.py program that needs to run on the hub.
  • The client.py program that runs on your computer.

To get the hub program onto the hub, the easiest option is to use the PyBricks website. It will demonstrate how to put the correct firmware on the hub and how to upload the program. Just copy-and-paste the hub.py code into the PyBricks editor.

Once the hub program is on the hub, it is important to disconnect the hub from the PyBricks website. To do this, simply press the Bluetooth button on the PyBricks editor. The little beams will disappear to indicate that the hub is no longer connected.

Protocol

The protocol to the robot has two message types: a 'D' or drive message and the 'B' or bye message.

Drive message

Every 'D' message must contains exactly 7 characters.

Example: +---+---+---+---+---+---+---+ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | +---+---+---+---+---+---+---+ | D | + | 2 | 0 | - | 3 | 0 | +---+---+---+---+---+---+---+

This command will set the left motor to turn at 20% of its maximum speed and the right motor to turn at 30% of its maximum speed in reverse.

The first character must always be uppercase D, the next 6 characters are used to control the motors:

  • All zeros (000000) will stop the motors.
  • The first and 4th character are either a + or a - to indicate the direction of the motor.
  • All other characters are digits between 0 and 9 to indicate the speed of the motor.

To parse a command, the following regex is used ^D([+-0])(\d\d)([+-0])(\d\d)$. You can expeirment with it here: https://regex101.com/r/vLf5D9/1

Bye message

The bye message is a single character 'B' that indicates that the client is done sending commands and that the hub can stop the program.