You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
soyer 0f7f8f45e4
pass strings by const reference and use find_last_not_of (#779)
1 week ago
.github/workflows retention-days: 3 # To not exceed the free MB/month quota so quickly 3 weeks ago
CMSIS_5@8a64562247 Support for Yamaha DX7 SysEx commands (#195) 3 years ago
Synth_Dexed@8c677ceb4b Support for Yamaha DX7 SysEx commands (#195) 3 years ago
circle-stdlib@61cf3a47bf Multi-core support (#47) 3 years ago
hwconfig Add hardware configuration for genXnoise devices (#768) 3 weeks ago
src pass strings by const reference and use find_last_not_of (#779) 1 week ago
.gitignore Ship example minidexed.ini files for various devices (#754) 2 months ago
.gitmodules Only small changes for README.md, so images for RPi2/RPi3 can now created alsoOnly small fixes. (#44) 3 years ago
README.md Fix typo [ci skip] 2 months ago
USBID.sh Add USB Gadget Device support (#567) 1 year ago
build.sh Set USB Gadget name to MiniDexed and fix setting of USB product (device) ID. Fixes #416 (#593) 1 year ago
getsysex.sh Update getsysex.sh (#602) 1 year ago
submod.sh Add support for 8 channel I2S mono audio output on RPi 5 (#657) 7 months ago

README.md

MiniDexed Github Build Status

minidexed

MiniDexed is a FM synthesizer closely modeled on the famous DX7 by a well-known Japanese manufacturer running on a bare metal Raspberry Pi (without a Linux kernel or operating system). On Raspberry Pi 2 and larger, it can run 8 tone generators, not unlike the TX816/TX802 (8 DX7 instances without the keyboard in one box). Featured by HACKADAY, Adafruit, The MagPi magazine (Issue 142 June 2024, PDF) and Synth Geekery.

Demo songs

Listen to some examples made with MiniDexed by Banana71 here.

Features

  • Uses Synth_Dexed with circle-stdlib
  • SD card contents can be downloaded from GitHub Releases
  • Runs on all Raspberry Pi models (except Pico); see below for details
  • Produces sound on the headphone jack, HDMI display or audio extractor (better), or a dedicated DAC (best)
  • Supports multiple voices through Program Change and Bank Change LSB/MSB MIDI messages
  • Loads voices from .syx files from SD card (e.g., using getsysex.sh or from Dexed_cart_1.0.zip)
  • Menu structure on optional HD44780 display and rotary encoder
  • Runs up to 8 Dexed instances simultaneously (like in a TX816) and mixes their output together
  • Allows for each Dexed instance to be detuned and stereo shifted
  • Allows to configure multiple Dexed instances through performance.ini files (e.g., converted from DX1, DX5, TX816, DX7II, TX802)
  • Compressor effect
  • Reverb effect
  • Voices can be edited over MIDI, e.g., using the synthmata online editor (requires additional hardware)

Introduction

Video about this project by Floyd Steinberg:

YouTube Video about MiniDexed (Floyd Steinberg)

System Requirements

  • Raspberry Pi 1, 2, 3, 4, or 400. Raspberry Pi Zero and Zero 2 can be used but need HDMI or a supported i2s DAC for audio out. On Raspberry Pi 1 and on Raspberry Pi Zero there will be severely limited functionality (only one tone generator instead of 8)
  • Raspberry Pi 5 can be used but currently support is experimental: HDMI sound and USB Gadget mode are not available yet, and it is not clear if there are implications for cooling from running MiniDexed. Also, MiniDexed is currently not taking advantage of the higher processing power of the Raspberry Pi 5 yet. Hence, you may consider using one of the less expensive, older Raspberry Pi boards for your first build.
  • A PCM5102A or PCM5122 based DAC, HDMI display or audio extractor for good sound quality. If you don't have this, you can use the headphone jack on the Raspberry Pi but on anything but the Raspberry 4 the sound quality will be seriously limited
  • Optionally (but highly recommended), an LCDC1602 Display (with or without i2c "backpack" board) and a KY-040 rotary encoder

Usage

  • In the case of Raspberry Pi 4, Update the firmware and bootloader to the latest version (not doing this may cause USB reliability issues)
  • Download from GitHub Releases
  • Unzip
  • Put the files into the root directory of a FAT32 formatted partition on SD/microSD card (Note for small SD cards which are no longer sold: If less than 65525 clusters, you may need to format as FAT16.)
  • Put SD/microSD card into Raspberry Pi 1, 2, 3 or 4, or 400 (Zero and Zero 2 can be used but need HDMI or a supported i2c DAC for audio out)
  • Attach headphones to the headphone jack using SoundDevice=pwm in minidexed.ini (default) (poor audio quality)
  • Alternatively, attach a PCM5102A or PCM5122 based DAC and select i2c sound output using SoundDevice=i2s in minidexed.ini (best audio quality)
  • Alternatively, attach a HDMI display with sound and select HDMI sound output using SoundDevice=hdmi in minidexed.ini (this may introduce slight latency)
  • Attach a MIDI keyboard via USB (alternatively you can build a circuit that allows you to attach a "traditional" MIDI keyboard using a DIN connector, or use a DIN-MIDI-to-USB adapter)
  • If you are using a LCDC1602 with an i2c "backpack" board, then you need to set LCDI2CAddress=0x27 (or another address your i2c "backpack" board is set to) in minidexed.ini
  • Boot
  • Start playing
  • If the system seems to become unresponsive after a few seconds, remove usbspeed=full from cmdline.txt and repeat (details)
  • Optionally, put voices in .syx files onto the SD card (e.g., using getsysex.sh)
  • See the Wiki for Menu operation
  • For voice programming, use any DX series editor (using MIDI sysex), including Dexed
  • For library management, use the dedicated MiniDexedLibrarian software
  • If something is unclear or does not work, don't hesitate to ask!

Pinout

All devices on Raspberry Pi GPIOs are optional.

Raspberry Pi Pinout/GPIO Diagram

Please see the wiki for more information.

Downloading

Compiled versions are available on GitHub Releases. Just download and put on a FAT32 formatted SD card.

Building

Please see the wiki on how to compile the code yourself.

Contributing

This project lives from the contributions of skilled C++ developers, testers, writers, etc. Please see https://github.com/probonopd/MiniDexed/issues.

Discussions

We are happy to hear from you. Please join the discussions on https://github.com/probonopd/MiniDexed/discussions.

Documentation

Project documentation is at https://github.com/probonopd/MiniDexed/wiki.

Acknowledgements

This project stands on the shoulders of giants. Special thanks to:

Stargazers over time

Stargazers over time