Next Article in Journal
Rényi Entropy and Rényi Divergence in Product MV-Algebras
Previous Article in Journal
Investigation of Finite-Size 2D Ising Model with a Noisy Matrix of Spin-Spin Interactions
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Marking Vertices to Find Graph Isomorphism Mapping Based on Continuous-Time Quantum Walk

1
College of Computer Science, National University of Defense Technology, Changsha 410073, China
2
Science and Technology on Parallel and Distributed Processing Laboratory, National University of Defense Technology, Changsha 410073, China
*
Author to whom correspondence should be addressed.
Entropy 2018, 20(8), 586; https://doi.org/10.3390/e20080586
Submission received: 21 June 2018 / Revised: 6 August 2018 / Accepted: 7 August 2018 / Published: 8 August 2018

Abstract

:
The isomorphism problem involves judging whether two graphs are topologically the same and producing structure-preserving isomorphism mapping. It is widely used in various areas. Diverse algorithms have been proposed to solve this problem in polynomial time, with the help of quantum walks. Some of these algorithms, however, fail to find the isomorphism mapping. Moreover, most algorithms have very limited performance on regular graphs which are generally difficult to deal with due to their symmetry. We propose IsoMarking to discover an isomorphism mapping effectively, based on the quantum walk which is sensitive to topological structures. Firstly, IsoMarking marks vertices so that it can reduce the harmful influence of symmetry. Secondly, IsoMarking can ascertain whether the current candidate bijection is consistent with existing bijections and eventually obtains qualified mapping. Thirdly, our experiments on 1585 pairs of graphs demonstrate that our algorithm performs significantly better on both ordinary graphs and regular graphs.

1. Introduction

The problem of graph matching is finding similarities between graphs [1,2]. Exact graph matching is usually known as the graph isomorphism problem, which is judging whether two graphs are topologically the same [3]. The key to graph isomorphism is finding a structure-preserving mapping called isomorphism mapping [4].
Definition 1 (Isomorphism mapping).
Given two graphs G 1 = ( V 1 , E 1 ) and G 2 = ( V 2 , E 2 ) , an isomorphism mapping is a bijective mapping between the vertex sets of G 1 and G 2
f : V 1 V 2 ,
such that for any two nodes ( v i , v j V 1 ), they are adjacent in G 1 if and only if two nodes ( f ( v i ) , f ( v j ) V 2 ) are adjacent in G 2 .
Based on Definition 1, we can see that the isomorphism mapping (f) is a set of many unit bijections, such as v i f ( v i ) and v j f ( v j ) . To make things clear, we use i s o m o r p h i s m m a p p i n g or m a p p i n g to represent the whole mapping (f) and use u n i t b i j e c t i o n or b i j e c t i o n to represent a particular bijective relation between two nodes. Based on unit bijections, we can establish an isomorphism mapping and ascertain whether two graphs are isomorphic. Accordingly, the solution to the graph isomorphism problem often provides an isomorphism mapping rather than a judgement.
Definition 2 (Isomorphic).
Two graphs G 1 = ( V 1 , E 1 ) and G 2 = ( V 2 , E 2 ) are isomorphic if there is an isomorphism mapping (f) between the vertex sets of G 1 and G 2 .
Graph matching and graph isomorphism are widely used in various areas, including biochemistry [5], chemical database searches [6], electronic design automation [7], information retrieval [8], pattern recognition [9], and many other areas [10]. Because of its applications, graph isomorphism has been deeply studied by scholars and researchers. It is considered to be NP (nondeterministic polynomial-time) in computational complexity theory, but it is unknown whether it is NP-complete or not [11].
Some of the most influential isomorphism algorithms, including VF2 (an improved graph-matching algorithm proposed by Vento) [12], VF3 (a novel matching algorithm proposed by Vento) [13,14], RI (a matching algorithm proposed by Bonnici) [5], and LAD (Local All Different proposed by Solnon) [15], are based on the tree search. Starting with an empty mapping, they add verified unit bijections one after another and eventually obtain an isomorphism mapping. They often utilize backtracking and heuristics for pruning. Hence, they are among the most effective classical algorithms. Moreover, they can always give a correct isomorphism mapping, because they utilize verification while exploring. Although these algorithms are perfectly accurate, they are computationally complex. Their complexity may become exponential in the worst cases. In fact, most classical algorithms for graph isomorphisms have a high computational complexity, and thus, their performance is usually limited. There are also some other algorithms. For instance, Gori announced a method based on random walks [16]. It solves the problem in polynomial time, but only works on certain kinds of graphs. In 2015, Babai proposed a quasi-polynomial time algorithm [17], but the complexity of it was still not very satisfying.
Quantum walks gave people new inspiration to design algorithms. These algorithms can work on all kinds of graphs in polynomial time. Although they lack theoretical proof, their experimental accuracy is satisfying. Based on either the continuous-time quantum walk (CTQW) [18] or the discrete-time quantum walk (DTQW) [19], diverse algorithms have been proposed to solve the isomorphism problem with high accuracy and polynomial complexity. Douglas and Wang proposed an algorithm to distinguish two graphs using DTQW [20]. It is relatively accurate, with a complexity of O ( | V | 7 ) . David Emms’ algorithm, called Emms, is based on CTQW [21], and he gives a discrete-time version likewise [22]. The two algorithms have both polynomial time complexity, but they have very limited performance on regular graphs. Regular graphs are usually highly symmetric because each vertex has the same degree. Algorithms often find them difficult to distinguish, and thus produce incorrect isomorphism mappings.
The algorithm named Qiang1 proposed by Qiang utilizes CTQW to ascertain whether two graphs are isomorphic [23]. It is accurate and fast, with a complexity of O ( | V | 5 ) [23]. Nevertheless, it can only provide a judgement rather than a detailed isomorphism mapping. Moreover, its performance is also limited when faced with regular graphs. Its extension, the Intuitive Method, tries different unit bijections and integrates them into an isomorphism mapping [24]. It is effective but still suffers from poor accuracy on regular graphs. Another algorithm by Qiang, named Qiang3 [24], can both ascertain the isomorphism between two graphs and obtain an isomorphism mapping. Although Qiang3 claims to achieve improved accuracy, especially on regular graphs, its performance is still not very satisfying.
In a word, most algorithms based on quantum walks are still far from satisfactory. Some cannot provide detailed isomorphism mapping. Moreover, most algorithms have limited performance on regular graphs and thus output incorrect isomorphism mappings.
In this paper, we propose IsoMarking, inspired by Qiang’s algorithms. IsoMarking can discover the detailed isomorphism mapping between two graphs. It not only reduces the symmetry by marking vertices but also keeps the unit bijections qualified for a correct isomorphism mapping. It achieves better accuracy and, in particular, performs better on regular graphs. Our main contributions are listed as follows:
  • We propose the idea of using vertex markings to reduce the impact of symmetry provided by regular graphs.
  • We design a delicate and practical mechanism to mark diverse vertices and implement a detailed algorithm.
  • We propose an algorithm to ascertain whether the current unit bijection is consistent with the existing ones so that the isomorphism mapping is correct.
  • We conduct experiments on 1585 pairs of graphs and discover that IsoMarking performs significantly better on both ordinary graphs and regular graphs.
The rest of paper is organized as follows. Section 2 introduces related works, including quantum walks and isomorphism algorithms based on quantum walks. Section 3 introduces IsoMarking. Firstly, we discuss the impact of symmetry that regular graphs have. Then, we introduce the basic idea of marking vertices to reduce the symmetry. Based on a delicate marking mechanism, we present the detailed algorithm and a further discussion in Section 3. In Section 4, we take a pair of pentagrams as an example and see how IsoMarking works out correct isomorphism mapping between regular graphs compared with the Intuitive Method. Experiments are conducted in Section 5 to evaluate IsoMarking and other algorithms. The paper is concluded in Section 6.

