midinoteonoct is designed to simplify writing instruments that can be used interchangeably for either score or MIDI input, and to make it easier to adapt instruments originally written for score input to work with MIDI input.
In general, it should be possible to write instrument definitions that work identically with both scores and MIDI, including both MIDI files and real-time MIDI input, without using any conditional statements, and that take full advantage of MIDI voice messages.
Note that correlating Csound instruments with MIDI channel numbers is done using the massign opcode for real-time performance,. For file-driven performance, instrument numbers default to MIDI channel number + 1, but the defaults are overridden by any MIDI program change messages in the file.
xoct -- returns MIDI key translated to linear octaves during MIDI activation, remains unchanged otherwise.
xvelocity -- returns MIDI velocity during MIDI activation, remains unchanged otherwise.
If the instrument was activated by MIDI input, the opcode overwrites the values of xoct and xvelocity with the corresponding value from MIDI input. If the instrument was NOT activated by MIDI input, the values of xoct and xvelocity remain unchanged.
This enables score p-fields to receive MIDI input data during MIDI activation, and score values otherwise.
![]() | Adapting a score-activated Csound instrument. |
---|---|
To adapt an ordinary Csound instrument designed for score activation for score/MIDI interoperability:
|
Here is an example of the midinoteonoct opcode. It uses the files midinoteonoct.orc and midinoteonoct.sco.
Example 1. Example of the midinoteonoct opcode.
/* midinoteonoct.orc */
/* Written by Kevin Conder */
; Initialize the global variables.
sr = 44100
kr = 4410
ksmps = 10
nchnls = 1
; Instrument #1.
instr 1
koct init 0
kvelocity init 0
midinoteonoct koct, kvelocity
; Display the octave-point-decimal value when it changes.
printk2 koct
endin
/* midinoteonoct.orc */
/* midinoteonoct.sco */
/* Written by Kevin Conder */
; Play Instrument #1 for ten seconds.
i 1 0 10
e
/* midinoteonoct.sco */
i1 8.00000 i1 9.33333