Jump to content

MIDI

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Charlierichmond (talk | contribs) at 13:17, 24 October 2005. The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Musical Instrument Digital Interface, or MIDI, is an industry-standard electronic communication protocol that defines each musical note in an electronic musical instrument such as a synthesizer, precisely and concisely, allowing electronic musical instruments and computers to exchange data, or "talk", with each other. MIDI does not transmit audio - it simply transmits digital information about a music performance.

The MIDI Show Control (MSC) protocol (in the Real Time System Exclusive subset) is an industry standard ratified by the MIDI Manufacturers Association in 1991 which allows all types of media control devices to talk with each other and with computers to perform show control functions in live and canned entertainment applications.

Almost all music recordings today utilize MIDI as a key enabling technology for recording music. In addition, MIDI is also used to control hardware including recording devices as well as live performance equipment such as stage lights and effects pedals. Lately, MIDI has exploded onto the scene with its adoption into mobile phones. MIDI is used to play back the ringtones of MIDI capable phones. MIDI is also used to provide game music in some video games.

The MIDI standard was first proposed by Dave Smith in 1981 in a paper to the Audio Engineering Society and the MIDI Specification 1.0 was published in August 1983.

MIDI allows computers, synthesizers, sound cards and drum machines to control one another, and to exchange system information. Though modern computer sound cards are MIDI-compatible and capable of creating realistic instrument sounds, the fact that sound cards' MIDI synthesizers have historically produced sounds of dubious quality has tarnished the image of a general purpose computer as a MIDI instrument. This despite the fact that the MIDI specification itself has nothing to do with the quality of the sound produced which varies depending on the sound card used.

MIDI is almost directly responsible for bringing an end to the "wall of synthesizers" phenomenon in 1970s-80s rock music concerts, when musical keyboard performers were sometimes hidden behind banks of various instruments. Following the advent of MIDI, many synthesizers were released in rack-mount versions, enabling performers to control multiple instruments from a single keyboard. Another important effect of MIDI has been the development of hardware and computer-based sequencers, which can be used to record, edit and play back performances.

Synchronization of MIDI sequences is made possible by the use of MIDI timecode, an implementation of the SMPTE time code standard using MIDI messages, and MIDI timecode has become the standard for digital music synchronization.

A number of music file formats have been based on the MIDI bytestream. These formats are very compact; often a file of only 10 kilobytes can produce a full minute of music.

How MIDI works in a nutshell

How musical MIDI works

When any note is played by a musician, the musical instrument serially transmits one or more single byte binary numbers from its 'MIDI Out' port. These numbers depict MIDI messages. A typical MIDI message sequence is:

  1. the user just played a note
  2. the note just played was the middle C note
  3. the user just stopped playing a note
  4. the note that was just turned off was the middle C note

MIDI messages are transmitted at the rate of 31250 bits per second, where each bit would be translated into turning the current on if the bit is 0 or turning it off, if the bit is 1. Other performance parameters would also be transmitted, such as for example, if the pitch wheel was being turned, that information would also be transmitted using different MIDI messages. The musical instrument does this completely autonomously requiring only that the musician play a note (or do something else that generates MIDI messages).

All notes that a musical instrument is capable of playing are assigned specific MIDI messages according to what the note and octave are. For example, the Middle C note played on any MIDI compatible musical instrument will always transmit the same MIDI message from its 'MIDI Out' port. Which MIDI message and thus which binary digits will be transmitted upon playing of a certain note are defined in the MIDI specification and this comprises the core of the MIDI standard.

All MIDI compatible instruments follow the MIDI specification and thus transmit identical MIDI messages for identical MIDI events such as the playing of a certain note on the musical instrument. Since they follow a published standard, all MIDI instruments can communicate with and understand each other, as well as with computers which have been programmed to understand MIDI messages using MIDI-aware software. The MIDI interface, converts the current fluctuations transmitted by a MIDI musical instrument, into binary numbers that the receiving musical instrument or computer can process. All MIDI compatible instruments have a built-in MIDI interface. In addition, computer sound cards usually have a built-in MIDI interface - if not, it can be separately purchased as a card and easily installed.

The MIDI specification

Electrical connections

MIDI ports and cable.

The MIDI standard consists of a messaging protocol designed for use with musical instruments, as well as a physical interface standard. A physical MIDI connection consists of a one-way (simplex) serial current-loop connection running at 31,250 bits per second.

