This is the wiki for products made by Fractal Audio Systems, maintained by members of the community.

Difference between revisions of "MIDI"

From Fractal Audio Wiki
Jump to navigation Jump to search
 
(301 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 
__TOC__
 
__TOC__
[[image:MIDI.png|link=]]
+
=Axe-Fx III and MIDI=
=Fractal Audio's processors and MIDI=
 
  
==Axe-Fx III==
+
The Axe-Fx III has MIDI IN, OUT and THRU ports. The FM9 has a combined MIDI Out/Thru port.
  
The Axe-Fx III has MIDI IN, OUT and THRU ports.
+
Incoming MIDI data via MIDI IN or via MIDI-over-USB is indicated by a LED on the front panel.
  
Incoming MIDI data (via MIDI IN or via MIDI-over-USB) is indicated by a LED on the front panel. Data at the MIDI IN port is passed through to the MIDI THRU port (not to MIDI OUT).
+
Data at the MIDI IN port is passed through to the MIDI THRU port (FM9: MIDI OUT/THRU).
  
There's no support for MIDI phantom power.
+
Fractal Audio's proprietary communication protocol (not MIDI) for the Axe-Fx III, FM3 and FM9 allows Fractal Audio's [[Fractal Audio FC-6 and FC-12]] to control the device, through the [[FASLINK|FASLINK II port]], or [[USB]].
  
A proprietary communication protocol (not MIDI, exclusive to Axe-Fx III and FM3) over the FASLINK II port or USB lets external controllers (such as Fractal Audio's own FC controllers) take control of the Axe-Fx III.
+
There's MIDI support for 3rd-party devices, such as RJM's MIDI foot controllers, to switch presets, scenes and channels, to turn effects on/off, to display preset and scene titles and the tuner and to control tap tempo. This is done through SysEx commands, documented in the [https://wiki.fractalaudio.com/wiki/index.php?title=Owners_Manuals Axe-Fx III MIDI for Third-Party Devices guide].
  
There's MIDI support for 3rd-party devices, such as RJM's MIDI controllers, to set and/or get scenes, channels, bypass states, scene names and preset names via System Exclusive messages. [http://www.fractalaudio.com/downloads/misc/Axe-Fx%20III%20MIDI%20for%203rd%20Party%20Devices.pdf Documentation: Axe-Fx III MIDI for Third-Party Devices.] The Axe-Fx III doesn't provide fixed MIDI CCs. You can assign these as desired in the MIDI/Remote menu. In the MIDI/Remote menu, you can instruct the III to process or ignore incoming Program Changes, process or ignore duplicate ("redundant") Program Changes, send out Program Changes at MIDI Out when loading presets, enable mapping of Program Changes, and choose between to two Effect Bypass modes. The MIDI settings are part of the System Settings which can be backed up with [[Fractal-Bot]].
+
The Axe-Fx III, FM3 and FM9 do not use fixed MIDI CCs. But you can assign these as desired in SETUP > MIDI/Remote. This menu also lets you instruct the device to process or ignore incoming Program Changes, process or ignore duplicate/redundant Program Changes, send out Program Changes through the MIDI OUT port when loading presets, enable mapping of Program Changes, and choose between two Effect Bypass modes. The MIDI settings are part of the system data which can be backed up with [[Fractal-Bot]].
  
The Axe-Fx III processes incoming MIDI-over-USB, but doesn’t pass incoming MIDI data to outgoing USB. [http://forum.fractalaudio.com/threads/midi-thru-through-usb.141326/#post-1674639]
+
The devices process incoming MIDI-over-USB, but don’t pass incoming MIDI data to outgoing USB. [http://forum.fractalaudio.com/threads/midi-thru-through-usb.141326/#post-1674639]
  
MIDI-over-USB is much faster on the Axe-Fx III than on the II, because of the III's dedicated USB processor. Also, USB communication does not increase CPU usage. The FM9 has the same chip.
+
Windows computers require a driver for MIDI-over-USB. The driver can be downloaded from the product pages on [https://www.fractalaudio.com/family Fractal Audio's website]. Install the driver with Fractal-Bot. macOS computers do not require a driver because they're class compliant.
 +
 
 +
MIDI-over-USB is much faster on the Axe-Fx III and FM9 than it was on the II, because of the III's dedicated USB processor. Also, USB communication does not increase CPU usage.
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
 
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/keep-losing-connection-on-mac-os-x-10-13-6.140954/#post-1676488]
 +
The Axe-Fx III moves a LOT more data over USB than the II. The audio is 8x8 vs. 4x2 and the MIDI-Over-USB interface runs 10-100x faster. Therefore it is important that the cable adhere to specifications (5m max).
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/so-whats-new-on-the-iii-axe-fx-2-vs-3.134729/page-8#post-1592610]
 +
Still USB-over-MIDI but at least 10x faster.
 +
</blockquote>
 +
</blockquote>
  
 
The [[Scene MIDI block]] in presets lets you send up to 8 MIDI CCs and PCs through the MIDI OUT port when switching scenes. Also, a Program Change can be transmitted to MIDI OUT upon preset loading.
 
The [[Scene MIDI block]] in presets lets you send up to 8 MIDI CCs and PCs through the MIDI OUT port when switching scenes. Also, a Program Change can be transmitted to MIDI OUT upon preset loading.
Line 23: Line 37:
 
The FC controllers provide additional MIDI features through the use of [[Control Switches]].
 
The FC controllers provide additional MIDI features through the use of [[Control Switches]].
  
The [[Owners_Manuals|Owner's Manual]] lists the MIDI Program Changes that correspond with Axe-Fx III presets. The first value is MIDI Bank Select, the second one is MIDI Program Change.
+
The [[Owners_Manuals|Owner's Manual]] lists the MIDI Program Changes that correspond with presets. The first value is MIDI Bank Select, the second one is MIDI Program Change.
 
* Preset 0 = Bank/PC 0,0
 
* Preset 0 = Bank/PC 0,0
 
* Preset 128 = Bank/PC 1,0
 
* Preset 128 = Bank/PC 1,0
Line 29: Line 43:
 
* Preset 384 = Bank/PC 3,0
 
* Preset 384 = Bank/PC 3,0
  
MIDI Thru over UASB is not supported.
+
MIDI Thru over USB is not supported.
 +
 
 +
<blockquote>
 +
'''FRACTAL AUDIO QUOTES'''
 +
<HR>
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/where-is-usb-a.176230/post-2140433]
 +
That would be what we'd call "USB adapter Mode" and it is not a feature of our current generation of products at this time.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
=FM9 and MIDI=
 +
 
 +
The FM9 provides the same MIDI support as the Axe-Fx III.
 +
 
 +
=FM3 and MIDI=
 +
 
 +
The FM3 has a MIDI IN port and a combined MIDI OUT/THRU port.
 +
 
 +
It supports MIDI like the Axe-Fx III and FM9 do.
 +
 
 +
However, the FM3 is NOT a MIDI-over-USB device. It communicates through USB with Fractal-Bot and the editor, but it does not appear as a MIDI device in a DAW or other MIDI programs. To add MIDI-over-USB functionality, use a separate MIDI/USB cable or interface.
 +
 
 +
The MIDI runs at 5V.
 +
 
 +
Read <q>[https://forum.fractalaudio.com/threads/midi-output-voltage-widi-master-is-getting-hot.171579/page-2 MIDI output voltage: WIDI Master is getting hot]</q> about the FM3 getting hot when connecting a wireless MIDI adapter for more information.
 +
 
 +
<blockquote>
 +
'''FRACTAL AUDIO QUOTES'''
 +
<HR>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/fm3-general-discussion-thread.158170/post-1890325]
 +
MIDI over USB is used for Fractal-Bot and FM3-Edit, but the FM3 does not appear amongst the MIDI devices on your computer. For the purpose of preset changes, cc messages, tempo, etc, it can definitely be controlled by a 3rd party MIDI device or MIDI interface, such as a MIDI Sport.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/fm3-and-fm3-edit-going-nuts-when-clock-syncd.159967/post-1923031]
 +
The FM-3 does NOT support MIDI-over-USB. Sending MIDI to it over USB can lead to unpredictable behavior.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
=VP4 and MIDI=
 +
 
 +
The VP4 has 3.5 mm (1/8”) MIDI IN and OUT ports. Adapters are available at the [https://shop.fractalaudio.com/ Fractal Audio shop].
 +
 
 +
The Boss BMIDI-5-35 cable has been tested and works with the VP4 to connect to 5-pin MIDI gear.
 +
 
 +
The VP4 supports:
 +
* Sending and receiving Program Changes (PC), to select presets
 +
* Sending and receiving Control Changes (CC), to turn effects on/off and control other stuff
 +
* MIDI-over-USB
 +
* MIDI clock (receiving only, currently)
 +
* Software MIDI Thru
 +
 
 +
A table in the [[Owners_Manuals|Manual]] translates MIDI Program Changes to VP4 presets.
 +
 
 +
<blockquote>
 +
'''FRACTAL AUDIO QUOTES'''
 +
<HR>
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/announcing-the-new-vp4-virtual-pedalboard-compact-multi-fx-processor.208713/post-2607516]
 +
The VP4 supports MIDI over USB so it appears as MIDI ports in a DAW.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/vp4-fm3-pc-editor-connectivity-question.208827/post-2609096]
 +
Messages sent to the VP4 via MIDI-over-USB are not echoed to its MIDI OUT port, and messages received at its MIDI IN port are not passed to the computer via USB.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/announcing-the-new-vp4-virtual-pedalboard-compact-multi-fx-processor.208713/page-17#post-2609869]
 +
The VP4 has fewer than 128 presets. MIDI Bank Select messages are not necessary to access all of its presets
 +
</blockquote>
 +
</blockquote>
 +
 
 +
=FC controllers: no MIDI support=
 +
 
 +
The [[Fractal Audio FC-6 and FC-12]] don't have onboard MIDI functionality and can't be used by themselves to control MIDI devices directly.
 +
 
 +
However, the connected processors have MIDI OUT ports. The FC controller can initiate MIDI operations through [[Control Switches]], which are transmitted via the MIDI OUT port on the processor, or via the [[Scene MIDI block]].
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/welcome-fc-controllers.144675/page-2#post-1711520]
 +
The system has a MIDI jack. It's on the Axe-Fx III! Actions on the foot controller can cause MIDI to be transmitted to downstream devices.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
=MIDI/Remote menu=
 +
 
 +
This menu can be accessed through SETUP on the hardware and in the editors.
 +
 
 +
The settings are saved as part of the system data backup you create with [[Fractal-Bot]].
 +
 
 +
The parameters are also explained in the [[Owners Manuals]].
 +
 
 +
==MIDI Channel==
 +
 
 +
Set this to the desired channel to communicate with nother MIDI device. It defaults to 1.
 +
 
 +
Don't select OMNI, because this will slow down MIDI traffic.
 +
 
 +
==MIDI Thru==
 +
 
 +
On devices without a physical MIDI Thru port (FM3, FM9, VP4), this merges messages received at the 5-pin MIDI IN port with any internally generated MIDI data at the MIDI THRU port.
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
 
 +
[https://forum.fractalaudio.com/threads/midi-clock-thru.165843/post-1991421]
 +
You cannot pass USB MIDI messages to the MIDI out port. The feature that would be required is "USB adapter mode" which does not exist on the Axe-Fx III.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/midi-block-bug.183724/post-2260162]
 +
MIDI Thru is just that, it's a hardware thru. The Axe-Fx does not send any data to MIDI Thru.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
==Display Offset==
 +
 
 +
The processor starts numbering presets at 0. This parameter lets you shift the displayed number by 1. This adjusts the displayed number only, not the underlying Program Change number (see MIDI PC Offset).
 +
 
 +
A copy of this parameter also appears in SETUP > Global Settings on the Axe-Fx III, FM9 and FM3.
 +
 
 +
==Scene Revert==
 +
 
 +
Read [[Scenes]] for more information.
 +
==Effect Bypass Mode==
 +
 
 +
Axe-Fx III, FM9 and FM3 only.
 +
 
 +
This parameter determines how an effect (block) is engaged/bypassed via MIDI. When set to <q>Value</q>, the bypass state of an effect assigned to a CC is controlled by the CC value (0 = off, 128 = on). When set to <q>Toggle</q>, the bypass state toggles whenever the CC message is received, regardless of the value.
 +
 
 +
==Send Realtime SysEx==
 +
 
 +
Supported on the Axe-Fx II and III, FM9 and FM3.
 +
 
 +
MIDI tempo and tuner data can be sent continuously from the unit (the only data to be "pushed" by the unit). This allows an external MIDI controller to display the tuner on its display and make a tempo LED blink in time with the device's tempo. Transferring this data requires a bidirectional connection between the unit and the controller.
 +
 
 +
This parameter doesn't have to be enabled for use with [[Fractal Audio FC-6 and FC-12]].
 +
 
 +
Realtime SysEx on the Axe-Fx II is always disabled when entering the Utility menu.
 +
 
 +
Realtime SysEx is also used extensively by 3rd-party MIDI controllers to control the Axe-Fx III and FM3, as documented in <q>[http://www.fractalaudio.com/downloads/misc/Axe-Fx%20III%20MIDI%20for%203rd%20Party%20Devices.pdf AXE-FX III MIDI FOR THIRD-PARTY DEVICES]</q>.
 +
 
 +
<blockquote>
 +
'''FRACTAL AUDIO QUOTES'''
 +
<HR>
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/weird-issue-with-axe-fx-ii-and-noise-over-midi.87255/#post-1062827]
 +
Sysex data doesn't have a channel. It is not a voice message. All equipment should ignore any sysex data that does not contain its manufacturer's ID. If you gear is responding to Fractal Audio sysex messages then it is violating the spec.
 +
</blockquote>
 +
</blockquote>
  
<blockquote>"That would be what we'd call "USB adapter Mode" and it is not a feature of our current generation of products at this time." [https://forum.fractalaudio.com/threads/where-is-usb-a.176230/post-2140433]</blockquote>
+
==Program Change==
  
==FM9==
+
Instructs the hardware to process or ignore ''incoming'' Program Changes.
  
Same as Axe-Fx III.
+
On the VP4, this is: Receive MIDI PC.
  
The FM9 has a combined MIDI Out/Thru port.
+
==Ignore Redundant PC==
  
==FM3==
+
If set to ON, this parameter tells the device to ignore an incoming MIDI Program Change if the corresponding preset is already loaded. This prevents unnecessary reloading and the audio gap that may occur. While the preset isn't re-loaded, effect blocks return to their saved states and the default scene is selected.
  
Same as Axe-Fx III, but:
+
This parameter defaults to OFF on the Axe-Fx III, FM9, FM3, VP4.
  
* The FM3 has MIDI IN and combined MIDI OUT/THRU ports.
+
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
* The FM3 is NOT a USB MIDI Device. It uses “COMM over USB” channels for Fractal-Bot and FM3-Edit, but will not appear as a MIDI device in a DAW or other MIDI program.
+
<blockquote>
 +
[https://forum.fractalaudio.com/threads/ignore-redundant-pc-not-being-ignored.163776/post-1963417]
 +
The current behavior is as designed. The reasoning behind the implementation is that if Ignore Redundant PC is on then sending a PC gets you back to the original state of the preset but there is no audio dropout as would happen if Ignore was off.
 +
</blockquote>
 +
</blockquote>
  
<blockquote>(Can it be controlled with a regular MIDI pedal) "Of course." [https://forum.fractalaudio.com/threads/announcing-the-fm3-amp-modeler-fx-processor.149900/page-19#post-1779861]</blockquote>
+
==Send MIDI PC==
  
<blockquote>"MIDI over USB is used for Fractal-Bot and FM3-Edit, but the FM3 does not appear amongst the MIDI devices on your computer. For the purpose of preset changes, cc messages, tempo, etc, it can definitely be controlled by a 3rd party MIDI device or MIDI interface, such as a MIDI Sport." [https://forum.fractalaudio.com/threads/fm3-general-discussion-thread.158170/post-1890325]</blockquote>
+
Supported on the Axe-Fx III, FM9, FM3, VP4.
  
<blockquote>"The FM-3 does NOT support MIDI-over-USB. Sending MIDI to it over USB can lead to unpredictable behavior." [https://forum.fractalaudio.com/threads/fm3-and-fm3-edit-going-nuts-when-clock-syncd.159967/post-1923031]</blockquote>
+
This setting determines whether the Axe-Fx III, FM9, FM3 and VP4 automatically send a MIDI Program Change at its MIDI OUT port upon loading a new preset (front panel, using an FC or otherwise). You can select the MIDI channel to be used.
  
<blockquote>"The MIDI runs at 5V." </blockquote>
+
==MIDI PC Offset==
  
==Axe-Fx II==
+
This parameter lets you shift Program Change numbers by 1, to improve compatibility with other MIDI devices. This is different from the Display Offset parameter (see above).
 +
 
 +
==PC Mapping==
 +
 
 +
This controls the mapping of incoming MIDI Program Changes to preset numbers and scenes on the Axe-Fx II and III. On the III, FM9 and FM3 this is further configured in the Mapping submenu.
 +
 
 +
==Initial Value External Controllers==
 +
 
 +
Read <q>[[Expression pedals and external switches#What_happens_if_the_pedal_is_not_connected|What happens if the pedal is not connected]]</q> for more information.
 +
 
 +
==Tuner on heel down==
 +
 
 +
Read this: [[Tuner#Display_Tuner_on_heel_down|Tuner]]
 +
 
 +
==More parameters==
 +
 
 +
The MIDI/Remote menu on the Axe-Fx III, FM9 and FM3 lets you map MIDI commands to various other functions on the device:
 +
 
 +
* Load or switch presets
 +
* Set global I/O levels
 +
* Change output level
 +
* Bypass effect blocks
 +
* Change channels
 +
* Configure external controllers
 +
* Configure the Looper
 +
* etc.
 +
 
 +
=Send a MIDI Program Change=
 +
 
 +
; When loading a preset : Enable the SEND MIDI PC parameter in SETUP to instruct the device to send a MIDI Program Change through the MIDI OUT port when a preset is loaded. The MIDI channel is selectable.
 +
 
 +
; When switching scenes : The [[Scene MIDI block]] on the FM3, FM9, Axe-Fx III and VP4 lets you send MIDI CCs or PCs through the MIDI OUT port when switching scenes.
 +
 
 +
; With a Control Switch : Configure [[Control Switches]] on an Axe-Fx III, FM3 or FM9, and assign these to onboard foot switches or an FC-6 or FC-12 to transmit MIDI Program Changes and Control Changes when desired.
 +
 
 +
=MIDI Clock=
 +
 
 +
MIDI Clock is the same as MIDI Beat Clock. See Wikipedia's <q>[http://en.m.wikipedia.org/wiki/MIDI_beat_clock MIDI Beat Clock]</q> article for more information.
 +
 
 +
In current device firmware, the Axe-Fx III, FM3 and FM9 are capable of handling incoming MIDI Clock as well as transmitting it, via MIDI (default) and USB. Make sure to install the latest version of the USB firmware.
 +
 
 +
MIDI commands such as MIDI Start and MIDI Stop (MIDI Time Code) are not supported.
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/fm3-and-fm3-going-nuts-when-clock-syncd.159967/post-1914946]
 +
Our products do not recognize or support MTC. They do support MIDI Clock.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/fm9-din-midi-clock-wildly-inaccurate-with-high-cpu-load-out-of-sync-with-metronome.214554/#post-2694899]
 +
The audio processing thread is, necessarily, the highest priority thread. MIDI Clock is generated by a lower priority thread. If the CPU usage is high enough that thread may get starved and will cause the clock to be inaccurate. The solution is to reduce CPU usage. You can't get blood from a stone.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
=Tips, tricks and troubleshooting=
 +
 
 +
==MIDI System Exclusive (SysEx)==
 +
 
 +
Known SysEx commands for Fractal Audio devices are listed on the [[MIDI SysEx]] wiki page.
 +
 
 +
==iOS devices==
 +
 
 +
Use a USB-A to USB-B cable, or a wireless MIDI adapter, or the Apple Lightning-to-USB Camera Adapter, to connect the Axe-Fx III or FM9 directly to an iOS device. This lets apps such as [[BandHelper]] send and receive MIDI commands and USB Audio to/from the device without requiring an additional MIDI-to-USB interface (which the Axe-Fx II required).
 +
 
 +
The FM3 does not support a direct connection to iOS devices.
 +
 
 +
==Issues with Google Chrome, Pro Tools, Logic==
 +
 
 +
Read <q>[[Editors#Troubleshooting_connectivity_issues#Troubleshooting|Editors]]</q> for more information.
 +
 
 +
==Issue with Diezel VH4 amplifier==
 +
 
 +
Read <q>[https://forum.fractalaudio.com/threads/diezel-vh-4-wrong-channels-recall-with-fm9.194160/post-2416800 Diezel VH-4 wrong channels recall with FM9]</q>.
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
[https://forum.fractalaudio.com/threads/midi-problem-with-diezel-amps.154661/#post-2613602]
 +
Diezel amps have a known bug in the MIDI. If you contact them they can send you a new EPROM to install that fixes the issue.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
==MIDI ground issue==
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/midi-issues-fractal-latency-issues.109286/page-5#post-1368042]
 +
On MIDI devices the MIDI Out jack should be grounded but the MIDI In jack should not be. MIDI devices powered by wall-warts aren't grounded. The AX-8 uses AC power and is therefore grounded. So a simple solution would be to cut the ground pin (pin 2) at the MIDI In (amp) side. Pin 2 is the important one. Pin 1 is often not wired and even if it is it's not-connected on the AX-8 end. The AX-8 uses pins 2, 4 and 5. The rest are not connected. Pin 2 is ground, 4 and 5 are the data. If the pin 2 is grounded at the amp side then current will flow in the ground which could corrupt the data.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
==MIDI/Remote menu looses settings==
 +
 
 +
If adjusted parameters in SETUP return to their default values after powering off and on, there’s probably an issue with the internal battery. It’s exhausted or has come loose.
 +
 
 +
<blockquote>'''FRACTAL AUDIO QUOTES'''<HR>
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/axe-fx-iii-does-not-remember-midi-settings.146083/page-2#post-1727976]
 +
It sounds like there is a short in the battery holder or at the memory IC. I've seen this once before. A solder blob was lodged under the battery holder.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
==MIDI phantom power==
 +
 
 +
Only the Axe-Fx II provides power to MIDI devices over a MIDI cable, also known as "phantom power". This requires a 7-pin MIDI cable ([http://forum.fractalaudio.com/connections-routings/21547-axe-fx-7-pin-bidirectional-midi-pinout.html#post356116 pin definitions]) and the power supply for the floor controller to be plugged in at the rear of the Axe-Fx II.
 +
 
 +
Other Fractal Audio processors (current and legacy) do NOT support phantom power.
 +
 
 +
The MIDI phantom power connection can be used for DC as well as AC power. [http://forum.fractalaudio.com/threads/midi-phantom-power-jack.112471/#post-1345043]
 +
 
 +
Warning: do not connect a power supply to the phantom power input on the Axe-Fx II that has a load of more than 1A! E.g. power supplies for Liquid-Foot or RJM foot controllers.
 +
 
 +
<blockquote>
 +
'''PREVIOUS GENERATIONS'''
 +
<HR>
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/the-phantom-power-connector-behind-the-axe-what-connection-it-is.86760/#post-1049803]
 +
2.1mm is the standard for DC. 2.5mm is the standard for AC. The phantom power jack is designed for AC, hence the 2.5mm jack.
 +
</blockquote>
 +
</blockquote>
 +
 
 +
==MIDI noise bleed==
 +
 
 +
If you hear a tick in your audio signal which syncs to the tempo, and it's not the Metronome, it's probably MIDI noise bleeding into the signal. You can easily check this by turning off Send Realtime Sysex in SETUP. If the noise stops, it's caused by the MIDI cabling. Use better MIDI cables and keep the MIDI cables away from problematic sources. If that doesn't solve the issue, consider a wireless MIDI (Bluetooth) connection.
 +
 
 +
=Legacy devices and MIDI=
 +
 
 +
==Basic MIDI tutorial==
 +
 
 +
The explanation below is written by Clarky. It refers to MIDI control on the Axe-Fx II.
 +
 
 +
<b>What is MIDI?</B>
 +
 
 +
MIDI = <q>Musical Instrument Digital Interface</q>.
 +
 
 +
If I turned that into more friendly English, I’d end up with something like this: MIDI is a means of <q>interfacing</q> or connecting musical instruments together using a digitally encoded protocol, essentially a language. It is a method of connecting together MIDI-capable musical instruments or devices so that they can use a <q>language</q> to communicate with each other.
 +
 
 +
A key thing often misunderstood about MIDI is that it does not actually contain audio or sound, so you can’t actually <q>hear</q> MIDI. It’s simply a stream of information or instructions from one device to another, essentially:
 +
* <q>turn this 'thing' on in that device</q>
 +
* <q>change the value of this parameter in that effect</q>
 +
* <q>play this note on that device using this patch</q>
  
The Axe-Fx II has MIDI IN, OUT and THRU ports. Data at the MIDI IN port is passed through to the MIDI THRU port.
+
<B>What is MIDI used for?</B>
  
Incoming MIDI data (via MIDI IN or via MIDI-over-USB) is indicated by a LED on the front panel.
+
MIDI is basically all about control - one device being able to control another. Back in the 70’s it’d not be unusual to see a prog rock band with a keys player completely surrounded by all kinds of synthesizers and keyboards. Just take a look at pictures of Keith Emerson or Rick Wakeman from around the 1972 to 1978 era. Sometimes they’d want to play a musical phrase but use more than one sound at the same time and blend them together. In the early days they have to play the part with each hand playing a different synth. It was recognised that some sort of ‘remote control’ was needed. In the early days control was achieved via analogue signals but that had limitations of its own. The thing that really unlocked the door for control was MIDI because:
 +
* it was standardized, enabling devices made by different manufacturers to communicate
 +
* it could communicate much more information that simple ‘on / off’ and pitch information
  
MIDI-over-USB is managed by the main DSP. Therefore USB communication increases CPU usage.
+
So think of MIDI as being the language used for a music specific ‘remote control’. With MIDI I can connect several synths together and use one of them to ‘play’ all of the others. I can use a floor controller [like the MFC] to control a keyboard or FX unit [like the Axe] to make it change preset [program] or to take control of some effect’s parameters enabling control in real-time via switches or expression pedals. I can use a Digital Audio Workstation [like Logic or Ableton] to control effects units [like the Axe] or play synths and keys. I can use a MIDI control surface to control a DAW remotely so that I can ‘play’, ‘stop’, ‘record’, use real faders [just like on a mixing desk] to control the software faders in the DAW’s mixer.
  
Data transfers happen via MIDI, MIDI-over-USB, FASLINK or Ethernet/Ethercon.
+
MIDI can also be used to synchronize tape machines to a DAW or sequencer and provide a clock source.
  
MIDI phantom power is supported.
+
<B>What basics do I need to know?</B>
  
There's support for MIDI controllers through MIDI PCs, MIDI CCs and SysEx. Realtime SysEx is used to provide MIDI controllers with tuner and tempo data. MIDI SysEx is used extensively for communication with Axe-Edit.
+
IN / OUT / THRU – these are the MIDI sockets [ports] you’ll see on any MIDI device and here is what they do:
 +
* IN – this contains the MIDI in-coming from the controlling instrument / device
 +
* OUT – this contains MIDI that is being created by the instrument / device
 +
* THRU – this is a copy of the MIDI that arrives from the MIDI IN and is sent outwards to other instruments/ devices
 +
* OUT / THRU – as you’d expect, this contains both OUT and THRU MIDI information
  
MIDI-over-USB is supported for incoming as well as outgoing transmissions.
+
Channels – MIDI uses to concept of channels to identify different devices. Example: I could have a Korg synth on channel 1, a Moog synth on channel 2, and could have a Roland to use as the ‘mother board’ [controller keyboard]. I would set the channels in the Korg and Moog myself manually. Roland OUT ----> IN Korg THRU ----> IN Moog. In the Roland I’d setup some presets to also send MIDI on channels 1 and / or 2. Imagine something like this: Roland preset 1 = piano in the Roland and also sends channel 1/pgm 20 [preset 20] which could be strings. I play the Roland preset 1 and hear piano. The MIDI sent from the Roland [MIDI OUT] arrives at the Korg [MIDI IN]. The Korg recognises that channel 1 means “it’s for me” and pgm 20 means “let’s use my strings sound that is stored in preset 20”. The outcome is that you hear piano and strings simultaneously and the Korg also sends a copy of the incoming MIDI IN to the MIDI THRU. The Korg’s MIDI THRU is connected to the Moog’s MIDI IN meaning that the Moog also receives the same MIDI information, but it will only react to anything that arrives on channel 2. So as this MIDI information is on channel 1 the Moog ignores it, and sends a copy of out to it’s MIDI THRU port.
  
MIDI CCs are set in the I/O > MIDI menu.
+
Some devices can be set to MIDI channel OMNI. This means “react to all in-coming MIDI messages from all channels”.
  
In the MIDI menu, you can instruct the II to process or ignore incoming Program Changes, process or ignore duplicate ("redundant") Program Changes, and enable mapping of Program Changes.
+
Some examples of common MIDI messages that one device would send to another:
 +
* Note messages – this are used to tell keys / synths to turn on / off notes
 +
* Program Change – this is a MIDI message that allows a device to make another device to change preset. This is exactly what the MFC does to the Axe
 +
* Control Change – this enables a device to control another device’s parameters remotely
 +
* System Exclusive [SysEx] – this allows manufacturers to add extra functions and capabilities to those found in regular MIDI. These ‘extras’ are bespoke / manufacturer specific, so you wouldn’t expect a Moog to be able to react to Korg SysEx. But two Korgs with SysEx would have some extra cool capabilities available.
  
The MIDI settings are part of the System Settings which can be backed up with [[Fractal-Bot]].
+
<B>Control Changes</B>
  
The II does not transmit a MIDI PC via MIDI OUT when changing presets on the hardware.
+
MIDI Control Change [CC] is extremely flexible and enables configurable parameters within the Axe [or any MIDI device] to be controlled remotely. This opens up a vast range of tonal possibilities. These are the key pieces of information that sit within a CC message:
 +
* MIDI channel [so we know who this message is aimed at]
 +
* CC#: there are 128 control ‘numbers’ available that number from 0 to 127. Some of these numbers are standardized by the industry, for example CC# 7 = master volume (volume control for the whole box, after all effects etc), CC# 16 = ribbon controller / general purpose slide 1 (keys / synth stuff).
 +
 
 +
Some CC values are ‘spare’. For example; values from 22 to 31 aren’t defined to you can assign them to anything you want.
 +
 
 +
So now let’s talk about the Axe. The Axe is designed to have a one to one relationship with a controller [such as the MFC]. This being the case, Fractal has created its own assignments of MIDI CC numbers and they can be seen via the front panel in Setup  > CTRL. There are two columns in here:
 +
* Left col = the ‘thing’ in the Axe that can be controlled
 +
* Right col = the MIDI CC number that will control it
 +
 
 +
==Axe-Fx II==
 +
 
 +
The Axe-Fx II has MIDI IN, OUT and THRU ports. Data at the MIDI IN port is passed through to the MIDI THRU port. Incoming MIDI data via MIDI IN or via MIDI-over-USB is indicated by a LED on the front panel. MIDI-over-USB is managed by the main DSP, which is why [[USB|USB communications]] increase CPU usage. Data transfers happen via MIDI, MIDI-over-USB, [[FASLINK]] or Ethernet/Ethercon. There's support for MIDI controllers through MIDI PCs, MIDI CCs and SysEx. Realtime SysEx is used to provide MIDI controllers with [[Tuner]] and [[Tempo and Metronome]] data. MIDI SysEx is used extensively for communication with the editor. MIDI-over-USB is supported for incoming as well as outgoing transmissions. MIDI CCs are set in SETUP > MIDI. In that menu, you can instruct the II to process or ignore incoming Program Changes, process or ignore duplicate ("redundant") Program Changes, and enable mapping of Program Changes. The MIDI settings are part of the system settings which can be backed up with Fractal-Bot. The II does not transmit a MIDI PC via MIDI OUT when changing presets on the hardware.
  
Below is a list of all MIDI CCs on the Axe-Fx II XL+. The CCs are listed in the I/O > CTRL menu as well. There's also a list in the Owner's Manual.
+
Below is a list of all MIDI CCs on the Axe-Fx II XL+. The CCs are listed in SETUP as well. There's also a list in the Owners Manual.
  
 
<div style="column-count:3;-moz-column-count:3;-webkit-column-count:3;font-size:85%">
 
<div style="column-count:3;-moz-column-count:3;-webkit-column-count:3;font-size:85%">
Line 201: Line 535:
  
 
'''MIDI THRU''':
 
'''MIDI THRU''':
* With the MFC­‐101 at the FASLINK port, do not use the MIDI THRU port. Instead, connect downstream devices to the MIDI OUT port and set MFC ECHO TO MIDI OUT to “ON” in the I/O > MIDI menu. This turns MIDI OUT into a “soft thru".
+
* With the MFC­‐101 at the [[FASLINK]] port, do not use the MIDI THRU port. Instead, connect downstream devices to the MIDI OUT port and set MFC ECHO TO MIDI OUT to “ON” in SETUP. This turns MIDI OUT into a “soft thru".
 
* If your MFC-101 or other controller is connected to the Axe­‐Fx II's MIDI IN port — whether using 5-­ or 7‐pin — use the standard 5‐pin MIDI THRU port. No special settings are required.
 
* If your MFC-101 or other controller is connected to the Axe­‐Fx II's MIDI IN port — whether using 5-­ or 7‐pin — use the standard 5‐pin MIDI THRU port. No special settings are required.
 
* More information about the MIDI THRU functionality of the Axe-Fx II XL and XL+ can be found in the [[Owners_Manuals|MIDI THRU Guide]].
 
* More information about the MIDI THRU functionality of the Axe-Fx II XL and XL+ can be found in the [[Owners_Manuals|MIDI THRU Guide]].
  
The "MFC ECHO TO MIDI OUT” option in I/O > MIDI (XL and XL+ only) echoes all MIDI data from the MFC to MIDI Out. This can be used to send MIDI PC and CC messages to other equipment connected to MIDI Out.
+
The <q>MFC ECHO TO MIDI OUT</q> option in the system settings for the XL and XL+ only, echoes all MIDI data from the MFC to MIDI Out. This can be used to send MIDI PC and CC messages to other equipment connected to MIDI Out.
  
<blockquote>(MIDI data transfers on the Axe-Fx II Mark I/II models) "The Axe-Fx II is not designed to be a general-purpose MIDI I/O. It can handle most things but not large sysex dumps." [https://forum.fractalaudio.com/threads/midi-thru-still-modifying-data-from-other-devices.46607/#post-611607] </blockquote>
+
<blockquote>
 +
'''PREVIOUS GENERATIONS'''
 +
<HR>
  
<blockquote>"The Axe-Fx simply passes the data. It doesn't parse messages. If a message is arriving altered then the fault is in the monitoring software or the OS." [https://forum.fractalaudio.com/threads/midi-through-broken-in-usb-midi.75518/#post-924219] </blockquote>
+
<blockquote>
 +
[https://forum.fractalaudio.com/threads/midi-thru-still-modifying-data-from-other-devices.46607/#post-611607]
 +
The Axe-Fx II is not designed to be a general-purpose MIDI I/O. It can handle most things but not large sysex dumps.
 +
</blockquote>
  
<blockquote>"MIDI Thru is a "soft" thru. It the delay is problematic for you then you need to change the order of things or use a MIDI splitter." [https://forum.fractalaudio.com/threads/axe-fx-ii-midi-thru-extra-120ms-delay.80401/#post-976985] </blockquote>
+
<blockquote>
 +
[https://forum.fractalaudio.com/threads/midi-through-broken-in-usb-midi.75518/#post-924219]
 +
The Axe-Fx simply passes the data. It doesn't parse messages. If a message is arriving altered then the fault is in the monitoring software or the OS.
 +
</blockquote>
  
<blockquote>(about using multiple MIDI devices to control the Axe-Fx) "The Axe-Fx was never designed to support multiple MIDI inputs simultaneously." [http://forum.fractalaudio.com/threads/sigh-gig-failure.117387/page-4#post-1401405] </blockquote>
+
<blockquote>
 +
[https://forum.fractalaudio.com/threads/axe-fx-ii-midi-thru-extra-120ms-delay.80401/#post-976985]
 +
MIDI Thru is a "soft" thru. It the delay is problematic for you then you need to change the order of things or use a MIDI splitter.
 +
</blockquote>
 +
 
 +
<blockquote>
 +
[http://forum.fractalaudio.com/threads/sigh-gig-failure.117387/page-4#post-1401405]
 +
The Axe-Fx was never designed to support multiple MIDI inputs simultaneously.
 +
</blockquote>
 +
</blockquote>
  
 
==AX8==
 
==AX8==
  
The AX8 has MIDI IN and MIDI OUT/THRU ports. It supports "soft" MIDI Thru (MIDI IN > MIDI OUT).
+
The AX8 has MIDI IN and MIDI OUT/THRU ports and supports <q>soft</q> MIDI Thru (MIDI IN > MIDI OUT).
  
 
Incoming MIDI data is indicated by a LED on the top panel. Data at the MIDI IN port is passed through to the MIDI THRU port.
 
Incoming MIDI data is indicated by a LED on the top panel. Data at the MIDI IN port is passed through to the MIDI THRU port.
  
MIDI-over-USB is managed by the main DSP. Therefore USB communication increases CPU usage.
+
MIDI-over-USB is managed by the main DSP which is why [[USB]] communications increase CPU usage. Data transfers happen via MIDI or MIDI-over-USB. MIDI SysEx is used extensively for communication with the editor, but only through MIDI-over-USB.
 +
 
 +
The AX8 accepts incoming MIDI PCs/CCs through MIDI IN and MIDI USB. It does not transmit MIDI CCs itself. The MIDI settings are part of the system settings which can be backed up with Fractal-Bot. The AX8 can send out a single MIDI Progam Change when loading a preset scene. The PC and the MIDI channel can vary per scene.
 +
 
 +
When sending from the AX8, MIDI Program Changes are sent via the MIDI Out/Thru port, and SysEx format MIDI Program Changes are sent via USB port.
  
MIDI phantom power is not supported.
+
==FX8==
  
Data transfers happen via MIDI or MIDI-over-USB. MIDI SysEx is used extensively for communication with AX8-Edit, but only through MIDI-over-USB.
+
The FX8 has MIDI IN and MIDI OUT/THRU ports. It supports <q>soft</q> MIDI Thru (MIDI IN > MIDI OUT). Data at the MIDI IN port is passed through to the MIDI THRU port.
  
The AX8 accepts incoming MIDI PCs/CCs through MIDI IN and MIDI USB. It does not transmit MIDI CCs itself.
+
The FX8 does not have a hardware LED for incoming MIDI traffic, unlike the Axe-Fx II and AX8; when it detects incoming MIDI data, an indicator appears at the top of the LCD screen.
  
The MIDI settings are part of the System Settings which can be backed up with [[Fractal-Bot]].
+
MIDI-over-USB is handheld by the main DSP which is why [[USB]] communications increase CPU usage. Data transfers happen via MIDI or MIDI-over-USB.
  
The AX8 can send out a single MIDI Progam Change when loading a preset scene. The PC (and the MIDI channel) can vary per scene. When sending from the AX8, MIDI Program Changes are sent via the MIDI Out/Thru port, and SysEx format MIDI Program Changes are sent via USB port.
+
MIDI SysEx is used extensively for communication with the editor, but only through MIDI-over-USB. The FX8 accepts incoming MIDI CCs through MIDI IN.
  
==FX8==
+
MIDI CCs are set in the system settings. The MIDI settings are part of the System Settings which can be backed up with Fractal-Bot. The FX8 can send out a single MIDI Progam Change and a MIDI Control Change when changing scenes, which can vary per scene. The FX8 can send MIDI data using a footswitch which is assigned to a MIDI footswitch block. It can send a PC and a CC, when turning the switch ON or OFF. This is configured on the Footswitch page.
 +
 
 +
The block supports X/Y switching.
 +
 
 +
=AxeForLemur (legacy)=
 +
 
 +
AxeForLemur is a Lemur Template designed by David Sorlien to control the Axe-Fx. The Template runs on the Lemur APP by Liine, and connects wirelessly through a logical midi connection to the AxeFx. <BR>This page is intended for users and developers of this template.
 +
 
 +
==Usage==
 +
 
 +
[https://liine.net/en/community/user-library/view/690/ AxeForLemur] is a JZML script, licensed by Creative Commons to be a non-commercial, free to use script. The script runs on IOS and Android devices with the [http://liine.net/en/products/lemur/ Lemur Application from Liine]. The Lemur application communicates with the Axe-Fx either through a direct MIDI connection that is connected either through USB or MIDI to the Axe-Fx, or through Wi-Fi to a host computer.
 +
 
 +
To configure an IOS/Android Patch Editor for the  Axe-Fx:
 +
# Purchase the [http://itunes.apple.com/ca/app/lemur/id481290621?mt=8 Lemur App] (approximately $20-$35) and install it on your Tablet or iPad.
 +
# Go to the [http://liine.net/assets/files/lemur/Lemur-Installer-5.3.2WIN.exe Liine Website] and register yourself as a user, then download the Lemur Editor and Daemon Software.
 +
# Connect your Tablet or iPad to your computer's IP network. Verify IP address, and ping your tablet to verify.
 +
# Start the Lemur App on your Tablet or iPad.
 +
# Download the AxeForLemur.jzml script. The current version is 3.08.
 +
# On your PC run the LemurEditor and load the AxeForLemur.jzml script, click Connect to send the script to your Tablet or iPad.
 +
# You should see the AxeForLemur Script on your iPad, on the Default AMP page.
 +
# If your Axe-Fx is connected to your PC/Mac through a USB cable, run the LIINE LEMUR DAEMON on your machine. This daemon will provide an IP Socket on the Network for MIDI and OSC communications from the iPad to any MIDI devices on your PC/Mac.
 +
# Within Lemur on your Tablet or iPad open the Settings drop down list and select "More Settings...", Setup Midi Targets, From: and To:. You may need to tap "Add Target". You should see a list of network computers, with the MIDI devices highlighted. Choose Axe-Fx from the computer that is running the LEMUR DAEMON, for both "From: and "To:. If no devices show up, verify that the iPad is connected to the IP network, and that the Lemur Daemon is running, and the Axe-FX is turned on, and it is connected with USB or MIDI cable.
 +
# On the Preset Select page of the AxeForLemur script, configure the MIDI settings to match your setup.  Example, Column-A Device should be set to AxeFxII or AxeFxXL+ etc, MIDI channel to "1" to match your MIDI settings, and Lemur target set to the Target within the Lemur Menu.
 +
# Test by tapping the Preset Up/Down.
 +
# Troubleshooting can be a bit challenging and might require a bit of system debugging and tweaking.
 +
 
 +
==Design==
 +
 
 +
Design background into key elements of the AxeToLemur script:
 +
 
 +
Axe For Lemur is a comprehensive Lemur script based in Quasi XML, Objector based C-Script without pre-processor, structures, pointers etc. The Script is object-based, and exists in the JazzInterface tab object AxeForLemur.  Global references exist in this scope.
 +
 
 +
===Design Initialization===
 +
 
 +
===Design Device Selection===
 +
 
 +
The preset page (AxeForLemur/dlgProgChange/T1) contains a matrix of MIDI settings for up to four target devices.
  
The FX8 has MIDI IN and MIDI OUT/THRU ports. It supports "soft" MIDI Thru (MIDI IN > MIDI OUT). Data at the MIDI IN port is passed through to the MIDI THRU port.
+
For each 'Target Device'  The user can select and increment/decrement (cTargets/padUpDn) the following (cTargets/swSettings):
  
The FX8 does not have a hardware LED for incoming MIDI traffic (unlike the Axe-Fx II and AX8); when it detects incoming MIDI data, an indicator appears at the top of the LCD screen.
+
* Type : { AxeFx, AxeFx II, Gen Midi, No Bank, Eclipse } = aUser.cMidi.devtypes[ ]
  
MIDI-over-USB is handheld by the main DSP. Therefore USB communication increases CPU usage.
+
* Display Offset : { 0 or 1 } = aUser.cMidi.dispoffset[ ]
  
MIDI phantom power is not supported.
+
* MIDI Channel : { 1 .. 16} = aUser.cMidi.chans[ ]
  
MIDI-over-USB is managed by the main DSP. Therefore USB communication increases CPU usage.
+
* Lemur Target : { 0.. 3 } = aUser.cMidi.targets[ ]
  
Data transfers happen via MIDI or MIDI-over-USB. MIDI SysEx is used extensively for communication with FX8-Edit, but only through MIDI-over-USB.
+
The user can select one of A,B,C, or D target devices; only one is active at a time.
  
The FX8 accepts incoming MIDI CCs through MIDI IN.  
+
'''The objective is to integrate  AxeFxXL and AxeFxXL+ into the list of supported Device Types.
  
MIDI CCs are set in the I/O > MIDI menu.
+
Since this template was last updated by David Sorlien, two new AxeFx devices have been created.    The XL and XL+ have more or less the same SysEx protocols as the AxeFx ( subject to change ), but have New SysEx device ID codes.  The following is a break down of work required to make AxeForLemur support other Fractal Audio Devices.
  
The MIDI settings are part of the System Settings which can be backed up with [[Fractal-Bot]].
+
Essentially the T1/cTargets/swSettings is a 4 x 4 Switch matrix.  Pressing a button will provide a 0..16 button index within the T1/cTargets/swSettings/x variable.  Pressing one of the T1/cTargets/padUpDn will cause the selected T1/cTargets/swSettings/x indexed value to be Incremented/decremented.  The padUpDn/tap() changesbutton matrix.
  
The FX8 can send out a single MIDI Progam Change and a MIDI Control Change when changing scenes, which can vary per scene.
+
Add two more values to devtypes
  
The FX8 can send MIDI data using a footswitch which is assigned to a MIDI footswitch block. It can send a PC and a CC, when turning the switch ON or OFF. This is configured on the Footswitch page. The block supports [[X/Y switching]].
+
  change:
 +
    aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]+1, 0, 4);
 +
    aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]-1, 0, 4);
 +
  to:
 +
    aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]+1, 0, 6);
 +
    aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]-1, 0, 6);
  
=Fractal Audio's foot controllers and MIDI=
+
Add two more strings to button objet lablels
  
Read this:
+
  swSettings/updatelabels()
 +
  for(i=0;i<4;i++){
 +
    if(aUser.cMidi.devtypes[i]==0) a[i] = 'AxeFX';
 +
    else if(aUser.cMidi.devtypes[i]==1) a[i] = 'AxeFX II';
 +
    else if(aUser.cMidi.devtypes[i]==2) a[i] = 'Gen MIDI';
 +
    else if(aUser.cMidi.devtypes[i]==3) a[i] = 'No Bank';
 +
    else if(aUser.cMidi.devtypes[i]==4) a[i] = 'Eclpse';
 +
    else if(aUser.cMidi.devtypes[i]==5) a[i] = 'AxeXL';
 +
    else if(aUser.cMidi.devtypes[i]==6) a[i] = 'AxeXL+'; }
  
* [[FC-6 and FC-12 foot controllers]]
+
Change Device ID's within SysEx messages to include devie ids { 6 and 7 }
* [[MFC-101 MIDI foot controller]]
 
* [[EV-1 and EV-2 pedals]]
 
  
=MIDI/Remote menu=
+
  <SCRIPT name="IsAxeSysex(msg)" ..
 +
  if(msg[0]==0 && msg[1]==1 && msg[2]==0x74 && ( msg[3]<=3 || msg[3]==6 || msg[3]==7 )
 +
  ...
 +
  else if(msg[3]==3) st = 'Axe-FX II';
 +
  else if(msg[3]==6) st = 'Axe-FX XL';
 +
  else if(msg[3]==7) st = 'Axe-FX XL+';
  
The parameters are also explained in the [[Owners_Manuals|Owner's Manuals]].
+
and change all hard coded device id's "0x74,3" with "0x74,6" or "0x74,7" in
  
==MIDI Channel==
+
  SendSetParam(b, p, v)
 +
  SendGetParam(b, p)
 +
  SendGetPresetName()
 +
  SendGetBypState()
 +
  SendGetPresetNumber()
 +
  SendLooperMonEn(en)
 +
  SendGetSceneState()
 +
  SendSetModifier(b, p, m, v)
 +
  SendGetModifier(b, p, m)
 +
  SendPlaceEffect(b, pos, flag)
 +
  SendConnectEffect(p1, p2, f)
 +
  SendSetPresetName(name)
 +
  SynthMidiNoteOnIn(MIDI_ARGS)
 +
  SendSavePatch(program, bank)
 +
  SendGetCabName(cabnum)
  
Set this to the desired channel (default: 1). Don't select OMNI, because this will slow down MIDI traffic.
+
It makes sense to define a class variable like cV.DevID, and make sure it is set on startup by the AxeFx device ID selected by the A,B,C,D device selector.
  
==MIDI Thru==
+
===Design Modifiers===
  
On some devices, this merges messages received at the 5-pin MIDI IN port with any internally generated MIDI data at the MIDI THRU port.
+
Modifiers provide a means to dynamically change a subset of the block parameters with automatic, and external functions.    The AxeToLemur Script has a partial implementation of Modifiers.  The AxeToLemur.pdf describes 'double tapping' the intended modify-able' control to enable modifier, but this doesn't appear to be within the implementation.  
  
<blockquote>(Axe-Fx III) "You cannot pass USB MIDI messages to the MIDI out port. The feature that would be required is "USB adapter mode" which does not exist on the Axe-Fx III." [https://forum.fractalaudio.com/threads/midi-clock-thru.165843/post-1991421]</blockquote>
+
Within the 'control's bps[] array, for hw==0, element at index==6 is the Modifier number, if this value is >= 0, then the control should have modify-able values.  This applies to 'bps' of sliders, custom buttons, muxed-sliders.  If the 'control's bps[8] is set to 1, then there is an active modifier on the control.
  
==Display Offset==
+
It is assumed that 'double tapping' the 'Zoom' button will enable a RED "MOD" feature on the Zoom button.  cS.DoubleTap() captures double tap event. This sets cV.dbltapzoom[2] = 1;  A parameter that is 'Modify-able' has a Green 'txt' value.
  
The processor starts numbering presets at 0. This parameter lets you shift the displayed number by 1. This adjusts the displayed number only, not the underlying Program Change number (see MIDI PC Offset).
+
As of 3.08, the repainting logic within the APP did not support GREEN 'txt' labels.
  
A copy of this parameter also appears in the Global > Config menu on the Axe-Fx III, FM9 and FM3.
+
cS.psmxfdr(obj, p, p, m, t), and cS.psmxcb(obj,b,p,m,t) used to set/map a 'muxed fader' to an AxeFx control.  This function also sets the colour of the text of a control
  
==Scene Revert==
+
Notes:
  
Read this: [[Scenes]]
+
ResetModifierText(..), called when changing pages in Lemur, to clear out cV.modlistlast
  
==Effect Bypass Mode==
+
(cV.rState==5) modifiers are being queried
 +
SendGetModifier(..)
  
Axe-Fx III, FM9 and FM3 only.
+
(cV.rState==6) modifiers are being queried
 +
SendGetModifier(mbps[hw], mbps[hw+6], a[i]); response in HandleModifierValMsg(msg), calls UpdateModifier(b, p, m, v);
  
This parameter determines how an effect (block) is engaged/bypassed via MIDI. When set to “Value”, the bypass state of an effect assigned to a CC is controlled by the CC value (0 = off, 128 = on). When set to “Toggle”, the bypass state toggles whenever the CC message is received, regardless of the value.
+
(cV.rState==7) modifiers are being reset
 +
SendSetModifier(..)
  
==Send Realtime SysEx==
+
buildModCtlList() saves cV.modlist[] to cV.modlistlast[], iterates through all objects in cMain. To find build a cV.modlist[] of modifyable parameters within objects that 1. contain a bps[], 2. are in a visible block, 3. the block is active in the preset, the bps[6] is >= 0.  cV.dbltapzoom[] is filled with same array of objects
  
Supported on the Axe-Fx II and III, FM9 and FM3.
+
cS.DoubleTap() appears to be implemented to open a Modifier Dialog: dlgModifiers.showme(1); but it is not called within the Script.  This function will trigger a 'DoEveryFrame' midi query of the Modifier setting.
  
MIDI tempo and tuner data can be sent continuously from the unit. This allows an external MIDI controller to display the tuner on its display and make a tempo LED blink in time with the device's tempo. Transferring this data requires a bidirectional connection between the unit and the controller. This information is transmitted through MIDI OUT only, not via MIDI-over-USB.
+
3.09 TODO List:
  
This parameter doesn't have to be enabled for use with FC controllers.
+
1. confirm all modifier indexes on Fractal Parameters
  
Realtime SysEx on the Axe-Fx II is always disabled when entering the Utility > Preset menu.
+
2. call cS.DoubleTap() when Zoom == MOD and a modifyable control is Tapped.
  
Realtime SysEx is also used extensively by 3rd-party MIDI controllers to control the Axe-Fx III and FM3, as documented in  [http://www.fractalaudio.com/downloads/misc/Axe-Fx%20III%20MIDI%20for%203rd%20Party%20Devices.pdf this Guide].
+
3. verify control's txt value is rendered RED when control modified control is active (previously engaged, polled through DoEveryFrame())
  
<blockquote>"Sysex data doesn't have a channel. It is not a voice message. All equipment should ignore any sysex data that does not contain its manufacturer's ID. If you gear is responding to Fractal Audio sysex messages then it is violating the spec." [http://forum.fractalaudio.com/threads/weird-issue-with-axe-fx-ii-and-noise-over-midi.87255/#post-1062827] </blockquote>
+
===Project Globals===
  
==Program Change==
+
Var blkd=
  
Instructs the hardware to process or ignore ''incoming'' Program Changes.
+
Var blksq=
  
==Ignore Redundant PC==
+
Var blok=
  
If set to ON, this parameter tells the device to ignore an incoming MIDI Program Change if that preset is already active. This prevents unnecessary reloading and the audio gap that comes with that.
+
Var blx=
  
While the preset isn't loaded again, the current preset is reset to its original state, including the default scene.
+
Var debugflag=
  
<blockquote>"The current behavior is as designed. The reasoning behind the implementation is that if Ignore Redundant PC is on then sending a PC gets you back to the original state of the preset but there is no audio dropout as would happen if Ignore was off." [https://forum.fractalaudio.com/threads/ignore-redundant-pc-not-being-ignored.163776/post-1963417]</blockquote>
+
Var hw= 'hardware version =0 AxeFx, =1 others, Ultra etc.
  
This parameter defaults to ON on the Axe-Fx II, and OFF on the Axe-Fx III, FM9 and FM3.
+
Var Querying=
  
==Send MIDI PC==
+
tidx=
  
Supported on the Axe-Fx III, FM9 and FM3.
+
'''Script BuildParamList()'''
  
This setting determines whether the Axe-Fx III, FM9 or FM3 automatically sends a MIDI Program Change at its MIDI OUT port upon loading a new preset (front panel, using an FC or otherwise). You can select the MIDI channel to be used.
+
:Sets cV.bpobj to first object in cMain, and iterates through all objects to build cV.BlocksToRefresh list. For Block numbers (99..200) that are in the preset values are added to a refresh list
  
==MIDI PC Offset==
+
Script RefreshSequencer()
  
This parameter lets you shift Program Change numbers by 1, to improve compatibility with other MIDI devices. This is different from the Display Offset parameter (see above).
+
Script SendCCAxe(ccnum, ccval)
  
==PC Mapping==
+
Script SendConnectEffect(p1, p2, f)
  
This controls the mapping of incoming MIDI Program Changes to preset numbers and scenes on the Axe-Fx II and III. On the III, FM9 and FM3 this is further configured in the Mapping submenu.
+
Script SendGetByState()
  
==Initial Value External Controllers==
+
Script SendGetCabName(cabnum)
  
Read this: [[Remote_control,_pedals_and_switches#What_happens_if_the_pedal_is_not_connected|What happens if the pedal is not connected]]
+
Script SendGetModifier(b, p, m)
  
==MIDI commands to control functionality==
+
Script SendGetParam(b,p)
  
The MIDI/Remote menu on the Axe-Fx III, FM9 and FM3 lets you map MIDI commands to various functions on the device:
+
Script SendGetPresetName()
  
* recalling presets
+
Script SendGetPresetNumber()
* switching scenes
 
* set global I/O levels
 
* changing output level of current preset
 
* bypassing effect blocks
 
* changing channels
 
* external controllers
 
* looper
 
  
==Tuner on heel down==
+
Script SendGetRoutingGrid()
  
Firmware Ares 13.03 and later adds the ability to display the tuner with the expression pedal on "heel down". This is configured in the MIDI/Remote menu.
+
Script SendGetSceneState()
  
<blockquote>"Added “Tuner on Heel Down” to MIDI/Remote. The corresponding controller will automatically display the tuner when the value is less than 5%. Typically the user would set this to the same CC# (or internal/external pedal) that they use for their primary volume control, whether that is assigned to a global volume control or to a modifier in a Volume block. For example, if you use CC #23 as External Control 1 and connect that to the Volume 1 block in all your presets then set this to 23. Likewise if you use FC 1 Pedal 1 as a global Input 1 Volume control then set this to FC 1 Pedal 1. Now when you set your expression pedal to the heel down position the tuner will automatically display."</blockquote>
+
Script SendLooperMonEn(en)
  
=Scene MIDI block=
+
Script SendPG2Axe(pgnum)
  
Adding the [[Scene MIDI block]] to an FM3, FM9 or Axe-Fx III preset lets you send MIDI CCs or PCs through the MIDI OUT port when switching scenes.
+
Script SendPlaceEffect(b,pos,flag)
  
=Control Switches=
+
Script SendSavePath(program, bank)
  
Using [[Control Switches]] with an FC-6 or FC-12, or an FM9, FM3 or AX8, lets you transmit MIDI at will.
+
Script SendSetModifier(b, p, m, v)
  
Read this: [[Modifiers, Controllers and Control Switches]]
+
Script SendSetParam(b, p, v)
  
=MIDI Clock=
+
Script SendSetPresetName(name)
  
MIDI Clock is the same as MIDI Beat Clock. [http://en.m.wikipedia.org/wiki/MIDI_beat_clock More information]
+
Script SynthMidiNoeOffIn(MIDI_ARGS)
  
Fractal Audio's processors do not transmit MIDI Clock to other devices. They do process ''incoming'' MIDI clock. This can’t be disabled.
+
Script SynthMidiNoteOnIn(MIDI_ARGS)
  
Fractal Audio's processors do not support MIDI commands such as MIDI Start and MIDI Stop.
+
Script sxoutHandler(b,p, s, val)
  
<blockquote>"Our products do not recognize or support MTC. They do support MIDI Clock." [https://forum.fractalaudio.com/threads/fm3-and-fm3-going-nuts-when-clock-syncd.159967/post-1914946]</blockquote>
+
Script UserMidiCCIn(MIDI_ARGS)
  
=MIDI phantom power=
+
Script UserMIDINOTEIn(MIDI_ARGS)
  
The Axe-Fx II can provide power to MIDI devices via a MIDI cable, also known as "phantom power". This requires a 7-pin MIDI cable ([http://forum.fractalaudio.com/connections-routings/21547-axe-fx-7-pin-bidirectional-midi-pinout.html#post356116 pin definitions]) and the power supply for the floor controller to be plugged in at the rear of the Axe-Fx II.
+
==Objects==
  
Other Fractal Audio processors do not support MIDI phantom power.
+
Major AxeForLemur Objects:
  
Warning: do not connect a power supply to the phantom power input on the Axe-Fx II that has a load of more than 1A! E.g. power supplies for Liquid-Foot or RJM foot controllers.
+
===aUser===
 +
User specific settings, like favorite presets, midi channel. These can be persistent if the user re-saves the script after mondifications are made through the script itself. Global midi CC's are stored in gen1.cc*
  
<blockquote>"2.1mm is the standard for DC. 2.5mm is the standard for AC. The phantom power jack is designed for AC, hence the 2.5mm jack." [http://forum.fractalaudio.com/threads/the-phantom-power-connector-behind-the-axe-what-connection-it-is.86760/#post-1049803] </blockquote>
+
Querying : set to 1 during referesh, most likely to prevent re-triggering
  
The MIDI phantom power connection can be used for DC as well as AC power. [http://forum.fractalaudio.com/threads/midi-phantom-power-jack.112471/#post-1345043]
+
'''aUser.cMidi.gen2''' :: MIDI CC # numbers for different MIDI CC parameters
 +
 +
'''..scenescc[0]'''  :   MIDI CC # number for 'scene select'
  
=MIDI tutorial=
+
===cMain===
 +
User interface for Axe-Fx blocks. 
  
The explanation below is written by forum member Clarky.
+
cMain contains UI design and configuration for each Block (pair) Tab within AxeForLemur script
  
==What is MIDI?==
+
IntState3(..) macro, configures button labels within the UI interface.  Typically these buttons are for Block instance selection, but some are for selecting other aspects of each' block Tab.
  
MIDI = "Musical Instrument Digital Interface". If I turned that into more friendly English, I’d end up with something like this: MIDI is a means of “interfacing” [connecting] “Musical Instruments” together using a “digitally” encoded protocol [essentially a language]. It is a method of connecting together MIDI capable musical instruments or devices so that they can use a "language" to communicate with each other.
+
Each AxeForLemur Block Tab contains multiple containers, one for each UI element.   These containers more or less contain a symetrical set of attributes, functions and UI controls that allow for support from a common set of functions (else where in the code).
  
A key thing often misunderstood about MIDI is that it does not actually contain audio or sound, so you can’t actually "hear" MIDI. It’s simply a stream of information or instructions from one device to another. Essentially:
+
Each UI Element contains:
* "turn this 'thing' on in that device"
+
  bps: Midi / UI control structure
* "change the value of this parameter in that effect"
+
  ctl: the lemur screen object
* "play this note on that device using this patch"
+
    x : Primary value for this control
 +
    z : ???
 +
  txt:  A screen description of the parameter. Example ('volume')
 +
  txtval: text object on screen to describe the object parameter value.  Example (0..127)
 +
  Optional:
 +
    cbDlg: a pop up dialog object
 +
        x : value for the selected value of the dialog
 +
        tap(..) : function called to initialize the dialog
  
==What is MIDI used for?==
+
When a control changes a 'magic' must be called to send the ctl's value to the bps[..] defined midi destination
  
MIDI is basically all about control - one device being able to control another. Back in the 70’s it’d not be unusual to see a prog rock band with a keys player completely surrounded by all kinds of synthesizers and keyboards. Just take a look at pictures of Keith Emerson or Rick Wakeman from around the 1972 to 1978 era. Sometimes they’d want to play a musical phrase but use more than one sound at the same time and blend them together. In the early days they have to play the part with each hand playing a different synth. It was recognised that some sort of ‘remote control’ was needed. In the early days control was achieved via analogue signals but that had limitations of its own. The thing that really unlocked the door for control was MIDI because:
+
===cS===
* it was standardized, enabling devices made by different manufacturers to communicate
+
Common Scripting Object.
* it could communicate much more information that simple ‘on / off’ and pitch information
 
  
So think of MIDI as being the language used for a music specific ‘remote control’. With MIDI I can connect several synths together and use one of them to ‘play’ all of the others. I can use a floor controller [like the MFC] to control a keyboard or FX unit [like the Axe] to make it change preset [program] or to take control of some effect’s parameters enabling control in real-time via switches or expression pedals. I can use a Digital Audio Workstation [like Logic or Ableton] to control effects units [like the Axe] or play synths and keys. I can use a MIDI control surface to control a DAW remotely so that I can ‘play’, ‘stop’, ‘record’, use real faders [just like on a mixing desk] to control the software faders in the DAW’s mixer.
+
Common Script Object Container
  
MIDI can also be used to synchronize tape machines to a DAW or sequencer and provide a clock source.
+
'''addRefreshParam( b, p) : Adds a parameter to one of:
  
==What basics do I need to know?==
+
  (cV.blist[0..249],    cV.plist[0..249]),
 +
  (cV.blist2[250..499], cVplist2[250..499]),
 +
  (cV.blist3[500..749], cV.plist3[500..749]) at position cV.numcontrols,
  
IN / OUT / THRU – these are the MIDI sockets [ports] you’ll see on any MIDI device and here is what they do:
+
But doesn't appear to increase cV.numcontrols, called from Project.BuildParamList()
* IN – this contains the MIDI in-coming from the controlling instrument / device.
 
* OUT – this contains MIDI that is being created by the instrument / device.
 
* THRU – this is a copy of the MIDI that arrives from the MIDI IN and is sent outwards to other instruments/ devices.
 
* OUT / THRU – as you’d expect, this contains both OUT and THRU MIDI information.
 
  
Channels – MIDI uses to concept of channels to identify different devices. Example: I could have a Korg synth on channel 1, a Moog synth on channel 2, and could have a Roland to use as the ‘mother board’ [controller keyboard]. I would set the channels in the Korg and Moog myself manually. Roland OUT ----> IN Korg THRU ----> IN Moog. In the Roland I’d setup some presets to also send MIDI on channels 1 and / or 2. Imagine something like this: Roland preset 1 = piano in the Roland and also sends channel 1/pgm 20 [preset 20] which could be strings. I play the Roland preset 1 and hear piano. The MIDI sent from the Roland [MIDI OUT] arrives at the Korg [MIDI IN]. The Korg recognises that channel 1 means “it’s for me” and pgm 20 means “let’s use my strings sound that is stored in preset 20”. The outcome is that you hear piano and strings simultaneously and the Korg also sends a copy of the incoming MIDI IN to the MIDI THRU. The Korg’s MIDI THRU is connected to the Moog’s MIDI IN meaning that the Moog also receives the same MIDI information, but it will only react to anything that arrives on channel 2. So as this MIDI information is on channel 1 the Moog ignores it, and sends a copy of out to it’s MIDI THRU port.
+
'''cS.psmxfdr(obj, b, p, -1, 'label')'''
  
Some devices can be set to MIDI channel OMNI. This means “react to all in-coming MIDI messages from all channels”.
+
===cScanX===
  
Some examples of common MIDI messages that one device would send to another:
+
===AxeForLemur cShow===
* Note messages – this are used to tell keys / synths to turn on / off notes.
+
Group of scripts to refresh Axe Block Tabs.
* Program Change – this is a MIDI message that allows a device to make another device to change preset. This is exactly what the MFC does to the Axe.
 
* Control Change – this enables a device to control another device’s parameters remotely.
 
* System Exclusive [SysEx] – this allows manufacturers to add extra functions and capabilities to those found in regular MIDI. These ‘extras’ are bespoke / manufacturer specific, so you wouldn’t expect a Moog to be able to react to Korg SysEx. But two Korgs with SysEx would have some extra cool capabilities available.
 
  
==How does MIDI relate to the Axe-Fx II and MFC?==
+
===cTabSel===
  
By default, the Axe, the MFC and Axe-Edit are all set to MIDI channel 1. When you stomp on a switch on the MFC, the MFC sends a ‘program change’ message out to the Axe. This message contains the MIDI channel [channel 1] and the program [preset] number. The Axe receives this message and changes preset corresponding to the received program number.
+
===cV===
 +
Group of global variables.  
  
==IAs, controllers and modifiers==
+
'''blist, plist, blist2, plist2, blist3, plist3'''  250 entry lists of active 'b==block id's and p==parameter ids.  each list has a physical limit of 250 elements.  These 6 arrays constitute a 2D array of 750 items.
  
MIDI Control Change [CC] is extremely flexible and enables configurable parameters within the Axe [or any MIDI device] to be controlled remotely. This opens up a vast range of tonal possibilities. These are the key pieces of information that sit within a CC message:
+
===AxeForLemur ...===
* MIDI channel [so we know who this message is aimed at]
+
Pop Up Dialogs.
* CC#: there are 128 control ‘numbers’ available that number from 0 to 127. Some of these numbers are standardized by the industry, for example CC# 7 = master volume (volume control for the whole box, after all effects etc), CC# 16 = ribbon controller / general purpose slide 1 (keys / synth stuff).
 
  
Some CC values are ‘spare’. For example; values from 22 to 31 aren’t defined to you can assign them to anything you want.
+
Lesser Objects (for now)
  
So now let’s talk about the Axe. The Axe is designed to have a one to one relationship with a controller [such as the MFC]. This being the case, Fractal has created its own assignments of MIDI CC numbers and they can be seen via the front panel in I/O  > CTRL page. There are two columns in here:
+
cbHideRoutes :
* Left col = the ‘thing’ in the Axe that can be controlled.
 
* Right col = the MIDI CC number that will control it.
 
  
=MIDI controller tutorial=
+
cbHideRoutes :
  
[https://www.youtube.com/watch?v=cVJdBXoDTYM RJM explains the basics of a MIDI controller]
+
cbProgName : Button on bottom of UI to display dlgProgChange.showme(x)
  
=MIDI 2.0=
+
cbRefresh :
  
Manufacturers are working on an improved MIDI protocol: [https://www.midi.org/midi-articles/details-about-midi-2-0-midi-ci-profiles-and-property-exchange MIDI 2.0].
+
cbTapTempo : Sends a CC 14 value 127 to currently selected Axe target, method cbTapTempo.hdlSxin(..) sets the lemur Tap button different colors
  
=Troubleshooting=
+
cbZoom:  A double tap 'Zoom' function for sliders, dont know how this works.
  
==Google Chrome issue==
+
aUser.cMidi.gen2.ccTapTempo
  
[[Editors#Google_Chrome|Read this]]
+
''' Global Functions
  
==Wireless MIDI adapter gets very hot==
+
SendCC2Axe(..)
  
If a wireless MIDI gets very hot when connected to the FM3: [https://forum.fractalaudio.com/threads/midi-output-voltage-widi-master-is-getting-hot.171579/page-2 read this]
+
==Development Tools==
  
==MIDI ground issue==
+
[http://www.firstobject.com/dn_editor.htm firstobject XML Editor Application.]
 +
This is a light weight free XML editor that doesnt get confused by the Lemur script. The Editor has a good dual view ( one view is an XML object tree, the other side is the pure text.  Using F7 allows you to sync between the two.
  
<blockquote>(about MIDI corruption with certain amps): "On MIDI devices the MIDI Out jack should be grounded but the MIDI In jack should not be. MIDI devices powered by wall-warts aren't grounded. The AX-8 uses AC power and is therefore grounded. So a simple solution would be to cut the ground pin (pin 2) at the MIDI In (amp) side. Pin 2 is the important one. Pin 1 is often not wired and even if it is it's not-connected on the AX-8 end. The AX-8 uses pins 2, 4 and 5. The rest are not connected. Pin 2 is ground, 4 and 5 are the data. If the pin 2 is grounded at the amp side then current will flow in the ground which could corrupt the data." [http://forum.fractalaudio.com/threads/midi-issues-fractal-latency-issues.109286/page-5#post-1368042] </blockquote>
+
KDIFF3 [http://kdiff3.sourceforge.net/ http://kdiff3.sourceforge.net]
 +
Since the AxeForLemur is a large monolithic text file, having a good DIFF tool allows you to see the changes LemurEditor and text editors have applied to your file. The LemurEditor does some strange things to this template when it is edited, the preference is to make clean edits with FirstObject Editor, and not use the Lemur Editor directly, as it has a habit of changing many unintended parameters throughout the script.
  
==Hardware won't store MIDI parameters==
+
SVN or Git are good tools to manage progressive changes to the script.
  
If adjusted parameters in the MIDI menu are restored to their default values after powering off and on, there’s probably an issue with the internal battery. It’s exhausted or has come loose.
+
==Releases and Resources==
  
<blockquote>"It sounds like there is a short in the battery holder or at the memory IC. I've seen this once before. A solder blob was lodged under the battery holder." [http://forum.fractalaudio.com/threads/axe-fx-iii-does-not-remember-midi-settings.146083/page-2#post-1727976]</blockquote>
+
[http://forum.fractalaudio.com/axe-fx-ii-discussion/98926-return-lemur-support-here.html return-lemur-support-here]
  
==MIDI noise==
+
=Videos=
  
If you hear a tick in your audio signal which syncs to the tempo, and it's not the Metronome, it's probably MIDI noise bleeding into the signal. You can easily check this by turning off Send Realtime Sysex in the Setup menu. If the noise stops, it's indeed caused by the MIDI cabling. Use better MIDI cables and keep the MIDI cables away from problematic sources.
+
[[video:Cooper-MIDI]]
 +
[[video:Leon-MIDI]]
 +
[[video:RJM-MIDI]]
  
 
[[category:Axe-Fx2]]
 
[[category:Axe-Fx2]]
Line 485: Line 909:
 
[[category:FM3]]
 
[[category:FM3]]
 
[[category:FM9]]
 
[[category:FM9]]
 +
[[category:VP4]]
 
[[category:AX8]]
 
[[category:AX8]]
 
[[category:FX8]]
 
[[category:FX8]]
 
[[category:Remote]]
 
[[category:Remote]]
 
[[category:All]]
 
[[category:All]]

Latest revision as of 16:46, 10 September 2025

Axe-Fx III and MIDI

The Axe-Fx III has MIDI IN, OUT and THRU ports. The FM9 has a combined MIDI Out/Thru port.

Incoming MIDI data via MIDI IN or via MIDI-over-USB is indicated by a LED on the front panel.

Data at the MIDI IN port is passed through to the MIDI THRU port (FM9: MIDI OUT/THRU).

Fractal Audio's proprietary communication protocol (not MIDI) for the Axe-Fx III, FM3 and FM9 allows Fractal Audio's Fractal Audio FC-6 and FC-12 to control the device, through the FASLINK II port, or USB.

There's MIDI support for 3rd-party devices, such as RJM's MIDI foot controllers, to switch presets, scenes and channels, to turn effects on/off, to display preset and scene titles and the tuner and to control tap tempo. This is done through SysEx commands, documented in the Axe-Fx III MIDI for Third-Party Devices guide.

The Axe-Fx III, FM3 and FM9 do not use fixed MIDI CCs. But you can assign these as desired in SETUP > MIDI/Remote. This menu also lets you instruct the device to process or ignore incoming Program Changes, process or ignore duplicate/redundant Program Changes, send out Program Changes through the MIDI OUT port when loading presets, enable mapping of Program Changes, and choose between two Effect Bypass modes. The MIDI settings are part of the system data which can be backed up with Fractal-Bot.

The devices process incoming MIDI-over-USB, but don’t pass incoming MIDI data to outgoing USB. [1]

Windows computers require a driver for MIDI-over-USB. The driver can be downloaded from the product pages on Fractal Audio's website. Install the driver with Fractal-Bot. macOS computers do not require a driver because they're class compliant.

MIDI-over-USB is much faster on the Axe-Fx III and FM9 than it was on the II, because of the III's dedicated USB processor. Also, USB communication does not increase CPU usage.

FRACTAL AUDIO QUOTES


[2] The Axe-Fx III moves a LOT more data over USB than the II. The audio is 8x8 vs. 4x2 and the MIDI-Over-USB interface runs 10-100x faster. Therefore it is important that the cable adhere to specifications (5m max).

[3] Still USB-over-MIDI but at least 10x faster.

The Scene MIDI block in presets lets you send up to 8 MIDI CCs and PCs through the MIDI OUT port when switching scenes. Also, a Program Change can be transmitted to MIDI OUT upon preset loading.

The FC controllers provide additional MIDI features through the use of Control Switches.

The Owner's Manual lists the MIDI Program Changes that correspond with presets. The first value is MIDI Bank Select, the second one is MIDI Program Change.

  • Preset 0 = Bank/PC 0,0
  • Preset 128 = Bank/PC 1,0
  • Preset 256 = Bank/PC 2,0
  • Preset 384 = Bank/PC 3,0

MIDI Thru over USB is not supported.

FRACTAL AUDIO QUOTES


[4] That would be what we'd call "USB adapter Mode" and it is not a feature of our current generation of products at this time.

FM9 and MIDI

The FM9 provides the same MIDI support as the Axe-Fx III.

FM3 and MIDI

The FM3 has a MIDI IN port and a combined MIDI OUT/THRU port.

It supports MIDI like the Axe-Fx III and FM9 do.

However, the FM3 is NOT a MIDI-over-USB device. It communicates through USB with Fractal-Bot and the editor, but it does not appear as a MIDI device in a DAW or other MIDI programs. To add MIDI-over-USB functionality, use a separate MIDI/USB cable or interface.

The MIDI runs at 5V.

Read MIDI output voltage: WIDI Master is getting hot about the FM3 getting hot when connecting a wireless MIDI adapter for more information.

FRACTAL AUDIO QUOTES


[5] MIDI over USB is used for Fractal-Bot and FM3-Edit, but the FM3 does not appear amongst the MIDI devices on your computer. For the purpose of preset changes, cc messages, tempo, etc, it can definitely be controlled by a 3rd party MIDI device or MIDI interface, such as a MIDI Sport.

[6] The FM-3 does NOT support MIDI-over-USB. Sending MIDI to it over USB can lead to unpredictable behavior.

VP4 and MIDI

The VP4 has 3.5 mm (1/8”) MIDI IN and OUT ports. Adapters are available at the Fractal Audio shop.

The Boss BMIDI-5-35 cable has been tested and works with the VP4 to connect to 5-pin MIDI gear.

The VP4 supports:

  • Sending and receiving Program Changes (PC), to select presets
  • Sending and receiving Control Changes (CC), to turn effects on/off and control other stuff
  • MIDI-over-USB
  • MIDI clock (receiving only, currently)
  • Software MIDI Thru

A table in the Manual translates MIDI Program Changes to VP4 presets.

FRACTAL AUDIO QUOTES


[7] The VP4 supports MIDI over USB so it appears as MIDI ports in a DAW.

[8] Messages sent to the VP4 via MIDI-over-USB are not echoed to its MIDI OUT port, and messages received at its MIDI IN port are not passed to the computer via USB.

[9] The VP4 has fewer than 128 presets. MIDI Bank Select messages are not necessary to access all of its presets

FC controllers: no MIDI support

The Fractal Audio FC-6 and FC-12 don't have onboard MIDI functionality and can't be used by themselves to control MIDI devices directly.

However, the connected processors have MIDI OUT ports. The FC controller can initiate MIDI operations through Control Switches, which are transmitted via the MIDI OUT port on the processor, or via the Scene MIDI block.

FRACTAL AUDIO QUOTES


[10] The system has a MIDI jack. It's on the Axe-Fx III! Actions on the foot controller can cause MIDI to be transmitted to downstream devices.

MIDI/Remote menu

This menu can be accessed through SETUP on the hardware and in the editors.

The settings are saved as part of the system data backup you create with Fractal-Bot.

The parameters are also explained in the Owners Manuals.

MIDI Channel

Set this to the desired channel to communicate with nother MIDI device. It defaults to 1.

Don't select OMNI, because this will slow down MIDI traffic.

MIDI Thru

On devices without a physical MIDI Thru port (FM3, FM9, VP4), this merges messages received at the 5-pin MIDI IN port with any internally generated MIDI data at the MIDI THRU port.

FRACTAL AUDIO QUOTES


[11] You cannot pass USB MIDI messages to the MIDI out port. The feature that would be required is "USB adapter mode" which does not exist on the Axe-Fx III.

[12] MIDI Thru is just that, it's a hardware thru. The Axe-Fx does not send any data to MIDI Thru.

Display Offset

The processor starts numbering presets at 0. This parameter lets you shift the displayed number by 1. This adjusts the displayed number only, not the underlying Program Change number (see MIDI PC Offset).

A copy of this parameter also appears in SETUP > Global Settings on the Axe-Fx III, FM9 and FM3.

Scene Revert

Read Scenes for more information.

Effect Bypass Mode

Axe-Fx III, FM9 and FM3 only.

This parameter determines how an effect (block) is engaged/bypassed via MIDI. When set to Value, the bypass state of an effect assigned to a CC is controlled by the CC value (0 = off, 128 = on). When set to Toggle, the bypass state toggles whenever the CC message is received, regardless of the value.

Send Realtime SysEx

Supported on the Axe-Fx II and III, FM9 and FM3.

MIDI tempo and tuner data can be sent continuously from the unit (the only data to be "pushed" by the unit). This allows an external MIDI controller to display the tuner on its display and make a tempo LED blink in time with the device's tempo. Transferring this data requires a bidirectional connection between the unit and the controller.

This parameter doesn't have to be enabled for use with Fractal Audio FC-6 and FC-12.

Realtime SysEx on the Axe-Fx II is always disabled when entering the Utility menu.

Realtime SysEx is also used extensively by 3rd-party MIDI controllers to control the Axe-Fx III and FM3, as documented in AXE-FX III MIDI FOR THIRD-PARTY DEVICES.

FRACTAL AUDIO QUOTES


[13] Sysex data doesn't have a channel. It is not a voice message. All equipment should ignore any sysex data that does not contain its manufacturer's ID. If you gear is responding to Fractal Audio sysex messages then it is violating the spec.

Program Change

Instructs the hardware to process or ignore incoming Program Changes.

On the VP4, this is: Receive MIDI PC.

Ignore Redundant PC

If set to ON, this parameter tells the device to ignore an incoming MIDI Program Change if the corresponding preset is already loaded. This prevents unnecessary reloading and the audio gap that may occur. While the preset isn't re-loaded, effect blocks return to their saved states and the default scene is selected.

This parameter defaults to OFF on the Axe-Fx III, FM9, FM3, VP4.

FRACTAL AUDIO QUOTES


[14] The current behavior is as designed. The reasoning behind the implementation is that if Ignore Redundant PC is on then sending a PC gets you back to the original state of the preset but there is no audio dropout as would happen if Ignore was off.

Send MIDI PC

Supported on the Axe-Fx III, FM9, FM3, VP4.

This setting determines whether the Axe-Fx III, FM9, FM3 and VP4 automatically send a MIDI Program Change at its MIDI OUT port upon loading a new preset (front panel, using an FC or otherwise). You can select the MIDI channel to be used.

MIDI PC Offset

This parameter lets you shift Program Change numbers by 1, to improve compatibility with other MIDI devices. This is different from the Display Offset parameter (see above).

PC Mapping

This controls the mapping of incoming MIDI Program Changes to preset numbers and scenes on the Axe-Fx II and III. On the III, FM9 and FM3 this is further configured in the Mapping submenu.

Initial Value External Controllers

Read What happens if the pedal is not connected for more information.

Tuner on heel down

Read this: Tuner

More parameters

The MIDI/Remote menu on the Axe-Fx III, FM9 and FM3 lets you map MIDI commands to various other functions on the device:

  • Load or switch presets
  • Set global I/O levels
  • Change output level
  • Bypass effect blocks
  • Change channels
  • Configure external controllers
  • Configure the Looper
  • etc.

Send a MIDI Program Change

When loading a preset 
Enable the SEND MIDI PC parameter in SETUP to instruct the device to send a MIDI Program Change through the MIDI OUT port when a preset is loaded. The MIDI channel is selectable.
When switching scenes 
The Scene MIDI block on the FM3, FM9, Axe-Fx III and VP4 lets you send MIDI CCs or PCs through the MIDI OUT port when switching scenes.
With a Control Switch 
Configure Control Switches on an Axe-Fx III, FM3 or FM9, and assign these to onboard foot switches or an FC-6 or FC-12 to transmit MIDI Program Changes and Control Changes when desired.

MIDI Clock

MIDI Clock is the same as MIDI Beat Clock. See Wikipedia's MIDI Beat Clock article for more information.

In current device firmware, the Axe-Fx III, FM3 and FM9 are capable of handling incoming MIDI Clock as well as transmitting it, via MIDI (default) and USB. Make sure to install the latest version of the USB firmware.

MIDI commands such as MIDI Start and MIDI Stop (MIDI Time Code) are not supported.

FRACTAL AUDIO QUOTES


[15] Our products do not recognize or support MTC. They do support MIDI Clock.

[16] The audio processing thread is, necessarily, the highest priority thread. MIDI Clock is generated by a lower priority thread. If the CPU usage is high enough that thread may get starved and will cause the clock to be inaccurate. The solution is to reduce CPU usage. You can't get blood from a stone.

Tips, tricks and troubleshooting

MIDI System Exclusive (SysEx)

Known SysEx commands for Fractal Audio devices are listed on the MIDI SysEx wiki page.

iOS devices

Use a USB-A to USB-B cable, or a wireless MIDI adapter, or the Apple Lightning-to-USB Camera Adapter, to connect the Axe-Fx III or FM9 directly to an iOS device. This lets apps such as BandHelper send and receive MIDI commands and USB Audio to/from the device without requiring an additional MIDI-to-USB interface (which the Axe-Fx II required).

The FM3 does not support a direct connection to iOS devices.

Issues with Google Chrome, Pro Tools, Logic

Read Editors for more information.

Issue with Diezel VH4 amplifier

Read Diezel VH-4 wrong channels recall with FM9.

FRACTAL AUDIO QUOTES


[17] Diezel amps have a known bug in the MIDI. If you contact them they can send you a new EPROM to install that fixes the issue.

MIDI ground issue

FRACTAL AUDIO QUOTES


[18] On MIDI devices the MIDI Out jack should be grounded but the MIDI In jack should not be. MIDI devices powered by wall-warts aren't grounded. The AX-8 uses AC power and is therefore grounded. So a simple solution would be to cut the ground pin (pin 2) at the MIDI In (amp) side. Pin 2 is the important one. Pin 1 is often not wired and even if it is it's not-connected on the AX-8 end. The AX-8 uses pins 2, 4 and 5. The rest are not connected. Pin 2 is ground, 4 and 5 are the data. If the pin 2 is grounded at the amp side then current will flow in the ground which could corrupt the data.

MIDI/Remote menu looses settings

If adjusted parameters in SETUP return to their default values after powering off and on, there’s probably an issue with the internal battery. It’s exhausted or has come loose.

FRACTAL AUDIO QUOTES


[19] It sounds like there is a short in the battery holder or at the memory IC. I've seen this once before. A solder blob was lodged under the battery holder.

MIDI phantom power

Only the Axe-Fx II provides power to MIDI devices over a MIDI cable, also known as "phantom power". This requires a 7-pin MIDI cable (pin definitions) and the power supply for the floor controller to be plugged in at the rear of the Axe-Fx II.

Other Fractal Audio processors (current and legacy) do NOT support phantom power.

The MIDI phantom power connection can be used for DC as well as AC power. [20]

Warning: do not connect a power supply to the phantom power input on the Axe-Fx II that has a load of more than 1A! E.g. power supplies for Liquid-Foot or RJM foot controllers.

PREVIOUS GENERATIONS


[21] 2.1mm is the standard for DC. 2.5mm is the standard for AC. The phantom power jack is designed for AC, hence the 2.5mm jack.

MIDI noise bleed

If you hear a tick in your audio signal which syncs to the tempo, and it's not the Metronome, it's probably MIDI noise bleeding into the signal. You can easily check this by turning off Send Realtime Sysex in SETUP. If the noise stops, it's caused by the MIDI cabling. Use better MIDI cables and keep the MIDI cables away from problematic sources. If that doesn't solve the issue, consider a wireless MIDI (Bluetooth) connection.

Legacy devices and MIDI

Basic MIDI tutorial

The explanation below is written by Clarky. It refers to MIDI control on the Axe-Fx II.

What is MIDI?

MIDI = Musical Instrument Digital Interface.

If I turned that into more friendly English, I’d end up with something like this: MIDI is a means of interfacing or connecting musical instruments together using a digitally encoded protocol, essentially a language. It is a method of connecting together MIDI-capable musical instruments or devices so that they can use a language to communicate with each other.

A key thing often misunderstood about MIDI is that it does not actually contain audio or sound, so you can’t actually hear MIDI. It’s simply a stream of information or instructions from one device to another, essentially:

  • turn this 'thing' on in that device
  • change the value of this parameter in that effect
  • play this note on that device using this patch

What is MIDI used for?

MIDI is basically all about control - one device being able to control another. Back in the 70’s it’d not be unusual to see a prog rock band with a keys player completely surrounded by all kinds of synthesizers and keyboards. Just take a look at pictures of Keith Emerson or Rick Wakeman from around the 1972 to 1978 era. Sometimes they’d want to play a musical phrase but use more than one sound at the same time and blend them together. In the early days they have to play the part with each hand playing a different synth. It was recognised that some sort of ‘remote control’ was needed. In the early days control was achieved via analogue signals but that had limitations of its own. The thing that really unlocked the door for control was MIDI because:

  • it was standardized, enabling devices made by different manufacturers to communicate
  • it could communicate much more information that simple ‘on / off’ and pitch information

So think of MIDI as being the language used for a music specific ‘remote control’. With MIDI I can connect several synths together and use one of them to ‘play’ all of the others. I can use a floor controller [like the MFC] to control a keyboard or FX unit [like the Axe] to make it change preset [program] or to take control of some effect’s parameters enabling control in real-time via switches or expression pedals. I can use a Digital Audio Workstation [like Logic or Ableton] to control effects units [like the Axe] or play synths and keys. I can use a MIDI control surface to control a DAW remotely so that I can ‘play’, ‘stop’, ‘record’, use real faders [just like on a mixing desk] to control the software faders in the DAW’s mixer.

MIDI can also be used to synchronize tape machines to a DAW or sequencer and provide a clock source.

What basics do I need to know?

IN / OUT / THRU – these are the MIDI sockets [ports] you’ll see on any MIDI device and here is what they do:

  • IN – this contains the MIDI in-coming from the controlling instrument / device
  • OUT – this contains MIDI that is being created by the instrument / device
  • THRU – this is a copy of the MIDI that arrives from the MIDI IN and is sent outwards to other instruments/ devices
  • OUT / THRU – as you’d expect, this contains both OUT and THRU MIDI information

Channels – MIDI uses to concept of channels to identify different devices. Example: I could have a Korg synth on channel 1, a Moog synth on channel 2, and could have a Roland to use as the ‘mother board’ [controller keyboard]. I would set the channels in the Korg and Moog myself manually. Roland OUT ----> IN Korg THRU ----> IN Moog. In the Roland I’d setup some presets to also send MIDI on channels 1 and / or 2. Imagine something like this: Roland preset 1 = piano in the Roland and also sends channel 1/pgm 20 [preset 20] which could be strings. I play the Roland preset 1 and hear piano. The MIDI sent from the Roland [MIDI OUT] arrives at the Korg [MIDI IN]. The Korg recognises that channel 1 means “it’s for me” and pgm 20 means “let’s use my strings sound that is stored in preset 20”. The outcome is that you hear piano and strings simultaneously and the Korg also sends a copy of the incoming MIDI IN to the MIDI THRU. The Korg’s MIDI THRU is connected to the Moog’s MIDI IN meaning that the Moog also receives the same MIDI information, but it will only react to anything that arrives on channel 2. So as this MIDI information is on channel 1 the Moog ignores it, and sends a copy of out to it’s MIDI THRU port.

Some devices can be set to MIDI channel OMNI. This means “react to all in-coming MIDI messages from all channels”.

Some examples of common MIDI messages that one device would send to another:

  • Note messages – this are used to tell keys / synths to turn on / off notes
  • Program Change – this is a MIDI message that allows a device to make another device to change preset. This is exactly what the MFC does to the Axe
  • Control Change – this enables a device to control another device’s parameters remotely
  • System Exclusive [SysEx] – this allows manufacturers to add extra functions and capabilities to those found in regular MIDI. These ‘extras’ are bespoke / manufacturer specific, so you wouldn’t expect a Moog to be able to react to Korg SysEx. But two Korgs with SysEx would have some extra cool capabilities available.

Control Changes

MIDI Control Change [CC] is extremely flexible and enables configurable parameters within the Axe [or any MIDI device] to be controlled remotely. This opens up a vast range of tonal possibilities. These are the key pieces of information that sit within a CC message:

  • MIDI channel [so we know who this message is aimed at]
  • CC#: there are 128 control ‘numbers’ available that number from 0 to 127. Some of these numbers are standardized by the industry, for example CC# 7 = master volume (volume control for the whole box, after all effects etc), CC# 16 = ribbon controller / general purpose slide 1 (keys / synth stuff).

Some CC values are ‘spare’. For example; values from 22 to 31 aren’t defined to you can assign them to anything you want.

So now let’s talk about the Axe. The Axe is designed to have a one to one relationship with a controller [such as the MFC]. This being the case, Fractal has created its own assignments of MIDI CC numbers and they can be seen via the front panel in Setup > CTRL. There are two columns in here:

  • Left col = the ‘thing’ in the Axe that can be controlled
  • Right col = the MIDI CC number that will control it

Axe-Fx II

The Axe-Fx II has MIDI IN, OUT and THRU ports. Data at the MIDI IN port is passed through to the MIDI THRU port. Incoming MIDI data via MIDI IN or via MIDI-over-USB is indicated by a LED on the front panel. MIDI-over-USB is managed by the main DSP, which is why USB communications increase CPU usage. Data transfers happen via MIDI, MIDI-over-USB, FASLINK or Ethernet/Ethercon. There's support for MIDI controllers through MIDI PCs, MIDI CCs and SysEx. Realtime SysEx is used to provide MIDI controllers with Tuner and Tempo and Metronome data. MIDI SysEx is used extensively for communication with the editor. MIDI-over-USB is supported for incoming as well as outgoing transmissions. MIDI CCs are set in SETUP > MIDI. In that menu, you can instruct the II to process or ignore incoming Program Changes, process or ignore duplicate ("redundant") Program Changes, and enable mapping of Program Changes. The MIDI settings are part of the system settings which can be backed up with Fractal-Bot. The II does not transmit a MIDI PC via MIDI OUT when changing presets on the hardware.

Below is a list of all MIDI CCs on the Axe-Fx II XL+. The CCs are listed in SETUP as well. There's also a list in the Owners Manual.

  • INPUT VOLUME 10
  • OUT1 VOLUME 11
  • OUT2 VOLUME 12
  • BYPASS 13
  • TEMPO TAP 14
  • TUNER 15
  • EXTERNAL 1 16
  • EXTERNAL 2 17
  • EXTERNAL 3 18
  • EXTERNAL 4 19
  • EXTERNAL 5 20
  • EXTERNAL 6 21
  • EXTERNAL 7 22
  • EXTERNAL 8 23
  • EXTERNAL 9 24
  • EXTERNAL 10 25
  • EXTERNAL 11 26
  • EXTERNAL 12 27
  • LOOPER1 REC 28
  • LOOPER1 PLAY 29
  • LOOPER1 ONCE 30
  • LOOPER1 DUB 31
  • LOOPER1 REV 32
  • LOOPER2 BYP 33
  • LOOPER2 HALF 120
  • LOOPER2 UNDO 121
  • METRONOME 122
  • SCENE SELECT 34
  • SCENE INCR 123
  • SCENE DECR 124
  • VOLUME INCR 35
  • VOLUME DECR 36
  • AMP1 BYPASS 37
  • AMP2 BYPASS 38
  • CABINET1 BYP 39
  • CABINET2 BYP 40
  • CHORUS1 BYP 41
  • CHORUS2 BYP 42
  • COMPRESS1 BYP 43
  • COMPRESS2 BYP 44
  • CROSSOVER 1 BYP 45
  • CROSSOVER 2 BYP 46
  • DELAY1 BYP 47
  • DELAY2 BYP 48
  • DRIVE1 BYP 49
  • DRIVE2 BYP 50
  • ENHANCER BYP 51
  • FILTER1 BYP 52
  • FILTER2 BYP 53
  • FILTER3 BYP 54
  • FILTER4 BYP 55
  • FLANGER1 BYP 56
  • FLANGER2 BYP 57
  • FORMANT BYP 58
  • FXLOOP BYP 59
  • GATE1 BYP 60
  • GATE2 BYP 61
  • GRAPHEQ1 BYP 62
  • GRAPHEQ2 BYP 63
  • GRAPHEQ3 BYP 64
  • GRAPHEQ4 BYP 65
  • MEGATAP1 BYP 66
  • MULTICOMP1 BYP 67
  • MULTICOMP2 BYP 68
  • MULTIDLY1 BYP 69
  • MULTIDLY2 BYP 70
  • PARAEQ1 BYP 71
  • PARAEQ2 BYP 72
  • PARAEQ3 BYP 73
  • PARAEQ4 BYP 74
  • PHASER1 BYP 75
  • PHASER2 BYP 76
  • PITCH1 BYP 77
  • PITCH2 BYP 78
  • QDCHORUS1 BYP 79
  • QDCHORUS2 BYP 80
  • RESONATR1 BYP 81
  • RESONATR2 BYP 82
  • REVERB1 BYP 83
  • REVERB2 BYP 84
  • RINGMOD BYP 85
  • ROTARY1 BYP 86
  • ROTARY2 BYP 87
  • SYNTH1 BYP 88
  • SYNTH2 BYP 89
  • TREMOLO1 BYP 90
  • TREMOLO2 BYP 91
  • VOCODER BYP 92
  • VOLUME1 BYP 93
  • VOLUME2 BYP 94
  • VOLUME3 BYP 95
  • VOLUME4 BYP 96
  • WAHWAH1 BYP 97
  • WAHWAH2 BYP 98
  • TONEMATCH BYP 99
  • AMP1 X/Y 100
  • AMP2 X/Y 101
  • CABINET1 X/Y 102
  • CABINET2 X/Y 103
  • CHORUS1 X/Y 104
  • CHORUS2 X/Y 105
  • DELAY1 X/Y 106
  • DELAY2 X/Y 107
  • DRIVE1 X/Y 108
  • DRIVE2 X/Y 109
  • FLANGER1 X/Y 110
  • FLANGER2 X/Y 111
  • PHASER1 X/Y 112
  • PHASER2 X/Y 113
  • PITCH1 X/Y 114
  • PITCH2 X/Y 115
  • REVERB1 X/Y 116
  • REVERB2 X/Y 117
  • ROTARY1 X/Y 125
  • ROTARY2 X/Y 126
  • WAHWAH1 X/Y 118
  • WAHWAH2 X/Y 119

MIDI THRU:

  • With the MFC­‐101 at the FASLINK port, do not use the MIDI THRU port. Instead, connect downstream devices to the MIDI OUT port and set MFC ECHO TO MIDI OUT to “ON” in SETUP. This turns MIDI OUT into a “soft thru".
  • If your MFC-101 or other controller is connected to the Axe­‐Fx II's MIDI IN port — whether using 5-­ or 7‐pin — use the standard 5‐pin MIDI THRU port. No special settings are required.
  • More information about the MIDI THRU functionality of the Axe-Fx II XL and XL+ can be found in the MIDI THRU Guide.

The MFC ECHO TO MIDI OUT option in the system settings for the XL and XL+ only, echoes all MIDI data from the MFC to MIDI Out. This can be used to send MIDI PC and CC messages to other equipment connected to MIDI Out.

PREVIOUS GENERATIONS


[22] The Axe-Fx II is not designed to be a general-purpose MIDI I/O. It can handle most things but not large sysex dumps.

[23] The Axe-Fx simply passes the data. It doesn't parse messages. If a message is arriving altered then the fault is in the monitoring software or the OS.

[24] MIDI Thru is a "soft" thru. It the delay is problematic for you then you need to change the order of things or use a MIDI splitter.

[25] The Axe-Fx was never designed to support multiple MIDI inputs simultaneously.

AX8

The AX8 has MIDI IN and MIDI OUT/THRU ports and supports soft MIDI Thru (MIDI IN > MIDI OUT).

Incoming MIDI data is indicated by a LED on the top panel. Data at the MIDI IN port is passed through to the MIDI THRU port.

MIDI-over-USB is managed by the main DSP which is why USB communications increase CPU usage. Data transfers happen via MIDI or MIDI-over-USB. MIDI SysEx is used extensively for communication with the editor, but only through MIDI-over-USB.

The AX8 accepts incoming MIDI PCs/CCs through MIDI IN and MIDI USB. It does not transmit MIDI CCs itself. The MIDI settings are part of the system settings which can be backed up with Fractal-Bot. The AX8 can send out a single MIDI Progam Change when loading a preset scene. The PC and the MIDI channel can vary per scene.

When sending from the AX8, MIDI Program Changes are sent via the MIDI Out/Thru port, and SysEx format MIDI Program Changes are sent via USB port.

FX8

The FX8 has MIDI IN and MIDI OUT/THRU ports. It supports soft MIDI Thru (MIDI IN > MIDI OUT). Data at the MIDI IN port is passed through to the MIDI THRU port.

The FX8 does not have a hardware LED for incoming MIDI traffic, unlike the Axe-Fx II and AX8; when it detects incoming MIDI data, an indicator appears at the top of the LCD screen.

MIDI-over-USB is handheld by the main DSP which is why USB communications increase CPU usage. Data transfers happen via MIDI or MIDI-over-USB.

MIDI SysEx is used extensively for communication with the editor, but only through MIDI-over-USB. The FX8 accepts incoming MIDI CCs through MIDI IN.

MIDI CCs are set in the system settings. The MIDI settings are part of the System Settings which can be backed up with Fractal-Bot. The FX8 can send out a single MIDI Progam Change and a MIDI Control Change when changing scenes, which can vary per scene. The FX8 can send MIDI data using a footswitch which is assigned to a MIDI footswitch block. It can send a PC and a CC, when turning the switch ON or OFF. This is configured on the Footswitch page.

The block supports X/Y switching.

AxeForLemur (legacy)

AxeForLemur is a Lemur Template designed by David Sorlien to control the Axe-Fx. The Template runs on the Lemur APP by Liine, and connects wirelessly through a logical midi connection to the AxeFx.
This page is intended for users and developers of this template.

Usage

AxeForLemur is a JZML script, licensed by Creative Commons to be a non-commercial, free to use script. The script runs on IOS and Android devices with the Lemur Application from Liine. The Lemur application communicates with the Axe-Fx either through a direct MIDI connection that is connected either through USB or MIDI to the Axe-Fx, or through Wi-Fi to a host computer.

To configure an IOS/Android Patch Editor for the Axe-Fx:

  1. Purchase the Lemur App (approximately $20-$35) and install it on your Tablet or iPad.
  2. Go to the Liine Website and register yourself as a user, then download the Lemur Editor and Daemon Software.
  3. Connect your Tablet or iPad to your computer's IP network. Verify IP address, and ping your tablet to verify.
  4. Start the Lemur App on your Tablet or iPad.
  5. Download the AxeForLemur.jzml script. The current version is 3.08.
  6. On your PC run the LemurEditor and load the AxeForLemur.jzml script, click Connect to send the script to your Tablet or iPad.
  7. You should see the AxeForLemur Script on your iPad, on the Default AMP page.
  8. If your Axe-Fx is connected to your PC/Mac through a USB cable, run the LIINE LEMUR DAEMON on your machine. This daemon will provide an IP Socket on the Network for MIDI and OSC communications from the iPad to any MIDI devices on your PC/Mac.
  9. Within Lemur on your Tablet or iPad open the Settings drop down list and select "More Settings...", Setup Midi Targets, From: and To:. You may need to tap "Add Target". You should see a list of network computers, with the MIDI devices highlighted. Choose Axe-Fx from the computer that is running the LEMUR DAEMON, for both "From: and "To:. If no devices show up, verify that the iPad is connected to the IP network, and that the Lemur Daemon is running, and the Axe-FX is turned on, and it is connected with USB or MIDI cable.
  10. On the Preset Select page of the AxeForLemur script, configure the MIDI settings to match your setup. Example, Column-A Device should be set to AxeFxII or AxeFxXL+ etc, MIDI channel to "1" to match your MIDI settings, and Lemur target set to the Target within the Lemur Menu.
  11. Test by tapping the Preset Up/Down.
  12. Troubleshooting can be a bit challenging and might require a bit of system debugging and tweaking.

Design

Design background into key elements of the AxeToLemur script:

Axe For Lemur is a comprehensive Lemur script based in Quasi XML, Objector based C-Script without pre-processor, structures, pointers etc. The Script is object-based, and exists in the JazzInterface tab object AxeForLemur. Global references exist in this scope.

Design Initialization

Design Device Selection

The preset page (AxeForLemur/dlgProgChange/T1) contains a matrix of MIDI settings for up to four target devices.

For each 'Target Device' The user can select and increment/decrement (cTargets/padUpDn) the following (cTargets/swSettings):

  • Type : { AxeFx, AxeFx II, Gen Midi, No Bank, Eclipse } = aUser.cMidi.devtypes[ ]
  • Display Offset : { 0 or 1 } = aUser.cMidi.dispoffset[ ]
  • MIDI Channel : { 1 .. 16} = aUser.cMidi.chans[ ]
  • Lemur Target : { 0.. 3 } = aUser.cMidi.targets[ ]

The user can select one of A,B,C, or D target devices; only one is active at a time.

The objective is to integrate AxeFxXL and AxeFxXL+ into the list of supported Device Types.

Since this template was last updated by David Sorlien, two new AxeFx devices have been created. The XL and XL+ have more or less the same SysEx protocols as the AxeFx ( subject to change ), but have New SysEx device ID codes. The following is a break down of work required to make AxeForLemur support other Fractal Audio Devices.

Essentially the T1/cTargets/swSettings is a 4 x 4 Switch matrix. Pressing a button will provide a 0..16 button index within the T1/cTargets/swSettings/x variable. Pressing one of the T1/cTargets/padUpDn will cause the selected T1/cTargets/swSettings/x indexed value to be Incremented/decremented. The padUpDn/tap() changesbutton matrix.

Add two more values to devtypes

 change:
   aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]+1, 0, 4);
   aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]-1, 0, 4);
 to:
   aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]+1, 0, 6);
   aUser.cMidi.devtypes[a] = clamp(aUser.cMidi.devtypes[a]-1, 0, 6);

Add two more strings to button objet lablels

 swSettings/updatelabels()
 for(i=0;i<4;i++){
   if(aUser.cMidi.devtypes[i]==0) a[i] = 'AxeFX';
   else if(aUser.cMidi.devtypes[i]==1) a[i] = 'AxeFX II';
   else if(aUser.cMidi.devtypes[i]==2) a[i] = 'Gen MIDI';
   else if(aUser.cMidi.devtypes[i]==3) a[i] = 'No Bank';
   else if(aUser.cMidi.devtypes[i]==4) a[i] = 'Eclpse';
   else if(aUser.cMidi.devtypes[i]==5) a[i] = 'AxeXL';
   else if(aUser.cMidi.devtypes[i]==6) a[i] = 'AxeXL+'; }

Change Device ID's within SysEx messages to include devie ids { 6 and 7 }

 <SCRIPT name="IsAxeSysex(msg)" ..
 if(msg[0]==0 && msg[1]==1 && msg[2]==0x74 && ( msg[3]<=3 || msg[3]==6 || msg[3]==7 )
 ...
 else if(msg[3]==3) st = 'Axe-FX II';
 else if(msg[3]==6) st = 'Axe-FX XL';
 else if(msg[3]==7) st = 'Axe-FX XL+';

and change all hard coded device id's "0x74,3" with "0x74,6" or "0x74,7" in

 SendSetParam(b, p, v)
 SendGetParam(b, p)
 SendGetPresetName()
 SendGetBypState()
 SendGetPresetNumber()
 SendLooperMonEn(en)
 SendGetSceneState()
 SendSetModifier(b, p, m, v)
 SendGetModifier(b, p, m)
 SendPlaceEffect(b, pos, flag)
 SendConnectEffect(p1, p2, f)
 SendSetPresetName(name)
 SynthMidiNoteOnIn(MIDI_ARGS)
 SendSavePatch(program, bank)
 SendGetCabName(cabnum)

It makes sense to define a class variable like cV.DevID, and make sure it is set on startup by the AxeFx device ID selected by the A,B,C,D device selector.

Design Modifiers

Modifiers provide a means to dynamically change a subset of the block parameters with automatic, and external functions. The AxeToLemur Script has a partial implementation of Modifiers. The AxeToLemur.pdf describes 'double tapping' the intended modify-able' control to enable modifier, but this doesn't appear to be within the implementation.

Within the 'control's bps[] array, for hw==0, element at index==6 is the Modifier number, if this value is >= 0, then the control should have modify-able values. This applies to 'bps' of sliders, custom buttons, muxed-sliders. If the 'control's bps[8] is set to 1, then there is an active modifier on the control.

It is assumed that 'double tapping' the 'Zoom' button will enable a RED "MOD" feature on the Zoom button. cS.DoubleTap() captures double tap event. This sets cV.dbltapzoom[2] = 1; A parameter that is 'Modify-able' has a Green 'txt' value.

As of 3.08, the repainting logic within the APP did not support GREEN 'txt' labels.

cS.psmxfdr(obj, p, p, m, t), and cS.psmxcb(obj,b,p,m,t) used to set/map a 'muxed fader' to an AxeFx control. This function also sets the colour of the text of a control

Notes:

ResetModifierText(..), called when changing pages in Lemur, to clear out cV.modlistlast

(cV.rState==5) modifiers are being queried SendGetModifier(..)

(cV.rState==6) modifiers are being queried SendGetModifier(mbps[hw], mbps[hw+6], a[i]); response in HandleModifierValMsg(msg), calls UpdateModifier(b, p, m, v);

(cV.rState==7) modifiers are being reset SendSetModifier(..)

buildModCtlList() saves cV.modlist[] to cV.modlistlast[], iterates through all objects in cMain. To find build a cV.modlist[] of modifyable parameters within objects that 1. contain a bps[], 2. are in a visible block, 3. the block is active in the preset, the bps[6] is >= 0. cV.dbltapzoom[] is filled with same array of objects

cS.DoubleTap() appears to be implemented to open a Modifier Dialog: dlgModifiers.showme(1); but it is not called within the Script. This function will trigger a 'DoEveryFrame' midi query of the Modifier setting.

3.09 TODO List:

1. confirm all modifier indexes on Fractal Parameters

2. call cS.DoubleTap() when Zoom == MOD and a modifyable control is Tapped.

3. verify control's txt value is rendered RED when control modified control is active (previously engaged, polled through DoEveryFrame())

Project Globals

Var blkd=

Var blksq=

Var blok=

Var blx=

Var debugflag=

Var hw= 'hardware version =0 AxeFx, =1 others, Ultra etc.

Var Querying=

tidx=

Script BuildParamList()

Sets cV.bpobj to first object in cMain, and iterates through all objects to build cV.BlocksToRefresh list. For Block numbers (99..200) that are in the preset values are added to a refresh list

Script RefreshSequencer()

Script SendCCAxe(ccnum, ccval)

Script SendConnectEffect(p1, p2, f)

Script SendGetByState()

Script SendGetCabName(cabnum)

Script SendGetModifier(b, p, m)

Script SendGetParam(b,p)

Script SendGetPresetName()

Script SendGetPresetNumber()

Script SendGetRoutingGrid()

Script SendGetSceneState()

Script SendLooperMonEn(en)

Script SendPG2Axe(pgnum)

Script SendPlaceEffect(b,pos,flag)

Script SendSavePath(program, bank)

Script SendSetModifier(b, p, m, v)

Script SendSetParam(b, p, v)

Script SendSetPresetName(name)

Script SynthMidiNoeOffIn(MIDI_ARGS)

Script SynthMidiNoteOnIn(MIDI_ARGS)

Script sxoutHandler(b,p, s, val)

Script UserMidiCCIn(MIDI_ARGS)

Script UserMIDINOTEIn(MIDI_ARGS)

Objects

Major AxeForLemur Objects:

aUser

User specific settings, like favorite presets, midi channel. These can be persistent if the user re-saves the script after mondifications are made through the script itself. Global midi CC's are stored in gen1.cc*

Querying : set to 1 during referesh, most likely to prevent re-triggering

aUser.cMidi.gen2 :: MIDI CC # numbers for different MIDI CC parameters

..scenescc[0] : MIDI CC # number for 'scene select'

cMain

User interface for Axe-Fx blocks.

cMain contains UI design and configuration for each Block (pair) Tab within AxeForLemur script

IntState3(..) macro, configures button labels within the UI interface. Typically these buttons are for Block instance selection, but some are for selecting other aspects of each' block Tab.

Each AxeForLemur Block Tab contains multiple containers, one for each UI element. These containers more or less contain a symetrical set of attributes, functions and UI controls that allow for support from a common set of functions (else where in the code).

Each UI Element contains:
 bps: Midi / UI control structure
 ctl: the lemur screen object
    x : Primary value for this control
    z : ???
 txt:  A screen description of the parameter. Example ('volume')
 txtval: text object on screen to describe the object parameter value.  Example (0..127)
 Optional:  
    cbDlg: a pop up dialog object
       x : value for the selected value of the dialog
       tap(..) : function called to initialize the dialog

When a control changes a 'magic' must be called to send the ctl's value to the bps[..] defined midi destination

cS

Common Scripting Object.

Common Script Object Container

addRefreshParam( b, p) : Adds a parameter to one of:

 (cV.blist[0..249],    cV.plist[0..249]), 
 (cV.blist2[250..499], cVplist2[250..499]), 
 (cV.blist3[500..749], cV.plist3[500..749]) at position cV.numcontrols, 

But doesn't appear to increase cV.numcontrols, called from Project.BuildParamList()

cS.psmxfdr(obj, b, p, -1, 'label')

cScanX

AxeForLemur cShow

Group of scripts to refresh Axe Block Tabs.

cTabSel

cV

Group of global variables.

blist, plist, blist2, plist2, blist3, plist3 250 entry lists of active 'b==block id's and p==parameter ids. each list has a physical limit of 250 elements. These 6 arrays constitute a 2D array of 750 items.

AxeForLemur ...

Pop Up Dialogs.

Lesser Objects (for now)

cbHideRoutes :

cbHideRoutes :

cbProgName : Button on bottom of UI to display dlgProgChange.showme(x)

cbRefresh :

cbTapTempo : Sends a CC 14 value 127 to currently selected Axe target, method cbTapTempo.hdlSxin(..) sets the lemur Tap button different colors

cbZoom: A double tap 'Zoom' function for sliders, dont know how this works.

aUser.cMidi.gen2.ccTapTempo

Global Functions

SendCC2Axe(..)

Development Tools

firstobject XML Editor Application. This is a light weight free XML editor that doesnt get confused by the Lemur script. The Editor has a good dual view ( one view is an XML object tree, the other side is the pure text. Using F7 allows you to sync between the two.

KDIFF3 http://kdiff3.sourceforge.net Since the AxeForLemur is a large monolithic text file, having a good DIFF tool allows you to see the changes LemurEditor and text editors have applied to your file. The LemurEditor does some strange things to this template when it is edited, the preference is to make clean edits with FirstObject Editor, and not use the Lemur Editor directly, as it has a habit of changing many unintended parameters throughout the script.

SVN or Git are good tools to manage progressive changes to the script.

Releases and Resources

return-lemur-support-here

Videos