Source code for PAMI.subgraphMining.topK.extendedEdge

[docs] class ExtendedEdge: def __init__(self, v1, v2, vLabel1, vLabel2, edgeLabel): """ Represents an extended edge in a graph with vertices v1 and v2, vertex labels vLabel1 and vLabel2, and a specified edge label. Args: v1 (int): The index of the first vertex. v2 (int): The index of the second vertex. vLabel1 (str): The label of the first vertex. vLabel2 (str): The label of the second vertex. edgeLabel (str): The label of the edge. Attributes: v1 (int): The index of the first vertex. v2 (int): The index of the second vertex. vLabel1 (str): The label of the first vertex. vLabel2 (str): The label of the second vertex. edgeLabel (str): The label of the edge. hashCode (int): A hash code generated based on the vertices, vertex labels, and edge label. """ self.v1 = v1 self.v2 = v2 self.vLabel1 = vLabel1 self.vLabel2 = vLabel2 self.edgeLabel = edgeLabel self.hashCode = (1 + v1) * 100 + (1 + v2) * 50 + (1 + vLabel1) * 30 + (1 + vLabel2) * 20 + (1 + edgeLabel)
[docs] def smallerThan(self, that): """ Checks if this extended edge is smaller than another extended edge. """ if that is None: return True x1, x2, y1, y2 = self.v1, self.v2, that.v1, that.v2 if self.pairSmallerThan(x1, x2, y1, y2): return True elif x1 == y1 and x2 == y2: return (self.vLabel1 < that.vLabel1 or (self.vLabel1 == that.vLabel1 and self.vLabel2 < that.vLabel2) or (self.vLabel1 == that.vLabel1 and self.vLabel2 == that.vLabel2 and self.edgeLabel < that.edgeLabel)) else: return False
[docs] def smallerThanOriginal(self, that): """ Checks if this extended edge is smaller than another extended edge based on original conditions. """ if that is None: return True x1, x2, y1, y2 = self.v1, self.v2, that.v1, that.v2 if self.pairSmallerThan(x1, x2, y1, y2): return True elif x1 == y1 and x2 == y2: return (self.vLabel1 < that.vLabel1 or (self.vLabel1 == that.vLabel1 and self.edgeLabel < that.edgeLabel) or (self.vLabel1 == that.vLabel1 and self.edgeLabel == that.edgeLabel and self.vLabel2 < that.vLabel2)) else: return False
[docs] def pairSmallerThan(self, x1, x2, y1, y2): """ Determines if one pair of vertices is smaller than another pair. """ xForward = x1 < x2 yForward = y1 < y2 if xForward and yForward: return x2 < y2 or (x2 == y2 and x1 > y1) elif not xForward and not yForward: return x1 < y1 or (x1 == y1 and x2 < y2) elif xForward: return x2 <= y1 else: return x1 < y2
def __hash__(self): """ Generates a hash code based on the vertices, vertex labels, and edge label. """ return self.hashCode def __eq__(self, other): """ Checks if two extended edges are equal based on their vertices, vertex labels, and edge label. """ if not isinstance(other, ExtendedEdge): return False return (self.v1 == other.v1 and self.v2 == other.v2 and self.vLabel1 == other.vLabel1 and self.vLabel2 == other.vLabel2 and self.edgeLabel == other.edgeLabel) def __repr__(self): """ Returns a string representation of the ExtendedEdge object. """ return f"<{self.v1},{self.v2},{self.vLabel1},{self.vLabel2},{self.edgeLabel}>"
[docs] def getV1(self): """ Retrieves the index of the first vertex. """ return self.v1
[docs] def getV2(self): """ Retrieves the index of the second vertex. """ return self.v2
[docs] def getVLabel1(self): """ Retrieves the label of the first vertex. """ return self.vLabel1
[docs] def getVLabel2(self): """ Retrieves the label of the second vertex. """ return self.vLabel2
[docs] def getEdgeLabel(self): """ Retrieves the label of the edge. """ return self.edgeLabel