Source code for pm4py.algo.evaluation.simplicity.variants.extended_cyclomatic

from pm4py.objects.petri_net.obj import PetriNet, Marking
from pm4py.objects.petri_net.utils import reachability_graph
from typing import Optional, Dict, Any
from pm4py.util import nx_utils


[docs] def apply( petri_net: PetriNet, im: Optional[Marking] = None, parameters: Optional[Dict[Any, Any]] = None, ) -> float: """ Computes the extended cyclomatic metric as described in the paper: "Complexity Metrics for Workflow Nets" Lassen, Kristian Bisgaard, and Wil MP van der Aalst Parameters ------------- petri_net Petri net Returns ------------- ext_cyclomatic_metric Extended Cyclomatic metric """ if parameters is None: parameters = {} if im is None: # if not provided, try to reconstruct the initial marking by taking the # places with empty preset im = Marking() for place in petri_net.places: if len(place.in_arcs) == 0: im[place] = 1 reach_graph = reachability_graph.construct_reachability_graph( petri_net, im, use_trans_name=True ) G = nx_utils.DiGraph() for n in reach_graph.states: G.add_node(n.name) for n in reach_graph.states: for n2 in n.outgoing: G.add_edge(n, n2) sg = list(nx_utils.strongly_connected_components(G)) return len(G.edges) - len(G.nodes) + len(sg)