Usage guide

Table of Contents


If you encounter issues while using Amphimixis, see Troubleshooting for common problems and solutions.

Choose an installation method

For most users, the recommended path is to create a virtual environment and install directly from GitHub:

python3 -m venv .venv
source .venv/bin/activate
pip install git+https://github.com/ebzych/amphimixis.git@stable

This is the recommended path if you only want to run amixis and do not want to install anything into the system Python environment.

If you are developing Amphimixis itself, clone the repository and install dependencies with uv:

git clone https://github.com/ebzych/amphimixis.git
cd amphimixis
uv sync

If you specifically want to build a wheel locally and test the packaged artifact, use:

python3 -m venv .venv
source .venv/bin/activate
uv build
pip install dist/*.whl

Prepare a workspace

Run Amphimixis from a working directory that contains your configuration and any generated artifacts. Before starting, create an input.yml file there.

Make sure the required system tools are available

Required tools: rsync on each machine, perf and perf archive on each run_machine, and optionally sshpass for password-based SSH connections.

See Troubleshooting → System Dependencies for installation commands and the perf archive setup.

Create a configuration file

  • Start using provided config file sample

    amixis init sample-name
    

    Available sample name:

    • local

    • distributed

    • distributed-cross

  • Or create config with template:

    amixis add input
    
  • Configuration reference: config_instruction.md

  • Example file: input.yml

Understand the expected configuration

At minimum, input.yml should describe:

  • the build system and runner

  • the target platforms

  • the build recipes

  • the builds that connect platforms and recipes

In builds, you can optionally specify an executables list for each build. Each path must be relative to that build’s output directory, for example bin/my_app. If executables is omitted, Amphimixis profiles the first executable file it finds in the build directory.

Using SSH keys

You can use Amphimixis with SSH keys. See Troubleshooting: sshpass not found for setup.

Run the main workflow

amixis run /path/to/project

Use --config to specify a custom configuration file path:

amixis run --config ./my_input.yml /path/to/project

The full pipeline:

  1. analyzes the project

  2. builds it using the selected configuration

  3. profiles the resulting executables

  4. prints profiling results in the console

Run individual commands

Analyze only:

amixis analyze /path/to/project

Build only:

amixis build /path/to/project

Profile only:

amixis profile /path/to/project

Validate a configuration file:

amixis validate /path/to/input/config

Work with perf events

The same flag works with profiling-only mode:

amixis profile /path/to/project --events cycles cache-misses

With the main pipeline or profile, --events tells perf record which events to collect.

Compare profiling outputs

To compare two collected .scriptout files:

amixis compare build1.scriptout build2.scriptout

To limit how many symbols with the largest delta are shown for each event:

amixis compare build1.scriptout build2.scriptout --max-rows 10

Add a toolchain

Add a new toolchain to the global configuration file:

amixis add toolchain

Clean build directories

If you want to clean up on your build directories from previous builds, use:

# To interactively select builds to clean
amixis clean

# To clean specific builds by name
amixis clean build-name-1 build-name-2 ...

# To clean all builds
amixis clean --all