Yamaha OPL

From Wikipedia, the free encyclopedia
  (Redirected from Yamaha YM3812)
Jump to navigation Jump to search
Yamaha YM3526

The OPL (FM Operator Type-L) series were developed by Yamaha as low-cost sound chips providing FM synthesis for use in computer applications.

Chips in the series[edit]

OPL[edit]

The YM3526 was the first in the OPL family, providing a nine channel, two operator synthesizer. It was notably used in a Commodore 64 expansion, the Sound Expander, as well as several arcade games, such as Terra Cresta and Bubble Bobble.

A very closely related chip is the Y8950, or MSX-AUDIO, which was used as an MSX expansion. It is essentially a YM3526 with ADPCM recording and playback capability.

The circuit has 244 different write-only registers. It can produce 9 channels of sound, each made of two oscillators or 6 channels with 5 percussion instruments available. Each oscillator can produce sine waves which may also be modified into 3 other waveforms – the negative part of the sine can be muted or inverted, and pseudo sawtooth waves (¼ sine waves upward only with silent sections in between) can also be produced. This odd way of producing waveforms give the YM3812 a characteristic sound. Each wave generator has its own ADSR envelope generator. Its main method of synthesis is frequency modulation synthesis, accomplished via phase modulation of the phase of one channel's oscillators by the output of another.

YM3812 oscillator waveforms

Internal operation[edit]

The internal operation of the chip is completely digital. Each FM-tone is generated by a digital oscillator using a form of direct digital synthesis. A low-frequency oscillator and an envelope generator drive an FM operator to produce floating-point output for the DAC. Decapsulation of the chip shows two look-up tables, one for calculating exponents and one for log-sine.[1] This allows the FM operator to calculate its output without any multipliers, using the formula and two 256-entry look-up tables. Both tables are stored as pairs of values rounded to the nearest whole number, with the second value represented as the difference between it and the first value.

A quarter of the log-transformed sine waveform is stored as a sampled approximation in a 256-word read-only memory (ROM) table, computed by for values of 0 to 255. The rest of the sine-waveform is extrapolated via its property of symmetry. Scaling the output of an oscillator to a wanted volume would normally be done by multiplication, but the YM3812 avoids multiplications by operating on log-transformed signals, which reduces multiplications into computationally cheaper additions.[2]

Another 256-word ROM stores the exponential function as a lookup table, used to convert the logarithmic scale signal back to linear scale when required, as the final stage where the oscillator-outputs are summed together (just prior to the DAC-output bus), with the modulator waveform always delayed by one sample before the carrier waveform.[3] This table is computed by for values of 0 to 255. To compute the exponent, 1024 is added to the value at the index given by the least significant byte of input; this becomes the significand and the remaining bits of input become the exponent of the floating point output.

The YM3812's output, a sequence of floating point numbers clocked at a sampling frequency of approximately 49716 Hz, is sent to a separate digital-to-analog converter (DAC) chip, the YM3014B.

Overview of a channel's registers:

For the whole channel:

  • Main frequency (10 bits)
  • Octave (3 bits)
  • Note on/off
  • Synthesis mode (FM or just additive)
  • Feedback (0–7, the modulator modulating itself)

For each one of the 2 oscillators:

  • Frequency multiply (can be set to ½, 1 to 10, 12 or 15)
  • Waveform (Sine, half-sine, absolute-sine, quarter-sine)
  • Volume (0–63, logarithmic)
  • Attack, Decay, Sustain, Release (4 bits each, logarithmic)
  • Tremolo (On or off)
  • Vibrato (On or off)
  • Sustain (On or off)
  • Envelope scaling per key (On or off)
  • Volume scaling per key (0–3)

There are also a few parameters that can be set for the whole chip:

  • Vibrato depth
  • Tremolo depth
  • Percussion mode (uses 3 channels to provide 5 percussion sounds)
  • Composite sine mode (see Sinewave synthesis)

OPL2[edit]

An audio sample of music written for and played on YM3812

Yamaha created the YM3812, also known as the OPL2, in 1985. It saw wide use in IBM PC-based sound cards such as the AdLib, Sound Blaster and Pro AudioSpectrum (8bit),[4] as well as several arcade games by Nichibutsu, Toaplan and others.


