Source code for pm4py.objects.ocel.util.convergence_divergence_diagnostics

from pm4py.objects.ocel.util import (
    events_per_type_per_activity,
    objects_per_type_per_activity,
)
from typing import Optional, Dict, Any
from pm4py.objects.ocel.obj import OCEL


[docs] def apply(ocel: OCEL, parameters: Optional[Dict[Any, Any]] = None): """ Reports the activities and the object types for which the convergence / divergence problems occur. Parameters ---------------- ocel Object-centric event log parameters Parameters of the algorithm Returns ---------------- ret Dictionary with two keys ("convergence" and "divergence"). Each key is associated to a set of (activity, object_type) for which the specific problem occurs. An activity/object type which does not appear neither in the "convergence" and "divergence" section does not suffer of convergence and divergence problems. """ if parameters is None: parameters = {} ev_per_type_per_act = events_per_type_per_activity.apply( ocel, parameters=parameters ) obj_per_type_per_act = objects_per_type_per_activity.apply( ocel, parameters=parameters ) ret = {"divergence": set(), "convergence": set()} # analyze the divergence problems for act in ev_per_type_per_act: for ot in ev_per_type_per_act[act]: if ev_per_type_per_act[act][ot]["median"] > 1: ret["divergence"].add((act, ot)) # analyze the convergence problems for act in obj_per_type_per_act: for ot in obj_per_type_per_act[act]: if obj_per_type_per_act[act][ot]["median"] > 1: ret["convergence"].add((act, ot)) return ret