Skip to main content

A unified launcher for XCSP solver

Project description

XCSP-Launcher

License: LGPL v3+ Python 3.8+ Documentation Python Tests Release Quality Gate Status


XCSP-Launcher is a unified tool to install, build, and execute solvers supporting the XCSP3 format.

It provides a streamlined way to manage solvers, automate their compilation, and run constraint programming instances through a standard, extensible interface.


✨ Features

  • 🛠️ Solver installation from GitHub, GitLab, or custom URLs
  • 🧱 Automatic or manual build (Gradle, CMake, Makefile, Cargo, Maven, etc.)
  • 🔖 Solver versioning and multi-version management
  • Unified execution interface for solving XCSP3 instances
  • 📝 Support for solver configuration files (.xsc.yaml) for reproducibility
  • 📄 Detailed logging of build and run processes
  • 🧩 Extensible: Easily add support for new solvers

📦 Installation

You can install xcsp-launcher via PyPI:

pip install xcsp

Or from source:

git clone https://github.com/CPToolset/xcsp-launcher.git
cd xcsp-launcher
pip install .
Debian/Ubuntu

Download the latest binary from github releases and run:

sudo dpkg -i xcsp-launcher*.deb
MacOS

Install via Homebrew:

brew tap CPToolset/homebrew-xcsp-launcher
brew install xcsp

🚀 Quick Start

Install a solver

xcsp install --id ace --name ACE --repo xcsp3team/ace --source github.com

This will:

  • Clone the solver repository,
  • Automatically detect the build system (or use configuration),
  • Build the solver,
  • Register it in your local solver repository.

Solve an instance

xcsp solve --solver ace --instance path/to/instance.xml

🧰 Example Configuration (.xsc.yaml)

name: "ACE"
id: "fr.cril.xcsp.ace"
git: "https://github.com/xcsp3team/ace"
language: "java"
build:
  mode: manual
  build_command: "gradle build -x test"
command:
  prefix: "java -jar"
  template: "{{executable}} {{instance}} {{options}}"
  always_include_options: "-npc=true -ev"
versions:
  - version: "2.4"
    git_tag: "2.4"
    executable: "build/lib/ACE-2.4.jar"

For more information about the format of the solver-configuration please see the documentation of metrics.


🛠 Supported Build Systems (Auto-detection)

  • Gradle (build.gradle)
  • Maven (pom.xml)
  • CMake (CMakeLists.txt)
  • Make (Makefile)
  • Rust Cargo (Cargo.toml)
  • Python setuptools (setup.py, pyproject.toml)

📚 Other Projects

  • xcsp-launcher-homebrew — Homebrew Tap for installing XCSP-Launcher easily on macOS/Linux.
  • xcsp-metadata — A metadata repository for XCSP3 instances (domains, categories, etc.).
  • metrics-solver — Predefined solver configurations available by default with xcsp-launcher for easy installation and experimentation.

🚀 Projects Using XCSP-Launcher

  • metrics — An open-source Python library to automate experimental campaigns and analyze solver performances.

🤝 Contributing

We welcome contributions!
Feel free to open issues, suggest features, or submit pull requests.

Please read CONTRIBUTING.md for guidelines.


⚖️ License

This project is licensed under the LGPL v3+ License.
See LICENSE for details.


🌍 Related Links


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

xcsp-0.5.0.tar.gz (28.6 kB view details)

Uploaded Source

Built Distribution

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

xcsp-0.5.0-py3-none-any.whl (30.4 kB view details)

Uploaded Python 3

File details

Details for the file xcsp-0.5.0.tar.gz.

File metadata

  • Download URL: xcsp-0.5.0.tar.gz
  • Upload date:
  • Size: 28.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for xcsp-0.5.0.tar.gz
Algorithm Hash digest
SHA256 2617e56669336c4d9f306ed37050c65bef1d7f954e3f5882a6d66ce5248f20d8
MD5 f8cff6fe443a39bbce6a954efa2efa36
BLAKE2b-256 ea04438dcdaa3fe7873a71ccf849acb873a6ae14c29a5d8776b5958579fcb77f

See more details on using hashes here.

File details

Details for the file xcsp-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: xcsp-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 30.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for xcsp-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 18af01a9e0eb914eb675f6d07f3f2a4bfef530f32e48db54e774dc3c5dc69d0e
MD5 63cdb614ba09a4a455a18dd6e698eae9
BLAKE2b-256 02a5f4222b1a225151f58630d091134d09c2a8c1ad4400403fc45471c78dbaf3

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