2. Related Works

This section discusses related works. Firstly, we introduce some information concerning quantum walks. Then, we discuss isomorphism algorithms based on quantum walks in detail.

2.1. Quantum Walks

The quantum walk is the quantum analogue of classical random walks [25]. It introduces several kinds of quantum states to represent the current walker. The walker is a superposition described by a probability distribution over basis quantum states. Analogous to the classical random walk, the quantum walk can be described by different models, including the continuous-time quantum walk (CTQW) [18] and the discrete-time quantum walk (DTQW) [19]. A CTQW introduces position states to describe the current position of walker and utilizes the continuous unitary transformation to control the state evolution. In graph G = ( V , E ) , each position, namely, each node ( v V ), is represented by a column vector ( | v ), which is the basis state of the quantum walk in graph G. The walker is in a superposition of basis states, and each basis state has a corresponding probability amplitude ( α v ( t ) ). The probability amplitude is a complex number, and the square of its modulus equals the probability of basis state | v , namely the probability for the walker to be at node v. Consequently, the state of CTQW | φ t at time t can be written as follows:
| φ t = v V α v ( t ) | v
v V | α v ( t ) | 2 = 1 .
Given an initial state vector | φ 0 , we can compute the state vector with Equation (4). We usually choose the adjacency matrix or the Laplacian matrix as the Hamiltonian matrix (H):
| φ t = e i H t | φ 0 .
DTQW, in contrast, introduces position states and coin states to describe the current position and the moving direction, respectively. It is assumed that the walker is on an integer axis, and that the position state at point n Z can be represented by a basis state ( | n ). The moving direction can be described by two basis coin states | and | which represent g o i n g r i g h t and g o i n g l e f t , respectively. At position n, the walker is in a superposition of | n | and | n | . Each step of DTQW is a unitary transformation that has two operations on the current state. The first operation is called the coin flip transformation which changes the state of moving directions. The second is the shift operation, and it changes the position states. If the initial state and transformations are given, the quantum walk can be performed. Similarly, the probability of a basis state comes from the probability amplitude. On graphs, DTQW is similar, although the walk is more complicated.
Quantum walks can contribute to exponential speedup and are widely used in many algorithms. They can be applied to many fast search algorithms [26,27,28]. Some simulated annealing algorithms are also based on quantum walks [29]. Likewise, quantum walks can be used in mathematics, including graph theory [30] and the element distinctness problem [31].

2.2. Isomorphism Algorithms Based on Quantum Walks

Quantum walks are very sensitive to topological structures. Therefore, the probability amplitude can reveal topological patterns and roles. Consequently, quantum walks are widely used to solve many problems, including the computation of graph similarity [32] and graph kernels [33] and the detection of symmetries [34]. Likewise, quantum walks are applied in isomorphism algorithms to promote their performance. Moreover, quantum walks make it possible to solve the problem in polynomial time.
In 2008, Douglas and Wang [20] proposed the Douglas method based on DTQW, with a complexity of O ( | V | 7 ) . After performing DTQW, it compares the probability amplitude sets of two graphs. Although the correctness of Douglas is not theoretically proven, experiments demonstrate that it can distinguish most non-isomorphic graphs. In fact, for most isomorphism algorithms based on quantum walks, the correctness comes from massive experiments, rather than a theoretical proof.
Likewise, David Emms proposed two algorithms [21,22] based on CTQW and DTQW, respectively. Although these two algorithms utilize different quantum walks, they have similar mechanisms. Firstly, they co-join two graphs by a layer of indicator vertices and construct an auxiliary graph. Then, two quantum walks are simulated on two graphs in parallel. The probability amplitude of indicator vertices can reflect the quantum interference between two quantum walks. The interference amplitudes between equivalent nodes in two graphs are usually close to 0; therefore, such equivalent nodes can be detected. Emms establishes unit bijections according to equivalent nodes and then obtains the isomorphism mapping. Both algorithms are polynomial-time. However, they often produce incorrect mapping between regular graphs; hence, they have very limited performance on regular graphs. Regular graphs are highly symmetric; therefore, Emms’s auxiliary graph is even more symmetric. Both algorithms only consider the global structure rather than local patterns. Thus they can be confused by such equivalence between graphs.
Inspired by Douglas and Wang, Qiang proposed an enhanced approach called Qiang1 [23]. After performing CTQW on both graphs, it analyses the result and ascertains whether two graphs are isomorphic or not. Qiang1 focuses on pairs of vertices with an equal probability amplitude at some time, which can reflect the similarity between local structures. Qiang1 introduces the generalized similar vertex set and studies the similarity between graphs according to the probability amplitudes. Besides, it adds self-loops to reveal local topological information. Qiang’s algorithm is accurate and fast. Its complexity is O ( | V | 5 ) when the size of generalized similar vertex set is 2, and the complexity drops to O ( | V | 4 ) when the size is 1. Nevertheless, it can only provide a judgement rather than an isomorphism mapping. Moreover, it may distinguish regular graphs incorrectly, and therefore, its performance on regular graphs is limited.
Qiang extended the algorithm and proposed the Intuitive Method. This method can find an isomorphism mapping between isomorphic graphs by calling Qiang1 repeatedly [24]. At each turn, the algorithm randomly chooses one node from each graph and tries to establish a unit bijection between them. For node v 1 in graph G 1 and node v 2 in G 2 , the algorithm adds two new nodes only connected to v 1 and v 2 , respectively. It generates two new graphs, where the only changed parts are the local structures of v 1 and v 2 . If v 1 and v 2 are equivalent, the topological changes are the same. With the original isomorphic graphs, the new graphs are also isomorphic. Then, the algorithm establishes a unit bijection between v 1 and v 2 , denoted as v 1 v 2 . If the two nodes are not equivalent, the probability amplitudes will be significantly different, because the quantum walk is extremely sensitive to topological changes. Accordingly, the new graphs are not isomorphic, and the candidate unit bijection v 1 v 2 fails. With repeated trials, unit bijections between nodes can be established one by one, and the whole isomorphism mapping is obtained eventually. This strategy works effectively on ordinary graphs, but it performs poorly on regular graphs. There are too many possible bijections because regular graphs are highly symmetric. Any unit bijection alone is suitable, but unit bijections can have conflict with each other. A simple integration of unit bijections can be problematic. Thus, the Intuitive Method often produces incorrect mappings.
Qiang further proposed another algorithm, Qiang3 [24], which can both ascertain the isomorphisms between graphs and find isomorphism mappings. It studies the differences between the probability amplitude sets of two graphs. If two probability amplitudes are the same, the corresponding nodes can establish a unit bijection. It establishes an isomorphism mapping based on such bijections. If the algorithm is not able to find an isomorphism mapping, then the two graphs are non-isomorphic. Likewise, Qiang3 adds self-loops to vertices in order to reflect the local topological information, which can reduce the impact of symmetry to some extent. Qiang3 is O ( | V | 4 ) and is claimed to achieve improved performance on regular graphs, although the accuracy is still not satisfying.
In this paper, we propose an algorithm based on Qiang’s algorithms. It can not only find the isomorphism mapping between graphs but also performs better on regular graphs.

3. IsoMarking

This section introduces IsoMarking. Firstly, we discuss the impact of symmetry to see why regular graphs are difficult for isomorphism algorithms. Then, we introduce the basic idea of marking vertices to reduce the symmetry. In the third part, we design a delicate mechanism to mark vertices, followed by a detailed algorithm. In addition, we present a further discussion concerning IsoMarking, including the computational complexity.

3.1. The Impact of Symmetry