Only one end of the loop is referenced to ground, with the other end 'floating', to prevent ground loops from producing analog audio interference and hum. The current loop on the transmitter side drives the LED of an opto-coupler on the receiver side. This means the devices are in fact opto-isolated. The opto-coupler must be a high-speed type (the Sharp PC900 is very common). As most opto-couplers have asymmetrical switching times (delays for switching on are different from the delays when switching off), they distort the signal (the zero to one relations). If several MIDI devices are connected in series by daisy-chaining the MIDI-THRU to the next devices MIDI-IN, the signal gets more and more distorted (until receive errors happen because the pulses get too narrow).

MIDI connectors use standard 5-pin DIN connectors which at one time were a de facto European standard for consumer audio interconnection. Over time the simpler American RCA phono jack has replaced DIN in this application, leaving MIDI as the only place they are commonly encountered in modern equipment.

Message format

Each one-way connection (called a port) can transmit or receive standard musical messages, such as note-on, note-off, controllers (which include volume, pedal, modulation signals, etc.), pitch-bend, program change, aftertouch, channel pressure, and system-related messages. These signals are sent along with one of 16 channel identifiers. The channels are used to separate "voices" or "instruments", somewhat like tracks in a multi-track mixer.

The ability to multiplex 16 "channels" onto a single wire makes it possible to control several instruments at once using a single MIDI connection. When a MIDI instrument is capable of producing several independent sounds simultaneously (a multitimbral instrument), MIDI channels are used to address these sections independently. (This should not be confused with "polyphonic"; the ability to play several notes simultaneously in the same "voice".)

The MIDI protocol supports no more than 128 different instruments. To overcome the limitation, the concept of a "bank" was introduced - a collection of 128 instruments. The bank can usually be changed using a controller message, enabling access to many more instruments than normally possible.

