Dx7 Patches

  1. Original Dx7 Patches
  2. Dx7 Patches
  3. Dx7 Patches Free Download
  4. Dx7 Patches Collection

OPSIX is Korg’s latest innovative 6-operator FM Synthesizer of the next generation also supports patches of the legendary Yamaha DX7. How it works, you will find out here.

Bank 1 is electric piano and bell sounds (the DX7's calling card). Bank 2 is plucks, basses, and brass. Bank 3 is strings, pads, and everything else that didn't fit any of the other categories. Some of the patch names have been modified somewhat to better match the ones around them.

  • Ted Felix's dx7 utility then helped convert the sysex information into something I could read, which I then parsed with a file included in a different branch of this repository. Organization The original files came in banks of 32 patches each.
  • A selection of patches for the DX7 synthesizer. Contribute to jphaenlin/DX7-patches development by creating an account on GitHub.

Korg released the OPSIX this week with a big bang. It’s a kind of next-generation FM Synthesizer with significantly more sound design freedom than in classic DX synthesizers. Most of the questions that came up at the start: Can the OPSIX DX7 import and read patches.

Dx7

The most important questions that came up at the start went back to the DX7. How close does it sound and can we import/read DX7 patches. I can say YES to the second question. You can import/read them, but they don’t sound like in the original.

Korg OPSIX DX7 Patches

To load DX7 patches onto the OPSIX you don’t need much: the OPSIX, a USB cable, and a SysEx Librarian software for PC & Mac. Once connected, your computer recognizes the OPSIX as a Generic USB MIDI sound device and then you are ready to go. Attention: the OPSIX can only read DX7 patches of the first generation, so no sounds from the Yamaha DX7 II, etc. Further, you can only transfer patches in a bank of 32 patches, not individually.

Before you transmit a bank, you need to select a init sound in the browser. When this is done, you start the transfer process from your SysEx Librarian software. Once done, an indication appears in the OPSIX whether you want to transfer the sounds and where you want to save them. It’s already done. And your OPSIX is richer by 32 new DX7 sounds.

The exciting thing now: you can use this as a template to design new sounds. Perfect for musicians who are new to FM synthesis and don’t want to get lost in programming. An algorithm change, a filter, some effects can be used on a classic DX7 sound. Here the whole process and some sound examples also as a video.

Korg OPSIX Vs. Yamaha DX7

Two Japanese synthesizer worlds meet in one device. But does one sound like the original? No, they don’t. Even if the OPSIX is a more modern FM engine with significantly more features, it comes close to the DX7. Thanks to the Sine 12Bit waveform, which is automatically selected during DX7 import, the sounds have a vintage sound.

Anyone looking for a Synthesizer like the legendary Yamaha instrument is wrong here. You should use this function above all to load sound templates that can be transformed into new sounds. The huge selection of features in OPSIX invites you to do this. Personally, I love this functionality and I don’t need the character of the DX7. For me, it’s more a good starting point for new sounds.

Korg OPSIX will be available soon for 799€ worldwide.

Original Dx7 Patches

More information here: Korg

Available for pre-order at our partner

Ted Felix

I finally got myself a DX7. The story begins for me back in High School in 1985. The keyboardist in a band I was in had a DX7 and left it at my house for a weekend along with the manual. I started programming it and was hooked. Haven't touched one since then. Fast forward to August 2012, and I own one. Bought it locally via Craigslist. Only one previous owner (and his father). Came with a TSA approved case and a two bank RAM cartridge. And, unfortunately, a finicky E! Grey Matter Response upgrade.

E! Problems

The keyboard worked fine at first, although it seemed strange that the last half (patches 17-32) of a couple of the banks in the internal E! memory had garbage in them. I figured it was just a fluke, so I backed up the banks and then filled them back up with the factory ROMs. This seemed to work fine. But then after letting the keyboard sit for a few days, I turned it on and the last half of several of the banks was garbage. Time to take it apart and see what's going on.

The previous owner had had it worked on to replace the battery. I'm guessing the battery wasn't actually bad. Instead, the memory was going just like it was for me. Turns out the E! card was not fully seated into the main board. In fact, the design of the E! card precludes it being fully seated. The pins aren't long enough to be inserted completely into the ROM socket on the mainboard and this lifts the pins that go into the SRAM socket. I haven't come up with a clever solution for this yet.

Additional symptoms of a loose E! board are mainly refusal to boot with displays ranging from '88' on the LED display and a row of blocks across the LCD to random segments lighting on the LED display.

Going Back To Stock

I decided to revert back to the original stock setup, but this DX7 didn't come with its original pre-E! chips. Fortunately, there are plenty of resources for DX7 repair on the Internet. Installing the E! card requires pulling IC14 and IC21. So, going back to stock means replacing them.

IC14 - Firmware ROM

IC14 turns out to have been a Toshiba TMM24128AP (16Kx8bit ROM). On ebay you can find folks selling a 'Special Edition' (SER-7) version of this ROM for the DX7. I also found that a .bin file of the original DX7 ROM (v1.8) is available in the YamahaDX Yahoo group's file collection. If you ask nicely, one of the ROM sellers on ebay will be more than happy to burn that .bin image to a ROM for you. I now have both the SER-7 special edition ROM and the original v1.8 DX7 ROM.

IC21 - Static RAM

IC21 is one of the three SRAM chips on the mainboard that comprise the internal memory. It is a Mitsubishi M5M5118P-15L (2Kx8bit SRAM). These can be found on ebay for around $10. I got one on ebay and it is working perfectly.

Reboot

At power on, the DX7 realized its static RAM was filled with garbage so it prompted for a cart to be inserted. Apparently it will initialize itself from a cart after the battery is replaced. Unfortunately, the only cart I had was E! formatted, so it didn't recognize it. Always be prepared with a cart when replacing the battery. It turned out that bank B on my RAM cart was properly DX7 formatted, so I copied that into the internal memory and all was fine. I probably could have initialized it from MIDI also, but I didn't try that.

Success

Now my DX7 works perfectly. The two-bank memory card that I have is more than enough to allow me to load up banks from the Internet, pick the best voices, and copy them to the memory card. When a memory card bank is full, I copy back to the internal memory and dump to the computer for backup. With the original chips in place, I've had no trouble at all with the DX7. Occasionally, a bank from the Internet will crash it. Also, it has trouble handling certain MIDI messages. But then the DX7 MIDI implementation was always a bit weak as it predated the MIDI standard.

Sysex And Patches

The DX7 can transfer patches back and forth via sysex. See page 56 in the manual for instructions for configuring the DX7 to send/receive. (Function 8, set MIDI channel to 1, and SYSINFO to AVAIL. Then turn off memory protection for internal memory. Make sure you back it up first.) There are many tools for transferring sysex to/from a computer. In Linux, amidi is the command line tool for this. Here's how to send a .syx file:

When using amidi to receive sysex data, I noticed an extraneous 3 bytes on the front of the file (B0 60 7F). I think this is me pressing the OK button on the DX7 to start the transfer. I remove the three bytes with ghex, and the bank works fine. Using tail works fine too:

Originally I was using 'cat' to record sysex in Linux. This turns out to be a bad idea as it captures the 'Active Sensing' (keep-alive) FE bytes on the line. I used a hex editor (ghex) to remove the FE bytes from the front and end of the sysex dumps. This leaves me with a 4104 byte file for each bank. amidi does not have this problem so I recommend avoiding cat.

dx7dump

My little command line utility for Linux will turn a DX7 sysex dump into something you can read at the dinner table. Sure could've used this back in 1985...

dx7dump - Formats DX7 sysex files into human readable text.

Sample output:

The parameters are organized the same way they are on the DX7's front panel. This makes it easy to enter a patch from this listing. Only one parameter is on each line to make it easier to compare patches using diff (or meld). A more vertically compact format could be developed. Feel free to branch and develop.

'Not enough bytes' - If you build dx7dump in Windows, you'll likely see this message. This is because Microshaft's C 'standard' library opens files in 'text mode' which translates any CRLF's it finds into LF's, thus making the file smaller (and completely trashing it in the process). It also stops reading when it encounters the first 0x1A (Ctrl-Z, end of file). The fix is to link in binmode.obj which defaults fopen() to opening files in binary mode. (One could also change the fopen() mode to 'rb' or use _set_fmode(_O_BINARY). Since 'b' is explicitly ignored in Linux, we can probably go with it.)

Velocity Sensitivity

I've come to the conclusion that the velocity sensitivity on the DX7 is quite poor. Yamaha appears to agree with me as their ROM patches generally have the velocity sensitivity set to 3 or less. I assume the issue is the age of the technology. In 1983 there was a limit to how fast you can scan a keyboard. That limit translates into reduced velocity sensitivity. However, I think that with a velocity curve that better matched the numbers coming from the keyboard, the DX7 might have performed better. As it is, setting the velocity beyond 3 seriously reduces the output range of an operator.

A quick count of the number of operators on each ROM that use a specific velocity reveals that my suspicion is correct. Velocities above 3 are of limited value. Of the 797 operators with a velocity of 1 or greater, the majority (559 or 70.1%) use a velocity between 1 and 3.

This chart shows a count of the operators that use a specific velocity value in each of the Yamaha factory ROMs.

VelocityROM 1AROM 1BROM 2AROM 2BROM 3AROM 3BROM 4AROM 4BTotal
0908795136795988105739
12828351519183421198
23630261728392631233
3132011917261715128
42756152881081
55272868139
64211751122
71416126191110896

Note the spike at velocity 7. It would be interesting to track those patches down and find out how those 7's are used.

Patch Editors?

I need to track down a good patch/bank editor. Especially now that I only have three total banks of memory without the E! upgrade. Some to try:

JSynthLib sounds the most promising right now. Although its UI is a bit hard to get used to. It's free (as in GPL) and cross-platform (as in Java, hence the 'J').

FM-Alive's DXM3 is a patch editor for Windows for a fee.

Links

SER-7 Info - Direct from Yamaha. You can still order these on ebay.

Dx7 Patches

Dave Benson's DX7 Page - Great starting point. Manuals, sounds, etc...

Yahoo's YamahaDX Group - Lots of info and files and folks to talk to. This is where you'll find the ROM image for IC14.

Steve Sims - DX7 Rhodes patch is fantastic.

Hexter - Excellent DX7 emulator for Linux. Plays the real patches and sounds like the real thing.

Bristol - DX7 (and others) emulator for Linux. Really nifty as it brings the parameters to the front panel as knobs, making programming and experimenting really easy. This is not a complete DX7 simulation, but it is fun to play with. It's a tad buggy. Would be nice if they would use hexter as the backend.

Dx7

Native Instruments' FM8 - Professional FM synth for Windows. Pretty pricey.

Dx7 Patches Free Download

Dexed

<- Back to my Technology page.

Dx7 Patches Collection

Copyright ©2012, Ted Felix.Disclaimer