⚠ Important Notice:
TheSerial1
andSerial2
functionalities do not work with the ESP32 v3.#.# board library.
To ensure proper functionality, use ESP32 board library version 2.0.17 or earlier.
This library is made to be used for synthesizer projects. It contains modules to create sound, to drive an audio codec and create some audio effects.
In this documentation you will find:
- information about supported platforms
- information about the supported modules of this library
There are some references to the organ project because this was the first which supports the highest count of platforms/boards.
The installation manual can be found here: Installation manual
This library supports different platforms:
- ESP32, ESP32S2, ESP32S3
- ESP8266
- Seeedstudio XIAO (samd21 - cortex-m0plus)
- Teensy 4.1 (imxrt1062)
- Daisy Seed (cortex-m7)
- Raspberry Pi Pico (rp2040)
- Raspberry Pi Pico 2 (rp2350/cortex-m33)
- STM32F3* (cortex-m3)
- STM32F407 (cortex-m4)
The organ example can be found here: https://github.com/marcel-licence/ml_synth_organ_example
All platforms are tested. Actually the sound quality might be a bit limited. The organ supports full polyphony (you can play all 64 notes of the upper manual at the same time). You can modify the sound using 9 drawbars. Percussion is supported (2nd, 3rd). A simple rotary implementation creates a simple (noisy) leslie like sound.
Demo using ESP32, ESP8266: https://youtu.be/c7TL8jcrnzs Demo using the XIAO: https://youtu.be/2wT8nByoUNw Demo using the Teensy4.1: https://youtu.be/H-NDCQnSDV0
More information will be available in future
The library contains the following modules:
- midi module more details
- arpeggiator more details
- board pinout definitions more details
- a simple delay more details
- a simple reverb more details
- organ sound generator more details
- saw/square pulse width modulated oscillator more details
- vu meter (helper) more details
- oled scope more details
- midi file stream player more details
- mod tracker module more details
There are a lot of audio boards available on the market (for example ESP32-Audio-Kit). For that reason you can use some of the existing board includes to get all defines required to set up your board, codec etc. -> please look here for more information more details
There are some "multi-platform" examples available (click the link for more details):
- ml_epiano_example
is a full-polyphone e-Piano like sounding synth - ml_synth_basic_example
- ml_synth_multi_saw_example
creates stereo multi saw (like supersaw etc.) sounds - ml_synth_organ_example
is a full-polyphone organ implementation trying to work like a real tonewheel organ - ml_synth_pwm_osc_examples
A synthesizer module sounding a bit like the Alpha Juno.
It's strength is the pulse sound with a modulated pulse-width. - ml_mod_tracker
A MOD file player. It is a tracker implementation reminding of the Amiga game music. It plays back music of some DOS games too.
please see PlatformIO integration readme
In some cases the following error might occur:
The platform does not support 'compiler.libraries.ldflags' for precompiled libraries.
To fix this you can look for platform.txt
Add the following line:
compiler.libraries.ldflags=
Ref: https://youtu.be/c7TL8jcrnzs?t=419
If you get a lot of "undefined reference to" errors the library couldn't be found by Arduino.
To support new platforms I need the information in which folder Arduino was looking for the library. Example:
Compiling libraries...
Compiling library "ML_SynthTools"
Library ML_SynthTools has been declared precompiled:
Precompiled library in "C:\Users\...\Documents\Arduino\libraries\ML_SynthTools\src\cortex-m4\fpv4-sp-d16-hard" not found
Precompiled library in "C:\Users\...\Documents\Arduino\libraries\ML_SynthTools\src\cortex-m4" not found
Some changes in the toolchain cause that the linker searches the lib in the cortex-m0plus instead of the rp2040 path. Please copy the ML_SynthTools.a from src/rp2040 to src/cortex-m0plus and replace the existing file in case you want to use the lib with the RP2040
Please feel free to share your experience and ideas.
If you appreciate the work done on this project and would like to support its development, I would be more than happy to accept donations!
For more information on how to donate, please send an email to:
Thank you for your support!