Although the quantum walk is sensitive to topological structures, its performance suffers from the presence of symmetrical structures. Both DTQW and CTWQ rely on the probability amplitude to reveal the topological equivalence between graphs, based on which algorithms can establish unit bijections. Symmetric graphs, however, usually have many equivalent vertices that are confusing.
In regular graphs, nodes have the same number of neighbours. Therefore, regular graphs are highly symmetric and even automorphic which means the graph can be mapped onto itself by a structure-preserving permutation mapping [35]. Such strong symmetry can result in too many equivalent nodes and candidate unit bijections. Any candidate unit bijection alone is suitable because it comes from some equivalence. More unit bijections, however, can conflict with each other, because their integration as a mapping is not always structure-preserving. As a consequence, the mapping does not always qualify for an isomorphism mapping.
For instance, each pentagram in Figure 1, has five equivalent nodes. When we perform a quantum walk on both sides, the probability amplitudes are always the same, as shown in Table 1 and Table 2. Consequently, any two nodes are equivalent. One node in a pentagram can establish a unit bijection with any node in another pentagram. Hence, there are 25 candidate unit bijections in total. Then we choose five unit bijections, under the condition that every node is used only once. However, such bijections still cannot make an isomorphism mapping. For instance, the output can be { a i , b l , c h , d j , e k } . That result is not structure-preserving, because i and l are adjacent, while a and b are not.
Unfortunately, most algorithms treat graphs globally, and thus they make little effort to reduce the symmetry. Therefore, most algorithms perform poorly on regular graphs. They usually find it difficult to distinguish between regular graphs. Even though the isomorphism is correctly judged, the produced isomorphism mapping is still problematic.

3.2. Marking Vertices

The idea for coping with regular graphs and other symmetric graphs is to reduce the symmetry. Inspired by the Intuitive Method, we can add new adjacent nodes to vertices, which we call m a r k i n g v e r t i c e s . Different from the Intuitive Method, IsoMarking marks vertices not only to try diverse unit bijections but also to reduce the symmetry.
It is intuitive to reduce the symmetry by marking vertices. Since a regular graph is highly symmetric, there are several equivalent parts. If one part is marked by new neighbours while other parts are marked differently or not marked, these parts are no longer equivalent. Therefore, the symmetry is reduced. In addition, the quantum walk is so sensitive that only a few changes can give rise to dramatically different probability amplitudes. Therefore the influence of marking vertices on symmetry can be easily detected.
IsoMarking produces a more complicated mechanism to generate a new graph. We introduce four types of marking operations to mark more node pairs at the same time. Suppose we aim to mark node v 1 in graph G 1 = ( V 1 , E 1 ) and v 2 in G 2 = ( V 2 , E 2 ) . Because marking is operated equivalently on both sides, we only describe the operation of each marking type on G 1 :
  • Add one node v | V 1 | + 1 to G 1 which is only adjacent to v 1 ;
  • Add two nodes v | V 1 | + 2 , v | V 1 | + 3 to G 1 which are only adjacent to v 1 ;
  • Add two nodes v | V 1 | + 4 , v | V 1 | + 5 to G 1 which are adjacent to v 1 and to each other;
  • Add three nodes v | V 1 | + 6 , v | V 1 | + 7 , v | V 1 | + 8 to G 1 which are adjacent to v 1 and to one another.
The function of marking vertices is implemented in Algorithm 1. Given a graph, this function can mark, at most, four nodes using different marking types and then a new graph is returned. In Lines 3–6, node v a is marked by the first marking type, and in Line 7–10 i v b is marked by the second type. Similarly, v c and v d are marked by the third and fourth types, respectively. Vertices are marked only if they are in the graph, and thus, we can input illegal node ( 1 ) to indicate no more marking. The computational complexity of M a r k ( ) is O ( 1 ) because each line of Algorithm 1 is O ( 1 ) . Since the marking is operated equivalently on two graphs, Algorithm 1 is supposed to be called twice.
Note that we present four marking types in our paper. In fact, the number of marking types is not fixed. Intuitively, the number of marking types is related to the performance. There are some regular graphs requiring more marking types, while less marking types are sufficient sometimes. In Section 4, although IsoMarking uses four marking types, we can see that a pentagram marked by three types is no longer symmetric. Our algorithms are open to different numbers of marking types. We can easily modify our algorithms for a different number of types.
Algorithm 1 Mark
1:
Input:  G = ( V , E ) , nodes to mark v a , v b , v c , v d ;
2:
V n e w = V , E n e w = E ;
3:
if v a V then
4:
     V n e w = V n e w { v | V | + 1 } ;
5:
     E n e w = E n e w { { v a , v | V | + 1 } } ;
6:
end if
7:
if v b V then
8:
     V n e w = V n e w { v | V | + 2 , v | V | + 3 } ;
9:
     E n e w = E n e w { { v b , v | V | + 2 } , { v b , v | V | + 3 } } ;
10:
end if
11:
if v c V then
12:
     V n e w = V n e w { v | V | + 4 , v | V | + 5 } ;
13:
     E n e w = E n e w { { v c , v | V | + 4 } , { v c , v | V | + 5 } , { v | V | + 4 , v | V | + 5 } } ;
14:
end if
15:
if v d V then
16:
     V n e w = V n e w { v | V | + 6 , v | V | + 7 , v | V | + 8 } ;
17:
     E n e w = E n e w { { v i , v j } | v i , v j { v d , v | V | + 6 , v | V | + 7 , v | V | + 8 } } ;
18:
end if
19:
Output: the new graph G n e w = ( V n e w , E n e w ) .

3.3. Detailed Mechanism

Based on different marking types mentioned above, in this part, IsoMarking can establish unit bijections and reduce the impact of symmetry.
IsoMarking constructs isomorphism mapping based on unit bijections. At each turn, it picks up one node from each graph and tries to establish a unit bijection between picked nodes. In other words, IsoMarking checks whether the current candidate unit bijection is qualified. IsoMarking uses the first marking type to mark picked nodes and uses the other types to mark the other vertices to reduce the symmetry.
For a better understanding of the mechanism, we start with a simple case. Suppose there are two topologically equivalent nodes v i 1 and v j 1 in G 1 as well as two equivalent nodes v i 2 and v j 2 in an isomorphic graph G 2 . We aim to reduce equivalence in the same graph while preserving equivalence between graphs. We can simply mark v i 1 and v i 2 , and then such equivalence in the same graph no longer exists. If there are three equivalent nodes on both sides ( v i 1 , v j 1 , v k 1 in G 1 , and v i 2 , v j 2 , v k 2 in G 2 ), the method is similar. We mark v i 1 and v i 2 in one type, mark v j 1 and v j 2 differently, and then, the nodes are no longer equivalent. Therefore, for more equivalent vertices, we just need more marking types to distinguish them. We introduce three marking types to reduce the symmetry. More marking types are possible, although three marking types are usually powerful enough. Sometimes they can even change the regular graph into a non-symmetric ordinary graph, as shown in Section 4.
As a result, we can mark equivalent vertices in the same graph to distinguish them and reduce the symmetry. Nevertheless, there are still two problems remaining, as follows:
  • Marking vertices can easily distinguish equivalent nodes in the same graph, but how can we find those equivalent nodes?
  • When we mark nodes in one graph, we are also supposed to mark corresponding nodes equivalently in the other graph. How can we successfully find the corresponding nodes?
