MultiGraphMatch: a subgraph matching algorithm for multigraphs
Authors/Creators
Description
Subgraph matching is the problem of finding all the occurrences of a small graph, called the query, in a larger graph, called the target. While the problem has been widely studied in simple graphs, few solutions have been proposed for multi-relational graphs, in which two nodes can be connected by multiple edges, each denoting a different type of relationship. In our new algorithm MultiGraphMatch, nodes and edges can be associated with labels, denoting classes, and multiple properties. MultiGraphMatch introduces a novel data structure called a "bit signature" to efficiently index both the query and the target and filter the set of target edges that are
matchable with each query edge. In addition, the algorithm proposes a new order of processing query edges based on the cardinalities of the sets of matchable edges and defines symmetry breaking conditions on nodes and edges to filter out redundant matches. By using the CYPHER query definition language, MultiGraphMatch
is able to perform queries with logical conditions on node and edge labels. We compare MultiGraphMatch to SumGra and graph database systems Memgraph and Neo4J, showing comparable or better performance in all queries on a wide variety of synthetic and real-world graphs.
Files
SyntheticTest.zip
Files
(51.6 MB)
| Name | Size | Download all |
|---|---|---|
|
md5:1ac482388cfbce497f15b79507368db0
|
51.6 MB | Preview Download |