Skip to main content

Python library to perform discovery, conformance checking and query checking of DECLARE constraints.

Project description

Declare4Py

Declare4Py is the first Python package for declarative Process Mining with core functionalities to easily implement Machine Learning applications for Process Mining. Declarative process mining uses declarative behavioural rules (based on Linear Temporal Logic on finite traces) for defining process models. This results in a high flexibility of the business process model definition without neglecting hard constraints that must be satisfied. Moreover, declarative languages can be used as a bridge between Process Mining and Machine learning with the DECLARE encoding that encodes the traces in a log into a numeric format suitable as input to Machine Learning algorithms. Declare4Py implements such a bridge by including standard algorithms for:

  1. declarative Process Mining with LTLf or (MP)-DECLARE templates (e.g., conformance checking, model discovery, trace generation, query checking);
  2. log encodings (e.g., complex-index, aggregate, Declare);
  3. log labelling according to filtering or declarative rules.

All the Declare4Py data formats are compatible with the main Machine Learning Python packages: scikit-learn, Tensorflow and PyTorch.

Installation

We recommend the use of a virtual environment to avoid possible clashes between your local Python version and the required libraries. A virtual environment can be created with Conda or with the venv Python utility. Once a virtual environment has been created, download the Declare4Py project on your local machine, activate the created virtual environment and use pip or conda to install the required dependencies in the requirements.txt file. As an alternative you can install Declare4py from PyPi.

In addition, the Lydia backend for the LTLf conformance checking need to be installed with Docker:

  1. Install Docker;
  2. Download the Lydia Docker image with docker pull whitemech/lydia:latest;
  3. Make the Docker image executable under the name lydia. On Linux and MacOS machines, the following commands should work:
echo '#!/usr/bin/env sh' > lydia
echo 'docker run -v$(pwd):/home/default whitemech/lydia lydia "$@"' >> lydia
sudo chmod u+x lydia
sudo mv lydia /usr/local/bin/
  1. More information can be found here.

Tutorials

The docs/source/tutorials/ folder contains a walk-through of Declare4Py. In order, the tutorials cover the following topics:

  1. Managing event logs: methods to manage event logs, importing them, extracting useful information, converting them in other formats;
  2. Managing process models: simple methods to parse and manage process models from strings and/or files and checking their satisfiability;
  3. Conformance checking of LTLf templates/formulas: check what are the traces in an event log that satisfy a given LTLf model;
    1. Log filtering with LTLf properties: filter a log according to an LTLf model;
  4. Conformance checking of MP-DECLARE templates: check what are the traces in an event log (along with the fulfillments/violations) that satisfy a given MP_DECLARE model;
  5. Query Checking with DECLARE models: discover what are the activities that make an input DECLARE constraint satisfied in an event log;
  6. Discovery of DECLARE models: discover what are the most satisfied DECLARE constraints in an event log;
  7. Filtering an event log: select a subset of an event log that satisfy some input properties;
  8. Log generation with a MP-DECLARE model: generate synthetic cases that satisfy an MP-DECLARE model.

The tutorials are Jupyter notebooks and consider the Sepsis cases log.

Repository Structure

  • src/declare4py/ProcessModels -- the implementation of the supported process models.
  • src/declare4py/ProcessMiningTasks/ -- the implementation of the supported Process Mining tasks.
  • tests/ -- a collection of tests for computing the Declare4Py performance.
  • docs/source/tutorials/ -- tutorials to start with Declare4Py,

Citing Declare4Py

If you use Declare4Py in your research, please use the following BibTeX entry.

@inproceedings{DonadelloRMS22,
  author    = {Ivan Donadello and
               Francesco Riva and
               Fabrizio Maria Maggi and
               Aladdin Shikhizada},
  title     = {Declare4Py: {A} Python Library for Declarative Process Mining},
  booktitle = {{BPM} (PhD/Demos)},
  series    = {{CEUR} Workshop Proceedings},
  volume    = {3216},
  pages     = {117--121},
  publisher = {CEUR-WS.org},
  year      = {2022}
}

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

declare4py-2.2.0.tar.gz (3.3 MB view details)

Uploaded Source

Built Distribution

declare4py-2.2.0-py3-none-any.whl (89.1 kB view details)

Uploaded Python 3

File details

Details for the file declare4py-2.2.0.tar.gz.

File metadata

  • Download URL: declare4py-2.2.0.tar.gz
  • Upload date:
  • Size: 3.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for declare4py-2.2.0.tar.gz
Algorithm Hash digest
SHA256 e61041ce3aa0638a6025812bc0d89acc052fd1c0769ac05bc27a5d3ad4e86f24
MD5 25492136af91f4a989f2567e0484153d
BLAKE2b-256 a53fb5e1a320a9d7c00f14d22e3c661b6f38a46cfa1174744548464f68663c9a

See more details on using hashes here.

File details

Details for the file declare4py-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: declare4py-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 89.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for declare4py-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0c82ebba3abd140c39eec7524aeebc8a86156074a5f3fca67d1dcf7e138baa4a
MD5 1272a8bd49f6b98ff8ab1d8fcc16b8b2
BLAKE2b-256 1a8cb5f5585dd82210466bd1630e00eaea8ddcd14e7665e3c9f5ba57fbfa269b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page