=Paper=
{{Paper
|id=Vol-1293/paper2
|storemode=property
|title=Finding Suitable Activity Clusters for Decomposed Process Discovery
|pdfUrl=https://ceur-ws.org/Vol-1293/paper2.pdf
|volume=Vol-1293
|dblpUrl=https://dblp.org/rec/conf/simpda/HompesVA14
}}
==Finding Suitable Activity Clusters for Decomposed Process Discovery==
Finding Suitable Activity Clusters for Decomposed Process Discovery B.F.A. Hompes, H.M.W. Verbeek, and W.M.P. van der Aalst Department of Mathematics and Computer Science Eindhoven University of Technology, Eindhoven, The Netherlands b.f.a.hompes@student.tue.nl {h.m.w.verbeek,w.m.p.v.d.aalst}@tue.nl Abstract. Event data can be found in any information system and pro- vide the starting point for a range of process mining techniques. The widespread availability of large amounts of event data also creates new challenges. Existing process mining techniques are often unable to handle “big event data” adequately. Decomposed process mining aims to solve this problem by decomposing the process mining problem into many smaller problems which can be solved in less time, using less resources, or even in parallel. Many decomposed process mining techniques have been proposed in literature. Analysis shows that even though the de- composition step takes a relatively small amount of time, it is of key importance in finding a high-quality process model and for the compu- tation time required to discover the individual parts. Currently there is no way to assess the quality of a decomposition beforehand. We define three quality notions that can be used to assess a decomposition, before using it to discover a model or check conformance with. We then propose a decomposition approach that uses these notions and is able to find a high-quality decomposition in little time. Keywords: decomposed process mining, decomposed process discovery, distributed computing, event log 1 Introduction Process mining aims to discover, monitor and improve real processes by extract- ing knowledge from event logs readily available in today’s information systems [1]. In recent years, (business) processes have seen an explosive rise in support- ing infrastructure, information systems and recorded information, as illustrated by the term Big Data. As a result, event logs generated by these information systems grow bigger and bigger as more event (meta-)data is being recorded and processes grow in complexity. This poses both opportunities and challenges for the process mining field, as more knowledge can be extracted from the recorded data, increasing the practical relevance and potential economic value of process mining. Traditional process mining approaches however have difficulties coping with this sheer amount of data (i.e. the number of events), as most interesting 2 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst algorithms are linear in the size of the event log and exponential in the number of different activities [3]. In order to provide a solution to this problem, tech- niques for decomposed process mining [3–5] have been proposed. Decomposed process mining aims to decompose the process mining problem at hand into smaller problems that can be handled by existing process discovery and confor- mance checking techniques. The results for these individual sub-problems can then be combined into solutions for the original problems. Also, these smaller problems can be solved concurrently with the use of parallel computing. Even sequentially solving many smaller problems can be faster than solving one big problem, due to the exponential nature of many process mining algorithms. Sev- eral decomposed process mining techniques have been developed in recent years [2–5, 7, 8, 10, 12, 13]. Though existing approaches have their merits, they lack in generality. In [5], a generic approach to decomposed process mining is proposed. The proposed approach provides a framework which can be combined with differ- ent existing process discovery and conformance checking techniques. Moreover, different decompositions can be used while still providing formal guarantees, e.g. the fraction of perfectly fitting traces is not influenced by the decomposi- tion. When decomposing an event log for (decomposed) process mining, several problems arise. In terms of decomposed process discovery, these problems lie in the step where the overall event log is decomposed into sublogs, where submod- els are discovered from these sublogs, and/or where submodels are merged to form the final model. Even though creating a decomposition is computationally undemanding, it is of key importance for the remainder of the decomposed pro- cess discovery process in terms of the overall required processing time and the quality of the resulting process model. The problem is that there is currently no clear way of determining the quality of a given decomposition of the events in an event log, before using that decompo- sition to either discover a process model or check conformance with. The current decomposition approaches do not use any quality notions to create a decompo- sition. Thus, potential improvements lie in finding such quality notions and a decomposition approach that uses those notions to create a decomposition with. The remainder of this paper is organized as follows. In Section 2 related work is discussed briefly. Section 3 introduces necessary preliminary definitions for decomposed process mining and the generic decomposition approach. Section 4 introduces decomposition quality notions to grade a decomposition upon, and two approaches that create a high quality decomposition according to those notions. Section 5 shows a (small) use case. The paper is concluded with views on future work in Section 6. 2 Related Work Little work has been done on the decomposition and distribution of process mining problems [3–5]. In [14] MapReduce is used to scale event correlation as a preprocessing step for process mining. In [6] an approach is described to distribute genetic process mining over multiple computers. In this approach can- Finding Suitable Activity Clusters for Decomposed Process Discovery 3 didate models are distributed and in a similar fashion the log can be distributed as well. However, individual models are not partitioned over multiple nodes. More related are the divide-and-conquer techniques presented in [9], where it is shown that region-based synthesis can be done at the level of synchronized State Machine Components (SMCs). Also a heuristic is given to partition the causal dependency graph into overlapping sets of events that are used to construct sets of SMCs. In [4] a different (more local) partitioning of the problem is given which, unlike [9], decouples the decomposition approach from the actual conformance checking and process discovery approaches. The approach presented in this pa- per is an extension of the approach presented in [4]. Where [4] splits the process mining problem at hand into subproblems using a maximal decomposition, our approach first aims to recombine the many created activity clusters into better and fewer clusters, and only then splits the process mining problem into subprob- lems. As a result, fewer subproblems remain to be solved. The techniques used to recombine clusters are inspired by existing software quality metrics and the business process metrics listed in [15]. More information on the use of software engineering metrics in a process mining context is described there as well. 3 Preliminaries This section introduces the notations needed to define a better decomposition approach. A basic understanding of process mining is assumed [1]. 3.1 Multisets, Functions, and Sequences Definition 1 (Multisets). Multisets are defined as sets where elements may appear multiple times. B(A) is the set of all multisets over some set A. For some multiset b ∈ B(A), and element a ∈ A, b(a) denotes the number of times a appears in b. For example, take A = {a, b, c, d}: b1 = [] denotes the empty multiset, b2 = [a, b] denotes the multiset over A where b2 (c) = b2 (d) = 0 and b2 (a) = b2 (b) = 1, b3 = [a, b, c, d] denotes the multiset over A where b3 (a) = b3 (b) = b3 (c) = b3 (d) = 1, b4 = [a, b, b, d, a, c] denotes the multiset over A where b4 (a) = b4 (b) = 2 and b4 (c) = b4 (d) = 1, and b5 = [a2 , b2 , c, d] = b4 . The standard set operators can be extended to multisets, e.g. a ∈ b2 , b5 \ b2 = b3 , b2 ] b3 = b4 = b5 , |b5 | = 6 Definition 2 (Sequences). A sequence is defined as an ordering of elements of some set. Sequences are used to represent paths in a graph and traces in an event log. S(A) is the set of all sequences over some set A. s = ha1 , a2 , . . . , an i ∈ S(A) denotes a sequence s over A of length n. Furthermore: s1 = h i is the empty sequence and s1 · s2 is the concatenation of two sequences. For example, take A = {a, b, c, d}: s1 = ha, b, bi, s2 = hb, b, c, di, s1 · s2 = ha, b, b, b, b, c, di 4 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst Definition 3 (Function Projection). Let f ∈ X 6→ Y be a (partial) function and Q ⊆ X. f Q denotes the projection of f on Q: dom(f Q ) = dom(f ) ∩ Q and f Q (x) = f (x) for x ∈ dom(f Q ). The projection can be used for multisets. For example, b5 {a,b} = [a2 , b2 ]. Definition 4 (Sequence Projection). Let A be a set and Q ⊆ A a subset. Q ∈ S(A) → S(Q) is a projection function and is defined recursively: (1) h iQ = h i and (2) for s ∈ S(A) and a ∈ A: ( sQ if a ∈ /Q (hai · s)Q = hai · sQ if a ∈ Q So ha, a, b, b, c, d, di{a,b} = ha, a, b, bi. 3.2 Event Logs Event logs are the starting point for process mining. They contain information recorded by the information systems and resources supporting a process. Typ- ically, the executed activities of multiple cases of a process are recorded. Note that only example behavior is recorded, i.e. event logs only contain information that has been seen. An event log often contains only a fraction of the possible be- havior [1]. A trace describes one specific instance (i.e. one “run”) of the process at hand, in terms of the executed activities. An event log is a multiset of traces, since there can be multiple cases having the same trace. For the remainder of this paper, we let UA be some universe of activities. Definition 5 (Trace). Let A ⊆ UA be a set of activities. A trace s ∈ S(A) is a sequence of activities. Definition 6 (Event log). Let A ⊆ UA be a set of activities. Let L ∈ B(S(A)) be a multiset of traces over A. L is an event log over A. An example event log is L1 = [ha, b, c, di5 , ha, b, b, c, di2 , ha, c, di3 ]. There are three unique traces in L1 , and it contains information about a total of 10 cases. There are 4·5+5·2+3·3 = 39 events in total. The projection can be used for event logs as well. That is, for some log L ∈ B(S(A)) and set Q ⊆ A : LQ = [sQ |s ∈ L]. For example L1 {a,b,c} = [ha, b, ci5 , ha, b, b, ci2 , ha, ci3 ]. We will refer to these projected event logs as sublogs. 3.3 Activity Matrices, Graphs, and Clusters In [5] different steps for a generic decomposed process mining approach have been outlined. In [16], an implementation of the generic approach has been created which decomposes the overal event log based on a causal graph of activities. This section describes the necessary definitions for this decomposition method. Finding Suitable Activity Clusters for Decomposed Process Discovery 5 Definition 7 (Causal Activity Matrix). Let A ⊆ UA be a set of activities. M(A) = (A × A) → [−1.0, 1.0] denotes the set of causal activity matrices over A. For a, a0 ∈ A and M ∈ M(A), M (a, a0 ) denotes the “directly follows strength” from a to a0 . A M (a, a0 ) value close to 1.0 signifies that we are quite confident there exists a directly follows relation between two activities while a value close to −1.0 signifies that we are quite sure there is no relation. A value close to 0.0 indicates uncertainty, i.e., there may be a relation, but there is no strong evidence for it. Definition 8 (Causal Activity Graph). Let A ⊆ UA be a set of activities. G(A) denotes the set of causal activity graphs over A. A causal activity graph G ∈ G(A) is a 2-tuple G = (V, E) where V ⊆ A is the set of nodes and E ⊆ (V × V ) is the set of edges. G = (V, E) ∈ G(A) is the causal activity graph based on M ∈ M(A) and a specific causality threshold τ ∈ [−1.0, 1.0] iff E = {(a, a0 ) ∈ A×A | M (a, a0 ) > τ } and V = (a,a0 )∈E {a, a0 }. S That is, for every pair of activities (a, a0 ) ∈ A, there’s an edge from a to a0 in G iff the value for a to a0 in the causal activity matrix M exceeds some threshold τ . Note that V ⊆ A since some activities in A might not be represented in G. Definition 9 (Activity Cluster). Let A ⊆ UA be a set of activities. C(A) denotes the set of activity clusters over A. An activity cluster C ∈ C(A) is a subset of A, that is, C ⊆ A. Definition 10 (Activity Clustering). Let A ⊆ UA be a set of activities. C(A) b denotes the set of activity clusterings over A. An activity clustering Cb ∈ C(A) b is a set of activity clusters, that is, C ⊆ P (A). A k-clustering C ∈ C(A) is a clustering with size k, i.e. |C| b b b b = k. Let C ∈ C(A) be a clustering over A, the number of activities in C is denoted by b b b b = | S C|, i.e. ||C|| ||C|| b signifies the number of unique activities in C.b C∈C b 3.4 Process Models and Process Discovery Process discovery aims at discovering a model from an event log while confor- mance checking aims at diagnosing the differences between observed and modeled behavior (resp. the event log and the model). Literature suggests many different notations for models. We abstract from any specific model notation, but will define the set of algorithms that discover a model from an event log. Various discovery algorithms have been proposed in literature. These discovery algo- rithms are often called mining algorithms, or miners in short. For an overview of different algorithms we refer to [1]. Definition 11 (Process Model). Let A ⊆ UA be a set of activities. N (A) denotes the set of process models over A, irrespective of the specific notation (Petri nets, transition systems, BPMN, UML ASDs, etc.) used. 6 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst Definition 12 (Discovery Algorithm). Let A ⊆ UA be a set of activities. D(A) = B(S(A)) → N (A) denotes the set of discovery algorithms over A. A discovery algorithm D ∈ D(A) discovers a process model over A from an event log over A. 3.5 Decomposed Process Discovery As discussed, in [5], a generic approach to decomposed process mining is pro- posed. In terms of decomposed process discovery, this approach can be explained as follows: Let A ⊆ UA be a set of activities, and let L ∈ B(S(A))) be an event log over A. In order to decompose the activities in L, first a causal activity matrix M ∈ M(A) is discovered. Any causal activity matrix discovery algo- rithm DCA ∈ B(S(A))) → M(A) can be used. From M a causal activity graph G ∈ G(A) is filtered (using a specific causality threshold). By choosing the value of the causality threshold carefully, we can filter out uncommon causal relations between activities or relations of which we are unsure, for example those rela- tions introduced by noise in the event log. Once the causal activity graph G has been constructed, an activity clustering C b ∈ C(A) b is created. Any activity clustering algorithm AC ∈ G(A) → C(A) can be used to create the clusters. b For example, the maximal decomposition can be used where the causal activity graph is cut across its vertices and each edge ends up in precisely one submodel. This leads to the smallest possible submodels [5]. For every cluster in the clus- tering, L is filtered to a corresponding sublog by projecting the cluster to L, i.e., for all C ∈ C b a sublog LC is created. A process model is discovered for each sublog LC . These are the submodels. Any discovery algorithm D ∈ D(A) can be used to discover the submodels. Finally, the submodels are merged into an overal model. Any merging algorithm in B(N (A)) → N (A) can be used for this step. Currently, submodels are merged based on activity labels. Note that we have |C| b clusters, sublogs and submodels, and ||C||b activities in the final, merged model. 4 A Better Decomposition It is apparent that the manner in which activities are clustered has a substantial effect on required processing time, and it is possible for similarly sized clusterings (in the average cluster size) to lead to very different total processing times. As a result of the vertex-cut (maximal ) decomposition approach [5], most activities will be in two (or more) activity clusters, leading to double (or more) work, as the clusters have a lot of overlap and causal relations between them, which might not be desirable. From the analysis results in [11] we can see that this introduces a lot of unwanted overhead, and generally reduces model quality. Also, sequences or sets of activities with high causal relations are generally easily (and thus quickly) discovered by process discovery algorithms, yet the approach will often split up these activities over different clusters. Model quality can potentially suffer from a decomposition that is too fine-grained. It might be that the sublogs Finding Suitable Activity Clusters for Decomposed Process Discovery 7 created by the approach contain too little information for the process discovery algorithm to discover a good, high quality submodel from, or that a process is split up where it shouldn’t be. Merging these low-quality submodels introduces additional problems. Hence, a good decomposition should (1) maximize the causal relations be- tween the activities within each cluster in the activity clustering, (2) minimize the causal relations and overlap across the clusters and (3) have approximately equally sized clusters. The challenge lies in finding a good balance between these three properties. A clustering where one cluster is a subset of another cluster is not valid as it would lead to double work, and would thus result in an increase in required processing time without increasing (or even decreasing) model quality. Note that this definition of a valid clustering allows for disconnected clusters, and that some activities might not be in any cluster. This is acceptable as processes might consist of disconnected parts and event logs may contain noise. However, if activities are left out some special processing might be required. Definition 13 (Valid Clustering). Let A ⊆ UA be a set of activities. Let C b ∈ C(A) b be a clustering over A. Cb is a valid clustering iff: C 6= ∅ ∧ ∀C1 ,C2 ∈C∧C b b 1 6=C2 C1 6⊆ C2 . CV (A) denotes the set of b valid clusterings over A. 4.1 Clustering Properties We define decomposition quality notions in terms of clustering properties. The first clustering property we define is cohesion. The cohesion of an activity cluster- ing is defined as the average cohesion of each activity cluster in that clustering. A clustering with good cohesion (cohesion ≈ 1) signifies that causal relations between activities in the same cluster are optimized, whereas bad cohesion (co- hesion ≈ 0) signifies that activities with few causal relations are clustered to- gether. Definition 14 (Cohesion). Let A ⊆ UA be a set of activities. Let M ∈ M(A) be a causal activity matrix over b ∈ CbV (A) be a valid clustering over A. The cohesion of clustering C A, and let C b in matrix M , denoted Cohesion(C, M ) is defined as follows: b P Cohesion(C, M ) Cohesion(C, b M ) = C∈Cb |C| b P c1 ,c2 ∈C max(M (c1 , c2 ), 0) Cohesion(C, M ) = |C × C| The second clustering property is called coupling, and is also represented by a number between 0 and 1. Good coupling (coupling ≈ 1) signifies that causal relations between activities across clusters are minimized. Bad coupling (coupling ≈ 0) signifies that there are a lot of causal relations between activities in different clusters. 8 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst Definition 15 (Coupling). Let A ⊆ UA be a set of activities. Let M ∈ M(A) be a causal activity matrix over b ∈ CbV (A) be a valid clustering over A. The coupling of clustering C A, and let C b in matrix M , denoted Coupling(C, M ) is defined as follows: b 1 P if |C| b ≤1 Coupling(C, M ) = b Coupling(C1 ,C2 ,M ) 1 − C1 ,C2 ∈C∧C b 1 6=C2 if |C| b >1 |C|·(| b C|−1) b P h i max(M (c1 , c2 ), 0) + max(M (c2 , c1 ), 0) c1 ∈C1 ,c2 ∈C2 Coupling(C1 , C2 , M ) = 2 · |C1 × C2 | Note that the weights of the causal relations are used in the calculation of cohesion and coupling. Relations of which we are not completely sure of (or that are weak) therefore have less effect on these properties than stronger ones. The balance of an activity clustering is the third property. A clustering with good balance has clusters of (about) the same size. Decomposing the activities into clusters with low balance (e.g. a k-clustering with one big cluster holding almost all of the activities and (k − 1) clusters with only a few activities) will not speed up discovery or conformance checking, rendering the whole decomposition approach useless. At the same time finding a clustering with perfect balance (all clusters have the same size) will most likely split up the process / log in places that “shouldn’t be split up”, as processes generally consist out of different-sized natural parts. Balance is also represented by a number between 0 and 1, where a good balance (balance ≈ 1) signifies that all clusters are about the same size and a bad balance (balance ≈ 0) signifies that the cluster sizes differ quite a lot. This balance formula utilizes the standard deviation of the sizes of the clusters in a clustering to include the magnitude of the differences in cluster sizes. A variation of this formula using squared errors or deviations could also be used as a clustering balance measure. Definition 16 (Balance). Let A ⊆ UA be a set of activities. Let C b ∈ CbV (A) be a valid clustering over A. The balance of clustering C b denoted Balance(C) b is defined as follows: b =1− 2 · σ(C) b Balance(C) ||C|| b Where σ(C) b signifies the standard deviation of the sizes of the clusters in the clustering C. b In order to assess a certain decomposition based on the clustering properties, we introduce a weighted scoring function, which grades an activity clustering with a score between 0 (bad clustering) and 1 (good clustering). A weight can be set for each clustering property, depending on their relative importance. A clustering with clustering score 1 has perfect cohesion, coupling and balance scores, on the set weighing of properties. Finding Suitable Activity Clusters for Decomposed Process Discovery 9 Definition 17 (Clustering Score). Let A ⊆ UA be a set of activities. Let M ∈ M(A) be a causal activity matrix over A, and let C b ∈ CbV (A) be a valid clustering over A. The clustering score (score) of clustering C b in matrix M , denoted Score(C,b M ) is defined as follows: b M) · CohW Score(C, b M ) = Cohesion(C, CohW + CouW + BalW b M) · CouW + Coupling(C, CohW + CouW + BalW b · BalW + Balance(C) CohW + CouW + BalW where CohW , CouW , and BalW are the weights for Cohesion, Coupling, and Balance. 4.2 Recomposition of Activity Clusters Creating a good activity clustering is essentially a graph partitioning problem. The causal activity graph needs to be partitioned in parts that have (1) good cohesion, (2) good coupling and (3) good balance. The existing maximal decom- position approach [5] often leads to a decomposition that is too decomposed, i.e. too fine-grained. Cohesion and balance of clusterings found by this approach are usually quite good, since all clusters consist of only a few related activities. However, coupling is inherently bad, since there’s a lot of overlap in the activity clusters and there are many causal relations across clusters. This decomposition approach leads to unnecessary and unwanted overhead and potential decreased model quality. We thus want to find a possibly non-maximal decomposition which optimizes the three clustering properties. Instead of applying or creating a different graph partitioning algorithm, we recompose the activity clusters obtained by the vertex-cut decomposition. The idea is that it is possible to create a clustering that has fewer larger clusters, requiring less processing time to discover the final model, because overhead as well as cluster overlap are reduced. Additionally, model quality is likely to in- crease because of the higher number of activities in the clusters and the lower coupling between clusters. There are often many ways in which a clustering can be recomposed to the desired amount of clusters, as shown in Figure 1. We are interested in the highest quality clustering of the desired size, i.e. the clustering that has the best cohesion, coupling and balance properties. A clustering that has a high clustering score will very likely lead to such a decomposition. In order to find a good decomposition in the form of a high-scoring clustering quickly, we propose two agglomerative hierarchical recomposition approaches, which iteratively merge clusters, reducing the size of the clustering by one each iteration. 10 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst Fig. 1. 3 possible recompositions from 16 to 4 clusters. Creating a coarser clustering could potentially decrease processing time and increase model quality. Proximity-based approach We propose an hierarchical recomposition ap- proach based on proximity between activity clusters, where cluster coupling is used as the proximity measure. The starting point is the clustering as created by the vertex-cut approach. We repeatedly merge the clusters closest to one an- other (i.e. the pair of clusters with the highest coupling) until we end up with the desired amount of clusters (k ). After the k-clustering is found, it is made valid by removing any clusters that are a subcluster of another cluster, if such clusters exist. It is therefore possible that the algorithm returns a clustering with size smaller than k. By merging clusters we are likely to lower the overal cohe- sion of the clustering. This drawback is minimized, as coupling is used as the distance measure. Coupling is also minimized. The proximity-based hierarchical recomposition approach however is less favored towards the balance property, as it is possible that -because of high coupling between clusters- two of the larger clusters are merged. In most processes however, coupling between two “origi- nal” clusters will be higher than coupling between “merged” clusters. If not, the two clusters correspond to parts of the process which are more difficult to split up (e.g. a loop, a subprocess with many interactions and/or possible paths between activities, etc.). Model quality is therefore also likely to increase by merging these clusters, as process discovery algorithms don’t have to deal with missing activities, or incorrect causal relations introduced in the corresponding sublogs. A possible downside is that as the clustering might be less balanced, processing time can be slightly higher in comparison with a perfectly-balanced decomposition. Finding Suitable Activity Clusters for Decomposed Process Discovery 11 Score-based approach We propose a second hierarchical recomposition algo- rithm that uses the scoring function in a look-ahead fashion. In essence, this algorithm, like the proximity-based variant, iteratively merges two clusters into one. For each combination of clusters, the score of the clustering that results from merging those clusters is calculated. The clustering with the highest score is used for the next step. The algorithm is finished when a k-clustering is reached. Like in the proximity-based approach, after the k-clustering is found, it is made valid by removing any clusters that are a subcluster of another cluster, if such clusters exist. The advantage of this approach is that specific (combinations of) clustering properties can be given priority, by setting their scoring weight(s) ac- cordingly. For example, it is possible to distribute the activities over the clusters near perfectly, by choosing a high relative weight for balance. This would likely lead to a lower overall processing time. However, it might lead to natural parts of the process being split over multiple clusters, which could negatively affect model quality. A downside of this algorithm is that, as the algorithm only looks ahead one step, it is possible that a choice is made that ultimately leads to a lower clustering score, as that choice cannot be undone in following steps. 4.3 Implementation All concepts and algorithms introduced in this paper are implemented in the process mining toolkit ProM 1 , developed at the Eindhoven University of Tech- nology. All work can be found in the BartHompes package2 . For more elaborate explanations, pseudo-code of the algorithms, and analysis results we refer to [11]. 5 Use Case The proposed recomposition techniques are tested using event logs of different sizes and properties. Results for an event log consisting of 33 unique activities, and 1000 traces are shown in this section. For this test the ILP Miner process discovery algorithm was used [17]. Discovering a model directly for this log will lead to a high quality model, but takes ∼25 minutes on a modern quad-core sys- tem [11]. The vertex-cut decomposed process mining approach is able to discover a model in roughly 90 seconds, however the resulting model suffers from discon- nected activities (i.e. a partitioned model). The goal is thus to find a balance between processing times and model quality. We are interested in the clustering scores of each algorithm when recompos- ing the clustering created by the vertex-cut approach to a certain smaller size. Exhaustively finding the best possible clustering proved to be too time- and resource-consuming, therefore, besides the two hierarchical approaches listed here, a random recomposition approach was used which recomposes clusters randomly one million times, as to give an idea of what the best possible cluster- ing might be. The highest found clustering score is shown on the graph. Equal 1 See http://www.processmining.org 2 See https://svn.win.tue.nl/repos/prom/Packages/BartHompes/ 12 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst weights were used for the three clustering properties in order to compute the clustering scores. As can be seen in Figure 2, the vertex-cut approach creates 22 clusters. We can see that all algorithms perform very similarly in terms of clustering score. Only for very small clustering sizes the proximity-based ap- proach performs worse than the other approaches, due to its tendency to create unbalanced clusters. Clustering scores 0,75 0,7 0,65 Clustering score 0,6 0,55 0,5 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 # clusters Agglomerative Hierarchical w/ Proximity Agglomerative Hierarchical w/ Scoring Random (max) Fig. 2. Clustering score per recomposition algorithm. Besides clustering scores, we are even more interested in how each decom- position method performs in terms of required processing time and quality of the resulting process model. In Figure 3 we can see that decomposing the event log drastically reduces processing times. For an event log this size, the decom- position steps relatively takes up negligible time (see base of bars in figure), as most time is spent discovering the submodels (light blue bars). Processing times are reduced exponentially (as expected), until a certain optimum decomposition (in terms of speed) is reached, after which overhead starts to increase time lin- early again. We have included two process models (Petri Nets) discovered from the event log. Figure 4 shows the model discovered when using the vertex-cut decomposition. Figure 5 shows the model discovered when using the clustering recomposed to 11 clusters with the Proximity-based agglomerative hierarchical approach. We can see that in Figure 4, activity “10” is disconnected (marked blue). In Figure 5, this activity is connected, and a structure (loop) is discov- ered. We can also see that activity “12” now is connected to more activities. This shows that the vertex-cut decomposition sometimes splits up related activities, which leads to a lower quality model. By recomposing the clusters we rediscover these relations, leading to a higher quality model. Processing times for these two models are comparable, as can be seen in Figure 3. Finding Suitable Activity Clusters for Decomposed Process Discovery 13 Time per step & Partitions in model - ILP Miner Discovery Algorithm 900 4 800 700 3 600 Partitions in model Time in seconds 500 2 400 300 1 200 100 0 0 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 Agglomerative Hierarchical w/ Proximity Agglomerative Hierarchical w/ Scoring Max. Decomp. Recomposition method - # clusters Matrix Graph Clustering Sublogs Submodels Merge Partitions in model Fig. 3. Time per step & partitions in model using the Agglomerative Hierarchical recomposition approaches and the ILP Miner process discovery algorithm. Fig. 4. Process model discovered using the vertex-cut decomposition. Some activities are disconnected in the final model. Fig. 5. Process model discovered using the vertex-cut clustering recomposed to 11 clus- ters. Previously disconnected activities are connected again, improving model quality. 6 Conclusions and Future Work In decomposed process discovery, large event logs are decomposed by somehow clustering their events (activities), and there are many ways these activity clus- terings can be made. Hence, good quality notions are necessary to be able to assess the quality of a decomposition before starting the time-consuming actual discovery algorithm. Being able to find a high-quality decomposition plays a key role in the success of decomposed process mining, even though the decomposition step takes relatively very little time. 14 B.F.A. Hompes, H.M.W. Verbeek, W.M.P. van der Aalst By using a better decomposition, less problems arise when discovering sub- models for sublogs and when merging submodels into the overal process model. We introduced three quality notions in the form of clustering properties: cohe- sion, coupling and balance. It was shown that finding a non-maximal decom- position can potentially lead to a decrease in required processing time while maintaining or even improving model quality, compared to the existing vertex- cut maximal decomposition approach. We have proposed two variants of an agglomerative hierarchical recomposition technique, which are able to create a high-quality decomposition for any given size, in very little time. Even though the scope was limited to decomposed process discovery, the introduced quality notions and decomposition approaches can be applied to decomposed conformance checking as well. However, more work is needed to incorporate them in a conformance checking environment. Besides finding a better decomposition, we believe improvements can be gained in finding a better, more elaborate algorithm to merge submodels into the overal process model. By simply merging submodels based on activity labels it is likely that implicit paths are introduced. Model quality in terms of fitness, sim- plicity, generality or precision could suffer. An additional post-processing step (potentially using causal relations) could also solve this issue. Even though most interesting process discovery algorithms are exponential in the number of different activities, adding an infrequent or almost unrelated activity to a cluster might not increase computation time for that cluster as much as adding a frequent or highly related one. Therefore, besides weighing causal relations between activities in the causal activity matrix, activities themselves might be weighted as well. Frequency and connectedness are some of the many possible properties that can be used as weights. It might be possible that one part of a process can be discovered easily by a simple algorithm whereas another, more complex part of the process needs a more involved discovery algorithm to be modeled correctly. Further improvements in terms of processing time can be gained by somehow detecting the complexity of a single submodel in a sublog, and choosing an adequate discovery algorithm. Finally, as discussed, the proposed recomposition algorithms expect the de- sired amount of clusters to be given. Even though the algorithms were shown to provide good results for any chosen number, the approach would benefit from some method that determines a fitting clustering size for a given event log. This would also mean one less potentially uncertain step for the end-user. References [1] van der Aalst, W.M.P.: Process Mining: Discovery, Conformance and En- hancement of Business Processes. Springer, Berlin (2011) 1, 3, 4, 5 [2] van der Aalst, W.M.P.: Decomposing process mining problems using pas- sages. In: Application and Theory of Petri Nets, pp. 72–91. Springer (2012) 2 Finding Suitable Activity Clusters for Decomposed Process Discovery 15 [3] van der Aalst, W.M.P.: Distributed Process Discovery and Conformance Checking. In: de Lara, J., Zisman, A. (eds.) FASE. Lecture Notes in Com- puter Science, vol. 7212, pp. 1–25. Springer (2012) 2 [4] van der Aalst, W.M.P.: A general divide and conquer approach for process mining. In: Computer Science and Information Systems (FedCSIS), 2013 Federated Conference on. pp. 1–10. IEEE (2013) 3 [5] van der Aalst, W.M.P.: Decomposing Petri nets for process mining: A generic approach. Distributed and Parallel Databases 31(4), 471–507 (2013) 2, 4, 6, 9 [6] Bratosin, C.C., Sidorova, N., van der Aalst, W.M.P.: Distributed genetic process mining. In: Evolutionary Computation (CEC), 2010 IEEE Congress on. pp. 1–8. IEEE (2010) 2 [7] Carmona, J.: Projection approaches to process mining using region-based techniques. Data Min. Knowl. Discov. 24(1), 218–246 (2012), http://dblp. uni-trier.de/db/journals/datamine/datamine24.html 2 [8] Carmona, J., Cortadella, J., Kishinevsky, M.: A Region-Based Algorithm for Discovering Petri Nets from Event Logs. In: Business Process Management (BPM2008). pp. 358–373 (2008) 2 [9] Carmona, J., Cortadella, J., Kishinevsky, M.: Divide-and-conquer strategies for process mining. In: Business Process Management, pp. 327–343. Springer (2009) 3 [10] Goedertier, S., Martens, D., Vanthienen, J., Baesens, B.: Robust Process Discovery with Artificial Negative Events. Journal of Machine Learning Research 10, 1305–1340 (2009) 2 [11] Hompes, B.F.A.: On Decomposed Process Mining: How to Solve a Jigsaw Puzzle with Friends. Master’s thesis, Eindhoven University of Technology, Eindhoven, The Netherlands (2014), http://repository.tue.nl/776743 6, 11 [12] Muñoz-Gama, J., Carmona, J., van der Aalst, W.M.P.: Conformance Check- ing in the Large: Partitioning and Topology. In: Daniel, F., Wang, J., Weber, B. (eds.) BPM. Lecture Notes in Computer Science, vol. 8094, pp. 130–145. Springer (2013) 2 [13] Muñoz-Gama, J., Carmona, J., van der Aalst, W.M.P.: Hierarchical Confor- mance Checking of Process Models Based on Event Logs. In: Colom, J.M., Desel, J. (eds.) Petri Nets. Lecture Notes in Computer Science, vol. 7927, pp. 291–310. Springer (2013) 2 [14] Reguieg, H., Toumani, F., Motahari-Nezhad, H.R., Benatallah, B.: Using mapreduce to scale events correlation discovery for business processes min- ing. In: Business Process Management, pp. 279–284. Springer (2012) 2 [15] Vanderfeesten, I.T.P.: Product-based design and support of workflow pro- cesses (2009) 3 [16] Verbeek, H.M.W., van der Aalst, W.M.P.: Decomposed Process Mining: The ILP Case. In: BPI 2014 Workshop (2014), accepted for publication 4 [17] van der Werf, J.M.E.M., van Dongen, B.F., Hurkens, C.A.J., Serebrenik, A.: Process discovery using integer linear programming. In: Applications and Theory of Petri Nets, pp. 368–387. Springer (2008) 11