Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/smerrony/midibanger
A Raspberry Pico MIDI player that plays physical (toy) instruments via servos.
https://github.com/smerrony/midibanger
midi midi-player music pico pico-sdk raspberry-pi-pico rp2040 rp2040-zero
Last synced: about 2 months ago
JSON representation
A Raspberry Pico MIDI player that plays physical (toy) instruments via servos.
- Host: GitHub
- URL: https://github.com/smerrony/midibanger
- Owner: SMerrony
- License: bsd-3-clause
- Created: 2024-02-14T10:58:30.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-03-13T07:53:52.000Z (10 months ago)
- Last Synced: 2024-03-13T08:49:27.632Z (10 months ago)
- Topics: midi, midi-player, music, pico, pico-sdk, raspberry-pi-pico, rp2040, rp2040-zero
- Language: C
- Homepage:
- Size: 934 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MidiBanger
A Raspberry Pico* MIDI device that plays physical (toy) instruments via servos.MidiBanger supports both percussive (mallet-type) and pressed (key-type) instruments.
* Pan-and-tilt mode using just two servos to play reachable notes
* Servo-per-note mode
* Solenoid-per-note mode (soon)The current version supports up to 16 directly-connected servos, later versions may
support I2C servo controllers allowing hundreds of servos to be used.*Tested on Raspberry Pi Pico, Raspberry Pi Pico W, and Waveshare RP2040-Zero.
![Pan-and-tilt version playing Janod toy glockenspiel](images/MidiBanger_Janod_1.jpg)
## Hardware Requirements
* Raspberry Pico or compatible such as RP2040-Zero
* Servo per note eg. SG90 9g Micro Servo, or a pair if using pan-and-tilt
* Optional - Micro speaker - handy for debugging and setup
* Optional - 5V PSU for servos, if you think you need it
* Some 3D-printed parts to hold servos etc.Some sample 3D parts are included in the `3D` directory, there are [FreeCAD](https://www.freecad.org/) designs and `.3mf` files
for slicing.## Configuration
See the comments in `src/config.h` for details.To avoid masses of commented-out congfiguration I have put the configuration that is specific to a
particular physical instrument in a separate file which is then `#include`d in the main `config.h`.
Example configurations are `chicco_toy_glock_config.h` and `janod_toy_glock_config.h`.For the servo-per-note mode, the critical configuration item is the `NOTEPIN_INITIALISER`. Leave its first line alone, then replace the contents with a maximum of sixteen [MIDI note number] = GPIO_PIN pairs.
For the two-servo pan-and-tilt mode it's the `NOTE_PAN_INITIALISER` that you will need to adjust to set the
angles for each note. This will be a trial-and-error process, I suggest you start by installing the servos so that
their centres of movement roughly point to the middle of the instrument and then do a first run WITHOUT the hammer attached.If you are connecting up several MidiBangers I suggest you use a different string or
number for each one at the end of the `USB_PRODUCT` string. It will make your life a lot simpler!## Building
Don't forget to set `PICO_BOARD` to match your target microcontroller in `CMakeLists.txt`, then...
```
mkdir build
cd build
cmake ..
make
```
## Hints
### Pan-and-Tilt Players
* Try a metal-geared servo for the panning action, these seem to have less play than the plastic-geared equivalent.
* For greater accuracy playing large intervals (leaps) you can try setting the angles for the lowest and highest notes
just a little towards the centre, this will compensate for some overshoot.