Detailed reference¶
Module contents¶
- exception vf3py.ApplicabilityScopeError(message)¶
Bases:
Exception
VF3Py has two limitations:
nx.MultiGraph
andnx.MultiDiGraph
are not supported.Complex rules for matching nodes and edges. In particular, can not allow the same node (or edge) to be matched with multiple ‘colors’.
This exception can be thrown by any of these functions:
are_isomorphic
,get_automorphisms
,get_exact_isomorphisms
,get_subgraph_isomorphisms
,has_subgraph
,main_vf3_caller
.
- vf3py.are_isomorphic(source_graph: Graph | DiGraph, target_graph: Graph | DiGraph, get_mapping: bool = False, **kwargs) bool | Tuple[bool, Dict | None] ¶
Check if two graphs are isomorphic. This includes checks for number of nodes -
are_isomorphic
always returns False if two graphs have different number of nodes, as opposed to graph-subgraph isomorphisms.- Parameters:
main_graph (nx.Graph | nx.DiGraph) – First graph.
ref_graph (nx.Graph | nx.DiGraph) – Second graph. Swap between source_graph <-> target_graph changes nothing.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
True if graphs are isomorphic, False - otherwise. Also, optionally returns Dict | None. The Dict represents the mapping ‘target_graph’ labels -> ‘source_graph’ labels. Returned only if get_mapping set to True.
- Return type:
- vf3py.get_automorphisms(graph: Graph | DiGraph, **kwargs) List[Dict] ¶
Get isomorphic mappings of NetworkX graph onto itself (automorphism).
- Parameters:
graph (nx.Graph | nx.DiGraph) – The graph of interest.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
List of graph<->graph isomorphisms (represented as dicts).
- Return type:
List[Dict]
- vf3py.get_exact_isomorphisms(source_graph: Graph | DiGraph, target_graph: Graph | DiGraph, **kwargs) List[Dict] ¶
Get a list of all isomorphisms between two NetworkX graphs. This includes checks for number of nodes -
get_exact_isomorphisms
always returns[]
if two graphs have different number of nodes, as opposed to graph-subgraph isomorphisms.- Parameters:
main_graph (nx.Graph | nx.DiGraph) – First graph.
ref_graph (nx.Graph | nx.DiGraph) – Second graph. Swap between source_graph <-> target_graph swaps keys with values in the resulting isomorphisms dicts.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
List of source_graph<->target_graph isomorphisms. Each isomorphism is represented by a dict that maps: ‘target_graph’ labels -> ‘source_graph’ labels.
- Return type:
List[Dict]
- vf3py.get_subgraph_isomorphisms(subgraph: Graph | DiGraph, graph: Graph | DiGraph, **kwargs) List[Dict] ¶
Solve subgraph isomorphism problem, i.e. find ways to match nodes of subgraph with some/all nodes of graph.
- Parameters:
subgraph (nx.Graph | nx.DiGraph) – Searching for maps of this graph.
graph (nx.Graph | nx.DiGraph) – Searching for maps into this graph.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
List of subgraph->graph isomorphisms. Each isomorphism is represented by a dict that maps: ‘subgraph’ labels -> ‘graph’ labels.
- Return type:
List[Dict]
- vf3py.get_subgraph_monomorphisms(subgraph: Graph | DiGraph, graph: Graph | DiGraph, **kwargs) List[Dict] ¶
Solve subgraph monomorphism problem, i.e. find ways to match nodes of subgraph with some/all nodes of graph.
- Parameters:
subgraph (nx.Graph | nx.DiGraph) – Searching for maps of this graph.
graph (nx.Graph | nx.DiGraph) – Searching for maps into this graph.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
List of subgraph->graph isomorphisms. Each isomorphism is represented by a dict that maps: ‘subgraph’ labels -> ‘graph’ labels.
- Return type:
List[Dict]
- vf3py.has_monomorphic_subgraph(subgraph: Graph | DiGraph, graph: Graph | DiGraph, get_mapping: bool = False, **kwargs) bool | Tuple[bool, Dict | None] ¶
Check if subgraph is a subgraph of graph using VF3 algorithm.
- Parameters:
subgraph (nx.Graph | nx.DiGraph) – Searching for maps of this graph.
graph (nx.Graph | nx.DiGraph) – Searching for maps into this graph.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
True if subgraph is, indeed, a subgraph of graph, False - otherwise. Also, optionally returns Dict | None: subgraph->graph isomorphism represented by a dict that maps: ‘subgraph’ labels -> ‘graph’ labels. Returned only if get_mapping set to True.
- Return type:
- vf3py.has_subgraph(subgraph: Graph | DiGraph, graph: Graph | DiGraph, get_mapping: bool = False, **kwargs) bool | Tuple[bool, Dict | None] ¶
Check if subgraph is a subgraph of graph using VF3 algorithm.
- Parameters:
subgraph (nx.Graph | nx.DiGraph) – Searching for maps of this graph.
graph (nx.Graph | nx.DiGraph) – Searching for maps into this graph.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.
- Returns:
True if subgraph is, indeed, a subgraph of graph, False - otherwise. Also, optionally returns Dict | None: subgraph->graph isomorphism represented by a dict that maps: ‘subgraph’ labels -> ‘graph’ labels. Returned only if get_mapping set to True.
- Return type:
- vf3py.main_vf3_caller(subgraph: Graph | DiGraph, graph: Graph | DiGraph, node_match: Callable[[dict, dict], bool] | None = None, edge_match: Callable[[dict, dict], bool] | None = None, all_solutions: bool = True, return_integers: bool = False, verbose: bool = False, variant: Literal['B', 'P', 'L'] = 'B', num_threads: int = 1, induced: bool = True, bijective_for_nodes: bool = False) List[Dict] ¶
The core routine of the VF3Py library. It solves the subgraph iso/monomorphism problem, i.e. finds ways to match nodes of
subgraph
with some/all nodes ofgraph
. Only NetworkX graphs are accepted (either nx.Graph or nx.DiGraph). NOTE: It is not practical to call this function directly – use one of the front-end functions instead:are_isomorphic
,get_exact_isomorphisms
,get_automorphisms
,has_subgraph
,get_subgraph_isomorphisms
.- Parameters:
subgraph (nx.Graph | nx.DiGraph) – Searching for maps of this graph.
graph (nx.Graph | nx.DiGraph) – Searching for maps into this graph.
node_match (Callable[[dict, dict], bool], optional) – Nodes are allowed to be matched only if this function returns
True
for the nodes’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.edge_match (Callable[[dict, dict], bool], optional) – Edges are allowed to be matched only if this function returns
True
for the edges’ attributes. Order of arguments: (1) dict of the source graph/subgraph, (2) target graph. Defaults toNone
.all_solutions (bool, optional) – Whether to generate all possible subgraph->graph matches (
True
) or only one (False
). Defaults toTrue
.return_integers (bool, optional) – Whether to represent isomorphisms using integers (
True
) or the original labels of NetworkX graphs (False
). Defaults toFalse
.variant (str, optional) – The VF3 variant to be used. One of
('B', 'P', 'L')
. Defaults to'B'
.num_threads (int, optional) – Number of threads to be used in parallel variant. Defaults to
1
.verbose (bool, optional) – Whether to print info on some intermediate steps. Defaults to
False
.induced (bool, optional) – Whether to search for monomorphisms (
False
) or isomorphisms (True
). Iso does not allow the target graph to have additional edges that are not present in the source graph. Defaults toTrue
.bijective_for_nodes (bool, optional) – Whether to search for mono/isomorphisms between entire graphs (
True
) or allow to match with a subgraph of the target graph (False
). Defaults toFalse
.
- Returns:
List of subgraph->graph isomorphisms. Each isomorphism is represented by a dict that maps: ‘subgraph’ labels -> ‘graph’ labels.
- Return type:
List[Dict]
Submodules¶
This is the C++ backend that performs VF3 calculations. Some small modifications of the original VF3lib code were introduced to make it work with Pybind11 for calling C++ from Python.
vf3py.vf3py_base module¶
- vf3py.vf3py_base.calc_bothattrs(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶
- vf3py.vf3py_base.calc_edgeattr(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶
vf3py.vf3py_vf3l module¶
- vf3py.vf3py_vf3l.calc_l_bothattrs(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶
- vf3py.vf3py_vf3l.calc_l_edgeattr(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶
vf3py.vf3py_vf3p module¶
- vf3py.vf3py_vf3p.calc_p_bothattrs(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶
- vf3py.vf3py_vf3p.calc_p_edgeattr(pattern: dict, target: dict, directed: bool = False, all_solutions: bool = True, verbose: bool = False, induced: bool = True, num_threads: int = 1) object ¶