This repository contains the Java project for a Process Mining tool that works on top of an Event Graph Database.
- IDE: IntelliJ IDEA 2020.2.4 (Ultimate Edition)
- Java:
- jdk-13.0.1
- java version "13.0.1" 2019-10-15
- Java(TM) SE Runtime Environment (build 13.0.1+9)
- Java HotSpot(TM) 64-Bit Server VM (build 13.0.1+9, mixed mode, sharing)
- Neo4j:
- Version: 4.4.2
- Edition: Community
In order to run this project, please ensure access to a running Neo4j 4.4.2 database, with the GDS and APOC libraries installed.
To the database settings file, add the line cypher.lenient_create_relationship = true
.
In this section we provide the instructions on how to run the project using IntelliJ IDEA 2019.3.3.
-
Open the "Utils.java" file located on the following path: "src\EventGraphs" (starting from the main project folder).
-
Update following parameters:
-
NEO4J_IMPORT_PATH This path, specified in line 21 of the "Utils.java" file, is used to indicate the Neo4j Import folder, where the CSV files must be placed to be imported into the graph database.
-
Also in the "Utils.java" file, in lines 25 and 26, update the DEFAULT_USER and DEFAULT_PASS parameters if necessary.
The main class of the application is the "EventGraphs.java" file, located in "src\EventGraphs". The steps to run the project from IntelliJ are shown next:
-
Go to Run -> Edit Configurations
-
On the window that appears, in the top-left corner, click on the "+" sign to add a new "Application" configuration.
-
Set the following parameters:
-
Main class: EventGraphs.EventGraphs
-
VM options*:
--module-path "C:\Java\javafx-sdk-15.0.1\lib" --add-modules javafx.controls,javafx.fxml
*The JavaFX-SDK path may be different. For example, another valid path could be: "C:\Java\javafx-sdk-11.0.2\lib"
-
-
The final Configuration should look similar to this:
-
Clicking on the "Play" button should get the application started.
-
If Neo4j has already been started, the following window will appear:
Otherwise, the application will attempt to start Neo4j on the background and the window will show a different message when this is completed.
-
If the Neo4j connection could be confirmed, closing the "Neo4j Connection Status" window will lead to the main window of the application.
-
Place the "BPIC17_Sample_20cases.csv" file in the NEO4J_IMPORT_PATH specified during the Run Configuration.
-
In the user interface, go to File -> Upload CSV File
-
On the "Logs" panel on the left of the user interface, select the recently uploaded log so its name appears on the top label.
-
Go to the "Graph Data" panel and click on the Instance Level "View" button to visualize the Event nodes.
- Use the Mouse Scroll to zoom in or out of the Graph panel.
- Drag the mouse while pressing the Right Click to move around the Graph panel.
-
On the "Entities" panel, click on "New Entity".
-
On the window that appears, select the "case" attribute and click on Create Entity.
-
If the "Entity Type Attribute Selection" window appears, click on Skip.
-
On the "Classes" panel, click on "New Class".
-
On the window that appears, select the "Activity" attribute and click on Continue.
-
On the next window, select the "case" entity and click on Create Class.
-
On the "Algorithms" panel, select "Inductive Miner" from the dropdown menu and click on Generate Model.
-
On the window that appears, do the following:
- Make sure that the Class Type is "Activity".
- Make sure that the Entity Type is "case".
- Select "DFG" as the splitting type
- Click on Generate Model.
-
To visualize the model, go to the "Models" panel, select the recently generated model (whose name should be "IM_1_BPIC17_Sample_20cases.csv") and click on Show Model.
-
To visualize the Petri net that represents that model, select the "IM_1_BPIC17_Sample_20cases.csv" model and click on Show Petri Net.
- The input file used for the Python script "bpic17_prepare.py", which generates the data subsets included in the "evaluation/" folder of this repository, can be found in the website of the BPI Challenge 2017.
- The graph visualizations used for this project were configured with the help of the GraphStream JavaFX Viewer library. For more information on this java library, visit the website http://www.graphstream-project.org/