Process Mining

Loan Application Data

An example of parallel/negative duration processes, unsure on how to avoid this scenario.

Code

library(tidyverse)
library(xesreadR)
library(processanimateR)
library(processmapR)

#   ____________________________________________________________________________
#   Loan Application Event Logs                                             ####

loan  <- xesreadR::read_xes("https://solutiondesign.io/blog/data/loan_app_data.xes")

graph <- processmapR::process_map(loan, type_edges = performance(mean), render = F)
model <- DiagrammeR::add_global_graph_attrs(graph,
            attr      = c("layout", "rankdir", "splines"),
            value     = c("dot", "LR", "ortho"),
            attr_type = c("graph", "graph", "graph"))

animate_process(loan, model, mode = "relative", duration = 240)

Loan application event logs process maps generate negative durations when periods overlap with other activities.

  • Is there a way to capture parallel processes safely?
  • How should I approach situations like this?
#   ____________________________________________________________________________
#   Traffic Fines Event Logs                                                ####

fines   <- eventdataR::traffic_fines

graph_f <- processmapR::process_map(fines, type_edges = performance(mean), render = F)
model_f <- DiagrammeR::add_global_graph_attrs(graph_f,
            attr      = c("layout", "rankdir", "splines"),
            value     = c("dot", "LR", "ortho"),
            attr_type = c("graph", "graph", "graph"))

animate_process(fines, model_f, mode = "relative", duration = 240)

Traffic fines event logs do not have any parallel or overlapping periods and displays renders perfectly.

Output

Loan Process Map