For the first problem, we do not bother to find such nodes. Instead, we assume every node may have equivalent nodes in the same graph. We take all vertices into consideration and mark them in some order with their equivalent nodes in the other graph.
The answer to the second problem is crucial. Our aim is to find equivalent nodes between two graphs. Before that, however, we want to find equivalent nodes in the other graph to mark them and reduce the symmetry. There appears to be a circular reasoning. Actually, those equivalent nodes are not supposed to be the same. The key is when we mark vertices to reduce the symmetry, we only mark nodes which are already known to be equivalent. To put it another way, we use the first marking type to mark the nodes of the current candidate bijection and use the other types to mark the existing unit bijections. Given one node in a graph, it is easy to find its equivalent node in the other graph based on the known unit bijections.
From what has been discussed above, we can solve both problems. At each turn, IsoMarking chooses one node from each graph and marks them by the first marking type. Likewise, IsoMarking marks the nodes of the last three established unit bijections. Each pair of nodes is marked by one marking type. Initially, there are not enough existing unit bijections; hence, we just mark as many as possible.
Accordingly, there are usually three existing unit bijections with one candidate unit bijection marked in each new graph. The new graphs are isomorphic if and only if all the four changed parts in one graph are consistent with the corresponding parts in the other graph. The changed structures of existing bijections are already qualified for isomorphism as a whole, guaranteed by the former trial; therefore, they will never disturb the current trial unless the current bijection is not qualified. As long as the changed structure of current candidate bijection can keep two graphs isomorphic, the candidate bijection is acceptable.
The detailed algorithm of IsoMarking is presented in Algorithm 2. It depends on Q i a n g 1 ( ) [23] to ascertain whether two graphs are isomorphic. In Line 3, IsoMarking firstly calls Q i a n g 1 ( ) to see whether the two graphs are isomorphic, because it makes no sense to try discovering an isomorphism mapping between non-isomorphic graphs. It then tries establishing unit bijections between the nodes from the two graphs. Each time, it studies a pair of nodes and marks them with the last three bijections, as shown in Lines 9–10. If the generated graphs are isomorphic and the current nodes are not used, a new unit bijection is established in Line 13. In Lines 14–16, the last three bijections are updated when a new bijection is accepted. If there are not enough existing bijections, we use 1 to indicate no more marking when calling M a r k ( ) .
Algorithm 2 IsoMarking
1:
Input:  G 1 = ( V 1 , E 1 ) , G 2 = ( V 2 , E 2 ) ;
2:
M a p p i n g = ;
3:
if Q i a n g 1 ( G 1 , G 2 ) = = F a l s e then
4:
    exit(1);
5:
end if
6:
l a s t 1 = l a s t 2 = l a s t 3 = ( 1 , 1 ) ;
7:
for each v i V 1 do
8:
    for each v j V 2 do
9:
         G 1 n e w = M a r k ( G 1 , v i , l a s t 1 ( 0 ) , l a s t 2 ( 0 ) , l a s t 3 ( 0 ) ) ;
10:
         G 2 n e w = M a r k ( G 2 , v j , l a s t 1 ( 1 ) , l a s t 2 ( 1 ) , l a s t 3 ( 1 ) ) ;
11:
        if Q i a n g 1 ( G 1 n e w , G 2 n e w ) = = T r u e then
12:
           if v j is not already used in M a p p i n g then
13:
                M a p p i n g = M a p p i n g { v i v j } ;
14:
                l a s t 3 = l a s t 2 ;
15:
                l a s t 2 = l a s t 1 ;
16:
                l a s t 1 = ( v i , v j ) ;
17:
               break;
18:
           end if
19:
        end if
20:
    end for
21:
end for
22:
Output: the isomorphism mapping M a p p i n g .

3.4. Further Discussion

We can understand IsoMarking from another perspective. Most algorithms only establish unit bijections one after another, and simply integrate unit bijections into an isomorphism mapping. They ignore the possibility that unit bijections may conflict with each other. Conflicting unit bijections can make the mapping no longer structure-preserving, and thus, those algorithms often fail. IsoMarking marks a current candidate bijection and several existing bijections at the same time; therefore, it can figure out whether the current candidate bijection is consistent with existing ones. If there are conflicts between them, the overall isomorphism can be destructed; hence, the candidate bijection fails. Otherwise, the new graphs are still isomorphic; hence, the current candidate is consistent with existing bijections. By such methods, IsoMarking can avoid potential conflicts between unit bijections. Only unit bijections consistent with existing ones can be accepted.
By marking the existing unit bijections, IsoMarking can both reduce the symmetry and avoid conflicts between unit bijections. Such a powerful mechanism does not function independently, because it also relies on the quantum walk to capture topological changes sensitively.
IsoMarking has a satisfying computational complexity. Since the isomorphic mapping between non-isomorphic graphs is meaningless, we assume the graphs are isomorphic. Accordingly, two graphs have the same number of vertices, namely | V 1 | = | V 2 | = N . In Q i a n g 1 ( ) , we set the size of the generalized similar vertex set to be 1, which is accurate enough, so the complexity of Q i a n g 1 ( ) in Line 3 drops from O ( N 5 ) to O ( N 4 ) . There is a nested loop in Lines 9–19. Therefore, the codes are executed for O ( N · N ) = O ( N 2 ) times. In Lines 9–10, M a r k ( ) is O ( 1 ) , while Q i a n g 1 ( ) in Line 11 is O ( ( N + 8 ) 4 = N 4 ) . In fact, IsoMarking adds, at most, eight nodes to each graph; hence, there is little influence on complexity. Line 12 can be simply implemented by an array of Boolean variables within O ( 1 ) . The rest codes are all O ( 1 ) . Consequently, the overall complexity is O ( 1 + N 4 + N 2 · ( 1 + N 4 ) ) = O ( N 6 ) —the same as the Intuitive Method.

4. Case Study

This section compares IsoMarking with another algorithm. We chose the Intuitive Method because it is easy to understand and somewhat similar to IsoMarking. We performed both algorithms on a pair of pentagrams, as shown in Figure 1. The pentagram is a regular graph and is highly symmetric. We aimed to find an isomorphism mapping between two pentagrams.

4.1. Results of the Intuitive Method

Firstly we show how the Intuitive Method works. At each step, the Intuitive Method randomly picks one node from each graph and tries to establish a unit bijection, as discussed in Section 2.2. We assumed that it picked node a in the left and node i in the right, and then a new graph was generated, as shown in Figure 2a. Obviously, the new graphs are the same, and thus it a unit bijection ( a i ) was established.
At the second step, the Intuitive Method also picks two nodes randomly and tests the isomorphism. We assumed that it chose b and l; thus it generated the graphs shown in Figure 2b. The graphs in Figure 2b are isomorphic; hence, the algorithm established another unit bijection ( b l ). In fact, each step generated the same graph; therefore, the trial was always successful. After the second step, the algorithm established { a i , b l } . Nevertheless, those two bijections were already in conflict with each other, because i and l were adjacent while a and b were not. Consequently, whatever occurred at the following steps, it definitely failed in this case.
In fact, if we accept unit bijection a i , only h and j qualify for a unit bijection together with b. The Intuitive Method, however, considers b to be equivalent to the other four nodes in the right pentagram. Thus, the Intuitive Method has a possibility of 0.5 to fail at the second step. Even though the algorithm, fortunately, picked h or j at the second step, it is still likely to fail at the following steps. When faced with pentagrams, the Intuitive Method only needs five steps to establish the whole mapping, because each step is a successful trial. However, it is difficult for its speedy answer to be correct.

4.2. Results of IsoMarking