Note messages can represent any note from C,,,, (i.e. five octaves below middle C or 8.175 Hz in common Western musical tuning; designated as MIDI note 0) to g''''' (i.e. five octaves above the G above middle C or 12,557 Hz; designated as MIDI note 127) with precision down to the semitone.

Pitch-bend messages range in ±2 semitones (sometimes adjustable with Registered Parameter Numbers), with precision of 1/8192 semitone. (The human hearing system can not hear the difference between adjacent pure tones that differ by less than 1/20 semitone.)

Controllers are quite versatile; they can usually be controlled by a musician using knobs, sliders, and footswitches on the instrument. They can be used to change the tone, timbre, and volume of the sound, as well as many others.

Program change messages are used to change the instrument of a particular channel to another instrument. These messages are necessary because as there are only 16 channels, only 16 instruments can be selected at one time, and so instruments can be changed in the middle of a song.

Aftertouch messages (also known as poly pressure messages) are sent in some instruments to indicate pressure changes on the note while it is being played. Similarly, channel pressure changes the pressure for the entire instrument, not just one note. The channel pressure messages are more commonly implemented in most synthesizers, while the individual pressure sensors that aftertouch messages require are reserved mainly for expensive, high-end synthesizers.

Manufacturer's System exclusive messages (also known as Manufacturer SysEx, Manuf Sysx, etc.) are defined by the manufacturer of the sequencer/synthesizer and can be any length. These messages are commonly used to send non-MIDI data over a MIDI connection, such as a synthesizer instrument sample or settings and a sequencer's memory dump. Because they are defined by the device's manufacturer, they are mainly used for backup purposes and rarely (if ever) useful in another MIDI device.

Real Time System Exclusive messages include the significant MIDI Show Control extension which enables all types of entertainment equipment to communicate with each other through the process of show control.

System messages contain meta-information about other MIDI messages. A sequencer, for example, often sends MIDI clock messages during playback that correspond to the MIDI timecode, so the device receiving the messages (usually a synthesizer) will be able to keep time. Also, some devices will send Active Sense messages, used only to keep the connection between the sender and the receiver alive after all MIDI communication has ceased.

It should be noted that MIDI can be used to provide facilities for playing in nonstandard musical tunings. However, these features are not standardized across all instruments.

IN, OUT, THRU

Most MIDI-capable instruments feature a MIDI-IN, MIDI-OUT, and occasionally a MIDI-THRU connection in the form of five-pin DIN plugs. In order to build a two-way physical connection between two devices, a pair of cables must be used. The MIDI-THRU jack simply echoes the signal entering the device at MIDI-IN. This makes it possible to control several devices from a single source.

Daisy chaining of multiple devices on a single port can be accomplished using the MIDI-THRU port. This technique is generally limited to three devices in a row due to latency. The latency is caused by the fact that MIDI-IN ports are optically isolated. Instead of making a physical connection to pass electrical signals, the electrical signals arriving at the MIDI-IN port turn an LED on and off, which is read by a photo sensor. This physical break in the flow of electricity prevents the forming of ground loops. It also introduces a small amount of latency. Generally after travelling through 3 devices in a daisy chain, this latency becomes noticeable.

The 1985 Atari ST was the first home computer to sport the original five-pin format — which made the ST a very popular platform for running MIDI sequencer software. Most PC soundcards from the late 1990's had the ability to terminate a MIDI connection (usually through a MIDI-IN/MIDI-OUT converter on the game port). The game port has been supplanted in the modern PC by USB devices, and so typically a PC owner will need to purchase a MIDI interface that attaches to the USB or FireWire port of their machine to use MIDI.

General MIDI

In MIDI, instruments (one per channel) are selected by number (0-127), using the Program Change message. However, the basic MIDI 1.0 specification did not specify what instrument sound (piano, tuba, etc.) corresponds to each number. This was intentional, as MIDI originated as a professional music protocol, and in that context it is typical for a performer to assemble a custom palette of instruments appropriate for their particular repertoire, rather than taking a least-common-denominator approach.

Eventually interest developed in adapting MIDI as a consumer format, and for computer multimedia applications. In this context, in order for MIDI file content to be portable, the instrument program numbers used must call up the same instrument sound on every player. General MIDI (GM) was an attempt by the MIDI Manufacturer's Association (MMA) to resolve this problem by standardizing an instrument program number map, so that for example Program Change 1 always results in a piano sound on all GM-compliant players. GM also specified the response to certain other MIDI messages in a more controlled manner than the MIDI 1.0 specification. The GM spec is maintained and published by the MIDI Manufacturer's Association (MMA).

From a musical perspective, GM has a mixed reputation, mainly because of small or large audible differences in corresponding instrument sounds across player implementations, the limited size of the instrument palette (128 instruments), its least-common denominator character, and the inability to add customized instruments to suit the needs of the particular piece. Yet the GM instrument set is still included in most MIDI instruments, and from a standardization perspective GM has proven durable.

Later, companies in Japan's Association for Musical Electronic Industry (sic) (AMEI) developed General MIDI Level 2 (GM2), incorporating aspects of the Yamaha XG and Roland GS formats, extending the instrument palette, specifying more message responses in detail, and defining new messages for custom tuning scales and more. The GM2 specs are maintained and published by the MMA and AMEI.

Later still, GM2 became the basis of Scalable Polyphony MIDI (SP-MIDI), a MIDI variant for mobile applications where different players may have different numbers of musical voices. SP-MIDI is a component of the 3GPP mobile phone terminal multimedia architecture, starting from release 5.

GM, GM2, and SP-MIDI are also the basis for selecting player-provided instruments in several of the MMA/AMEI XMF file formats (XMF Type 0, Type 1, and Mobile XMF), which allow extending the instrument palette with custom instruments in the Downloadable Sound (DLS) formats, addressing another major GM shortcoming.

Low bandwidth

MIDI messages are extremely compact, due to the low bandwidth of the connection, and the need for near real-time accuracy. Most messages consist of a status byte (channel number in the low 4 bits, and an opcode in the high 4 bits), followed by one or two data bytes. However, the serial nature of MIDI messages means that long strings of MIDI messages take an appreciable time to send, and many people can hear those delays, especially when dealing with dense musical information or when many channels are particularly active. "Running status" is a convention that allows the status byte to be omitted if it would be the same as that of the previous message, helping to mitigate bandwidth issues somewhat.

MIDI file formats

MIDI messages (along with timing information) can be collected and stored in a computer file system, in what is commonly called a MIDI file, or more formally, a Standard MIDI File (SMF). The SMF specification was developed by, and is maintained by, the MIDI Manufacturers Association (MMA). MIDI files are typically created using desktop/laptop computer-based sequencing software (or sometimes a hardware-based MIDI instrument or workstation) that organizes MIDI messages into one or more parallel "tracks" for independent recording and editing. In most but not all sequencers, each track is assigned to a specific MIDI channel and/or a specific General MIDI instrument patch. Although most current MIDI sequencer software uses proprietary "session file" formats rather than SMF, almost all sequencers provide export or "Save As..." support for the SMF format.

An SMF consists of one header chunk and one or more track chunks. There are three SMF formats; the format is encoded in the file header. Format 0 contains a single track and represents a single song performance. Format 1 may contain any number of tracks, enabling preservation of the sequencer track structure, and also represents a single song performance. Format 2 may have any number of tracks, each representing a separate song performance. Format 2 is not commonly supported by sequencers nor commonly found in the wild.

Large collections of SMFs can be found on the web, most commonly with the extension .mid. These files are most frequently authored with the assumption that they will be played on General MIDI players, but not always. Occasional unintended bad-sounding playback is the result.

MIDI-Karaoke (which uses the ".kar" file extension) files are an "unofficial" extension of MIDI files, used to add synchronized lyrics to standard MIDI files. Most SMF players do not display these lyrics, however numerous .kar-specific players are available. These often display the lyrics synchronized with the music in "follow-the-bouncing-ball" fashion, essentially turning any PC into a Karaoke machine.

Note: ".kar" files can often be played by SMF players if the filename extension is changed to ".mid".

The MIDI Manufacturer's Association has now defined a new family of file formats, XMF (eXtensible Music File), some of which package SMF chunks with instrument data in DLS format (Downloadable Sounds, also an MMA specification), to much the same effect as MOD files. The XMF container is a binary format (not XML-based).

MIDI usage and applications

Extensions of the MIDI standard

Although traditional MIDI connections work well for most purposes, in 1994 a new high-bandwidth standard, named ZIPI, was proposed to replace MIDI for professional purposes. ZIPI failed due primarily to lack of demand.

USB, Firewire and ethernet embeddings of MIDI are now commonly available, and in the long run MIDI over ethernet is likely to replace the old current loop implementation of MIDI, as well as providing the high-bandwidth channel that ZIPI was intended to provide.

In 1992 the MIDI Tuning Standard, or MTS, was ratified by the MIDI Manufacturers' Association. While support for this standard is not great, it is supported by some instruments and software; in particular the freeware program Timidity supports it. MTS uses three bytes, which can be thought of as a three-digit number base 128, to specify a pitch in logarithmic form. Use of MTS allows any midi file to be tuned in any way desired, something which can be accomplished using the freeware program Scala.

Beyond MIDI

The Open Sound Control or OSC protocol, devised by CNMAT, transcends some of MIDI's musical coding limitations, and is considered by some to be technically superior. OSC has been implemented in software like SuperCollider, Max/MSP, Csound, and ChucK, however at present few mainstream musical applications and no standalone instruments support OSC, making whole-studio interoperability problematic. It can run over ethernet connections. OSC is not owned by any private company, however it is also not maintained by any standards organization.

Yamaha has its mLAN standard, which is a variation on FireWire [1] that carries multiple MIDI message channels and multiple audio channels. mLAN is a proprietary protocol.

See also: New interfaces for musical expression

Other applications of MIDI

MIDI can also be used for applications other than music:

Any device built with a standard MIDI-OUT port should (in theory) be able to control any other device with a MIDI-IN port, providing that developers of both devices have the same understanding about the semantic meaning of all the transmitted MIDI messages. This agreement can come either because both follow the published MIDI specifications, or else because for non-standard functionality the message meanings are agreed upon by both manufacturers.

See also: Mobile phone ringtone, Sound font, Pulse-code modulation (PCM), show control

MIDI software

List of MIDI editors/sequencers
Software Platform Company Wikipage Company Website
Ableton Live Windows Mac www.ableton.com
Anvil Studio Windows www.anvilstudio.com
Click MusicalKEYS Windows www.bapuli.co.nr
Cubase Windows Mac
(also previously for Atari ST)
Steinberg www.steinberg.net
Digital Performer Mac Mark of the Unicorn (MOTU) www.motu.com
FL Studio Windows Image-Line Software www.flstudio.com
GNMIDI:MIDI utilities Windows www.gnmidi.com
JAZZ++ Jazzware
Logic Windows Mac Apple/Emagic www.apple.com
MidiNotate Composer
Midisoft Windows www.midisoft.com
MusE Linux
Noteworthy Composer Windows Noteworthy Software www.noteworthysoftware.com
PowerTracks Windows PG Music www.pgmusic.com
Pro Tools Windows Mac Digidesign www.digidesign.com
Rosegarden Linux (GPL open source)
Seq24 Linux (GPL open source)
Sonar Windows Cakewalk www.cakewalk.com
Timidity Linux freesource
List of MIDI show control (MSC) programs
Software Platform Company Wikipage Company Website
ShowMan Windows www.richmondsounddesign.com

Also see

Magazines

Multimedia

  • HamieNET - library of over 23,000 MIDI/free online-based MIDI to MP3 converter
  • VGMusic - library of over 20,000 MIDI of sequenced music from game consoles
  • Laura's MIDI Heaven! - library of over 14,000 MIDI sequenced music in many categories