[TOC]
D-Painless is a flexible framework for parallel and distributed SAT solving that integrates multiple state-of-the-art SAT solvers and preprocessing techniques.
- The doxygen different Topics is a good introduction to the different components in the framework.
- For TACAS25 experiment reproducability, please check TACAS25.
- For an overview on the main interfaces, please check Main Interfaces.
- Souheib BAARIR souheib.baarir@lip6.fr
- Mazigh SAOUDI mazigh.saoudi@epita.fr
src/containers/
: Data structures for clause management and formula representationsrc/sharing/
: Learnt clause sharing management and strategiessrc/working/
: Worker organization and portfolio implementationssrc/solvers/
: Solver interface and implementationssrc/utils/
: Helper utilities and data structuressrc/preprocessors/
: Preprocessing techniques integration
The framework integrates several state-of-the-art SAT solvers:
- Kissat (v3.1.1)
- CaDiCaL (v1.9.1)
- MapleCOMSPS (SAT Competition 17)
- Glucose
- MiniSat
- Lingeling
- YalSAT
- Kissat-MAB and Kissat-INC variants
The framework includes preprocessing techniques from:
- C++20 compatible compiler (GCC recommended)
- Boost Library headers
- OpenMPI implementation
- Standard build tools (make, autoconf)
- POSIX-compatible environment
-
Clone the repository:
git clone https://github.com/lip6/painless cd painless
-
Build the entire project:
make # -j for parallel and quicker make
This will:
- Compile the M4RI library required by PRS and MapleCOMSPS
- Build all required SAT solvers
- Build both debug and release versions of Painless
-
Build specific targets:
make debug # Build debug version (uses -fsanitize=address) make release # Build release version make solvers # Build only the SAT solvers
-
Clean the build:
make cleanpainless # Clean Painless build make cleansolvers # Clean solver builds make clean # Clean Painless and Solver builds make cleanall # Clean everything including libraries (M4RI)
The compiled binaries will be located in:
- Debug build:
build/debug/painless_debug
- Release build:
build/release/painless_release
.
├── build/ # Build output directory
├── docs/ # Documentation
├── libs/ # External libraries
├── scripts/ # Utility scripts
├── solvers/ # Sequential SAT solver implementations
└── src/ # Painless source code
A bash script for running and analyzing SAT solver experiments:
./scripts/launch.sh <parameters_file> <input_files_list> [experiment_name] [debug]
- Automated execution of multiple SAT instances
- MPI process management and cleanup (MPI is used if the
-gshr-strat
option is not negatif) - Enforces timeout per instance via the
timeout
command - Result validation for SAT solutions
- Performance metrics collection
parameters_file
: Configuration file containing solver settingsinput_files_list
: File containing paths to CNF formulasexperiment_name
: (Optional) Name for the experimentdebug
: (Optional) Use debug build with verbose MPI output (--verbose --debug-daemons
outputs inerr_*.txt
file)
outputs/
├── metric_${solver}_L${lstrat}_G${gstrat}_${timestamp}/
│ ├── logs/ # Per-instance logs
│ │ ├── log_instance1.txt # Solver output
│ │ └── err_instance1.txt # Error messages
│ └── times_*.csv # Detailed timing results
└── times.csv # Overall experiments times
# Run in release mode
./scripts/launch.sh scripts/parameters.sh formula_list.txt
# Run in debug mode
./scripts/launch.sh scripts/parameters.sh formula_list.txt experiment1 debug
A comprehensive analysis tool for SAT solver results that can:
- Generate performance statistics and visualizations
- Compare multiple solver configurations
- Create cumulative execution time plots
- Generate scatter plots comparing solver pairs
Usage:
# Analyze results from metric directories:
python scripts/plot.py --base-dir outputs --timeout 5000
# Use existing CSV file:
python scripts/plot.py --file results.csv --timeout 5000
The --file
and --base-dir
options are mutually exclusive.
The script supports various options:
--scatter-plots
: Generate solver comparison scatter plots--output-dir
: Specify output directory for plots--output-format
: Set plot format (pdf, png, etc.)--dark-mode
: Use dark theme for plots
Output directory structure after a --base-dir
execution on directory outputs
:
outputs/
├── metric_solver1/ # Results for first solver configuration
│ └── times_*.csv
├── metric_solver2/ # Results for second solver configuration
│ └── times_*.csv
└── combined_results.csv # Generated combined statistics
The analysis provides:
- Solver performance statistics (solved instances, PAR2 scores, VBS-SMAPE score)
- SAT/UNSAT instance statistics
- Performance visualization plots
- Virtual best solver (VBS) analysis