- [Topic]
- MIDI
Common Music uses MIDI stream to support reading and writing MIDI data to to MIDI files, Portmidi and Midishare. Two levels of MIDI support are provided:
- A high level interface provides Lisp classes and methods for generating music to MIDI streams in non-real time mode.
- A low level interface implements "conless" midi messages that can be sent to, and received from an open Midiport or Midishare connection in real time without adding garbage to the Lisp heap.
High level MIDI support
High level MIDI support consists of class definitions of MIDI scores and events and functions that operate on them in non-real time. Note that non-real does not imply slower than real time -- the high level interface generates output many times faster than real time. High level support is documented by main entries in the Common Music dictionary, the following topic list provides links to this documentation:
MIDI event classes
- midi
- midi-note-on
- midi-note-off
- midi-key-pressure
- midi-control-change
- midi-program-change
- midi-channel-pressure
- midi-pitch-bend
- midi-system-event
- midi-sequence-number
- midi-text-event
- midi-eot
- midi-tempo-change
- midi-smpte-offset
- midi-time-signature
- midi-key-signature
- midi-sequencer-event
- midi-port-event
- midi-chan-event
MIDI score classes
MIDI functions
Low level MIDI support
Low level MIDI support provides functions for working with specially formatted unsigned fixnum values called midi messages. Common Music supports all of the message types defined in the MIDI 1.0 specification as well as those described in the MIDI Time Code and Cueing supplement.
MIDI Messages
A MIDI message is a specially formatted fixnum (28-30 bits) containing up to three 7-bit bytes of information. Each MIDI message is implemented by a constructor function, a predicate, and one or more field accessors. Some message types, such as System Exclusive and Meta messages, are implemented as composite data. Constructors for these types return two values: a message and a vector of message data bytes.
Message Utility Functions
- [Function]
- (- midi-copy-messagemsg {keyword value}*- )
Returns a copy of msg with fields altered according to keyword arguments.
midi-copy-message supports the
following keyword arguments:
Example 1. Copying MIDI messages.
 
Prints msg and an optional time value. Returns msg as its value.
 
Example 1. Printing MIDI messages.
 
