# PM4Py
PM4Py is a python library that supports state-of-the-art process mining algorithms in Python.
It is open source and intended to be used in both academia and industry projects.
PM4Py is managed and developed by PIS — Process Intelligence Solutions (https://processintelligence.solutions/),
a spin-off from the Fraunhofer Institute for Applied Information Technology FIT where PM4Py was initially developed.
## Licensing
The open-source version of PM4Py, available on GitHub (https://github.com/process-intelligence-solutions/pm4py), is licensed under the GNU Affero General Public License version
3 (**AGPL-3.0**).
We offer a separate version of PM4Py for **commercial use in closed-source environments** under a different license. For
more information about the licensing options for using PM4Py in closed-source settings, please
visit https://processintelligence.solutions/pm4py#licensing.
## Documentation / API
The documentation of PM4Py can be found at https://processintelligence.solutions/pm4py/.
## First Example
Here is a simple example to spark your interest:
import pm4py
if __name__ == "__main__":
log = pm4py.read_xes('<path-to-xes-log-file.xes>')
net, initial_marking, final_marking = pm4py.discover_petri_net_inductive(log)
pm4py.view_petri_net(net, initial_marking, final_marking, format="svg")
## Installation
PM4Py can be installed on Python 3.9.x / 3.10.x / 3.11.x / 3.12.x / 3.13.x by invoking:
pip install -U pm4py
PM4Py is also running on older Python environments with different requirements sets, including:
- Python 3.8 (3.8.10): third_party/old_python_deps/requirements_py38.txt
## Requirements
PM4Py depends on some other Python packages, with different levels of importance:
* *Essential requirements*: numpy, pandas, deprecation, networkx
* *Normal requirements* (installed by default with the PM4Py package, important for mainstream usage): graphviz,
intervaltree, lxml, matplotlib, pydotplus, pytz, scipy, tqdm
* *Optional requirements* (not installed by default): requests, pyvis, jsonschema, workalendar, pyarrow, scikit-learn,
polars, openai, pyemd, pyaudio, pydub, pygame, pywin32, pygetwindow, pynput
## Release Notes
To track the incremental updates, please refer to the CHANGELOG.md file.
## Third Party Dependencies
As scientific library in the Python ecosystem, we rely on external libraries to offer our features.
In the /third_party folder, we list all the licenses of our direct dependencies.
Please check the /third_party/LICENSES_TRANSITIVE file to get a full list of all transitive dependencies and the
corresponding license.
## Citing PM4Py
If you are using PM4Py in your scientific work, please cite PM4Py as follows:
> **Alessandro Berti, Sebastiaan van Zelst, Daniel Schuster**. (2023). *PM4Py: A process mining library for Python*.
> Software Impacts, 17, 100556. doi: 10.1016/j.simpa.2023.100556
[DOI](https://doi.org/10.1016/j.simpa.2023.100556) | [Article Link](https://www.sciencedirect.com/science/article/pii/S2665963823000933)
BiBTeX:
bibtex
@article{pm4py,
title = {PM4Py: A process mining library for Python},
journal = {Software Impacts},
volume = {17},
pages = {100556},
year = {2023},
issn = {2665-9638},
doi = {https://doi.org/10.1016/j.simpa.2023.100556},
url = {https://www.sciencedirect.com/science/article/pii/S2665963823000933},
author = {Alessandro Berti and Sebastiaan van Zelst and Daniel Schuster},
}
## Legal Notice
This repository is managed by Process Intelligence Solutions (PIS). Further information about PIS can be found online
at https://processintelligence.solutions.
Raw data
{
"_id": null,
"home_page": "https://processintelligence.solutions/",
"name": "pm4py",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": null,
"author": "Process Intelligence Solutions (PIS)",
"author_email": "info@processintelligence.solutions",
"download_url": "https://files.pythonhosted.org/packages/f5/d2/36f01f9251d420e216935c195099dceb169778d47ff5ea2c52e1e1b53736/pm4py-2.7.17.tar.gz",
"platform": null,
"description": "# PM4Py\r\n\r\nPM4Py is a python library that supports state-of-the-art process mining algorithms in Python.\r\nIt is open source and intended to be used in both academia and industry projects.\r\n\r\nPM4Py is managed and developed by PIS \u00e2\u20ac\u201d Process Intelligence Solutions (https://processintelligence.solutions/),\r\na spin-off from the Fraunhofer Institute for Applied Information Technology FIT where PM4Py was initially developed.\r\n\r\n## Licensing\r\n\r\nThe open-source version of PM4Py, available on GitHub (https://github.com/process-intelligence-solutions/pm4py), is licensed under the GNU Affero General Public License version\r\n3 (**AGPL-3.0**).\r\n\r\nWe offer a separate version of PM4Py for **commercial use in closed-source environments** under a different license. For\r\nmore information about the licensing options for using PM4Py in closed-source settings, please\r\nvisit https://processintelligence.solutions/pm4py#licensing.\r\n\r\n## Documentation / API\r\n\r\nThe documentation of PM4Py can be found at https://processintelligence.solutions/pm4py/.\r\n\r\n## First Example\r\n\r\nHere is a simple example to spark your interest:\r\n\r\nimport pm4py\r\n\r\nif __name__ == \"__main__\":\r\n log = pm4py.read_xes('<path-to-xes-log-file.xes>')\r\n net, initial_marking, final_marking = pm4py.discover_petri_net_inductive(log)\r\n pm4py.view_petri_net(net, initial_marking, final_marking, format=\"svg\")\r\n\r\n## Installation\r\nPM4Py can be installed on Python 3.9.x / 3.10.x / 3.11.x / 3.12.x / 3.13.x by invoking:\r\n\r\npip install -U pm4py\r\n\r\nPM4Py is also running on older Python environments with different requirements sets, including:\r\n\r\n- Python 3.8 (3.8.10): third_party/old_python_deps/requirements_py38.txt\r\n\r\n## Requirements\r\n\r\nPM4Py depends on some other Python packages, with different levels of importance:\r\n\r\n* *Essential requirements*: numpy, pandas, deprecation, networkx\r\n* *Normal requirements* (installed by default with the PM4Py package, important for mainstream usage): graphviz,\r\n intervaltree, lxml, matplotlib, pydotplus, pytz, scipy, tqdm\r\n* *Optional requirements* (not installed by default): requests, pyvis, jsonschema, workalendar, pyarrow, scikit-learn,\r\n polars, openai, pyemd, pyaudio, pydub, pygame, pywin32, pygetwindow, pynput\r\n\r\n## Release Notes\r\n\r\nTo track the incremental updates, please refer to the CHANGELOG.md file.\r\n\r\n## Third Party Dependencies\r\n\r\nAs scientific library in the Python ecosystem, we rely on external libraries to offer our features.\r\nIn the /third_party folder, we list all the licenses of our direct dependencies.\r\nPlease check the /third_party/LICENSES_TRANSITIVE file to get a full list of all transitive dependencies and the\r\ncorresponding license.\r\n\r\n## Citing PM4Py\r\n\r\nIf you are using PM4Py in your scientific work, please cite PM4Py as follows:\r\n\r\n> **Alessandro Berti, Sebastiaan van Zelst, Daniel Schuster**. (2023). *PM4Py: A process mining library for Python*.\r\n> Software Impacts, 17, 100556. doi: 10.1016/j.simpa.2023.100556\r\n\r\n[DOI](https://doi.org/10.1016/j.simpa.2023.100556) | [Article Link](https://www.sciencedirect.com/science/article/pii/S2665963823000933)\r\n\r\nBiBTeX:\r\n\r\nbibtex\r\n@article{pm4py, \r\ntitle = {PM4Py: A process mining library for Python}, \r\njournal = {Software Impacts}, \r\nvolume = {17}, \r\npages = {100556}, \r\nyear = {2023}, \r\nissn = {2665-9638}, \r\ndoi = {https://doi.org/10.1016/j.simpa.2023.100556}, \r\nurl = {https://www.sciencedirect.com/science/article/pii/S2665963823000933}, \r\nauthor = {Alessandro Berti and Sebastiaan van Zelst and Daniel Schuster}, \r\n}\r\n\r\n\r\n## Legal Notice\r\n\r\nThis repository is managed by Process Intelligence Solutions (PIS). Further information about PIS can be found online\r\nat https://processintelligence.solutions.\r\n",
"bugtrack_url": null,
"license": "AGPL 3.0",
"summary": "Process mining for Python",
"version": "2.7.17",
"project_urls": {
"Documentation": "https://processintelligence.solutions/pm4py/",
"Homepage": "https://processintelligence.solutions/",
"Source": "https://github.com/process-intelligence-solutions/pm4py",
"Tracker": "https://github.com/process-intelligence-solutions/pm4py/issues"
},
"split_keywords": [],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "b5ddd2064578a8442e4ad8915189181ee4864ee1f36adae93c4cac669cc18454",
"md5": "4558e809b00198a06a335633e61aea4a",
"sha256": "77fa0bbbe8284f0c94d577163213b5d4758bcf309a0266d34278a4476df28686"
},
"downloads": -1,
"filename": "pm4py-2.7.17-py3-none-any.whl",
"has_sig": false,
"md5_digest": "4558e809b00198a06a335633e61aea4a",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 2180398,
"upload_time": "2025-08-22T13:25:38",
"upload_time_iso_8601": "2025-08-22T13:25:38.728661Z",
"url": "https://files.pythonhosted.org/packages/b5/dd/d2064578a8442e4ad8915189181ee4864ee1f36adae93c4cac669cc18454/pm4py-2.7.17-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "f5d236f01f9251d420e216935c195099dceb169778d47ff5ea2c52e1e1b53736",
"md5": "303ae371861cf0b22d7fc0c24c046bf4",
"sha256": "3188b876fec35f03615a6a2d94e7e5e199d6cf812eb9bacd91709cef1d9eab36"
},
"downloads": -1,
"filename": "pm4py-2.7.17.tar.gz",
"has_sig": false,
"md5_digest": "303ae371861cf0b22d7fc0c24c046bf4",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 926580,
"upload_time": "2025-08-22T13:25:42",
"upload_time_iso_8601": "2025-08-22T13:25:42.168330Z",
"url": "https://files.pythonhosted.org/packages/f5/d2/36f01f9251d420e216935c195099dceb169778d47ff5ea2c52e1e1b53736/pm4py-2.7.17.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-08-22 13:25:42",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "process-intelligence-solutions",
"github_project": "pm4py",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "numpy",
"specs": []
},
{
"name": "pandas",
"specs": []
},
{
"name": "deprecation",
"specs": []
},
{
"name": "networkx",
"specs": []
},
{
"name": "graphviz",
"specs": []
},
{
"name": "wheel",
"specs": []
},
{
"name": "setuptools",
"specs": []
},
{
"name": "intervaltree",
"specs": []
},
{
"name": "lxml",
"specs": []
},
{
"name": "matplotlib",
"specs": []
},
{
"name": "pydotplus",
"specs": []
},
{
"name": "pytz",
"specs": []
},
{
"name": "scipy",
"specs": []
},
{
"name": "tqdm",
"specs": []
},
{
"name": "cvxopt",
"specs": []
}
],
"lcname": "pm4py"
}