This document will take you through the steps to get your module ready to program.
Note If you already have any version of the firmware or any other code loaded onto your EuroPi and want to ensure a clean installation, or you just want to make sure you have all the most recent scripts available, first follow these instructions:
-
Download flash_nuke.uf2 from Adafruit.
-
Holding down the white button labeled 'BOOTSEL' on the Raspberry Pi Pico, connect the module to your computer via the USB cable.
Note If you are already running the menu system on the EuroPi (with a version greater or equal to X.X.X) and would rather not take the module out of your rack, you can instead run the script
_Bootloader Mode
while the module is connected to your computer over USB, and the module will enter bootloader mode
-
Open your file manager and drag and drop the downloaded
flash_nuke.uf2
onto the new drive named 'RPI-RP2'. This will wipe your Pico clean, ready for a new installation of the firmware. -
The Pico will automatically eject once the process is completed.
-
Continue to Setting Up as normal.
Warning This version of firmware will not let you override
main.py
nor can you modify existing scripts. Do not use this version of the firmware if you plan to write custom scripts for the EuroPi.
The quickest way to get your EuroPi flashed with the latest firmware is to head over to the releases page and download the latest europi-vX.Y.Z.uf2
file. Then follow the 'BOOTSEL' instructions above to flash the EuroPi firmware to your pico.
This section assumes you are using the Raspberry Pi Pico (or a compatible clone) featuring the RP2040 processor. If you are using the newer Raspberry Pi Pico 2, with the RP2350 processor, see below.
To start with, you'll need to download the Thonny IDE. This is what you will use to program and debug the module.
-
Download the most recent firmware from the MicroPython website. The latest supported version is
1.23.0
. -
Holding down the white button labeled 'BOOTSEL' on the Raspberry Pi Pico, connect the module to your computer via the USB cable.
-
Open your file manager and drag and drop the downloaded .uf2 onto the new drive named 'RPI-RP2'.
-
The Pico will automatically eject once the process is completed.
-
Disconnect the Pico from the USB cable.
-
Reconnect, this time without holding down the button on the back.
-
Open up Thonny if not already open, and go to the bottom right where you can select the interpreter.
-
Click to select interpreter and choose 'MicroPython (Raspberry Pi Pico)'.
-
Important: Wait until the Shell window at the bottom shows the MicroPython version and the purple
>>>
symbol. -
Click Tools -> Manage Packages to open the package manager.
-
Type 'micropython-ssd1306' into the search box and click 'Search on PyPi'
-
Click the result named 'micropython-ssd1306'.
-
Click 'Install'.
-
You will see that a folder has been created inside the Pico named 'lib', which contains the new file 'ssd1306.py'.
Use the exact same process as for the ssd1306 library to install the europi library:
-
Type 'micropython-europi' into the search box and click 'Search on PyPi'
-
Click the result named 'micropython-europi'.
-
Click 'Install'.
-
You will now see several new files, including 'europi.py' alongside the 'ssd1306.py' inside the 'lib' folder.
The EuroPi Contrib library will make user-contributed software available on your EuroPi when using the Menu software. To install it, follow the same steps as the previous libraries on Thonny:
-
Type 'micropython-europi-contrib' into the search box and click 'Search on PyPi'
-
Click the result named 'micropython-europi-contrib'.
-
Click 'Install'.
-
You will now see a
contrib
folder inside thelib
folder which contains several software options with the extension.py
.
If you are using the Raspberry Pi Pico 2, or a compatible clone, with the RP2350 processor, you must download the MicroPython firmware for that board:
- Download here. At the time of writing, the latest supported version is 1.24.0
Once the firmware is installed, continue installing the rest of the software:
Once the software is installed, you will need to configure the software to finish setting up the Pico 2.
Now that you have installed the europi.py and ssd1306 libraries, you are ready to take the next step with the module.
- Option 1: Start writing your own program from scratch
- Option 2: Use someone else's program from the contrib folder
- Option 3: Install all of the contrib scripts and use the bootloader menu
- Option 4: Calibrate the module for higher accuracy
To program the module, just create a new Python file, and then press Ctrl-Shift-S to save as to the Raspberry Pi Pico, and name it 'main.py'. Do not save files to the 'lib' folder, as this is just for libraries to be imported rather than programs that you will write. Now import the entire europi library by simply adding the line 'from europi import *'
Now you have access to the inputs and outputs using easy methods, which you can read about more in the README.md of the software folder.
- Use the exact same process as for the ssd1306 and europi libraries to install the europi-contrib library:
- In Thonny, click Tools -> Manage Packages to open the package manager.
- Type 'europi' into the search box and click 'Search on PyPi'
- Click the result named 'micropython-europi-contrib'.
- Click 'Install'.
- You will now see the new directory 'contrib' inside the 'lib' folder, containing the contrib scripts.
- You can now choose any script from inside this contrib folder to run on your module. When you've chosen, double click the file on the Pico to open it.
- Press 'Ctrl-Shift-S' to Save As, and choose 'Raspberry Pi Pico'
5. Name the file main.py
, being careful to include the '.py' so the module knows it is a Python file. If you do not name it main.py
, the module will not know to automatically run your program whenever it is connected to power. Save the file to the root directory of the Pico (not inside any folders)
6. Now you can disconnect the module from your computer, connect it to rack power, and the your chosen script will run automatically.
- Make sure you've Installed the EuroPi Contrib library.
- Complete all of the steps for Option 2, but you must use
menu.py
as the file to save to the root directory. Name itmain.py
as you would any other script. - Now you can disconnect the module from your computer, connect it to rack power, and the menu will open automatically.
One of the scripts that is installed with the menu system is named '~ Calibrate', and it requires you to send precise voltages to the module to calibrate it for the future, allowing you to input and output precise values from your module. This is entirely optional and it will work with a usable degree of accuracy without calibration, however if you do want to then move to the 'Calibrate the module' step.
To navigate the menu use the right knob. Turning clockwise will scroll down and turning anticlockwise will scroll up.
To run the selected program, press the either button once. The last-run program will automatically start the next time you power-on your EuroPi.
To return to the main menu at any time, press and hold both buttons for 0.5s.
To use the module for accurately reading and outputting voltages, you need to complete a calibration process. This will allow your specific module to account for any differences in components, such as resistor tolerances. If you do not wish to calibrate the module and don't mind your voltages being slightly inaccurate, simply skip to the programming step and your module will use default values.
Note If you have just installed the menu, simply run the calibration script and skip to step 2.
- To begin, you need to choose the
calibrate.py
file and save it asmain.py
in the root directory, as we did in Option 2 above. You can obtain thecalibrate.py
file from either thelib
directory on your Pico, or from the firmware directory in the repository. - Make sure your module is connected to rack power for the calibration process. It doesn't matter if it connected to USB as well, however if it is it will give an extra warning to turn on rack power which you need to skip using button 1.
- Turn on the rack power supply, and the screen will display 'Calibration Mode'. If it doesn't, try troubleshooting.
- There are 2 options for calibration:
- Low Accuracy: Only a single 10V supply is required
- High Accuracy: A variable supply is required to produce voltages from 0-10V Press button 1 to choose Low Accuracy mode, or button 2 to choose High Accuracy mode.
- Connect your voltage source to the analogue input, and input each voltage displayed on the screen. To take a reading (once your voltage is connected), press button 1.
- Once all the required voltages have been input, you now need to disconnect the analogue input from your voltage source, and instead connect it to CV output 1.
- Once you have connected the analogue input to CV output 1, press button 1
- Wait for each voltage up to 10V to complete. The module will tell you once it has completed.
- NOTE: Skip this final step if you are running the calibration script from the menu system. The calibration process is now complete! You now need to rename or delete the 'calibrate.py' program, however DO NOT delete the new file created called 'calibration_values.py'. This file is where the calibration values are stored, and if you delete it you will have to complete the calibration again.
As with all hardware, the EuroPi has certain limitations. Some are more obvious and are required knowledge for any user, and some are more in depth and are only relevant if you will be programming the module yourself.
- Analogue input is only 0-10V
- Digital input can only detect signals above 0.7V (meaning it may trigger accidentally if you have a noisy 'low' state)
- Outputs, analogue input, and knobs, have a maximum resolution of 12 bits (4096 steps)
- Debouncing of the buttons means that very fast double presses may not be detected
- Clock pulses shorter than approximately 0.01s (10ms) will not be reliably detected (this depends on clock speed too)
- Reading any analogue source, either the analogue input or knobs, will result in a slight delay of the script (this can be reduced by using fewer samples, at the cost of accuracy)