Skip to content

programmingLego/legoBTLE4PI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

legoBTLE4PI

Prosa Introduction

legoBTLE4PI aims to provide an easy solution to give almost the same access to the functionality of 'cheaper' hubs like the LEGO|copy| Technic Powered Up Hub.

Such models are often used in cheaper LEGO|copy| Technic sets but have an amazing range of built-in functionality, e.g., tilt-sensors etc.

We wanted to achieve to connect and control the hub only using standard devices (no extra connectivity device etc.) and free and open-source libraries on a standard Raspberry Pi4 model using Bluetooth.

This said, we ended up using:

  • LEGO|copy| Technic Powered Up Hub #88012
  • Raspberry Pi 4, 8GB Ram (RAM size of 8 GB not required though)
  • DietPi 7.1 running (lightning fast, efficient and secure distribution, however, many things have to be tweaked and set and done to make some things happen; I definitively stay with it, and learn to, e.g., connect and mount my USB drive at boot time, has a great and helpful community :-) )
  • Python 3.7.3
    • using asyncio
    • the library bluepy
  • pycharm|copy| Community edition 2021.1.1
    • for no special reason pycharm|copy| is used on Windows (I can't remember, but I guess it was too much for the Pi and some functionality I liked was not available on Linux)

Goals reached and goals not reached (so far)

legoBTLE4Pi started out as a school project that aimed to show how to control a such a LEGO|copy| Jeep with Bluetooth on the Raspberry Pi.

The project tries to give pupils at the age of around 11 years the ability to program their Lego bots on a Rasberry Pi 4B connecting via Bluetooth.

Short Description

I am not sure if I could entirely reach that goal. However, this project models and implements:

  • an asyncio TCP streaming socket server that
    • receives commands from the attached devices
    • sends the commands to the Lego(c) Technic Hub 2.0 via Bluetooth connection
    • returns the feedback of the commands executed to the attached devices
  • an abstraction layer that models the attached device in general
  • an abstraction layer modelling the greater part of the Lego(c) Wireless Protocol 3.0 (see: Lego(c) Wireless Protocol)
    • One can argue the design of course, but I tried to keep everything as simple to use as possible. Now and then the software engineer will notice few redundancies that could be avoided - I am aware of this, but I had good reasons for doing so. Of course, I appreciate and would love to get comments and suggestions regarding the design.
  • a concrete device that models the Hub Brick and makes it functions accessible: any intelligent Brick that adheres to Lego's(c) Wireless Protocol should be usable without problems (I tested it on the Lego(c) Technic Hub 2.0)
  • a concrete device that models a Single Motor
    • almost everything has been implemented here; only the Mode Setting/Selection stuff is a mystery to me still.
    • also custom functions to stop time between commands in order to calculate average the speed, or the distance are available and are added over time
  • a concrete device that models a Synchronized Motor
  • a class Experiment that could once be the basis for a GUI but currently gives the user the means to:
    • define the Device Instances
    • set up and execute a command sequence - the Experiment

As indicated earlier, this project uses Python's asyncio. Python 3.7.3 is used as it is the Raspberry Pi's current supported Python version. However, the project has been tested on Python 3.9 as well and works fine too.

This is my first Python project, and I have many more years experience in C/C++ and Java - so please be gentle if I failed to adhere to the pythonic way once in a while.

Sources of information:

  1. Lego Boost Roboter steuern mit Python unter Windows oder Linux), S. Mack, Vers. 4 22.3.20, Reutlingen University,
  2. Lego's(c) Wireless Protocol
  3. Reverse engineering the LEGO BOOST Hub, J. Pereira
  4. Internet :-)
  5. bruteforce: send possible commands and, see what happens:

Releases

No releases published

Packages

No packages published