As for IsoMarking, the consequence becomes different. Since there is no existing bijection at the first step, IsoMarking only marks the nodes of the current candidate bijection. It randomly picks one node from each graph and marks them, similar to the Intuitive Method. We assumed that it also chose a and i, and thus, the new graphs shown in Figure 3a were generated. Obviously, these graphs are the same and IsoMarking accepted a i .
Suppose that IsoMarking also picks b and l at the second step, and then, it marks b and l using the first marking type and marks a and i using the second type. Obviously, the new graphs (shown in Figure 3b) are no more isomorphic; therefore, the bijection b l fails. Because nodes of the previous bijection are marked, the symmetry is strongly reduced. We can see that marking vertices does help IsoMarking to reject b l which conflicts with a i .
At the third step, IsoMarking has to test some other unit bijection candidates. As long as IsoMarking chooses node b in the left, only h and j in the right are qualified. We assumed that IsoMarking picked node h at the third step, and then new graphs were generated, as shown in Figure 3c. These two graphs are isomorphic, and thus b h is considered to beconsistent with a i . As a result, IsoMarking has two unit bijections { a i , b h } .
At the fourth step, IsoMarking continues marking two existing bijections { a i , b h } . With two existing bijections marked, the graphs are no longer symmetric. Hence, they become ordinary graphs, and the other unit bijections can be easily revealed: { c l , e j , d k } . We assumed IsoMarking chose d and k, and the new graphs are shown in Figure 3d. With isomorphic graphs, IsoMarking establishes d k . By marking existing bijections, IsoMarking can accept those unit bijections one by one and work out a correct isomorphism mapping eventually.
Consequently, we can see the symmetry of pentagrams is strongly reduced, and unit bijections established by trials will never be in conflict with each other. The pentagram is highly symmetric, and all its nodes are equivalent to each other. However, after the third step of IsoMarking, the marking of two existing bijections is sufficient to change pentagrams into ordinary graphs. Therefore, different marking types can collaborate and become even more powerful. As a result, IsoMarking only needs, in total, three marking types when faced with pentagrams. Although IsoMarking needs more steps due to failed trials, it can obtain correct mapping eventually. In the case of pentagrams, IsoMarking can always find a correct answer while the Intuitive Method is more likely to fail.

5. Experiments

In this section, we conduct experiments to evaluate IsoMarking. Firstly, we introduce information concerning the experimental setup. Then, we compare our algorithm with state-of-the-art algorithms on both ordinary graphs and regular graphs. Finally, we study the running costs of these algorithms.

5.1. Experimental Setup

We aimed to choose state-of-the-art algorithms to compare the performance. As discussed in Section 1, some of the most influential ones, including VF2 [12], VF3 [13,14], RI [5], and LAD [15], are usually based on the tree search and verification. These algorithms are optimal with perfectly correct results. Nevertheless, the complexity is exponential or quasi-polynomial in the worst cases. IsoMarking, in contrast, is based on random walks. It is similar to approximation algorithms. IsoMarking is polynomial-time in any graph, although the accuracy is relatively limited. Therefore, it is difficult to compare IsoMarking with optimal algorithms for accuracy, because the optimal algorithms are always correct. Likewise, it is difficult to compare them in terms of complexity, because IsoMarking is theoretically superior in computational complexity. Such a comparison does both sides an injustice.
Therefore, we only compared IsoMarking with other algorithms based on random walks. For better comparison, we chose polynomial-time algorithms with sacrificed accuracy. Thus we chose the Intuitive Method [24], Emms [21], and Qiang3 [24] for comparison. The Intuitive Method can discover an isomorphism mapping based on a judging algorithm (Qiang1) [23]. Emms [21,22] is most influential in the graph isomorphism problem, and we chose the continuous-time version [21]. We also chose Qiang3 [24] as a baseline, as it is claimed to perform particularly well on regular graphs. All the source codes were implemented in Matlab. Some source codes are available from the thesis [24], and we implemented the other codes, including an implementation of Emms according to its related works [21,36].
Because those algorithms are not perfectly correct, we concentrated on the accuracy performance. We evaluated the algorithms with two experiments. The first experiment focused on their performance on ordinary graphs, while the second was designed to evaluate them on regular graphs.
The two experiments were carried out in the same way except for the graph type. Firstly we generated groups of graph paisr. Each pair included two isomorphic graphs. We aimed to evaluate their accuracy of discovering an isomorphism mapping; thus, we performed algorithms on every graph pair and examined the output mapping. There can be more than one correct isomorphism mapping, especially in regular graphs. Therefore, it is not suitable to compare the output mapping with the ground truth. We returned to the definition of isomorphism mapping in Definition 1. Thus, we chose to check whether the output mapping was structure-preserving instead. In our experiments, we depended on Algorithm 3 [24] to verify the output. If the mapping passed the verification, and then it was deemed to be correct; otherwise, the mapping was deemed to have failed. The average accuracy of each algorithm in every group was calculated. Furthermore, we recorded the average running time and the peak memory cost while running each algorithm based on the Profiler in Matlab.
Algorithm 3 Check
1:
Input:  G 1 = ( V 1 , E 1 ) , G 2 = ( V 2 , E 2 ) , and the mapping f;
2:
if v 1 V 1 , v 2 V 2 , { v 1 v 2 } f then
3:
     P a s s = F a l s e ;
4:
    return P a s s ;
5:
end if
6:
for each v i V 1 do
7:
    for each v j V 1 do
8:
        if ( ( { v i , v j } E 1 ) ( { f ( v i ) , f ( v j ) } E 2 ) ) then
9:
            P a s s = F a l s e ;
10:
           return P a s s ;
11:
        end if
12:
    end for
13:
end for
14:
P a s s = T r u e ;
15:
Output: the result P a s s .
We generated 16 groups of graphs with 1585 pairs of isomorphic graphs in total. All experiments were performed on a 2.6 GHz Intel i5-4210M PC with 8 GB main memory, running Windows 8. Matlab codes were run in 64-bit Matlab R2012b (8.0.0.783).

5.2. Results on Ordinary Graphs

We generated six groups of ordinary graphs, namely Groups 1–6. Each group consisted of 100 ordinary graph pairs. Hence, there were 600 pairs of ordinary graphs in total. The basic information about Groups 1–6 is presented in Table 3, where N and k refer to the vertex number and the average degree, respectively.
The results are shown in Figure 4. All algorithms performed well in most groups. In Group 1 and Groups 3–5, all of the algorithms performed perfectly with an accuracy of 1.00. In Group 6, the Intuitive Method and Emms achieved 0.98 and 0.96, respectively. They were only a little worse than IsoMarking and Qiang3 whose accuracies were both 1.00. Group 2 was relatively distinctive. Because Group 2 had larger and more complicated graphs, it was more challenging. Therefore, various algorithms performed differently, and thus, the performance of some algorithms greatly dropped. Even so, IsoMarking still performed the best with a score of 0.99. On the contrary, the figures of the other algorithms were only about 0.55 or 0.64.
There was another interesting phenomenon. In the 600 graph pairs, IsoMarking rarely performed worse than any other algorithm. The only exception was the nineteenth graph pair in Group 2, where only Qiang3 gave the correct isomorphism mapping. For the other 599 graph pairs, IsoMarking definitely worked out a correct mapping, while the other algorithms failed occasionally.
As for the promotion of IsoMarking, we only studied the promotion in Group 2, because the figures for the other groups were very close. In the second group, IsoMarking outperformed the Intuitive Method and Emms by 54.69%, and it outperformed Qiang3 by 80%.
So, in ordinary graphs, we can see that IsoMarking performs the best. Although the others usually perform well, their performance drops greatly when the graphs become complicated. IsoMarking not only keeps an accuracy level that is never less than 0.99, but it also outperforms others considerably when graphs become more challenging.

5.3. Results on Regular Graphs

