This is the wiki for products made by Fractal Audio Systems, maintained by members of the community.
Difference between revisions of "MIDI"
| (291 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
| __TOC__ | __TOC__ | ||
| − | + | =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|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 [https://wiki.fractalaudio.com/wiki/index.php?title=Owners_Manuals 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  | + | 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  | + | 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  | + | 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  | + | 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  | + | 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> | + | <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. | |
| − | MIDI-over-USB  | + | 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 | ||
| − | ==Axe-Fx II== | + | 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> | ||
| + | |||
| + | ==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. | ||
| + | |||
| + | <blockquote>'''FRACTAL AUDIO QUOTES'''<HR> | ||
| + | <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> | ||
| + | |||
| + | ==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 <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> | ||
| + | |||
| + | <B>What is MIDI used for?</B> | ||
| + | |||
| + | 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. | |
| − | + | <B>What basics do I need to know?</B> | |
| − | MIDI- | + | 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. | |
| − | MIDI  | + | 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. | ||
| − | + | <B>Control Changes</B> | |
| − | MIDI  | + | 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. | |
| − | The MIDI  | + | 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== | |
| − | Below is a list of all MIDI CCs on the Axe-Fx II XL+. The CCs are listed in  | + | 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 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 203: | 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  | + | * 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  | + | 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> | ||
| + | '''PREVIOUS GENERATIONS''' | ||
| + | <HR> | ||
| − | <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> | + | <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> | + | <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> | + | <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 | + | 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.  | + | 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 <q>soft</q> 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. <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. | ||
| − | MIDI  | + | 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: | |
| − | The  | + | 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  | + | The preset page (AxeForLemur/dlgProgChange/T1) contains a matrix of MIDI settings for up to four target devices. | 
| − | The  | + | 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 | + | * MIDI Channel : { 1 .. 16} = aUser.cMidi.chans[ ] | 
| − | + | * Lemur Target : { 0.. 3 } = aUser.cMidi.targets[ ] | |
| − | The  | + | 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. | |
| − | The  | + | 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). | |
| − | A  | + |  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== | |
| − | + | [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.  | ||
| − | + | 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. | ||
| − | + | SVN or Git are good tools to manage progressive changes to the script. | |
| − | + | ==Releases and Resources== | |
| − | + | [http://forum.fractalaudio.com/axe-fx-ii-discussion/98926-return-lemur-support-here.html return-lemur-support-here] | |
| − | = | + | =Videos= | 
| − | + | [[video:Cooper-MIDI]] | |
| + | [[video:Leon-MIDI]] | ||
| + | [[video:RJM-MIDI]] | ||
| [[category:Axe-Fx2]] | [[category:Axe-Fx2]] | ||
| Line 490: | 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
Contents
- 1 Axe-Fx III and MIDI
- 2 FM9 and MIDI
- 3 FM3 and MIDI
- 4 VP4 and MIDI
- 5 FC controllers: no MIDI support
- 6 MIDI/Remote menu
- 7 Send a MIDI Program Change
- 8 MIDI Clock
- 9 Tips, tricks and troubleshooting
- 10 Legacy devices and MIDI
- 11 AxeForLemur (legacy)
- 12 Videos
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.
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.
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:
- Purchase the Lemur App (approximately $20-$35) and install it on your Tablet or iPad.
- Go to the 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.
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.
