Skip to main content

Command-line controller for AKAI MPKmini MK II.

Project description

Command-line controller for AKAI MPKmini MK II

SourceCC BY 2.0

CI PyPU - Version PyPI - Python Version

Best effort project to overcome the fact that AKAI doesn't seem to be interested in fixing Segmentation faults in their MPKmini Editor.

It currently fixes my own itches but I gladly accept feedback!

Install

To install via PyPi:

pip3 install --user akai-mpkmini-mkii-ctrl

Please note that the dependency python-rtmidi requires compilation resources to be present on your system. For Debian-like systems for example you need to install sudo apt-get install libasound2-dev. Refer to the project documentation for details.

To install from source you can use:

  • python3 setup.py install, or
  • make install which will run a pipenv including linting, tests, etc.

Usage

akai_mpkmini_mkii_ctrl supports a set of commands to push or pull presets to and from the device. All commands have a common set of options:

-p, --preset NUM     Target preset slot (0 = RAM, 1-4 = Stored preset, default: 0)
-m, --midi-port NUM  MIDI Port on which the device is located (default: 0)
-v, --verbose        Verbose output
--help               Show this message and exit.

Commands

print-preset: Print preset on device in human readable format. In this example it will print the preset stored in slot 1 on the device.

python3 -m akai_mpkmini_mkii_ctrl \
--preset 1 print-preset

pull-preset: Pull a binary from the device and write to file.

python3 -m akai_mpkmini_mkii_ctrl \
--preset 0 \
pull-preset \
--output-file ram-preset.mk2

push-preset: Push a local binary preset to the device. This also works with factory binary presets.

python3 -m akai_mpkmini_mkii_ctrl \
--preset 2 \
push-preset \
--input-file resources/factory-patches/preset1.mk2

push-config-preset: Push a local configuration preset (Example) to the device. Notice that you are able to combine several input files for easier re-use. YAML and JSON format is supported. The configurations are applied in order, e.g., in this case Base-Config.yaml will be extended/overwritten with the properties found in Logic-RetroSynth+Juno.yaml.

python3 -m akai_mpkmini_mkii_ctrl \
--preset 0 \
push-config-preset \
--input-file resources/config-presets/Base-Config.yaml \
--input-file resources/config-presets/Logic-RetroSynth+Juno.yaml

Development

You can prepare a pipenv-based development environment using:

make clean venv

You can also install the controller to your system using:

make install

To use the local pipenv-based version you can use the following command from where you cloned the repository:

pipenv run python akai_mpkmini_mkii_ctrl

Resources

The implementation is based upon the following resources:

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

akai_mpkmini_mkii_ctrl-0.2.0-py3-none-any.whl (17.9 kB view hashes)

Uploaded Python 3

Supported by

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