We also generated more regular graphs for experiments. There were 985 pairs of regular graphs in total, divided into ten groups, namely Groups 7–16. The basic information about these groups is shown in Table 4.
The results for regular graphs are shown in Table 5. Obviously, various algorithms performed significantly differently.
Emms had the worst performance with an accuracy level that was usually close to 0. The only exception was Group 15, in which its accuracy was 0.5. The Intuitive Method was also unsatisfying, although it was much better than Emms. Its score was always less than 0.5, except for Group 7. Its accuracy was even less than 0.3 in six groups. These two algorithms lack effective techniques to cope with the impact of symmetry. Therefore, they are easily confused by regular graphs and often fail to give a correct isomorphism mapping.
Our experiments demonstrated that Qiang3 achieves better performance on regular graphs. Its accuracy was usually about 0.5 to 0.6, and even 0.8 sometimes. In Group 11, Qiang3 even achieved a score very close to that of IsoMarking. Consequently, Qiang3 performed much better than the other two baselines in regular graphs, although its performance on ordinary graphs was relatively low. Qiang3 scored zero in Group 15, but such a case can be regarded as an exception considering its overall accuracy. Qiang3 was able to reduce the impact of symmetry to some extent and utilized verification to avoid conflicts between unit bijections. Therefore, it usually performed better than the Intuitive Method and Emms.
IsoMarking performed best in all groups. Its accuracy was usually higher than 0.75. It was the only algorithm whose accuracy reached 0.85. It scored 0.85 or higher in six groups. Even in Group 15, where two algorithms were utterly wrong, its accuracy was still not less than 0.75. With its superior performance, IsoMarking achieved brilliant promotion. It outperformed the Intuitive Method by 43.75–466.67%, and it outperformed Qiang3 by 3.61–48.72%, not to mention Emms whose score was usually 0.
When we analysed the results from the perspective of groups, we drew similar conclusions. In all ten groups, IsoMarking was always the best. Qiang3 usually performed well, followed by the Intuitive Method. Emms usually scored close to zero. There was an exception (Group 15), where Emms was superior to other baselines, but IsoMarking still performed the best.
For the 985 pairs of regular graphs, IsoMarking never performsedworse than the Intuitive Method or Emms. In other words, when IsoMarking failed to work out a correct isomorphism mapping between two regular graphs, only Qiang3 could still give a correct mapping between them. However, such cases were rare—there were about only 50 cases in the total 985 cases (5.076%). In such cases, the four marking types were not sufficient, thus IsoMarking required more marking types to work out a correct mapping. In the other cases, if IsoMarking could not work out a correct mapping, then no algorithm was able to do so.
In this subsection, the Intuitive Method and Emms were shown to have very limited performance in regular graphs, and the performance of Qiang3 was not always satisfying, either. IsoMarking, however, still maintained its good performance. We can safely draw a conclusion that the mechanism of marking vertices does have the ability to reduce the impact of symmetry which helps IsoMarking to perform much better on regular graphs.

5.4. Running Cost Study

In this subsection, we describe the study of the running cost, including the time cost and the memory cost. Since all codes were implemented in Matlab, we used the profiler in Matlab to record the cost. The peak memory in the profile summary was chosen as the peak memory cost of each algorithm, as shown in Table 6. As for the time cost, the verification time spent on Algorithm 3 was not included. The average running time of each algorithm in each group was calculated, as shown in Table 7.
Generally, the running cost is related to the algorithm, the group size and the graph size. Each group is processed in a batch. Thus, more memory is required if the group has more graph pairs, but the average running time is not influenced. When faced with larger graphs, algorithms usually require more memory and time, which is particularly obvious with Emms. In the following discussion, we mainly discuss the running costs of different algorithms.
The results of the memory cost were very different among groups. However, we can still obtain some conclusions. Emms is the most memory-consuming because it used the largest amount of memory in none groups. Emms conducts a quantum walk on a graph much larger than the original graphs, and thus, it definitely requires more memory. Moreover, when the graphs became larger in Group 2 and Group 7, the figure of Emms increased significantly. Likewise, Qiang3 is memory-consuming, although it is a little better than Emms. Its memory cost is the largest in four groups. The Intuitive Method performed better than Emms and Qiang3, but IsoMarking performed the best. The figure of IsoMarking was the least with six groups, while it used the largest amount of memory only in Group 9. As a consequence, the memory cost of IsoMarking was satisfying.
As for time cost, both Qiang3 and Emms performed the quantum walk only once, thus they are faster. Qiang3 was usually faster in ordinary graphs, while Emms was faster in regular graphs. In regular graphs, however, Emms simply considers all unit bijections to be acceptable. It returns a mapping almost immediately, regardless of the fact that the mapping can be incorrect. As a consequence, Emms usually scores zero in regular graphs, and thus such speed is meaningless. Therefore, Qiang3 performs the best. In fact, Qiang3 is computationally faster, which is O ( | V | 4 ) .
IsoMarking and the Intuitive Method, in contrast, take more time. IsoMarking is even slower. Both algorithms are O ( | V | 6 ) , and they require repeated quantum walks to establish unit bijections one after another. Thus, they spend a large amount of time conducting quantum walks. The Intuitive Method can accept unqualified unit bijections, and return a mapping more quickly, despite the fact that the mapping can be incorrect. IsoMarking, however, utilizes different marking types, thus it is more strict. It rejects unqualified unit bijections accepted by the Intuitive Method, and therefore, it takes more trials, as discussed in Section 4. Furthermore, IsoMarking adds vertices to graphs. Although those nodes have little influence on the theoretical complexity, they can increase the time cost to some extent.
From what has been discussed above, we can see that IsoMarking performs well on memory cost, but it is somewhat time-consuming. Therefore, the overall running cost is barely satisfactory. Considering its brilliant promotion on both ordinary graphs and regular graphs, we believe such cost is acceptable.

6. Conclusions

We propose IsoMarking to figure out the isomorphism mapping between graphs. It uses the continuous-time quantum walk to sense topological changes in graphs. By marking vertices, it strongly reduces the symmetry and keeps bijections consistent with each other. The experiments in this study demonstrated that IsoMarking rarely performs worse than other algorithms. It achieved higher accuracy when discovering isomorphism mappings. Moreover, it significantly outperformed other algorithms when graphs were highly symmetric, especially for regular graphs. Its running cost was also acceptable. We plan to optimize our algorithm so that it can be more efficient and effective. Likewise, we plan to study the marking mechanism more deeply, so that it can cope with some extremely difficult structures.

Author Contributions

Methodology, X.W. (Xin Wang); Formal Analysis, Y.Z.; Investigation, K.L. (Kai Liu); Data Curation, Y.Z. and K.L. (Kai Liu); Writing—Original Draft Preparation, X.W. (Xin Wang); Writing—Review & Editing, K.L. (Kai Lu) and X.W. (Xiaoping Wang); Project Administration, X.W. (Xiaoping Wang); Funding Acquisition, K.L. (Kai Lu).

Funding

This work is partially supported by The National Key Research and Development Program of China (2016YFB0200401), by program for New Century Excellent Talents in University, by National Science Foundation (NSF) China 61402492, 61402486, 61379146, by the laboratory pre-research fund (9140C810106150C81001), by the HUNAN Province Science Foundation 2017RS3045.

Acknowledgments

I gratefully acknowledge the editors and reviewers for promoting the quality of our paper. Likewise, I acknowledge stimulating discussions with Shichuan Xue. I also acknowledge Ondrej Drbohlav for sharing the implementation of the Hungarian algorithm on GitHub.

Conflicts of Interest

The authors declare no conflict of interest.

Abbreviations

The following abbreviations are used in this manuscript:
LADLocal All Different
CTQWContinuous-time quantum walk
DTQWDiscrete-time quantum walk
NPNondeterministic Polynomial-time

