Skip to main content

Python package to parse and solve COOM configuration instances using ASP.

Project description

COOM Suite

The COOM language is a domain-specific language for modelling product configuration problems. While currently geared towards ASP, the COOM Suite is intended to serve as a general workbench for experimentation with industrial-scale product configuration problems. It includes a (customizable) ANTLR v4 parser to convert COOM specifications into facts, and currently contains two ASP encodings for solving: one for clingo and one for hybrid solver flingo.

In addition, a prototypical UI, a range of examples and a benchmark collection with four scalable benchmark sets is provided.

If you want to cite the COOM Suite, please use the following reference

J. Baumeister, S. Hahn, K. Herud, M. Ostrowski, J. Reutelshöfer, N. Rühling, T. Schaub, P. Wanko. Towards Industrial-scale Product Configuration. CoRR, abs/2504.00013, 2025. doi: 10.48550/arXiv.2504.00013. URL https://arxiv.org/abs/2504.00013.

Usage

Look at our documentation page to see how to use the COOM Suite.

Solving

The main functionality the COOM Suite offers is converting a COOM configuration model and solving it using ASP. To do this, run

coomsuite solve examples/coom/kids-bike.coom

This will convert the given COOM file to a set of (serialized) facts, refine these facts, and finally solve them with the clingo encoding.

  • Note that the direct conversion of COOM into facts is a mere serialization of the COOM model. We make use of a preprocessing encoding to translate the "serialized" facts into a set of "refined" facts, capturing the essence of the configuration problem. To show the "refined" facts, run the solve mode with option --show-facts.

Convert COOM to facts

To convert a COOM instance into a set of (serialized) facts run

coomsuite convert examples/coom/kids-bike.coom

By default, the facts are printed to the console. Optionally, an output directory can be provided using option --output dir.

Examples

The COOM Suite contains a range of (product) configuration examples encoded in the COOM language. They can be found in the examples/coom directory. We highlight here only the Bike collection, containing three examples in increasing complexity that correspond to the three COOM language fragments defined above: the Kids, City, and Travel Bike.

We also provide the corresponding (serialized and refined) facts to these examples under examples/asp.

Installation

For instructions on how to install from source or pip see our documentation page.

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

coomsuite-1.0.0.tar.gz (380.4 kB view details)

Uploaded Source

Built Distribution

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

coomsuite-1.0.0-py3-none-any.whl (115.5 kB view details)

Uploaded Python 3

File details

Details for the file coomsuite-1.0.0.tar.gz.

File metadata

  • Download URL: coomsuite-1.0.0.tar.gz
  • Upload date:
  • Size: 380.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for coomsuite-1.0.0.tar.gz
Algorithm Hash digest
SHA256 551757975b33127c626224e0fdb9ad00e20b46ef0fc4c4bad953a7cbef778ad3
MD5 6dbdb9edf9b330a15cf78ba794c07a8c
BLAKE2b-256 91b98fce08a8a47eb99f951b7a4355a4881ecc59d7f9699ea4d982c7cb34ef31

See more details on using hashes here.

Provenance

The following attestation bundles were made for coomsuite-1.0.0.tar.gz:

Publisher: deploy.yml on potassco/coom-suite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file coomsuite-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: coomsuite-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 115.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for coomsuite-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a251f1b8097f55a1e4dff0580d615d98aa91ae3fb83f116826e34a4077388978
MD5 cada6bbe6730a91aa2d11aaa45750193
BLAKE2b-256 5fb02d69dda1f0065fe4df1bd062eccfec97f7a292f0caec71adf74d4be68e24

See more details on using hashes here.

Provenance

The following attestation bundles were made for coomsuite-1.0.0-py3-none-any.whl:

Publisher: deploy.yml on potassco/coom-suite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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