Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/codingblocks5/puppetblocks

Learn programming with blocks and a puppet.
https://github.com/codingblocks5/puppetblocks

blockly cs-education elementary-school embedded-systems esp32 firebase micropython programming puppet robotics static-website visual-programming-language

Last synced: 3 months ago
JSON representation

Learn programming with blocks and a puppet.

Awesome Lists containing this project

README

        

# PuppetBlocks

[![Deploy for GitHub Pages - Website](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/website.yml/badge.svg)](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/website.yml)
[![Vulnerabilities Check (CodeQL) - Security](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/vulnerabilities.yml/badge.svg)](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/vulnerabilities.yml)
[![GitHub](https://img.shields.io/github/license/CodingBlocks5/PuppetBlocks)](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/LICENSE)
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/CodingBlocks5/PuppetBlocks)](https://github.com/CodingBlocks5/PuppetBlocks/releases)
[![GitHub repo size](https://img.shields.io/github/repo-size/CodingBlocks5/PuppetBlocks)](https://github.com/CodingBlocks5/PuppetBlocks)
[![Website](https://img.shields.io/website?url=https%3A%2F%2Fcodingblocks5.github.io%2FPuppetBlocks%2F)](https://codingblocks5.github.io/PuppetBlocks/)

[![logo](/assets/cover.jpg)](https://github.com/CodingBlocks5/PuppetBlocks)

## About the Project

Computer programming education in elementary schools in Israel is constantly rising. As most
of the textual programming languages are based on the English language, as well as they have
strict syntax requirements, elementary school student face many difficulties using them. In
order to overcome these challenges, we suggest using a simple visual programming language,
called "PuppetBlocks", for programming an interactive puppet, made by ESP32 micro-controller
and MicroPython firmware. By using Google Blockly library with BIPES platform, such a puppet
can be used for teaching both the concepts of algorithmic thinking and the basics of
programming in Python.

This project is based on a [previous work](https://github.com/BIPES/BIPES), by A. G. D. S. Junior
et. al. (2020). In this work, a framework for website-based visual programming language for
controlling micro-controllers using MicroPython firmware was presented. Please read the paper
for more details about this work:

> Junior, Andouglas Gonçalves Da Silva et. al. 2020. “
> BIPES: Block Based Integrated Platform for Embedded Systems
.” In IEEE Access,
> volume 8, pages 197955-197968..
> .

This work is submitted as the final project in the course "Project in The Internet of Things"
(236333), at The Interdisciplinary Center for Smart Technologies (ICST), Taub Faculty of
Computer Science, Technion - Israel Institute of Technology. This project was written by
Orel Adivi `(orel.adivi [at] cs.technion.ac.il)`, Hila Ginzburg
`(hila.gin [at] campus.technion.ac.il)`, and Noy Shmueli `(noyshmueli [at] campus.technion.ac.il)`,
and under the supervision of Assel Aborokn, Tom Sofer, and Itai Dabran, Ph.D. . The work was done in about
an academic semester and is released under GNU General Public License v3.0.

## Hardware

As an IoT project, one of the main components is a Puppet, which is a robot with an ESP32 micro-controller,
two servo engines, two screens, a 2-dimension joystick, a speaker, and an SD card. We chose the components
to be cheap (we assume that the total cost is no more than 30$), so schools can replicate our work easily.

We used the following hardware components in the project:
- **ESP32 board** - the micro-controller we used to control the puppet.
- **Head and Gimbal Connector** - both 3-D printed specifically to the project.
- **MAX98357A Amplifier** - LRC connected to Pin 25, BCLK connected to Pin 32, DIN connected to Pin 33.
- **Joystick (Two Potentiometers)** - VRy connected to Pin SN, VRx connected to Pin SP, SW connected to Pin 16.
- **SG90 Servo (for pitch in a Gimbal)** - Signal connected to 26
- **SG90 Servo (for rotation in a Gimbal)** - Signal connected to 14
- **SH1109 1.3 Inch (Left screen with address 0x3dc)** - SCL connected to 22, SDA connected to 21.
- **SH1109 1.3 Inch (Right screen with address 0x3d)** - SCL connected to 22, SDA connected to 21.
- **SD Card** - CS connected to 5, MOSI connected to 23, CLK connected to 18, MISO connected to 19.

The following diagram shows the connections described above:

[![connections](/hardware/connections.png)](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/hardware/connections.png)

The script [`Check.py`](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/hardware/Check.py) can help ensuring that all
the hardware components work correctly. The code can be ran using Thonny, after installing the firmware as described below.

## Firmware

In order to perform actions using the website, a firmware with a standard library has to be burned on the micro-controller.
The firmware allows using MicroPython for interpreting the commands, the PuppetBlocks library provides an abstraction
of the possible actions for an easier use for elementary school students.

In order to burn MicroPython on the device, Requests and pathlib has to be install on the local computer, which can be
done using Pip package installer:

```bash
python -m pip install -r requirements.txt
```
Then, running the burner with `--help` flag gives the list of the parameters to provide:

```bash
python burn.py --help
```

The following output is given:

```text
usage: burn.py [-h] [-m MICROPYTHON] -e ESPTOOL -c CONNECTION

PuppetBlocks - Learn programming with blocks and a puppet.

options:
-h, --help show this help message and exit
-m MICROPYTHON, --micropython MICROPYTHON
the url of the MicroPython firmware (default: v1.19.1)
-e ESPTOOL, --esptool ESPTOOL
the root for esptool.exe
-c CONNECTION, --connection CONNECTION
the connection to the device (usually COM4)

For help with the burner please read SUPPORT.md .
```

After specifying a location for a local `esptool.exe` file, a serial connection to the micro-controller, and
optionally a URL for a MicroPython firmware (without the `--help` flag), a single click is required on the
BOOT button on the ESP32 controller for allowing the burning.

Additionally, the following files are part of the PuppetBlocks standard library:
- [**`Audio.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/Audio.py) - This file
include a class for a speaker player (which plays audio in a different thread) in the project.
- [**`boot.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/boot.py) - This file runs
on each start and *has to replace* the default file created when burning MicroPython.
- [**`PuppetBlocks.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/PuppetBlocks.py) -
This file contains the interface and the implementations for the blocks used in the website.
- [**`Screen.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/Screen.py) - This file
include a class for both of the screens in the project.
- [**`Secrets.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/Secrets.py) - In
this file, the actual WiFi SSID and the actual WiFi password *has to be specified*. Without setting these
parameters correctly, the ESP32 controller might not start successfully in the future.
- [**`Servo.py`**](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/Servo.py) - This file
include a class for both of the servo engine in the project.

As a summary, the following steps have to be performed in order to burn MicroPython and PuppetBlocks standard library:

1) Installing the dependencies for the burner with using Pip package installer.
2) Downloading an `esptool.exe` to the device (usually such a file is downloaded when installing Arduino IDE).
3) Optionally erasing the flash memory of the ESP32 micro-controller, optionally using the `esptool.exe`.
4) Burning MicroPython firmware using the script.
5) Setting the actual WiFi SSID and the actual WiFi password in the relevant file.
6) Uploading the six files to the device, optionally using Thonny.
7) Connecting the device (once) using the PuTTY, Thonny, or the serial connection in the website, writing `import webrepl_setup`,
writing `E`, specifying a password and confirming it, and finally resetting the device (optionally using disconnecting and
connecting the device).

The total process might take a few minutes, but it has to be performed only once for each device.

## Website

The main way in which the elementary school students interact with the system is using the website, available
on [https://codingblocks5.github.io/PuppetBlocks/](https://codingblocks5.github.io/PuppetBlocks/). This is a static,
single page frontend-based website, written in HTML, CSS, and JavaScript, allowing the students to program the
micro-controller. Beside the general blocks that were presented in BIPES, there are 31 unique blocks intend to
help the student interact with the device.

The following block categories were added:
- **Movement** - these blocks are used to control the two servo motors, read the joystick, record movements and
performing them.
- **Screens** - these blocks are used to control the two screens independently, allowing showing images and text
and providing fast whitening and blacking function.
- **Audio** - these blocks are used to control the speaker, allowing playing audio synchronously or asynchronously,
once or in loop, and providing easy functions for pausing, resuming, stopping, and checking whether the speaker is
currently playing.
- **Files** - these blocks are used to load files from the cloud to the device, to check whether a file exists, to
delete a file on the device, to rename a file on the device, and to get a list of all currently available files on
the device.
- **Time** - these blocks are used to sleep for a specified time or until a specified time, to get the current time
or get a unit of it, and to do basic arithmetical calculations connected with time.

Downloading files to the device require previous uploading to the PuppetBlocks cloud, which is stored in Cloud
Storage for Firebase. The website allows a simple uploading and viewing a list of all currently available files
in the cloud. Executing the code is possible either using a serial (USB) connection or using WiFi with MicroPython
WebREPL. It is possible to download the current code to a local file and to upload previously downloaded files
from the local computer. The interface is available on English, with a basic support for Hebrew, Arabic, Italian,
and Russian.

## Project Engineering

For security purposes, commits were signed cryptographically, security Github Actions were enabled, and a
[SECURITY.md](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/SECURITY.md) file was written. For documentation, a
[SUPPORT.md](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/SUPPORT.md) file was written. The project was written using
both Visual Studio Code and Thonny IDE, and was managed using [GitHub](https://github.com/CodingBlocks5/PuppetBlocks).

For allowing an easier development, the following Github Actions were set, running on Linux (Ubuntu 20.04).:
1) **[Website](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/website.yml)** - the
[PuppetBlocks website](https://codingblocks5.github.io/PuppetBlocks/) is updated with the current information.
2) **[Vulnerabilities check](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/vulnerabilities.yml)** - the
updated code is checked to ensure it does not contain any known vulnerability.
3) **[Dependency review](https://github.com/CodingBlocks5/PuppetBlocks/actions/workflows/dependency-review.yml)** - the
dependencies are reviewed to check for any security issues.
4) **[Dependabot](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/.github/dependabot.yml)** - the
dependency versions (in
[requirements.txt](https://github.com/CodingBlocks5/PuppetBlocks/blob/main/firmware/requirements.txt)) are updated regularly.

Please feel free to contact us with any questions you have about PuppetBlocks.