References

  1. Vento, M. A long trip in the charming world of graphs for Pattern Recognition. Pattern Recognit. 2015, 48, 291–301. [Google Scholar] [CrossRef]
  2. Foggia, P.; Percannella, G.; Vento, M. Graph matching and learning in pattern recognition in the last 10 years. Int. J. Pattern Recognit. Artif. Intell. 2014, 28, 1450001. [Google Scholar] [CrossRef]
  3. Conte, D.; Foggia, P.; Sansone, C.; Vento, M. Thirty years of graph matching in pattern recognition. Int. J. Pattern Recognit. Artif. Intell. 2004, 18, 265–298. [Google Scholar] [CrossRef]
  4. Hsieh, S.M.; Hsu, C.C.; Hsu, L.F. Efficient Method to Perform Isomorphism Testing of Labeled Graphs; Springer: Berlin/Heidelberg, Germany, 2006; pp. 422–431. [Google Scholar]
  5. Bonnici, V.; Giugno, R.; Pulvirenti, A.; Shasha, D.; Ferro, A. A subgraph isomorphism algorithm and its application to biochemical data. BMC Bioinform. 2013, 14, 1–13. [Google Scholar] [CrossRef] [PubMed]
  6. Cook, D.J.; Holder, L.B. Mining Graph Data; John Wiley & Sons: Hoboken, NJ, USA, 2006. [Google Scholar]
  7. Baird, H.S.; Cho, Y.E. An artwork design verification system. In Proceedings of the 12th Design Automation Conference; IEEE Press: Piscataway, NJ, USA, 1975; pp. 414–420. [Google Scholar]
  8. Brugger, A.; Bunke, H.; Dickinson, P.; Riesen, K. Generalized Graph Matching for Data Mining and Information Retrieval. In Proceedings of the Industrial Conference on Advances in Data Mining: Medical Applications, E-Commerce, Marketing, and Theoretical Aspects; John Wiley & Sons: Hoboken, NJ, USA, 2008; pp. 298–312. [Google Scholar]
  9. Kandel, A.; Bunke, H.; Last, M. Applied Graph Theory in Computer Vision and Pattern Recognition; Springer: Berlin/Heidelberg, Germany, 2007. [Google Scholar]
  10. Bunke, H. Graph matching: Theoretical foundations, algorithms, and applications. Proc. Vis. Interface 2000, 21, 82–88. [Google Scholar]
  11. Garey, M.R.; Johnson, D.S. Computers and Intractability: A Guide to the Theory of NP-Completeness; W. H. Freeman: New York, NY, USA, 1983. [Google Scholar]
  12. Cordella, L.; Foggia, P.; Sansone, C.; Vento, M. A (sub)graph isomorphism algorithm for matching large graphs. IEEE Trans. Pattern Anal. Mach. Intell. 2004, 26, 1367–1372. [Google Scholar] [CrossRef] [PubMed]
  13. Carletti, V.; Foggia, P.; Saggese, A.; Vento, M. Challenging the Time Complexity of Exact Subgraph Isomorphism for Huge and Dense Graphs with VF3. IEEE Trans. Pattern Anal. Mach. Intell. 2018, 40, 804–818. [Google Scholar] [CrossRef] [PubMed]
  14. Carletti, V.; Foggia, P.; Saggese, A.; Vento, M. Introducing VF3: A New Algorithm for Subgraph Isomorphism. In Graph-Based Representations in Pattern Recognition; Foggia, P., Liu, C.L., Vento, M., Eds.; Springer International Publishing: Cham, Switzerland, 2017; pp. 128–139. [Google Scholar]
  15. Solnon, C. AllDifferent -based filtering for subgraph isomorphism. Artif. Intell. 2010, 174, 850–864. [Google Scholar] [CrossRef]
  16. Gori, M.; Maggini, M.; Sarti, L. Exact and approximate graph matching using random walks. IEEE Trans. Pattern Anal. Mach. Intell. 2005, 27, 1100. [Google Scholar] [CrossRef] [PubMed]
  17. Babai, L. Graph isomorphism in quasipolynomial time [extended abstract]. In Proceedings of the Forty-Eighth Annual ACM Symposium on Theory of Computing, Cambridge, MA, USA, 19–21 June 2016; ACM: New York, NY, USA, 2016; pp. 684–697. [Google Scholar]
  18. Farhi, E.; Gutmann, S. Quantum computation and decision trees. Phys. Rev. A 1998, 58, 915–928. [Google Scholar] [CrossRef] [Green Version]
  19. Feynman, R.P.; Hibbs, A.R.; Weiss, G.H. Quantum Mechanics and Path Integrals; McGraw-Hill: New York, NY, USA, 1965; p. 101. [Google Scholar]
  20. Douglas, B.; Wang, J. A Classical approach to the graph isomorphism problem using quantum walks. J. Phys. A 2008, 41, 075303. [Google Scholar] [CrossRef]
  21. Emms, D.; Wilson, R.C.; Hancock, E.R. Graph matching using the interference of continuous-time quantum walks. Pattern Recognit. 2009, 42, 985–1002. [Google Scholar] [CrossRef]
  22. Emms, D.C.; Wilson, R.; Hancock, E. Graph matching using the interference of discrete-time quantum walks. Image Vis. Comput. 2009, 27, 934–949. [Google Scholar] [CrossRef]
  23. Qiang, X.; Yang, X.; Wu, J.; Zhu, X. continuous-time quantum walk. J. Phys. A 2012, 45, 045305. [Google Scholar] [CrossRef]
  24. Qiang, X. The Research of Graph Isomorphism Algorithm Based on Quantum Walk. Master’s Thesis, National University of Defense Technology, Changsha, China, 2011. (In Chinese). [Google Scholar]
  25. Childs, A.M.; Cleve, R.; Deotto, E.; Farhi, E.; Gutmann, S.; Spielman, D.A. Exponential algorithmic speedup by a quantum walk. In Proceedings of the Thirty-Fifth Annual ACM Symposium on Theory of Computing, San Diego, CA, USA, 9–11 June 2003; ACM: New York, NY, USA, 2003; pp. 59–68. [Google Scholar]
  26. Shenvi, N.; Kempe, J.; Whaley, K.B. Quantum random-walk search algorithm. Phys. Rev. A 2003, 67, 125–128. [Google Scholar] [CrossRef]
  27. Santha, M. Quantum walk based search algorithms. In Proceedings of the International Conference on Theory and Applications of Models of Computation, Xi’an, Xi’an, China, 25–29 April 2008; Springer: Berlin/Heidelberg, Germany, 2008; pp. 31–46. [Google Scholar]
  28. Wong, T.G. Faster Quantum Walk Search on a Weighted Graph. Phys. Rev. A 2015, 92, 032320. [Google Scholar] [CrossRef]
  29. Magniez, F.; Santha, M.; Szegedy, M. Quantum algorithms for the triangle problem. SIAM J. Comput. 2005, 37, 1109–1117. [Google Scholar] [CrossRef]
  30. Wu, J.; Zhang, B.; Tang, Y.; Qiang, X.; Wang, H. Finding tree symmetries using continuous-time quantum walk. Chin. Phys. B 2013, 22, 050304. [Google Scholar] [CrossRef]
  31. Ambainis, A. Quantum Walk Algorithm for Element Distinctness. SIAM J. Comput. 2007, 37, 210–239. [Google Scholar] [CrossRef] [Green Version]
  32. Rossi, L.; Torsello, A.; Hancock, E.R. Measuring graph similarity through continuous-time quantum walks and the quantum Jensen-Shannon divergence. Phys. Rev. E Stat. Nonlinear Soft Matter Phys. 2015, 91, 022815. [Google Scholar] [CrossRef] [PubMed]
  33. Bai, L.; Rossi, L.; Ren, P.; Zhang, Z.; Hancock, E.R. A Quantum Jensen-Shannon Graph Kernel Using Discrete-Time Quantum Walks. In Proceedings of the International Workshop on Graph-Based Representations in Pattern Recognition, Vienna, Austria, 13–15 May 2015; Springer: Cham, Switzerland, 2015; pp. 252–261. [Google Scholar]
  34. Rossi, L.; Torsello, A.; Hancock, E.R.; Wilson, R.C. Characterizing graph symmetries through quantum Jensen-Shannon divergence. Phys. Rev. E Stat. Nonlinear Soft Matter Phys. 2013, 88, 032806. [Google Scholar] [CrossRef] [PubMed]
  35. Mathon, R. A note on the graph isomorphism counting problem. Inf. Process. Lett. 1979, 8, 131–136. [Google Scholar] [CrossRef]
  36. Pelillo, M. Relaxation labeling networks that solve the maximum clique problem. In Proceedings of the 4th International Conference on Artificial Neural Networks, Cambridge, UK, 26–28 June 1995; pp. 166–170. [Google Scholar]
