Source code for pm4py.algo.discovery.alpha.data_structures.alpha_classic_abstraction

from pm4py.algo.discovery.causal import algorithm as causal_algorithm
from pm4py.algo.discovery.causal.algorithm import CAUSAL_ALPHA


[docs] class ClassicAlphaAbstraction: """ Class representing the basic abstraction of the alpha miner. The class covers start- and end attributes, the directly follows relation, the parallel relation and the causal relation. """ def __init__( self, start_activities, end_activities, dfg, activity_key="concept:name", ): self.__activity_key = activity_key self.__start_activities = start_activities self.__end_activities = end_activities self.__dfg = dfg self.__causal_relations = { k: v for k, v in causal_algorithm.apply( self.dfg, variant=CAUSAL_ALPHA ).items() if v > 0 }.keys() self.__parallel = {(f, t) for (f, t) in self.dfg if (t, f) in self.dfg} def __get_causal_relation(self): return self.__causal_relations def __get_start_activities(self): return self.__start_activities def __get_end_activities(self): return self.__end_activities def __get_directly_follows_graph(self): return self.__dfg def __get_parallel_relation(self): return self.__parallel def __get_activity_key(self): return self.__activity_key start_activities = property(__get_start_activities) end_activities = property(__get_end_activities) dfg = property(__get_directly_follows_graph) causal_relation = property(__get_causal_relation) parallel_relation = property(__get_parallel_relation) activity_key = property(__get_activity_key)