The OPL2 is backwards compatible with the YM3526, only adding 3 new waveforms. Another related chip is the YM2413 (OPLL), which is a cut down version.

OPL3[edit]

Yamaha YMF262 (year 1994)
decapsulated YMF262 with die surface visible
Decapsulated YMF262, showing the die surface

An upgraded version of the OPL2, the Yamaha YMF262 (OPL3), was used in a number of IBM PC soundcards including Sound Blaster 16 and Pro AudioSpectrum (16bit).

The YMF262 improved upon the feature-set of the YM3812, adding the following features:[5]

  • twice as many channels (18 instead of 9)
  • simple stereo (hard left, center or hard right)
  • 4 channel sound output
  • 4 new waveforms (alternating-sine, "camel"-sine, square and logarithmic sawtooth)
  • 4 operator mode, pairing 2 channels together to create up to six 4 operator FM voices
  • reduced latency for host-register access (the OPL2 had much longer I/O access delays)
  • subtle differences in the sine-wave lookup table and envelope generator to YM3812 (e.g. the modulator waveform on YM3812 is delayed by one sample, whereas both carrier and modulator waveforms on OPL3 are properly synchronized)[6]

YMF262 also removed support for the little-used CSM mode, featured on YM3812 and YM3526.[6]

The YMF262's FM synthesis mode is configurable in different ways:[5]

  • Its basic mode provides 18 two-operator FM channels.
  • One setting, common to the OPL line, converts 3 of the FM channels into a 5-channel percussion set.
  • Another setting, introduced with this chip, causes 12 of the channels to be paired up into six four-operator channels. This trades in polyphony for more complex sound formation.
  • The two settings can be used separately or in conjunction, resulting in four total modes:
    • 18 2-operator channels
    • 15 2-operator channels + 5 drum channels (drum setting on)
    • 6 2-operator channels + 6 4-operator channels (4-op setting on)
    • 3 2-operator channels + 6 4-operator channels + 5 drum channels (both settings on)

Like its predecessor, the OPL3 outputs audio in digital-I/O form, requiring an external DAC chip like the YAC512.

Competing sound chip vendors (such as ESS,[7] OPTi,[8] Crystal[9] and others) designed their own OPL3-compatible audio chips, with varying degrees of faithfulness to the original OPL3.

Yamaha YMF289[edit]

A comparison of the outputs of Yamaha's YMF262 and YMF289 FM sound chips. 0:00 is YMF262, and 0:31 onward is YMF289.

Yamaha also produced a fully compatible, low-power variant, the YMF289 OPL3-L, which targeted PCMCIA sound cards and laptop computers.[10] It was used in some Sound Blaster 16 sound cards made by Creative Technology. The YMF289B is paired with a YAC513 or YAC516 companion floating-point DAC chip.

The YMF289 is fully register-compatible with and retains the feature-set of the YMF262, with a number of differences:[10]

  • Supports 5 or 3.3 volt operation.
  • The registers can be read or written by the host CPU, whereas on the YMF262 they are write-only.
  • 44100 Hz (44.1 kHz) output sample rate.
  • A power-down mode is added.
  • Somewhat smaller overall footprint, including DAC, compared to a full YMF262 implementation.
  • 33.868 MHz input clock, compared to the 14.32 MHz input clock used for the YMF262.
  • Internal linear interpolator.

ESS ESFM[edit]

ESFM's output under Legacy / OPL3-compatible mode demonstrates some tangible differences in the way some sounds are synthesized.

ESS Technology's in-house developed derivative, termed ESFM, is an enhanced, 20-voice, 72-operator, OPL3-compatible clone incorporating two operating modes, a Native mode and a Legacy mode, which controls its feature-set and behavior.[7] In Native mode, ESFM allows more than six 4-operator FM voices to be mapped, potentially allowing for a significant increase in the complexity of tones generated. The drivers for Windows 9x incorporate their own custom instrument patches which make use of this extended mode. Conversely, Legacy mode provides full backward-compatibility with Yamaha's YMF262.[7] ESFM's output in this mode is moderately faithful to the YMF262 overall, but some tones are rendered quite differently, resulting in unique distortions in the sound and music of some games.

ESFM is available in ESS sound chips starting with the ISA-based ES1688 AudioDrive, up to the PCI-based ES1938 Solo-1, whereas earlier chips required an external FM synthesizer chip (typically a Yamaha YMF262). ESS's Maestro series of PCI-based sound chips rely on a software implementation of FM synthesis that lacks ESFM's special features.