Figure 1. Two pentagrams.
Figure 1. Two pentagrams.
Entropy 20 00586 g001
Figure 2. Each step of the Intuitive Method running on pentagrams. (a) The algorithm chose a and i. The generated graphs were the same, and thus a i was established. (b) The algorithm chose b and l. The generated graphs were the same, and thus b l was established.
Figure 2. Each step of the Intuitive Method running on pentagrams. (a) The algorithm chose a and i. The generated graphs were the same, and thus a i was established. (b) The algorithm chose b and l. The generated graphs were the same, and thus b l was established.
Entropy 20 00586 g002
Figure 3. Each step of IsoMarking running on pentagrams. (a) The algorithm chose a and i. The generated graphs are the same, and thus, a i was established. (b) The algorithm chose b and l. With a and i marked, the new graphs were non-isomorphic and therefore, the bijection b l failed. (c) The algorithm chose b and h, and thus established b h . (d) The algorithm chose d and k, and then established d k . Note that the marked graphs are no more symmetric after the third step.
Figure 3. Each step of IsoMarking running on pentagrams. (a) The algorithm chose a and i. The generated graphs are the same, and thus, a i was established. (b) The algorithm chose b and l. With a and i marked, the new graphs were non-isomorphic and therefore, the bijection b l failed. (c) The algorithm chose b and h, and thus established b h . (d) The algorithm chose d and k, and then established d k . Note that the marked graphs are no more symmetric after the third step.
Entropy 20 00586 g003
Figure 4. Accuracy results on ordinary graphs.
Figure 4. Accuracy results on ordinary graphs.
Entropy 20 00586 g004
Table 1. Continuous-time quantum walk (CTQW) on the left pentagram.
Table 1. Continuous-time quantum walk (CTQW) on the left pentagram.
Nodet = 1.0t = 2.0t = 3.0
a0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
b0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
c0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
d0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
e0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
Table 2. CTQW on the right pentagram.
Table 2. CTQW on the right pentagram.
Nodet = 1.0t = 2.0t = 3.0
h0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
i0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
j0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
k0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
l0.3251 − 0.0740i0.3747 − 0.1674i0.3284 + 0.2593i
Table 3. Information about the ordinary graph groups.
Table 3. Information about the ordinary graph groups.
Group Name# of Graph PairsNAverage k
Group 11001710.2353
Group 2100344.5294
Group 3100183
Group 4100184.1111
Group 5100203.8
Group 6100103
Table 4. Information about the regular graph groups.
Table 4. Information about the regular graph groups.
Group Name# of Graph PairsNk
Group  7100303
Group  8149163
Group  9100144
Group 10200143
Group 11100116
Group 12100114
Group 1385123
Group 1460105
Group 1532203
Group 1659104
Table 5. Accuracy results for regular graphs.
Table 5. Accuracy results for regular graphs.
Group NameIntuitive MethodIsoMarkingQiang3Emms
Group  70.640.920.640
Group  80.37580.89930.68460
Group  90.280.680.560
Group 100.280.870.5850
Group 110.440.860.830
Group 120.40.90.830.02
Group 130.15290.83530.57650.0118
Group 140.150.850.61670
Group 1500.7500.5
Group 160.22030.74580.61020
Table 6. Results of the peak memory cost.
Table 6. Results of the peak memory cost.
Group NameIntuitive MethodIsoMarkingQiang3Emms
Group  13.8203 MB3.6328 MB2.8750 MB3.9648 MB
Group  26.3867 MB4.6367 MB5.5000 MB39.9141 MB
Group  35.5078 MB4.6875 MB6.8242 MB7.2969 MB
Group  44.9492 MB5.8750 MB2.7578 MB9.6641 MB
Group  54.5000 MB3.0664 MB4.4453 MB4.4531 MB
Group  63.5000 MB3.8203 MB5.2500 MB3.6328 MB
Group  75.6367 MB6.1367 MB5.8125 MB21.1484 MB
Group  86.3750 MB1.5000 MB1.7930 MB3.2461 MB
Group  94.0000 MB7.0000 MB5.5625 MB4.6328 MB
Group 103.0664 MB3.3203 MB3.5000 MB2.9258 MB
Group 110.5938 MB0.6875 MB0.7500 MB1.0625 MB
Group 124.1992 MB3.5000 MB4.3125 MB6.8281 MB
Group 130.1250 MB0.1484 MB0.1523 MB0.3164 MB
Group 141.8750 MB3.7539 MB4.5000 MB0.5039 MB
Group 153.3750 MB3.3125 MB3.2500 MB6.8867 MB
Group 163.2500 MB2.0000 MB3.6250 MB0.5000 MB
Table 7. Results of the average running time.
Table 7. Results of the average running time.
Group NameIntuitive MethodIsoMarkingQiang3Emms
Group  13.2654 s3.2171 s0.0108 s0.0969 s
Group  244.8457 s54.0828 s0.8583 s4.5173 s
Group  33.7842 s5.1633 s0.0141 s0.1277 s
Group  43.6923 s5.9058 s0.0141 s0.1221 s
Group  55.3259 s7.8721 s0.0162 s0.2217 s
Group  60.5962 s0.9774 s0.0062 s0.0106 s
Group  722.5406 s30.4999 s0.3093 s1.9541 s
Group  83.1396 s3.7451 s0.1894 s0.1843 s
Group  92.0971 s2.5978 s0.2170 s0.0489 s
Group 102.0007 s2.5475 s0.2040 s0.0501 s
Group 110.9494 s1.2719 s0.0892 s0.0278 s
Group 121.0031 s1.2552 s0.1000 s0.0232 s
Group 131.3539 s1.5960 s0.1858 s0.0260 s
Group 141.0457 s0.9848 s0.1669 s0.0181 s
Group 156.7206 s7.7323 s0.5846 s0.2707 s
Group 161.1468 s1.1151 s0.1750 s0.0204 s

Share and Cite

MDPI and ACS Style

Wang, X.; Zhang, Y.; Lu, K.; Wang, X.; Liu, K. Marking Vertices to Find Graph Isomorphism Mapping Based on Continuous-Time Quantum Walk. Entropy 2018, 20, 586. https://doi.org/10.3390/e20080586

AMA Style

Wang X, Zhang Y, Lu K, Wang X, Liu K. Marking Vertices to Find Graph Isomorphism Mapping Based on Continuous-Time Quantum Walk. Entropy. 2018; 20(8):586. https://doi.org/10.3390/e20080586

Chicago/Turabian Style

Wang, Xin, Yi Zhang, Kai Lu, Xiaoping Wang, and Kai Liu. 2018. "Marking Vertices to Find Graph Isomorphism Mapping Based on Continuous-Time Quantum Walk" Entropy 20, no. 8: 586. https://doi.org/10.3390/e20080586

APA Style

Wang, X., Zhang, Y., Lu, K., Wang, X., & Liu, K. (2018). Marking Vertices to Find Graph Isomorphism Mapping Based on Continuous-Time Quantum Walk. Entropy, 20(8), 586. https://doi.org/10.3390/e20080586

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop