Installation#

Pip#

The preferred way to install the alpaqa Python interface is using pip:

python3 -m pip install --upgrade --pre alpaqa

(PyPI)

To compile problems using the Python interface, you will need a C compiler, such as GCC or Clang on Linux, Xcode on macOS, or MSVC on Windows (see the Tips and tricks page for details and alternatives).

From source#

Building alpaqa from source requires the installation of some C++ dependencies, see Installation (Doxygen) for detailed instructions.

C++ Library#

Pre-built binaries for Linux are available from the Releases page on GitHub.

For Debian-based systems, the .deb packages can be installed using

sudo apt update
sudo apt install ./libalpaqa*_1.0.0a20_amd64.deb

Different components are available:

  • libalpaqa contains the shared libraries needed to run applications that use alpaqa.

  • libalpaqa-debug contains the debugging symbols for those libraries.

  • libalpaqa-dl_dev contains the C header files needed to compile problem specifications that can be dynamically loaded by alpaqa.

  • libalpaqa-dev contains all development files such as headers and CMake configuration files needed to compile software that invokes alpaqa solvers.

  • libalpaqa-extra contains additional solvers and problem loaders that fall outside of the core library.

  • libalpaqa-extra-dev contains all development files for the extra libraries.

  • libalpaqa-casadi contains classes for loading and building problem definitions using CasADi.

  • libalpaqa-casadi-dev contains classes development files for those classes.

  • libalpaqa-tools contains command line utilities such as alpaqa-driver, which can be used to invoke the solvers directly, without the need to write any C++ code.

More information about the different components of alpaqa can be found in the CMake example.

The following distributions are tested:

  • Debian: 11 (Bullseye), 12 (Bookworm), Sid

  • Ubuntu: 20.04 (Focal), 22.04 (Jammy), rolling

Alternatively, the .tar.gz file can be extracted and installed manually.

sudo tar xzf alpaqa-1.0.0a20-Linux-x86_64.tar.gz -C /usr/local --strip-components=1

This requires glibc 2.17 or later. You may need to install or pre-load the following additional runtime dependencies:

  • libgfortran5 (GFortran 10 or later)

  • libquadmath0

When using the development packages, it is important to use the correct version of Eigen (currently 3.4.0) to avoid ABI incompatibilities. Adding architecture-specific flags (e.g. -march=skylake, -mavx512f) can also affect ABI, and building from source for optimal performance may be advisable.

MATLAB interface#

The experimental MATLAB/MEX interface can be installed by running the following command in the MATLAB command window:

unzip(['https://github.com/kul-optec/alpaqa/releases/download/1.0.0a20/alpaqa-matlab-' computer('arch') '.zip'], userpath)

You need CasADi to be installed as well: https://web.casadi.org/get

To uninstall the alpaqa MATLAB interface, simply remove the +alpaqa folder:

rmdir(fullfile(userpath, '+alpaqa'), 's');