Skip to main content

Protocol0 ableton remote script

Project description

Protocol0 Control Surface Script for Ableton

Protocol0 is a control surface script for Ableton Live 11

It is a "selected track control" like script focused on working in session view.

I've been specifically working on making the session recording more powerful and more adapted to my workflow. It has a focus on :

  • Recording external synths (both midi and audio) in a smart way
  • Being able to export / import sub tracks so as to always work on flattened audio track with the possibility to recall the base (midi track) at a button push.

The scripts react to a set of midi note and cc messages. I'm currently triggering those using a Faderfox EC4.

This script is definitely a "working on my machine" script and is not generic to any layout / usage. It should be interesting for a remote script dev though.

Features

I started writing the script specifically because I thought recording my Prophet Rev2 was tedious. Later on I realized I would probably produce better if I was working more in session view and experiment longer instead of rushing to arrangement. So now it is more of a session view tool. Regarding recording my goal was to achieve a satisfactory recording experience with hardware synths, as well as being able to use heavy vsts that I could easily bounce to audio and recall.

One of my main goals was to achieve a workflow where I had close to zero heavy vsts at any time, and a sleek set.

Specifically the script aims to achieve :

  • A better workflow in session view
  • A better workflow when using external synthesizers
  • An automated way to bounce big vsts tracks to audio and recall them easily
  • An integration with my generic FaderFox EC4 midi controller (could be used by any midi configurable controllers).
    • Use presses / long presses (both note messages) / button scrolls (cc messages) to trigger actions.
    • NB : a number of actions are relative to the selected track, and the script sees certain types of group track as one composite track (see External Synths).
    • Other actions can be relative to the selected scene, clip, or to the song.
  • A lot of little improvements in the session view including:
  • Fixed length recording
  • Re recording audio from midi at a button's push
  • Handling of audio clip tails (recording and playing) to have perfect loops when recording hardware
  • A way to "scroll" (and inside scenes) and launch scenes with keyboard shortcuts
  • A tool to bounce session to arrangement
  • Tools to split and crop scenes
  • Validator code that can detect different kind of set configuration "errors" (routings, volumes, unused devices etc.)
  • Some code to synchronize my push2 to the script (specifically the session component)
  • A few other tools that can be found in the action_groups folder



The bigger part of the script is dedicated to handling external synths.

External Synths

  • The script is able to record both midi, audio and automation at the same time doing unlimited or fixed length recordings.
  • It activates only on a group track that has the following layout (in this order, any other layout will not be detected) :
    • a midi track (records midi)
    • an audio track (records audio)
  • the record button has 2 main modes :
    • midi recording : will record midi and audio on the next scene available
    • audio recording : will record audio from midi on this scene

The backend

This script executes in the context of ableton's bundled python interpreter, like any script. Some things are not possible in this environment like spawning processes or accessing win32apis (keyboard, mouse ..) A simple example : clicking on a device show button is not possible from a "normal" script. To make this kind of thing possible I've created a backend that you can find in this repo.

NB : quite some features are not implemented in the API (freezing, flattening, cropping .. but also dragging in or out tracks etc ..). All of this is implemented using the backend mostly leveraging wild mouse clicks.

The backend is exposing its api over midi, and I'm using loopMidi virtual ports to communicate with it.

Without setting up the backend (might not be straightforward) the script will only partially work.

As it's not possible to listen to multiple midi ports from a surface script I'm using a "proxy" surface script that forwards messages from my backend on its port to the main script. See this repo The same purpose would be achievable my external midi routing using e.g. midi ox. I like this dependency better.

Installation

make bootstrap

Install the script in your remote scripts folder (for Live 11)

  • make install_script_p0
  • make install_script_p0_midi to add a midi port proxy

Install the backend

  • clone and follow the README install section of the backend.
  • You should also

Development

I've written a technical doc that details important parts of the script object model and techniques. Also, a few remote scripts concepts are explained. see this article (might be a bit outdated)

I'm working on dev and releasing working versions to master

I've been using DDD concepts to structure the script with a single central domain folder

Tools

  • make test runs the test suite (pytest).
  • make check runs the linting tools and tests on the whole project. I'm using flake8, vulture and mypy.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

protocol0-1.0.15.tar.gz (170.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

protocol0-1.0.15-py3-none-any.whl (356.4 kB view details)

Uploaded Python 3

File details

Details for the file protocol0-1.0.15.tar.gz.

File metadata

  • Download URL: protocol0-1.0.15.tar.gz
  • Upload date:
  • Size: 170.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.5

File hashes

Hashes for protocol0-1.0.15.tar.gz
Algorithm Hash digest
SHA256 f6741a9874217e73a781de2f9b21e6b66a38bab04877a1581dbd95957f331eef
MD5 7c79ef984013cffc1910842bf71560e4
BLAKE2b-256 bdc18584a7164b6e6b3c846d011dd4788d2a10274a770b9108eae840b3852e70

See more details on using hashes here.

File details

Details for the file protocol0-1.0.15-py3-none-any.whl.

File metadata

  • Download URL: protocol0-1.0.15-py3-none-any.whl
  • Upload date:
  • Size: 356.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.5

File hashes

Hashes for protocol0-1.0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 59a371278475309fc4749c778e7234582725feaf4685ca18bf5746765991fdc7
MD5 b9706b49787be00daf396c95e17fadd4
BLAKE2b-256 4443051421c4e2b798002d6f6b03711994085b94f95298e54cfa73071d4eff93

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page