by subpixel, subpixels.com
A small application made with Processing to produce MIDI control messages from a live audio feed. Auto-levelling frequency band meters are used to obtain "peak" output values across the entire audio spectrum analysed (whereas it is usual to have strong bass response with weaker treble response), and easing is applied to make the levels less erratic.
The auto-levelling algorithm tracks high and low values output by the audio analysis (FFT) for each frequency band:
10 separate monitor outputs are supplied, where each monitor is attached to one of the frequency band meters and that meter's output is scaled to the particular output range for the monitor, allowing for a reduced final output range as well as inverted ranges. Drop-down menus are provided to select the MIDI input and output devices, as well as the MIDI channels to use.
This app has been used to control VJ applications Resolume and Neon v2, allowing simultaneous control from an external MIDI controller on the same channel (using loopMIDI as a virtual MIDI driver and MIDI-OX for routing).
The "Stereo Mix" device only exists for some audio hardware. To do monitoring in Windows 10 when there is no "Stereo Mix" requires using a 3rd party driver. See How to Get Stereo Mix in Windows 10.
As of v11.3, spxlAudioToMidi searches for a mixer name starting with strings listed in a text file in the data directory called "mixer-prefs.txt", listed in order of preference., for example:
Microphone Stereo Mix VoiceMeeter Output VoiceMeeter Aux Output VoiceMeeter VAIO3 Output CABLE Output
This should match any mixer starting with "Microphone" (eg "Microphone Array ..."); the three outputs from Voicemeeter from VB-Audio Software (tested with Voicemeeter Potato), VB-CABLE Virtual Audio Device, also from VB-Audio Software, or the oldschool "Stereo Mix" available on some systems, if any of those are available. If you are using a different audio device, or want to change the order of preference, simply edit the text file and reload the mixer preferences by pressing F5 (or restarting the app).
spxlAudioToMidi v11.5 (2022-09-13): developed and tested with Processing v3 (3.5.4 Win 64) on Windows 10 Home (64-bit).
NOTE: MIDI input has been disabled. It needs to be rewritten for The MidiBus library.
You can also check the file list.
|The MidiBus||MIDI input/output||themidibus.zip (132KB)|
|Minim||Audio analysis (FFT)||minim.zip (18MB)|
The text at the top of the window controls the MIDI output. The left column of 30 bars are audio meters; each meter representing an average for a frequency band produced by FFT analysis with the low frequencies at the top of the display and the high frequencies at the bottom of the display. The meters are auto-levelling and provide normalised output values between 0 and 1 (inclusive). The right column of 10 bars are meter monitors, with each one connected to a particular meter. A monitor's output value is determiend by scaling the input meter value over the monitor's output range between 0 and 127 (inclusive); the lower and upper limits of each range can be adjusted, including to scale the meter input inversely, and the meter it is connected to (thus the frequency band it monitors) can be changed. If a MIDI output device is selected, each time a monitor output value changes, the value is emitted as a MIDI control message on the selected output channel. The control number is in the range 1 to 10, with the top monitor being control 1 and the bottom one being control 10.
Click on the "No MIDI input" text to pop up the "INPUT DEVICE:" menu. Click a displayed device to select. Subsequently, clicking the displayed device name presents the "SELECT DEVICE:" menu again, and clicking the displayed channel number to the left presents the "INPUT CHANNEL:" menu with channels 1 to 16.
Click on the "No MIDI output" text to pop up the "OUTPUT DEVICE:" menu. Click a displayed device to select. Subsequently, clicking the displayed device name presents the "OUTPUT DEVICE:" menu again, and clicking the displayed channel number to the left presents the "OUTPUT CHANNEL:" menu with channels 1 to 16.
The selected audio mixer is displayed just below the MIDI input and output devices on a red background. Click on the selected device text to pop up the "MIXER:" menu. The items listed in the menu begin with the preferred mixers on a red background (as supplied in the "data\mixer-prefs.txt" file; mixer names not matched shown in parentheses), followed other audio mixers detected in the system ("non-preferred mixers") on a grey background. The non-preferred mixers are display-only (not selectable) and are provided to guide what to put into the mixer-prefs.txt file. Click a displayed mixer to select that mixer. Subsequently, clicking the displayed device name presents the "MIXER:" menu again, and pressing F5 reloads the mixer preferences list from the file.
Selecting the mixer does not activate it immediately. You must press the F4 key to activate the selected audio mixer. This also resets the meter levels (like pressing the Z key).
Each monitor ouutputs values in the range 0 to 127 (inclusive) by default. The "minimum" and "maximum" limits can be adjusted by clicking (and dragging) the monitor output bar. Clicking in the top 3/4 of the bar adjusts the maximum; clicking in the top 1/4 of the bar adjusts the minimum. When dragging, if the mouse is dragged above or below the bar, the limit being dragged (min or max) snaps back to the previous value. Right-click the bar to reset to the default full range (0 to 127).
When the mouse is just off the left edge of a monitor bar the link to the associated meter is hilighted and "Drag to meter" is displayed. Click and drag the mouse pointer, releasing over to the desired meter; releasing when not over a meter leaves the link as it was previously. Right-clicking when "Drag to meter" is shown resets the link to the meter assigned by default when the application was started.
The "selected monitor" refers to the monitor that the mouse is over.
Note: These screenshots are from an earlier version running on Windows 7. The appearance and operation is similar in this version.