Source code for pm4py.statistics.util.times_bipartite_matching
'''
PM4Py – A Process Mining Library for Python
Copyright (C) 2024 Process Intelligence Solutions UG (haftungsbeschränkt)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see this software project's root or
visit <https://www.gnu.org/licenses/>.
Website: https://processintelligence.solutions
Contact: info@processintelligence.solutions
'''
from pm4py.util import nx_utils
import sys
[docs]
def exact_match_minimum_average(l1, l2):
"""
Performs an exact matching, having minimum average,
of two lists of times (a timestamp of the first list
is matched with a timestamp of the second list that
is greater or equal). Some timestamps in the two lists
may be left out of the matching.
Parameters
---------------
l1
First list of times
l2
Second list of times
Returns
---------------
exact_matching
Exact matching (list of tuples having as first element
an element of the first list, and as second element
an element of the second list)
"""
G = nx_utils.Graph()
for i in range(len(l1)):
G.add_node(i)
for j in range(len(l2)):
G.add_node(len(l1) + j)
for i in range(len(l1)):
for j in range(len(l2)):
if l1[i] <= l2[j]:
G.add_edge(i, len(l1) + j, weight=(l2[j] - l1[i]))
else:
G.add_edge(i, len(l1) + j, weight=sys.maxsize)
matching0 = {
x: y
for x, y in nx_utils.minimum_weight_full_matching(G).items()
if x < len(l1)
}
matching = []
for k1, k2 in matching0.items():
v1 = l1[k1]
v2 = l2[k2 - len(l1)]
if v2 >= v1:
matching.append((v1, v2))
return matching