Channel messages encode the performance information sent to particular
instruments on the synthesizer.
:opcode byte
:channel byte
:data1 byte
:data2 byte
Examples:
(define m1 (make-note-on 0 20 90))
(define m2 (midi-copy-message m1 :data1 73))
(midi-print-message m2)
#<Note-On 0 73 90>
⇒ 156890
(define m3 (midi-copy-message m2 :data1 73 :opcode #b1000 :data2 127))
(midi-print-message m3)
#<Note-Off 0 73 127>
⇒ 140543
(midi-print-message msg [time])Example:
(midi-print-message (make-note-on 0 60 90) )
#<Note-On 0 60 90>
⇒ 155226
(midi-print-message (make-note-off 9 60 90) 1000)
    1000 #<Note-Off P "hi-bongo" 90>
⇒ 2514522
(midi-print-message (make-program-change 2 45))
#<Program-Change 2 "pizzicato-strings">
⇒ 726656
(midi-print-message (make-control-change 0 +sustain+ 60))
#<Control-Change 0 "hold-1" 60>
⇒ 188476
Message Constructors, Predicates and Accessors
Channel Messages
All Channel Messages
(make-channel-message opcode channel data1 . data2)
(channel-message-p message)
(channel-message-channel message)
(channel-message-opcode message)
(channel-message-data1 message)
(channel-message-data2 message)Note-On
(make-note-on channel key velocity)
(note-on-p message)
(note-on-channel message)
(note-on-key message)
(note-on-velocity message)Note-Off
(make-note-off channel key velocity)
(note-off-p message)
(note-off-channel message)
(note-off-key message)
(note-off-velocity message
Key Pressure (Aftertouch)
- [Function]
- (- make-key-pressurechannel key pressure- )
- [Function]
- (- key-pressure-pmessage- )
- [Function]
- (- key-pressure-channelmessage- )
- [Function]
- (- key-pressure-keymessage- )
- [Function]
- (- key-pressure-pressuremessage- )
Control Change
- [Function]
- (- make-control-changechannel controller value- )
- [Function]
- (- control-change-pmessage- )
- [Function]
- (- control-change-channelmessage- )
- [Function]
- (- control-change-controllermessage- )
- [Function]
- (- control-change-valuemessage
Program Change
- [Function]
- (- make-program-changechannel program- )
- [Function]
- (- program-change-pmessage- )
- [Function]
- (- program-change-channelmessage- )
- [Function]
- (- program-change-programmessage- )
Channel Pressure
- [Function]
- (- make-channel-pressurechannel pressure- )
- [Function]
- (- channel-pressure-pmessage- )
- [Function]
- (- channel-pressure-channelmessage- )
- [Function]
- (- channel-pressure-pressuremessage- )
Pitch-Bend
- [Function]
- (- make-pitch-bendchannel lsb msb- )
- [Function]
- (- pitch-bend-pmessage- )
- [Function]
- (- pitch-bend-channelmessage- )
- [Function]
- (- pitch-bend-lsbmessage- )
- [Function]
- (- pitch-bend-msbmessage- )
System Messages
System messages are sent to the device (or each device in a daisy-chain), as opposed to a specific channel.
All System Messages
- [Function]
- (- make-system-messagetype route . data1 data2- )
- [Function]
- (- system-message-pmessage- )
- [Function]
- (- system-message-routemessage- )
- [Function]
- (- system-message-statusmessage- )
- [Function]
- (- system-message-data1message- )
- [Function]
- (- system-message-data2message- )
System Exclusive
A System Exclusive, or SysEx, message is a message that is specific to one vendor
or synthesizer. The first one or three data bytes of the sysex specifies the
vendor. The first one or three data bytes after the start
tag F0 of the sysex specifies the vendor.  If the
synthesizer recognizes this Manufacturer's ID as its own, it will
listen to the rest of the message.  Otherwise, the message will be
ignored.  System Exclusive is used to send bulk dumps such as patch
parameters and other non-spec data.
- [Function]
- (- make-sysexroute data- )
- [Function]
- (- sysex-pmessage- )
- [Function]
- (- sysex-routemessage
The make-sysex constructor returns two values, a message bitfield
indicating a system exclusive message and an array of system exclusive
data.  data must be either:
- A vector of unsigned bytes containing a full system exclusive message enclosed within FOandF7tags
- A polymorphous list of numbers, characters, strings, lists, vectors, or sequences of these, which will be used to construct the system exclusive message array.
MIDI Time Code Quarter Frame
- [Function]
- (- make-mtc-quarter-frameroute tag nibble- )
- [Function]
- (- mtc-quarter-frame-pmessage- )
- [Function]
- (- mtc-quarter-frame-routemessage- )
- [Function]
- (- mtc-quarter-frame-tagmessage- )
- [Function]
- (- mtc-quarter-frame-nibblemessage- )
Song Position
- [Function]
- (- make-song-positionroute lsb msb- )
- [Function]
- (- song-position-pmessage- )
- [Function]
- (- song-position-routemessage- )
- [Function]
- (- song-position-lsbmessage- )
- [Function]
- (- song-position-msbmessage- )
Song Select
- [Function]
- (- make-song-selectroute song- )
- [Function]
- (- song-select-pmessage- )
- [Function]
- (- song-select-routemessage- )
- [Function]
- (- song-select-songmessage- )
Cable Select
- [Function]
- (- make-cable-selectroute cable- )
- [Function]
- (- cable-select-pmessage- )
- [Function]
- (- cable-select-routemessage- )
- [Function]
- (- cable-select-cablemessage- )
Tune Request
- [Function]
- (- make-tune-requestroute- )
- [Function]
- (- tune-request-pmessage- )
- [Function]
- (- tune-request-routemessage- )
End of Sysex
- [Function]
- (- make-eoxroute- )
- [Function]
- (- eox-pmessage- )
- [Function]
- (- eox-routemessage- )
Timing Clock
- [Function]
- (- make-timing-clockroute- )
- [Function]
- (- timing-clock-pmessage- )
- [Function]
- (- timing-clock-routemessage- )
Timing Tick
- [Function]
- (- make-timing-tickroute- )
- [Function]
- (- timing-tick-pmessage- )
- [Function]
- (- timing-tick-routemessage- )
Start, Continue and Stop
- [Function]
- (- make-startroute- )
- [Function]
- (- start-pmessage- )
- [Function]
- (- start-routemessage- )
- [Function]
- (- make-continueroute- )
- [Function]
- (- continue-pmessage- )
- [Function]
- (- continue-routemessage- )
- [Function]
- (- make-stoproute- )
- [Function]
- (- stop-pmessage- )
- [Function]
- (- stop-routemessage- )
Active Sensing
- [Function]
- (- make-active-sensingroute- )
- [Function]
- (- active-sensing-pmessage- )
- [Function]
- (- active-sensing-routemessage- )
System Reset
- [Function]
- (- make-system-resetroute- )
- [Function]
- (- system-reset-pmessage- )
- [Function]
- (- system-reset-routemessage- )
Meta Messages
Meta messages store various sorts of non-event information for MIDI tracks and MIDI files. The meta message constructors return two values, a message and an array of unsigned bytes. Meta messages should not be sent to MIDI devices.
All Meta Messages
- [Function]
- (- make-meta-messagetype- )
- [Function]
- (- meta-message-pmessage- )
- [Function]
- (- meta-message-typemessage- )
Sequence Number
- [Function]
- (- make-sequence-numbernum- )
- [Function]
- (- sequence-number-pmessage- )
Text Event
- [Function]
- (- make-text-eventstring . type- )
- [Function]
- (- text-event-pmessage- )
- [Function]
- (- make-copyright-notestring- )
- [Function]
- (- copyright-note-pmessage- )
- [Function]
- (- make-sequence/track-namestring- )
- [Function]
- (- sequence/track-name-pmessage- )
- [Function]
- (- make-instrument-namestring- )
- [Function]
- (- instrument-name-pmessage- )
- [Function]
- (- make-lyricstring- )
- [Function]
- (- lyric-pmessage- )
- [Function]
- (- make-markerstring- )
- [Function]
- (- marker-pmessage- )
- [Function]
- (- make-cue-pointstring- )
- [Function]
- (- cue-point-pmessage- )
MIDI Channel
- [Function]
- (- make-midi-channelchannel- )
- [Function]
- (- midi-channel-pmessage- )
MIDI Port
- [Function]
- (- make-midi-portport- )
- [Function]
- (- midi-port-pmessage- )
End of Track
- [Function]
- (- make-eot- )
- [Function]
- (- eot-pmessage- )
Tempo Change
- [Function]
- (- make-tempo-changeusec- )
- [Function]
- (- tempo-change-pmessage- )
SMPTE Offset
- [Function]
- (- make-smpte-offsethours mins secs frames fractional-frames- )
- [Function]
- (- smpte-offset-pmessage- )
Time Signature
Denominator is a negative power of 2. clocks expresses the number of MIDI clocks per metronome click and 32nds the number of notated 32nd notes in a MIDI quarter note (i.e., 24 MIDI clocks). This event allows a program to relate what MIDI thinks of as a quarter to any desired value.
- [Function]
- (- make-time-signaturenumerator denominator . clocks 32nds- )
- [Function]
- (- time-signature-pmessage- )
Key Signature
Key is either a number between -7 and 7 representing the number of
  flats (-) or sharps (+) in the key signature or a note symbol such as 
c, cf, cs etc. indicating the tonic.  
  mode is either :major (the default) or :minor.
- [Function]
- (- make-key-signaturekey mode- )
- [Function]
- (- key-signature-pmessage- )
Sequencer Event
- [Function]
- (- make-sequencer-event. data- )
- [Function]
- (- sequencer-event-pmessage- )
MIDI Values
Common Music provides numerous constants and variables that symbolically encode common MIDI values such as program changes and controller values.
General MIDI (GM) Values
GM Program Changes
- Piano (0-7)
- +acoustic-grand-piano+ +bright-acoustic-piano+ +electric-grand-piano+ +honky-tonk-piano+ +electric-piano-1+ +electric-piano-2+ +harpsichord+ +clavi+
- Chromatic Percussion (8-15)
- +celesta+ +glockenspiel+ +music-box+ +vibraphone+ +marimba+ +xylophone+ +tubular-bells+ +dulcimer+
- Organ (16-23)
- +drawbar-organ+ +percussive-organ+ +rock-organ+ +church-organ+ +reed-organ+ +accordion+ +harmonica+ +tango-accordion+
- Guitar (24-31)
- +acoustic-guitar-nylon+ +acoustic-guitar-steel+ +electric-guitar-jazz+ +electric-guitar-clean+ +electric-guitar-muted+ +overdriven-guitar+ +distortion-guitar+ +guitar-harmonics+
- Bass (32-39)
- +acoustic-bass+ +electric-bass-finger+ +electric-bass-pick+ +fretless-bass+ +slap-bass-1+ +slap-bass-2+ +synth-bass-1+ +synth-bass-2+
- Solo strings (40-47)
- +violin+ +viola+ +cello+ +contrabass+ +tremolo-strings+ +pizzicato-strings+ +orchestral-strings+ +timpani+
- Ensemble (48-55)
- +string-ensemble-1+ +string-ensemble-2+ +synthstrings-1+ +synthstrings-2+ +choir-aahs+ +voice-oohs+ +synth-voice+ +orchestra-hit+
- Brass (56-63)
- +trumpet+ +trombone+ +tuba+ +muted-trumpet+ +french-horn+ +brass-section+ +synthbrass-1+ +synthbrass-2+
- Reed (64-71)
- +soprano-sax+ +alto-sax+ +tenor-sax+ +baritone-sax+ +oboe+ +english-horn+ +bassoon+ +clarinet+
- Pipe (72-79)
- +piccolo+ +flute+ +recorder+ +pan-flute+ +blown-bottle+ +skakuhachi+ +whistle+ +ocarina+
- Synth Lead (80-87)
- +lead-1-square+ +lead-2-sawtooth+ +lead-3-calliope+ +lead-4-chiff+ +lead-5-charang+ +lead-6-voice+ +lead-7-fifths+ +lead-8-bass+lead+
- Synth Pad (88-95)
- +pad-1-new-age+ +pad-2-warm+ +pad-3-polysynth+ +pad-4-choir+ +pad-5-bowed+ +pad-6-metallic+ +pad-7-halo+ +pad-8-sweep+
- Synth Effects (96-103)
- +fx-1-rain+ +fx-2-soundtrack+ +fx-3-crystal+ +fx-4-atmosphere+ +fx-5-brightness+ +fx-6-goblins+ +fx-7-echoes+ +fx-8-sci-fi+
- Ethnic (104-111)
- +sitar+ +banjo+ +shamisen+ +koto+ +kalimba+ +bagpipe+ +fiddle+ +shanai+
- Percussive (112-119)
- +tinkle-bell+ +agogo+ +steel-drums+ +woodblock+ +taiko-drum+ +melodic-tom+ +synth-drum+ +reverse-cymbal+
- Sound Effects (120-127)
- +guitar-fret-noise+ +breath-noise+ +seashore+ +bird-tweet+ +telephone-ring+ +helicopter+ +applause+ +gunshot+
GM Drum Map
The GM drum map on channel 9 (zero-based counting) maps key numbers 35-81 to the following sounds:
+acoustic-bass-drum+ +bass-drum-1+ +side-stick+ +acoustic-snare+ +hand-clap+ +electric-snare+ +low-floor-tom+ +closed-hi-hat+ +high-floor-tom+ +pedal-hi-hat+ +low-tom+ +open-hi-hat+ +low-mid-tom+ +hi-mid-tom+ +crash-cymbal-1+ +high-tom+ +ride-cymbal-1+ +chinese-cymbal+ +ride-bell+ +tambourine+ +splash-cymbal+ +cowbell+ +crash-cymbal-2+ +vibraslap+ +ride-cymbal-2+ +hi-bongo+ +low-bongo+ +mute-hi-conga+ +open-hi-conga+ +low-conga+ +high-timbale+ +low-timbale+ +high-agogo+ +low-agogo+ +cabasa+ +maracas+ +short-whistle+ +long-whistle+ +short-guiro+ +long-guiro+ +claves+ +hi-wood-block+ +low-wood-block+ +mute-cuica+ +open-cuica+ +mute-triangle+ +open-triangle+
Controller Values
The following standard controller and Registered Parameter Numbers (RPNs) are defined:
- Specific Coarse Controllers
- +bank-select+ +modulation-wheel+ +breath-control+ +foot-controller+ +portamento-time+ +data-entry+ +channel-volume+ +volume+ +balance+ +pan+ +expression-controller+ +effect-control-1+ +effect-control-2+ +general-purpose-controller-1+ +general-purpose-controller-2+ +general-purpose-controller-3+ +general-purpose-controller-4+
- Specific Fine Controllers
- +bank-select-fine+ +modulation-wheel-fine+ +breath-control-fine+ +foot-controller-fine+ +portamento-time-fine+ +data-entry-fine+ +channel-volume-fine+ +volume-fine+ +balance-fine+ +pan-fine+ +expression-controller-fine+ +effect-control-1-fine+ +effect-control-2-fine+ +general-purpose-controller-1-fine+ +general-purpose-controller-2-fine+ +general-purpose-controller-3-fine+ +general-purpose-controller-4-fine+
- Common Switches
- +sustain+ +portamento+ +sostenuto+ +soft-pedal+ +legato-footswitch+ +hold-2+
- Sound Controllers
- +sound-variation+ +sound-timbre+ +sound-release-time+ +sound-attack-time+ +sound-brightness+ +portamento-control+
- Level Controller
- +effects-level+ +tremolo-level+ +chorus-level+ +detune-level+ +phasor-level+
- Data Entry Step Controllers
- +data-entry-increment+ +data-entry-decrement+
- Parameter Number Selection
- +non-registered-parameter-number-fine+ +non-registered-parameter-number+ +registered-parameter-number-fine+ +registered-parameter-number+
- Channel Mode Messages
- +all-sound-off+ +reset-all-controllers+ +local-control+ +all-notes-off+ +omni-mode-off+ +omni-mode-on+ +poly-mode-on/off+ +poly-mode-on+
- Registered Parameter Numbers
- +rpn-pitch-bend-sensitivity+ +rpn-fine-tuning+ +rpn-coarse-tuning+ +rpn-reset+