OPL4[edit]

Yamaha's later PC audio controllers, including the YMF278 (OPL4), the single-chip Yamaha YMF718/719S, and the PCI YMF724/74x family, included the YMF262's FM synthesis block for backward compatibility with legacy software. See YMF7xx for more information.

Products using the OPL Series[edit]

The YMF262 was used in many sound cards, including the popular Sound Blaster Pro 2, Sound Blaster 16 ASP[11]. Later models of the Sound Blaster 16 and Sound Blaster AWE series integrated the OPL3 with other chips. In the final model Creative Labs used an OPL3 clone chip, the CQM, integral with other chips.[12] It was used in the Pro AudioSpectrum (16bit).[11]

Synthesizers[edit]

Synthesizers that use the YM3812:[13]

  • Yamaha PSR-11 49-keys 16-sounds (1986)
  • Yamaha PSR-12 49-keys 32-sounds (1987)
  • Yamaha PSR-21 49-keys 16-sounds, 2 steps sliders (1986)
  • Yamaha PSR-22 49-keys 32-sounds, 2 steps sliders (1987)
  • Yamaha PSR-31 61-keys 16-sounds, additional YM3301 chip[14] for drums (1991)
  • Yamaha PSR-32 61-keys 32-sounds, additional YM3301 chip[14] for drums (1987)
  • Yamaha PSS-360 49 mini-keys 21-sounds, 5 steps sliders, low-cost mono version of PSS-460 (1986)
  • Yamaha PSS-460 49 mini-keys 21-sounds, 5 steps sliders (1986)
  • Yamaha PSS-470 49 mini-keys 21-sounds, 5 steps sliders (1987)
  • Yamaha PSS-560 49 mini-keys 21-sounds, 5 steps sliders, additional YM3301 chip[14] for drums (1986)
  • Yamaha PSS-570 49 mini-keys 21-sounds, 5 steps sliders, additional YM3301 chip[14] for drums (1987)

Synths that use the YM2413 (cost reduced YM3812):[13]

  • Yamaha PSR-6 49-keys 100-sounds (1994)
  • Yamaha PSS-140 37 mini-keys 100-sounds (1988)
  • Yamaha PSS-170 44 mini-keys 100-sounds (1986)
  • Yamaha PSS-270 49 mini-keys 100-sounds (1986)

Variants and Derivatives[edit]

In 2015 an open-source RTL implementation of the OPL3 was written in SystemVerilog and adapted to an FPGA.[15]

See also[edit]

References[edit]

  1. ^ http://yehar.com/blog/?p=665
  2. ^ https://docs.google.com/document/d/18IGx18NQY_Q1PJVZ-bHywao9bhsDoAqoIn1rIm42nwo/
  3. ^ http://dev.kewl.org/misc/ymf262/ymf262.c
  4. ^ https://www.youtube.com/watch?v=z3DU2mNBa6M&t=10m11s
  5. ^ a b https://web.archive.org/web/20030520163334/http://www.fit.vutbr.cz/~arnost/opl/lost+found/ymf262.pdf
  6. ^ a b http://dev.kewl.org/misc/ymf262/ymf262.c
  7. ^ a b c ftp://ftp.alsa-project.org/pub/manuals/ess/DS1878A.PDF
  8. ^ http://www.datasheets360.com/pdf/-97977721078553128
  9. ^ http://gd.tuwien.ac.at/linux/alsa/datasheets/cirrus/4236b.pdf
  10. ^ a b http://doc.chipfind.ru/pdf/yamaha/ymf289b.pdf
  11. ^ a b https://www.youtube.com/watch?v=z3DU2mNBa6M&t=10m11s
  12. ^ http://www.flaterco.com/kb/audio/ISA/index.html
  13. ^ a b "Meet the little-known "Soundblaster" Keyboards". The 8-Bit Guy, Youtube. Retrieved 19 August 2015.
  14. ^ a b c d "Edward D-tech, Yamaha Chips, YM series". Edward D-tech. Archived from the original on 16 May 2016. Retrieved 25 January 2016.
  15. ^ https://github.com/gtaylormb/opl3_fpga

External links[edit]