Firmware-633 Command-106
Contents
EDIT CONFIG (106, 6Ah)
Each of the sensor inputs of the USB-microDig can be edited using the EDIT CONFIG command. Upon completion of the command the USB-microDig is re-initialized with the new settings and the USB-microDig sends out the CONFIG message. The EDIT CONFIG command can be used to start sending out MIDI messages calculated from sensor values immediately while the USB-microDig is powered, but it is also possible to send a STREAM command to the USB-microDig. Activating either or both signal processing methods will enable the sending of MIDI messages. To change the sampling interval use the INTERVAL command. The RESET command does not change any of the settings as stored by the EDIT CONFIG command in non-volatile memory.
Editing Sensor Inputs
To edit a sensor input of the USB-microDig the [BODY] of the EDIT CONFIG command consists of the following bytes:
| 00000001: | 1; configuration number | 
| 00bbbaaa: | aaa = [0..7]; sensor input number | 
| bbb = [0..7]; virtual input number | |
| 0bbbcccc: | bbb = [0..6]; MIDI mapping type (0 = note-off, 1 = note-on, 2 = key-pressure, 3 = control-change, 4 = program-change, 5 = after-touch, 6 = pitch-bend) | 
| cccc = [0..15]; MIDI channel | |
| 0ddddddd: | ddddddd = [0..127]; note number (mapping type 0..2), controller number (mapping type 3), irrelevant for mapping type 4..6 | 
| 00efghij: | e,f,g,h,i,j determine signal processing settings, see notes for combining | 
| e = [0,1]; impulse end notification (0 = off, 1 = on) | |
| f = [0,1]; impulse maximum/minimum constant (0 = off, 1 = on) | |
| g = [0,1]; continuous and/or impulse signal differentiation (0 = off, 1 = on) | |
| h = [0,1]; continuous and/or impulse signal smoothing (0 = off, 1 = on) | |
| i = [0,1]; impulse signal processing (0 = off, 1 = on) | |
| j = [0,1]; continuous signal processing (0 = off, 1 = on) | |
| 0kkkkkkk: | kkkkkkk = [0..127]; sensor input threshold | 
| 0mmmmmmm: | mmmmmmm = [0..127]; sensor input ceiling | 
| 0nnnnnnn: | nnnnnnn = [0..127]; noise gate | 
| 0pppqqqq: | ppp = [0..7]; smoothing (if {h} = 1) | 
| qqqq = [0..15]; time window (if {i} = 1) or constant value (if {i} = 1 and {f} = 1) | 
Default Settings for sensor inputs
Default settings for each sensor input are:
| Sensor input MIDI mapping type {bbb}: | 3; control-change | 
| Sensor input MIDI channel mapping {cccc}: | 0 | 
| Sensor input MIDI ctl/note mapping {ddddddd}: | sensor input {aaa} + 1 | 
| Sensor input impulse end notification {e}: | 0; off | 
| Sensor input impulse maximum set to constant {f}: | 0; off | 
| Sensor input cont. and/or impulse signal diff. {g}: | 0; off | 
| Sensor input continuous signal smoothing {h}: | 0; off | 
| Sensor input impulse signal processing {i}: | 0; off | 
| Sensor input continuous signal processing {j}: | 1; on | 
| Sensor input threshold {kkkkkkk}: | 0; minimum | 
| Sensor input ceiling {mmmmmmm}: | 127; maximum | 
| Sensor input noise gate {nnnnnnn}: | 0 | 
| Sensor input constant value {ppp}: | 0 | 
| Sensor input time window or smoothing factor {qqqq}: | 0; off | 
MIDI mapping settings
{bbbcccc} in decimal with MIDI channel = 0:
| 0 = note-off | 
| 16 = note-on | 
| 32 = key-pressure | 
| 48 = control-change | 
| 64 = program-change | 
| 80 = after-touch | 
| 96 = pitch-bend | 
Signal processing operations
{efghij} in decimal:
| 1 = continuous signal output | 
| 2 = impulse (peak or dip) detection | 
| 3 = impulse detection, then continuous output | 
| 4 = no signal processing (output disabled) | 
| 5 = continuous smoothed output | 
| 6 = impulse detection, peak-peak timing output (as milliseconds in pitch-bend message, scaled otherwise) | 
| 7 = impulse detection, smoothed, then continuous smoothed output | 
| 8 = no signal processing (output disabled) | 
| 9 = continuous differentiated output (ie. the difference between the last two samples) | 
| 10 = impulse detection, differentiated | 
| 11 = impulse detection differentiated, then continuous differentiated output | 
| 12 = no signal processing (output disabled) | 
| 13 = continuous output, smoothed and then differentiated | 
| 14 = impulse detection, smoothed and then differentiated | 
| 15 = impulse detection, smoothed and differentiated, then continuous smoothed, differentiated output | 
| 16 = no signal processing (output disabled) | 
| 17 = continuous signal output ({f} is ignored) | 
| 18 = impulse detection, output as a constant value | 
| 19 = impulse detection, output as a constant value, then continuous output | 
| 20 = no signal processing (output disabled) | 
| 21 = smoothed continuous output ({f} is ignored) | 
| 22 = impulse detection, peak-peak timing output as BPM (beats per minute) | 
| 23 = impulse detection, output as a constant value, then continuous smoothed output | 
| 24 = no signal processing (output disabled) | 
| 25 = continuous differentiated output ({f} is ignored) | 
| 26 = impulse detection, smoothed, output as a constant value | 
| 27 = impulse detection, output as a constant value, then continuous differentiated output | 
| 28 = no signal processing (output disabled) | 
| 29 = continuous smoothed output, differentiated ({f} is ignored) | 
| 30 = impulse detection, output as a constant value ({gh} are ignored) | 
| 31 = impulse detection, output as a constant value, then continuous smoothed output, differentiated | 
| 32 = no signal processing (output disabled) | 
| 33 = continuous output ({e} is ignored) | 
| 34 = impulse detection with end of impulse notification | 
| 35 = impulse detection with end of impulse notification, then continuous output | 
| 36 = impulse detection, smoothed, with end of impulse notification | 
| 37 = continuous smoothed output ({e} is ignored) | 
| 38 = impulse detection, single peak-end timing output | 
| 39 = impulse detection, single peak-end timing output, then continuous output | 
| 40 = no signal processing (output disabled) | 
| 41 = continuous differentiated output ({e} is ignored) | 
| 42 = impulse detection, differentiated, with end of impulse notification | 
| 43 = impulse detection, with continuous differentiated output and end of impulse notification | 
| 44 = no signal processing (output disabled) | 
| 45 = continuous smoothed, differentiated output ({e} is ignored) | 
| 46 = impulse detection, single peak-end timing output ({g} is ignored) | 
| 47 = impulse detection, with continuous differentiated output, then single peak-end timing output | 
| 48 = no signal processing (output disabled) | 
| 49 = continuous output ({ef} are ignored) | 
| 50 = impulse detection, output as a constant value, with end of impulse notification | 
| 51 = impulse detection, output as a constant value, with end of impulse notification, then continuous output | 
| 52 = no signal processing (output disabled) | 
| 53 = continuous smoothed output ({ef} are ignored) | 
| 54 = impulse detection, single peak-end timing output, smoothed | 
| 55 = impulse detection, with continuous output, then single peak-end timing output, smoothed | 
| 56 = no signal processing (output disabled) | 
| 57 = continuous differentiated output ({ef} are ignored) | 
| 58 = impulse detection, single peak-end timing output ({f} is ignored) | 
| 59 = impulse detection, with continuous differentiated output, then single peak-end timing output ({f} is ignored) | 
| 60 = no signal processing (output disabled) | 
| 61 = continuous smoothed, differentiated output ({ef} are ignored) | 
| 62 = impulse detection, single peak-end timing output, smoothed ({f} ignored) | 
| 63 = impulse detection, with continuous differentiated output, then single peak-end timing output, smoothed ({f} are ignored) | 
Mapping sensor inputs
Impulse signal processing is useful when the sensor signal can be characterized as an impulse, ie. as either rising from below a minimum value to a maximum value after which it eventually drops below a certain minimum value, or as dropping below a minimum value after which it eventually rises above a certain maximum value. Subsequent impulses may appear asynchronously.
Continuous signal processing is useful when the sensor signal can be characterized as a continuously varying signal without any specific start or end.
The impulse signal processing settings are:
- The activation status {i} which will also start sampling of the sensor input.
- The time window setting {qqqq} within which {qqqq} + 1 sensor values are compared so as to find the highest value (peak search, where the threshold {kkkkkkk} is smaller than {mmmmmmm}) or lowest value (dip search, where the threshold {kkkkkkk} is greater than {mmmmmmm}).
- The end notification setting {e} which provides a way to determine the duration of the impulse.
- The maximum/minimum constant setting {f}. For this setting the time window {qqqq} is not used. It provides a way to output each impulse maximum/minimum (peak/dip) as a constant of value 16 x {ppp} + 15, ie. There are only 8 constant values available.
If the sensor value rises above {mmmmmmm} ({mmmmmmm} greater than {kkkkkkk}) or drops below {mmmmmmm} (ie. {mmmmmmm} smaller than {kkkkkkk}) before {qqqq} + 1 samples have been obtained, the peak/dip search is stopped and is immediately output as peak/dip value.
The continuous signal processing settings are:
- The activation status {j} which will also start sampling of the sensor input
- The smoothing setting {g} which enables calculation of the exponential moving average of the sensor value.
- The smoothing factor setting {qqqq} (the higher the value, the more smoothing is applied).
- The differentiation setting {g} which enables calculation of the difference between the current and last output value.
Continuous signal processing can be combined with impulse signal processing and will be useful for sensor signals that have an onset with a local maximum or minimum after which the sensor value continues for some time to stay above the minimum or below the maximum before it eventually drops below the minimum or rises above the maximum.
Impulse signal processing can also be applied to continuously varying signals such as AC (alternating current) signals and recurring impulses of which only the peak (or dip) value is relevant. Deactivate impulse end notification, ie. set {e} = 0, to avoid sending out MIDI value zero.
In both impulse and continuous signal processing the 10-bit sensor value is scaled between the threshold {kkkkkkk} and ceiling {mmmmmmm}, and the resulting value has to increase beyond the noise gate {nnnnnnn} (mapping types 1-5) or beyond the noise gate {nnnnnnn} times 4 (mapping type 6) before being output. After passing the noise gate the value itself or the absolute difference between the current and last calculated value can be output by activating the differentiation setting {g}.
If either impulse or continuous signal processing is active, the calculated values are represented by the 2nd data field of a MIDI channel voice note-off (header 80h), note-on (header 90h), key-pressure (header A0h) message with note number {ddddddd}, or by the 2nd data field of a control-change (header B0h) message with control number {ddddddd}, or by the 1st data field of a program-change (header C0h) or after-touch (header D0h) message or by the two data fields of a pitch-bend (header E0h) message.
If both impulse and continuous signal processing are active the sensor value’s start and end are characterized using impulse signal processing and represented as one of the channel voice MIDI messages listed above, while the signal between start and end is characterized using continuous signal processing and always represented as the key-pressure value of a MIDI channel voice key-pressure (header A0h) message. Note that if smoothing is activated, {qqqq} will also be used as the smoothing factor, ie. {qqqq} + 1 samples will be taken for peak/dip detection and subsequently {qqqq} will be used as smoothing factor.
For example, if impulse signal processing is activated ({i} = 1), the threshold {kkkkkkk} is smaller or equal than the ceiling {mmmmmmm} and note-on mapping has been selected, then, once the sensor value rises above the threshold {kkkkkkk}, a note-on message with velocity value greater than zero will be sent and no new note-on message with velocity greater than zero will be sent until the sensor value has dropped below {kkkkkkk}. If continuous signal processing is activated as well ({j} = 1), then, after sending a note-on message, the sensor value will be represented by the key-pressure data field of a MIDI channel voice key-pressure message, until the sensor drops below {mmmmmmm} upon which a note-on message with velocity zero will be sent out.
If either impulse or continuous signal processing is activated, MIDI messages calculated as defined by the signal processing method(s) will be sent out. If both are deactivated no MIDI output is generated. MIDI running status is implemented in the MIDI output mapping when using stand-alone mode.
