General repository for Wavetable Synthesis Capstone project at Portland State, Fall 2016 - Winter 2017
The purpose of this project is to provide a C++ library and accompanying Python utility scripts allowing realistic instrumentation audio to be synthesized on the Teensy 3.2/3.6 Arduino Digital Analog Converter (DAC).
The project consists of two main components:
- SoundFont Decoder
- Audio Synth Wavetable class
The project documentation can be found at: https://teensyaudio.github.io/Wavetable-Synthesis/html/index.html.
The project's source is available on GitHub: https://github.com/TeensyAudio/Wavetable-Synthesis
A tutorial video for how to decode and use a SoundFont file with our library, see https://www.youtube.com/watch?v=5laaNHLhS98
The SoundFont decoder is a python utility to decode a SoundFont file into native C++ datatypes. The decoder can be run via a GUI or via the command line.
To run the pre-built version of the SoundfontDecoder, simply execute the SoundfontDecoder.exe executable
- Note this is built for Windows. If running on a different OS, run the decoder using the Python instructions below
To run the GUI via Python, you must use Python3, specifically 3.6. The Sf2Utils Python package must be installed in order to run/build the decoder.
Sf2Utils can be installed via pip install sf2utils
After dependancies have been installed, invoke the decoder GUI with $ python3 controller.py
How to invoke the script:
The -d
flag is for debug mode
The -i
flag precedes the input file
$ python decoder.py -i soundfont
$ python decoder.py -d -i soundfont
- Pull the latest version of PyInstaller from https://github.com/pyinstaller/pyinstaller (at the time of this writing, PyInstaller in PIP doesn't support Python 3.6).
- Run the setup.py script from the PyInstaller repo.
- After PyInstaller is installed on the system, the pyinstaller.exe will be within the \Scripts folder of the system's Python directory. Navigate to this directory, and run the following command:
pyinstaller --onefile --noconsole --name SoundfontDecoder <path-to-wavetable-code>\controller.py
- This will produce an executable file named controller.exe which contains the Soundfont Decoder.
Additional Instructions for building on Ubuntu:
- for step 2, make sure to use python3 when installing: i.e. python3 setup.py install -- this is because tkinter has been renamed to Tkinter in python3
- the executable file will be in the dist directory
C++ class implementing wavetable synthesis. For in-depth class member and field descriptions, see https://teensyaudio.github.io/Wavetable-Synthesis/html/index.html
- Ryan Mellmer (rmellmer)
- Nicholas Craig (beroberobaa)
- Joshua Bucklin (jdbucklin)
- Aida Keifer (aidakeifer)
- Jonathan Jensen (itsjonnyjyo)
- Yu Tang (27tang)
- Connor Delaplane (ConnorReilly)