$T L S 52$
M4!

- F614
no. 82-7

FTL REPORT R82-7

FTL COPY, DONT REMOVE 33-412, MIT ... 02139

# DEPARTMENT <br> OF AERONAUTICS 

\& ASTRONAUTICS

June 1982

## FLIGHT TRANSPORTATION <br> LABORATORY

Cambridge, Mass. 02139

## FTL REPORT R82-7

ALGORITHMIC APPROACHES TO CIRCUIT ENUMERATION PROBLEMS AND APPLICATIONS

Boon Chai Lee

June 1982

# ALGORITHMIC APPROACHES TO CIRCUIT ENUMERATION <br> PROBLEMS AND APPLICATIONS 

by

BOON CHAI LEE
B.S., University of Michigan
(1978)

SUBMITTED TO THE DEPARTMENT OF AERONAUTICS AND ASTRONAUTICS
IN PARTIAL FULFILLMENT OF THE REQUIREMENTS OF THE DEGREE OF

MASTER OF SCIENCE IN AERONAUTICS AND ASTRONAUTICS
at the
MASSACHUSETTS INSTITUTE OF TFCHNOLOGY
June 1982
(C) Boon Chai Lee 1982

The author hereby grants to M.I.T. permission to reproduce and to distribute copies of this thesis document in whole or in part.
/ .
Signature of Author


Certified by


Accepted by $\qquad$ Chairman, Departmental Graduate Committee

# ALGORITHMIC APPROACHES TO CIRCUIT ENUMERATION 

PROBLEMS AND APPLICATIONS
by

## BOON CHAI LEE

Submitted to the Department of Aeronautics and Astronautics
on May 7, 1982 in partial fulfillment of the requirements for the Degree of Master of Science in Aeronautics and Astronautics

## ABSTRACT

A review of methods of enumerating elementary cycles and circuits is presented. For the directed planar graph, a geometric view of circuit generation is introduced making use of the properties of dual graphs. Given the set of elementary cycles or circuits, a particular algorithm is recommended to generate all simple circuits. A simple example accompanies each of the methods discussed. Some methods of reducing the size of the graph but maintaining all circuits are introduced. Worst-case bounds on computational time and space are also given.

The problem of enumerating elementary circuits whose cost is less than a certain fixed cost is solved by modifying an existing algorithm. The cost of a circuit is the sum of the cost of the arcs forming the circuit where arc costs are not restricted to be positive. Applications of circuits with particular properties are suggested.

Thesis Supervisor: Robert W. Simpson
Title: Professor of Aeronautics and Astronautics

## ACKNOWLEDEMENTS

Professor Simpson had been most helpful with his comments and directions throughout the duration of this thesis. He is also always willing to share his invaluable time for discussions. He helped me present my thesis clearer and better and showed interest in this work throughout. I owe much to him for his gentleness and generousity.

My stay here in the United States was possible from the support of my family. They have been very generous and loving and I missed them alot. I am very grateful that they have provided me with the chance not only to further my education but also to introduce me to such a variety of people and habits that continues to entreat me even now.

Next, I would like to thank Yutaka Takase for the excellent diagrams he drew for me, and to Wu, Yiren and lirofumi Matsuo for countless hours of interesting discussions.

Joanne Clark also helped with proof reading this thesis and showed much patience.

This thesis was completed with the help also of Debbi who spent several beautiful Spring days typing.

## TABLE OF CONTENTS

Page
SECTION 1. INTRODUCTION. ..... 6
1.1. Definitions ..... 8
SECTION 2. REVIEW OF CIRCUIT AND CYCLE ENUMERATION METHODS ..... 11
2.1. Cycle Vector Space Methods - (Simple and Elementary Cycles) ..... 12
2.2. Search and Backtrack Methods - (Elementary Circuits) ..... 20
2.3. Connection Matrix Methods - (Elementary Circuits) ..... 30
2.4. Directed Graph Transformation Methods - (Elementary Circuits) ..... 47
2.5. Obtaining All Simple Circuits from the Set of Elementary Circuits ..... 52
2.6. Methods for Generating All Cycles and Circuits in a Planar Graph ..... 63
SECTION 3. ANALYSIS OF ALGORITHMS ..... 77
3.1. Graph Reduction and Edition ..... 78
3.2. Discussion of the Time and Space Bound of all Circuit and Cycle Enumeration Algorithms ..... 80
3.3. Conversion of an Undirected Graph to a Directed Graph for Circuit Enumeration ..... 84
3.4. Recommendations ..... 86
SECTION 4. APPLICATIONS OF CIRCUIT ENUMERATION ..... 91
4.1. Elementary Circuits with Particular Properties ..... 91
4.2. Some Suggested Applications ..... 93
Page
SECTION 5. SUMMARY ..... 104
FOOTNOTES ..... 107
APPENDIX A. METHODS FOR FINDING STRONG COMPONENTS (Christofides [7]) ..... 109
appendix b. EULerian and hamiltonian circuits and cycles, ..... 113
B1. Enumeration of Hamiltonian Circuits Using the Algebraic Approach: An Example (Christofides [7]) ..... 121
B2. Enumeration of Hamiltonian Circuit Using Enumerative Procedure: An Example (Christofides [7]) ..... 126
REFERENCES ..... 129
BIBLIOGRAPHY ..... 132

## Section 1

Introduction

The circuit enumeration problem is of theoretical as well as practical interest. In the past years, we have seen a wide range of researchers from many disciplines working on this topic. These areas include, Mathematics [3], Computer Science [1,18,34,32], Medicine [25], Transportation [9,21], and Engineering [19,36]. The reason is that many problems can be represented as graphs. Furthermore, many problems have a cyclic structure where the problem is to identify some or all of the circuits or cycles in the graph.

In particular, this thesis addresses the problem of finding all elementary circuits and cycles in a graph and suggests some related applications. The areas we will be covering are represented in fig. 1.].

In Section 2, we create four classes of methods of generating elementary circuits. Every algorithm for generating elementary circuits known thus far, belongs to one of the four methods; namely, the Cycle Vector Space Methods; the Search and Backtrack Methods; the Connection Matrix Methods, and the Directed Graph Transformation Methods. In addition, we provide an algorithm for generating all simple cycles or circuits given the set of all elementary cycles or circuits. If the directed graph is planar, we introduce a method for enumerating all the elementary circuits using the dual graphs.

Section 3 deals with an analysis of all the algorithms on circuit
fig. 1.] Structured approach to generating all cycles or circuits and applications.

enumeration. Before comparing algorithms, the graphs are edited and reduced. Several ways of reducing and editing graphs are given. Thereafter, the running time and storage requirement of each algorithm is given followed by a short discussion, and recommendations for the best algorithms.

Since complete elementary circuit enumeration problems are known to be difficult and intractable, we have, in section 4 , identified a list of circuits with particular properties which, honefully, greatly reduces the number of circuits to be enumerated, followed by some suggested applications that fit into our problem classification. An example would be finding all elementary circuits that do not exceed a certain fixed cost. (The cost of a circuit is the sum of the cost of all arcs in that circuit).

In the final section, we summarize what we have done, and point to some interesting areas of research.

For completion, we have included Appendices to find "strong components" of a graph and a treatment of the problems of finding Eulerian and Hamiltonian circuits.

### 1.1 Definitions

The terminologies used in graph theory have hitherto remained at the discretion of the writer. Some writers choose an arc over an edge, a link over a line, or a path over a chain, etc. Furthermore, there have been additions to the glossary of terms used; for instance with flowers, came blossoms, with spanning tree, came forest. Then there are branches
and fronds and twigs, and so forth. As a result, there is a need in this subsection to define certain terms that will be used throughout this thesis. Many ambiguities would be clarified if the reader would take a minute to browse through this subsection.

A graph $G(V, E)$ is defined as a finite set of vertices $V$ and edges $E$ which connects pairs of vertices. The number of vertices $|V|=n$ and edges $|E|=e$ for a graph $G(V, E)$. A directed graph has arcs which are edges with directions associated with them. A directed graph is more commonly represented by $G(V, \Gamma)$ where $V$ is the set of vertices and $P$ is the vertex operator, where for $i \varepsilon V, j \varepsilon V, j \varepsilon .(i)$ if an arc ij exists. Two vertices are said to be adjacent if they are connected by a common edge. Two edges with a common vertex are said to be adjacent.

A path is a directed or undirected sequence of edges or arcs where the final vertex of one is the initial vertex of the next edge or arc. A simple path is a path which does not use the same edge or arc more than once. A simple cycle is a simple path where the initial and final vertex coincide, and the edges contained in the path are assumed to be undirected. A circuit is a directed version of a cycle. An elementary path is a path which does not use the same vertex more than once. An elementary cycle is an elementary path where the initial and final vertex coincide. An elementary circuit is a directed version of an elementary cycle. All elementary paths and cycles or circuits also must be simple. Two elementary cycles or circuits are distinct if one is not a cyclic permutation of the other. We refer to cycles or circuits that are neither elementary nor simple as infinite cycles and circuits respectively.

In this work, we will not be concerned with infinite cycles or circuits.
The length or cardinality of a path, cycle or circuit is the number of edges or arcs appearing in it. A path of length $k$ is called a $k$-path. The same applies to cycles or circuits.

For a directed graph, the indegree and outdegree of a vertex is the number of arcs terminating and originating at that vertex. The degree of a vertex in an undirected graph is the number of arcs incident to it.

A vertex $i$ is connected to $j$ if there exists a path from $i$ to $j$. A connected undirected graph is one for which a path exists between every pair of vertices. Similarly, a directed graph is connected if its associated undirected graph is connected. Note there may not be a directed path connecting all vertices in a directed graph. In our work, we shall only be concerned with connected graphs.

A subgraph $G(X, A)$ of a graph $G(V, E)$ is a graph such that $X \subset V$ and $A \subset E$. A tree of an undirected graph is a connected subgraph which has no cycles. A spanning tree of a graph is a tree of the graph that contains all the vertices.

Any other definitions that are necessary will be introduced subsequently.

## Section 2

## Review of Circuit and Cycle Enumeration Methods

This section reviews the different methods for generation of the elementary cycles/circuits in a graph. All algorithms known thus far for enumerating elementary cycles/circuits can be classified into one of the following methods:
2.1 Cycle Vector Space Methods.
2.2 Search and Backtrack Methods.
2.3 Connection Matrix Methods.
2.4 Directed Graph Transformation Methods.

The purpose here is to explore the underlying idea behind each of these methods by referring to explicit algorithms.

Thereafter, we examine procedures for generation of all the simple circuits in a graph given the set of elementary circuits. An easy procedure to do this is recommended.

Due to close associations of the Travelling Salesman and the Chinese Postman Problem to the Hamiltonian and Eulerian circuit generation, we have included a rather complete discussion on the enumeration of Hamiltonian and Eulecian circuits in Appendix B. We have not included the discussion in this section in order to reduce the amount of redundancy since the enumeration of Hamiltonian and Eulecian circuits are special cases of the cycle/circuit enumeration methods we will be dealing with in this section.

Finally, this section concludes by introducing a method of generating all elementary circuits in a directed planar graph using vertex aggregation of the associated dual graph.

### 2.1 Cycle Vector Space Methods

These methods apply to an undirected graph and finds all elementary and/or simple cycles. Given an undirected graph $G(V, E)$, a spanning tree Tg is first constructed having $\mathrm{n}-1$ edges. Tg is not unique. The addition to Tg of any edge in G (but not in Tg ) will form a unioue elementary cycle. Every cycle formed in this way contains at least one edge not found in another. The set of cycles formed by adding all edges in $G$ (but not in Tg ) provides a basis for the vector space of all the simple cycles in the graph. Since there are e edges in $G$ and $n-1$ edges in Tg , the number of such cycles that will be formed is $e-n+1$. This is the cyclomatic number of $G, v(G)$. The $v(G)$ cycles formed in this way are known as a fundamental set of cycles The derivation of the fundamental set of cycles is not difficult and therefore, the reader is referred to Gotlieb and Corneil [15], Welch [36] or Paton [25] for an algorithm for finding the fundamental set of cycles. The algorithm of Gotlieb and Corneil [15] is slower than that of Welch [36] but requires less storage for graphs with a large number of vertices. The algorithm of Paton [25] on the other hand is compatible to Gotlieb and Corneil [15] in terms of storage and to Welch [36] in terms of speed. The author recommends the algorithm of Paton for finding the fundamental set of cycles.

Since the fundamental set of cycles is a basis of the vector space for cycles, then any cycle in $G$ not in $\Phi$, can be formed by a linear combination of cycles in $\Phi$ by the following convention.

Let every fundamental cycle $\Phi_{i}, i=1,2, \ldots \nu(G)$, be represented by an e dimensional vecter where the $j^{\text {th }}$ element is 1 if the $j^{\text {th }}$ edge is part of the cycle, and zero otherwise. The ring sum operation can be expressed for vectors $A$ and $B$ as $A+B=\{x \mid x \in A \cup B B, \notin A \cap B\}$. If the ring sum, $\theta$, is used for mod 2 addition, any cycles in $G$ not in $\Phi$, can be expressed as a ring sum operation of fundamental cycle. The ring sum of 2 cycles is a cycle or an edge disjoint union of cycles. ${ }^{1}$ The edge disjoint union of cycles means the union of cycles having no common edges. To generate all the cycles in $G$, we need to consider all $2^{\nu(G)}-\nu(G)-1$ combinations of fundamental cycles. However, some of the combinations will be disjoint cycles, but, if'a given combination is disjoint one cannot disregard other combinations containing it since the mod 2 addition of it and another combination might produce a single cycle. Thus, one can simply enumerate all possible cycles in the graph using this property of the fundamental set of cycles found by selecting a spanning tree.

Gibbs [14] presented a corrected version of Welch's algorithm to generate all the elementary cycles in the graph. The algorithm is presented here as ALGORITHM 1 for completion.

We note that the set $R$ generally remains smaller than $Q$ which contains all the linear combinations of fundamental cycles at the end. This is more suitable for programming.

To illustrate the above method, an example is provided in Example 1.

## ALGORITHM 1. GIBB's algorithm for generating all elementary cycles

 from the fundamental set of cycles.Given a set of fundamental cycles $\Phi=\left\{\Phi_{1}, \Phi_{2}, \ldots \Phi_{U(G)}\right\}$

1. Set $S=\left\{\Phi_{1}\right\}, Q=\left\{\Phi_{1}\right\}, R=\emptyset, R^{*}=\emptyset, i=2$.
2. For all $T$ in $Q$,

If T $\cap \Phi_{i} \neq \emptyset$ place $T \otimes \Phi_{i}$ into $R$,
If $T \cap \Phi_{i}=\emptyset$ place $T \otimes \Phi_{i}$ into $R^{*}$.
3. For all $U$ and $V$ in $R$, if $U \subset V$ set $R=R-\{V\}$
and $R^{*}=R^{*} U\{V\}$.
4. Set $S=S \cup R \cup\left\{\Phi_{i}\right\}$.
5. $\operatorname{Set} Q=Q \cup R \cup R^{\star} \cup\left\{\Phi_{i}\right\}$. Reset $R=\emptyset$; Reset $R^{*}=\emptyset$.
6. Set $\mathfrak{i}=\mathbf{i}+1$. If $\mathfrak{i} \leq U(G)$, go to 2. If $\mathfrak{i}>\cup(G)$, STOP; $S$ consists of all the elemenatary cycles in the graph.

Note: $T$ is any element of $Q$, i.e., it could be a cycle or an edge disjoint union of cycles.

Example 1. Generating all elementary cycles using Cycle Vector Space
Methods.

Given: G,


We obtain the fundamental set of cycles :-
$\bar{\wp}_{1}$ : Adding edge 1

$\Phi_{3}$ : Adding edge 5

$\Phi_{2}$ : Adding edge 3

$\Phi_{4}$ : Adding edge 8


$\Phi=$|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\Phi_{1}$ | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| $\Phi_{2}$ | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| $\Phi_{3}$ | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |
| $\Phi_{4}$ | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |

Obtaining all elementary cycles from the fundamental set using Gibb's algorithm:

Iteraion
Results
Action

| 1 | $\mathrm{S}=\Phi_{1}, \quad \mathrm{Q}=\Phi_{1}, \quad \mathrm{R}=\emptyset, \quad \mathrm{R}^{*}=\emptyset$ | (STEP 1) |
| :---: | :---: | :---: |
| 2 | $\Phi_{1} \cap \Phi_{2} \neq \emptyset \quad \Rightarrow \quad \mathrm{R}=\Phi_{1} \oplus \Phi_{2}$ | (STEP 2) |
| 3 | $\mathrm{S}=\Phi_{1}, \Phi_{1} \oplus \Phi_{2}, \Phi_{3}$ | (STEP 4) |
| 4 | $Q=\Phi_{1}, \Phi_{1} \oplus \Phi_{2}, \Phi_{2}, R=\emptyset, \quad R^{*}=\emptyset$ | (STEP 5) |
| 5 | $\mathrm{i}=3,3 \leq U(G)=4$ | (STEP 6) |
| 6 | $\begin{aligned} & \Phi_{1} \cap \Phi_{3} \neq \emptyset \\ & \left(\Phi_{1} \oplus \Phi_{2}\right) \cap \Phi_{3}=\emptyset \\ & \Phi_{2} \cap \Phi_{3} \neq \emptyset \end{aligned} \quad \Rightarrow \begin{aligned} & \mathrm{R}=\Phi_{1} \oplus \Phi_{3}, \Phi_{2} \oplus \Phi_{3} \\ & R^{\star}=\Phi_{1} \oplus \Phi_{2} \oplus \Phi_{3} \end{aligned}$ | (STEP 2) |
| 7 | $S=\Phi_{1}, \Phi_{1} \oplus \Phi_{2}, \Phi_{1} \oplus \Phi_{3}, \Phi_{2} \oplus \Phi_{3}, \Phi_{3}$ | (STEP 4) |
| 8 | $\begin{aligned} \mathrm{Q}= & \Phi_{1}, \Phi_{1} \oplus \Phi_{2}, \Phi_{2}, \Phi_{1} \oplus \Phi_{3}, \Phi_{1} \oplus \Phi_{2} \oplus \Phi_{3}, \\ & \Phi_{2} \oplus \Phi_{3}, \Phi_{3} . \\ \mathrm{R}=\emptyset, & R^{*}=\emptyset . \end{aligned}$ | (STEP 5) |
| 9 | $\mathrm{i}=4,4 \leq U(G)=4$ | (STEP 6) |
| 10 | $\begin{array}{ll} \Phi_{1} \cap \Phi_{4} \neq \emptyset, & \Phi_{2} \cap \Phi_{4}=\emptyset, \\ \left(\Phi_{1} \oplus \Phi_{2}\right) \cap \Phi_{4}=\emptyset, & \left(\Phi_{1} \oplus \Phi_{2} \oplus \Phi_{3}\right) \cap \Phi_{4} \neq \emptyset, \\ \left(\Phi_{1} \oplus \Phi_{3}\right) \cap \Phi_{4} \neq \emptyset, & \left(\Phi_{2} \oplus \Phi_{3}\right) \cap \Phi_{4} \neq \emptyset, \\ \Phi_{3} \cap \Phi_{4} \neq \emptyset . & \\ \Rightarrow R=\left\{\Phi_{1} \oplus \Phi_{3} \oplus \Phi_{4}, \Phi_{1} \oplus \Phi_{2} \oplus \Phi_{3} \oplus \Phi_{4},\right. \\ & \left.\Phi_{2} \oplus \Phi_{3} \oplus \Phi_{4}, \Phi_{3} \oplus \Phi_{4}\right\} \\ R *=\left\{\Phi_{1} \oplus \Phi_{4},\right. & \left.\Phi_{1} \oplus \Phi_{2} \oplus \Phi_{4}, \Phi_{2} \oplus \Phi_{4}\right\} \end{array}$ | (STEP 2) |
| 11 | In this case, we enter step 3 , | (STEP 3) |


$S$ in iteration 12 contains all the elementary cycles in the graph, and $Q$ in 13 all the linear combinations of the fundamental cycles.

The edges are labeled from 1 to $\mathrm{e}=8 . \mathrm{Tg}$ is one of the spanning trees of the graph G.

Example 1 illustrates the enumeration of all elementary cycles from the fundamental set of cycles. However, the set of fundamental cycle forms a basis for all the simple cycles of the graph as well. These simple but non-elementary cycles can be found in set Q. One way of obtaining these will be discussed in section 2.5 .

Thus far, we have restricted our discussion to an undirected graph only. For a directed graph, there are no equivalent fundamental sets of circuits. Under the ring sum operation, + , cycles and edge disjoint union of cycles in the undirected graph form a group. Every element of this group can be expressed as a ring sum of some of the fundamental cycles with respect to a spanning tree. However, there exists no binary operation under which all circuits and edge disjoing unions of circuits form a group, let alone a vecter space. (Narsingh Deo [10]). Cycle Vector Space Methods are not applicable to a directed graph.

We note from the above discussion that the fundamental set of cycles is central to cycle enumeration. In the discussion following we point out two interesting relationships between the fundamental cycle matrix and the cutset and incidence matrix. These relationships not only offer better insight into the properties of the fundamental cycle set but also application to other seemingly unrelated problems. A few definitions are necessary before we proceed. The fundamental cutset ${ }^{2}$ matrix is defined as an $(n-1) \times$ e matrix $K=\left[k_{i j}\right]$ where $k_{i j}=1$ if edge $j$ is part of cutset $k_{j}$ and 0 otherwise. Similarly, and incidence matrix is defined
as an $n \times e$ matrix $B=[b i j]$ where bij $=1$ if vertex $i$ is incident to edge $j$ and zero otherwise. We state the two relationships under theorems one and two.

Theorem 1. The incidence matrix $B$ and the transpose of the fundamental cycle matrix $\Phi^{\top}$ are orthogonal, i.e., $B \cdot \Phi^{\top}=0$.
Theorem 2. The fundamental cycle matrix $\Phi$ and the cutset matrix $K^{\top}$ are also orthogonal, i.e., $\Phi \cdot K^{\top}=0$.

The two theorems can be shown easily by observing that:-

1. Each vertex in a cycle is incident with an even number of edges in the cycle.
2. Each cycle cut by a cutset has an even number of edges in common with the cutset.

Observe that all operations are done in mod. 2. Moveover, the theorems are valid for any cycle and cutset matrices defined so long as matrix multiplication rule is not violated. The fundanental cycle set have been used to solve electrical circuit problems (see Christofides [7]). In addition, from the max-flow-min-cut theorem for the maximum flow prohlem, one would search for the min-cut by observing the relationship between the fundamental cycles and the fundamental cutsets. Note that this orthogonality relationship extends beyond the fundamental sets to include all the cycles and cutsets in any given graph.

One of the drawbacks of the Cycle Vector Space Methods stem from the fact that in most cases, the ratio of the number of nondegenerate or valid cycles to the number of vectors goes asymptotically to zero
as the number of vertices in the graph increases. The number of vertices in the graph increases. The number of vectors is $2 U(G)-U(G)-1$ (excluding the basic cycles and the null elements). The ring sum, $\theta$, taken on combinations of fundamental cycles thus produces many degenerate cycles or edge disjoint unions of cycles. In fact, it is shown in Mateti and Deo [23] that there are only four graphs having all $2^{\nu(G)}$ - 1 cycles, that is, every combination of fundamental cycles produces a distinct cycle.

Algorithms which make use of this method were given by Welch [36], Gibbs [14], Mateti and Deo [23], Maxwell and Reed [24], and Hsu and Honkanen [17]. The discussion above attempts to capture the essence of the Cycle Vector Space Methods.

### 2.2. Search and Backtrack Methods

The search and backtrack method applies to a directed graph only. One such algorithm is presented here to introduce the main idea behind the Search and Backtrack Methods.

The vertices of a directed graph are numbered 1 to $|V|=n$. The algorithm generates all elementary paths $P=\{P(1), P(2), P(3), \ldots P(k)\}$ where $P(i)$ is the $i^{\text {th }}$ vertex in the $k$-path $P$ and $P(1)<P(i)$ for all $2 \leq i \leq k$ by starting from an arbitrary vertex $P(1)$, choosing an arc to extend to another vertex $P(2)>P(1)$, and continuing in this way. If the path cannot be extended any further, the procedure backs up one vertex and chooses to extend to a different vertex. If $P(1)$ is
adjacent to $P(k)$, the algorithm lists an elementary circuit $(P(1), P(2), \ldots, P(k), P(1))$. This algorithm enumerates each elementary circuit exactly once, since each circuit contains a unique "initial vertex," $P(1)$, and thus corresponds to a unique elementary path starting from that vertex.

Given a directed graph, we first reduce the size of the graph by eliminating vertices which cannot belong to any circuits. The process is to remove any vertices on which no arcs terminate and all arcs originating from these vertices. Similarly, all vertices in which no arc originates, and any arcs terminating on these vertices are also removed. This step is repeated until no such vertices remain. Then, k parallel arcs are reduced to a single arc, but $k$ circuits are later listed if that particular arc forms part of any circuit. More discussions on graph reduction will appear in Section 3.1. The reduced directed subgraph $G(V, \Gamma)$ is defined as a set of vertices $V=(1,2, \ldots n)$ and an arc operator $\Gamma(\cdot)$ which operates on all elements of $V ; j \varepsilon \Gamma(i)$ if there exists an arc from $i$ to $j$. Graph $G(V, \Gamma)$ is an $n x n$ array G(i,j) (see Example 2).

The algorithm assigns integer values, $1,2, \ldots, n$ to each of the vertices in $G$. It utilizes two principal arrays in addition to $G(i, j)$. The first, $P$, is an $n \times 1$ array, containing all the vertices in an elementary path. The second is an $n \times n$ array, $H$, which is initially zeroed. $H$ contains the list of vertices "closed", to each vertex. Vertex $j$ is "closed" to $i$ whenever an arc from $i$ to $j$ has been previously considered. The algorithm
basically involves elementary path building in array, $P$. We can now explain the algorithmic process.

## Search

Starting from an "initial" vertex 1 , a path is extended from its end, one arc at a time such that:-
a. The extension vertex cannot be already in $P$.
b. The extension vertex value must be larger than the initial vertex.
c. The extension vertex is not "closed" to the last vertex in P. $H$ contains the list of vertices closed to each vertex. (Vertex closure will be discussed further under (Backtrack).)
(a) assures that an elementary path is being considered. (b) assures that each circuit will be considered only once. (c) assures that each elementary path is considered only once.

At some point, no vertices will be available for extension. We test for a circuit by seeing whether there is an arc connecting the last vertex of $P$ to the first vertex. If there is, then a circuit is reported. In any case, vertex closure occurs unless there is only one vertex remaining in the path. $P$.

## Backtrack

Vertex closure consists of three steps:

1. Enter the last vertex of $P$ into the list in $H$ for the next to the last vertex in $P$.
2. Clear the list in $H$ for the last vertex.
3. Shorten P by one arc by eliminating the last vertex.
(1) assures that the path extension just performed will not be repeated. (2) allows correct forward continuation from the last vertex if it is reached by a different path in the future.

The extension and backtracking continues until the path has been backed to the "initial" vertex 1. Then, the "initial" vertex is advanced. This means that the first vertex is incremented by one; $H$ is cleared; and the extension process resumes. No paths, and thus circuits containing vertex 1 will be considered again. All circuits containing vertex 1 will have been found. The algorithm continues to extend paths and advance the "initial" vertex sequentially until $P$ contains a path of one vertex, namely, vertex $n$. At this point, the algorithm terminates. All elementary circuits have been identified.

The algorithm discussed above, and the exact algorithm presented in ALGORITHM 2 is attributed to Tiernan [34]. Example 2 illustrates Tiernan's algorithm.

The author selected this algorithm by Tiernan [34] to introduce the fundamental idea behind the Search and Backtrack Methods because of its simplicity in exposition, and also because all the other Search and Backtrack Methods develop upon the main idea that was introduced by this algorithm. In Section 4.2, we will show how some slight modifications of Tiernan's algorithm solves a specific problem. In

ALGORITHM 2: An Algorithm for Enumerating all Elementary Circuits in the Graph (Tiernan)

B1. Initialize
Read N,G
$P \leftarrow 0$
$\mathrm{H} \leftarrow \mathrm{O}$
$k \leftarrow 1$
$P(1)+1$

B2. Path Extension
Search $G(P(k, j)$ for $j=1,2, \ldots N$ such that the following three conditions are satisfied:
(1) $G(P(k), j)>P(1)$
(2) $G(P(k), j) \notin P$
(3) $G(P(k), j) \notin H(P(k), m), \quad m=1,2, \ldots N$.

If this $j$ is found, extend the path,
$k \leftarrow k+1$
$P(k)+G(P(k-1), j)$
go to B2.
If no $j$ meets the above conditions, the path cannot be extended.

B3. Circuit Confirmation
If $P(1) \notin G(P(k), j), j=1,2, \ldots N$ then no circuit has been formed,
go to $B 4$.
Otherwise a circuit is reported,
Print $P$.

B4. Vertex Closure
If $k=1$, then all of the circuits containing vertex $P(1)$ has been considered.
go to $B 5$.
Otherwise,
$H(P(k), m) \leftarrow 0, \quad m=1,2, \ldots N$
For $m$ such that $H(P(k-1), m)$ is the leftmost zero in the
$P(K-1)^{\prime}$ - the row of $H$,
$H(P(k-1), m) \leftarrow P(k)$
$P(k)+0$
$k+k-1$
go to B 2 .

B5. Advance Initial Vertex
If $P(1)=N$ then .
go to $B 6$.
otherwise,
$P(1)+P(1)+1$
$-26-$

$$
\begin{aligned}
& k+1 \\
& H+0 \\
& \text { go to } B 2 .
\end{aligned}
$$

B6. Terminate

Example 2. Circuit Enumeration using Tiernan's algorithm presented

## in ALGORITHM 2.



$$
G(V, \Gamma)=\left[\begin{array}{lllll}
1 & 2 & 0 & 0 & 0 \\
3 & 0 & 0 & 0 & 0 \\
1 & 2 & 3 & 4 & 0 \\
5 & 0 & 0 & 0 & 0 \\
1 & 3 & 0 & 0 & 0
\end{array}\right]
$$

Note: The parallel arcs $(5,1)$ have been replaced by a single arc $(5,1)$.


| 23400 | B2. No extension. B3. No circuit formed. B4. Clear the last vertex, $H(4,1)<--0$, Backtrack and vertex closure, $H(3,1)<--4$. |
| :---: | :---: |
| 23000 | B2. No path extension. B3. Circuit formed, ( $\left.\begin{array}{lll}2 & 3 & 2\end{array}\right)$ B4. Clear last vertex, $H(3,1)<--0$, Backtrack and vertex closure $H(2,1)<--3$. |
| 20000 | B2. No path extension. B3. No circuit formed. <br> B4. Cannot Backtrack. B5. Advance vertex, i.e. set $P(1)=3$. Clear $H$. <br> Comment: No circuit formed hereafter would contain vertices 1 or 2. |
| 30000 | B2. Path extension. |
| 34000 | B2. Path extension. |
| 34500 | B2. No path extension. B3. Circuit reported, ( $\begin{aligned} & 3 \\ & 4 \\ & 5\end{aligned}$ 3). B4. Backtrack and vertex closure, $H(4,1)<--5$. |
| 34000 | B2. No path extension. B3. No circuit reported. <br> B4. Clear last vertex $H(4,1)<--0$, Backtrack and vertex closure $H(3,1)<--4$. |
| 30000 | B2. No path extension. B3. Circuit reported, (3 3). <br> B4. Cannot Backtrack. B5. Advance vertex, i.e. set <br> $P(1)=4$. Clear $H$. <br> Comment: No circuits formed hereafter would contain vertices 1,2 or 3 . |
| 40000 | B2. Path extension. |
| 45000 | 32. No path extension. B3. No circuit found. B4. Backtrack and vertex closure, $H(4,1)<--5$. |
| 40000 | B2. No path extension. B3. No circuit formed. B4. Cannot Backtrack. B5. Advance vertex, i.e. set $P(1)=5$, Clear H. Comment: No circuit formed hereafter would contain vertices $1,2,3$ or 4. |
| 50000 | B2. No extension possible. B3. No circuit formed. <br> B4. Cannot Backtrack; all circuits containing $P(1)=5$ <br> have been found. <br> B6. Since $P(1)=5$; Terminate. <br> Comment: All circuits in the graph have been found. |
| Circuits founded are:- |  |
|  | ```2 1-circuits(self-loops), (1 1) and (3 3) 1 2-circuit, (2 3 2) 2 3-circuits, (1 2 3 1) and (3 4 5 3) 2 5-circuits, (1 2 3 4 5 1)``` |

the discussions following, some similar methods are highlighted.
An example provided by Tarjan [32] shows the inefficiency of the above algorithm in the worst case. Weinblatt [35] provides an algorithm that examines each arc of the graph only once. He uses a recursive backtracking procedure to test combinations of subpaths from old circuits to see if they result in new ones. Tarjan [32], however, showed also that Weinblatt's algorithm does not have a running time polynomial to the number of circuits in the given graph.

Taijan [32] uses Tiernan's backtracking procedure but also uses a marking procedure to avoid unnecessary searches which help decrease the size of the subset of paths that need to be generated considerably. The running time of Tarjan's algorithm is shown to be polynomial to the number of circuits in the graph.

Johnson [18] and Szwarcfiter and Lauer [31] use improved pruning methods over Tarjan's [32]. Their algorithms have running times that are also polynomial to the number of circuits in the graph, but are an improvement over Tarjan's. In particular, Johnson's [18] algorithm is shown to be asymptotically fastest (for a large graph).

The algorithms of Char [5] and Chan and Chang [4] use the set of all permutations of vertices of the graph as the search space. Other algorithms using the Search and Backtrack Methods have also been presented by Berztiss [2], Roberts and Flores [29], Reed and Taijan [28] and Ehrenfeucht et a1. [12].

### 2.3. Connection Matrix Methods

These methods make use of the properties of the connection matrix of a directed graph to generate elementary paths as vertex sequences. In our generation of elementary paths however, we would also be generating simple and non-simple paths. ${ }^{3}$ The method eliminates all simple (but non elementary) and non-simple paths as soon as they are formed. It builds elementary paths one arc at a time and lists circuits for each cardinality in increasing order.

Before proceeding to discuss the method, a simple but important theorem is given. This theorem establishes the fundamental idea behind the Connection Matrix Method. We state the theorem for the adjacency matrix, - but the idea can be easily extended to connection matrix since the difference between the adjacency and connection matrix is that the $i j e l e m e n t s$ of the adjacency matrix are ones or zeros depending on whether arc ij exists whereas the ij elements in the connection matrix tells us the number of arcs from vertex $i$ to $j$.

A directed graph can be represented as an $n \times n$ adjacency matrix, $A=\left[(a)_{i j}\right]$ where $(a)_{i j}=1$ if arc ij exists and zero otherwise. Only self loops would appear as a non zero element in the diagonal of $A$. We state the theorem formally:

Theorem 3: The ij element of $A^{k}$ is the number of paths of length $k$, or "k-paths" from $i$ to $j$.
Proof of this theorem can be found in Narsingh Deo [10].

If a $k$-circuit (that is, of cardinality $k$ ) exists, there would be a non-zero element in the diagonal of the $A^{k}$ matrix. However, a non zero element in the diagonal does not mean that a simple $k$ circuit exists. The reason for this is that when we take the product of the adjacency matrices, infinite paths and/or circuits (that uses one or more arcs repeatedly) are formed. One could extend this result to the connection matrix, that is, the ij element for the matrix $C_{1}^{k}$ (where $C_{1}$ is the connection matrix) equal to the number of paths of length k from vertex $i$ to $j$.

A method to resolve the problem outlined above is suggested by Kamae [19]. This method breaks up circuit generation into three stages: (1) path enumeration, (2) flower enumeration and (3) circuit enumeration. We now proceed to discuss this method in more detail.

Define a connection matrix $C_{1}=\left[\left(c_{1}\right)_{i j}\right]$ of a directed graph $G$ such that the $i j$ element, $\left(c_{1}\right)_{i j}$ equals to the number of arcs from $i$ to $j$ in $G .{ }^{4}$ (Note that $C_{1}$ is similar to the adjacency matrix if there are no parallel arcs in G.) Next, define $C_{j}^{\prime}$ as a matrix where,

$$
\begin{aligned}
\left(c_{1}^{\prime}\right)_{i j} & =\left(c_{1}\right)_{i j} & & \text { if } i \neq j \\
& =0 & & \text { for } i=j, \text { where } i, j=1,2, \ldots n
\end{aligned}
$$

that is, $C_{1}^{\prime}$ is the same matrix as $C_{1}$ with self loops removed.

Then, let $C_{2}=C_{j}^{\prime} \cdot C_{j}^{\prime}=\left(C_{j}^{\prime}\right)^{2}$ which means that each non zero element in $C_{2}$ indicates the number of 2-paths or 2-circuits. Next, let $C_{2}^{\prime}$ be the matrix $C_{2}$ with no 2-circuits, i.e.,

$$
\begin{aligned}
\left(c_{2}^{\prime}\right) & =0 & & \text { if } i=j \\
& =\left(c_{2}\right)_{i j} & & \text { otherwise }
\end{aligned}
$$

then, consider the matrix multiplication $C_{2}^{1} \cdot C_{j}^{\prime}$ where the elements are:-

$$
\left(c_{2}^{\prime} \cdot c_{1}^{\prime}\right)_{i j}=\sum_{k=1}^{n}\left(c_{2}^{\prime}\right)_{i k}\left(\dot{c}_{j}^{\prime}\right)_{k j}
$$

Given these elements, we will generate elementary paths, circuits and flowers. Suppose $i \neq j, i \neq k$ and $j \neq k$, we have two cases:

Case 1


3-path

Whenever $i=k$ or $j=k,\left(c_{2}^{\prime}\right)_{i k} \cdot\left(c_{j}^{\prime}\right)_{k j}=0$, thus $i \neq j$ implies that $\left(C_{2}^{\prime} \cdot C_{j}\right)_{i j}$ is equal to the number of 3 -paths and 3-flowers from $i$ to $j$. Next, suppose $i=j$, then $\left(C_{2}^{1} \cdot C_{j}^{\prime}\right)_{i j}$ equals to the number of 3 -circuits containing $i$.

The method by Kamae [19], for more general cases is stated is stated in ALGORITHM 3.

Since all circuits must be of length lesser or equal to $n$, we need to compute only up to matrix $Z_{n}$.

We shall work on the same graph as used in section 2.2. to illustrate the method that was discussed in Example 3.

At this point, we can make several observations. Note that there is more than one way of obtaining the h-path connection matrix. We have merely illustrated one way of doing so in our example. Kamae's method chooses to eliminate non simple paths as the algorithm proceeds instead of sorting paths at various points in the algorithm. Due to this, Kamae's method is more favorable for computer implementation.

In general, different Connection Matrix Methods differ only in the way they avoid generating the arc or vertex sequences that can neither belong to paths nor circuits, i.e. non simple or infinite arc sequences.

Other algorithms that belong to this class can be found in Ponstein [26], Yau [37], Danielson [8] and Ardon and Malik [1]. In particular, Ardon and Malik reduce the storage bound to $0\left(n^{2}\right)$ by finding circuits, using Boolean reduction, to an expression which

## ALGORITHM 3: Kamae's Algorithm for Generating All Elementary Circuits Using Connection Matrix Method.

## 1. Path Enumeration

Def. 1. The element of an h-path connection matrix, $C_{h}$, of $G$ is defined by:

$$
\begin{aligned}
\left(c_{h}\right)_{i j}= & \text { number of } h \text {-paths from } i \text { to } j \text { if } i \neq j \\
= & \text { number of } h \text { elementary circuits containing } i \\
& \text { if } i=j .
\end{aligned}
$$

Def. 2. A proper h-path connection matrix $C_{h}^{\prime}$ of $G$ is defined by:

$$
\begin{aligned}
\left(c_{h}^{\prime}\right)_{i j} & =\left(c_{h}\right)_{i j} & & \text { if } i \neq j \\
& =0 & & \text { if } i=j
\end{aligned}
$$

Def. 3. Let $L$ be the set of all (h-t)-circuits and $\mu$ be a particular (h-t)-circuit belonging to set $L$. Then, an (h-t) flower matrix $C_{h, t}$ of $G$ is defined by,

$$
C_{h, t}=\sum_{\mu \varepsilon L} C_{\mu}(h, t), \quad t \geq 1, h-t \geq 2
$$

where $\left(c_{\mu}(h, t)\right)_{i j}$ equals the number of $t$-paths from $i$ to $j$ which do not touch $\mu$ except at $j$ if $i \notin \mu$ and $j \varepsilon \mu$, and
zero otherwise.
An (h,t)-flower is an h-flower which contains a $t$-path and an ( $h-t$ )-circuit with only one vertex in common, that is the joint. $C_{\mu}(h, t)$ then represents all (h,t)-flowers which contains $\mu$, since a flower from $i$ to $j$ consists of a circuit $\mu$ containing $j$ and a path from $i$ to $j$ not touching $\mu$ except at $j . C_{h, t}$ as defined above, is then the sum of $C_{\mu}(h, t)$ over all (h-t)-circuits, $\left(c_{h, t}\right)_{i j}$ then equals to the number of ( $h, t$ )-flowers from $i$ to $j$ where $j$ is the joint.

With this backtround, we are now able to state a theorem for $C_{h}$ (The connection matrix which counts $h$-paths and $h$-circuits).

Theorem 4.

$$
\begin{array}{ll}
C_{h}=C_{h-1} \cdot C_{1}-\sum_{t=1}^{h-2} c_{h, t} & h \geq 3 \\
C_{h}=C_{h-1}^{\prime} \cdot C_{1}^{\prime} & h=2
\end{array}
$$

$\sum_{t=1}^{h-2} C_{h, t}$ denotes the sum of the number of $(h-t)$-flowers where $t=1, \ldots . h-2$. We are essentially removing all flowers each time we try to find $C_{h}$. Note that for $h=2$, no flowers can be formed therefore the term $\sum_{t=1}^{h-2} C_{h, t}$ is not needed.
2. Flower Enumeration

Def. 4.

$$
\begin{array}{rlrl}
\left(D_{l}^{j}\right)_{q r} & =0 & \forall q \in \mu \\
& =\left(c_{p}^{\prime}\right)_{q r} & & \text { otherwise } .
\end{array}
$$

that is, $D_{1}^{\mu}$ is a matrix of the graph $G$ obtained from the connection matrix by deleting all edges incident from vertices contained in circuit $\mu . D_{h}^{\mu}, D_{h}^{\mu \mu}$ etc., are defined in parallel with $C_{h}, C_{h}^{\prime}$ etc. So with theorem 4 for connection matrices, we have,

Theorem 5:

$$
\begin{array}{ll}
D_{t}^{\mu}=D_{t-1}^{\prime \mu} \cdot D_{1}^{\prime \mu}-\sum_{s=1}^{t-2} D_{t, s} & t \geq 3 \\
D_{t}^{\mu}=D_{t-1}^{\prime \mu} \cdot D_{1}^{\prime \mu} & t=2
\end{array}
$$

As in theorem 4, $\sum_{s=1}^{t-2} D_{t, s}$ denotes the flowers of length $t$, with circuits of length $t-1$ and less (but not lesser than 2). We next state another theorem which will be useful for obtaining the number of flowers.

Theorem 6: Recall that $\mu$ is a ( $h-t$ ) circuit,

$$
\begin{aligned}
\left(D_{t}^{\mu}\right)_{i j} & =\left(c_{\mu(h, t)}\right)_{i j} & & \text { if } i \notin \mu \text { and } j \varepsilon \mu \\
& =0 & & \text { otherwise }
\end{aligned}
$$

From definition 4, for $i \notin \mu$ and $j \varepsilon \mu,\left(D_{t}^{\mu}\right)_{i j}$ is the number of $t$-paths from $i$ to $j$, not touching $\mu$ except at $j$ (since $j$ has outdegree 0 for the graph defined by $D_{j}^{\mu}$ ). Note that this corresponds to the definition of $\left(c_{\mu(h, t)}\right)_{i j}$. (See Def. 3). Hence, $\left(c_{\mu(h, t)}\right)_{i j}$ can be determined from $D_{t}^{\mu}$. This is desirable since by applying definition 5 and theorems 5 and 6 repeatedly, we can obtain $D_{t}^{4}$.

## 3. Circuit Generation

After obtaining $c_{h}$, we would like to be able to list the circuits as vertex sequences. We know that all h-circuits appear as a non zero element in the diagonal of $C_{h}$. The following definition will help us.

Def. 5. A h-circuit matrix $Z_{h}$ is defined as,

$$
\left(z_{h}\right)_{i j}=\left(c_{h-l}^{\prime}\right)_{j i}\left(c_{j}^{\prime}\right)_{i j} \quad 1 \leq i, \quad j \leq n
$$

Notice that since $\left(c_{h-1}^{\prime}\right)_{j i}$ equals to the number of $(h-1)$ paths from $j$ to $i$, and $\left(c_{j}^{\prime}\right)_{i j}$ equals the number of arcs from $i$ to $j$, $\left(z_{h}\right)_{i j}$ is the number of $h$-circuits which contains an arc from $i$ to $j$. The difference between $\left(z_{h}\right)_{i j}$ and $\left(c_{h}\right)_{i j}$ for $i=j$, is that the former provides us with arcs belonging to a $h$-circuit (that is, a starting point for listing our circuit, whereas the latter just tells us the number of $h$-circuits containing a certain vertex.

Having obtained $Z_{h}$, we list the $h$-circuits by making the first non-zero element in the first non zero row, and list the first arc belonging to the $h$-circuit. For example, $p q$, observe that $p$ represents the row and $q$, the column in which the non-zero element appears. Next, we proceed to the $q^{\text {th }}$ row; search for the first (left most) non zero element, and list the next arc in the $h$-circuit by reading off the corresponding row and column, for instance qr. We proceed in this manner, building an arc at a time until we return to the initial vertex $p$. Note that we are guaranteed to return to $p$ after connecting
$h$ arcs. The $h$-circuit is then pqr...p. In some instances, there might exist more than one h-circuit or more than one that uses the same arc many times. It is then necessary for us to do two things:-

1. After each h-circuit has been listed, we remove all arcs of the $h$-circuit from the $Z_{h}$ matrix. This is accomplished as follows:-

$$
\begin{aligned}
\left(z_{h}^{\prime}\right)_{i j} & =\left(z_{h}\right)_{i j}-1 & & \nabla \text { ij belonging to h-circuit listed } \\
& =\left(z_{h}\right)_{i j} & & \text { otherwise }
\end{aligned}
$$

The resultant matrix $Z_{h}^{\prime}$ contains the remainder of the h-circuits of the graph.
2. We return to our procedure for listing h-circuits until

$$
\left(z_{h}^{\prime}\right)_{i j}=0, \text { for all } i \text { and } j .
$$

Example 3. Kamae's Algorithm Applied to Circuit Enumeration

| Results | Comments |
| :---: | :---: |
| 1. $C=C_{1}=\left[\begin{array}{lllll} 1 & 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 1 & 1 & 1 & 1 & 0 \\ 0 & 0 & 0 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0 \end{array}\right]$ <br> From $C_{1}$, two 1 -circuits, $1,1,3,3$ are read off the diagonal | By definition 1. |
| 2. $C_{1}^{\prime}=\left[\begin{array}{lllll}0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0\end{array}\right]$ | Ry definition 2. |
| $3.1 \begin{aligned} & \text { 3. } \\ & C_{2}=\left[\begin{array}{lllll}0 & 0 & 1 & 0 & 0 \\ 1 & 1 & 0 & 1 & 0 \\ 0 & 1 & 1 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0 \\ 1 & 3 & 0 & 1 & 0\end{array}\right]\end{aligned}$ | $c_{2}=\left(c_{1}^{\prime}\right)^{2}$ <br> By definition 1 and theorem 4. |

Results
4.

$$
Z_{2}=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 1 & 0 & 0 \\
0 & 1 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0
\end{array}\right]
$$

From $Z_{2}$, a 2-circuit 232
is obtained.

| $Z_{2}=\left[\begin{array}{lllll} 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \end{array}\right]$ <br> From $Z_{2}$, a 2-circuit 232 is obtained. | From definition 5, $\begin{gathered} \qquad\left(z_{2}\right)_{i j}=\left(c_{j}^{\prime}\right)_{j i} \cdot\left(c_{j}^{\prime}\right)_{i j} \\ \text { e.g. }\left(z_{2}\right)_{23}=\left(c_{j}^{\prime}\right)_{32} \cdot\left(c_{j}^{\prime}\right)_{23}=1 \end{gathered}$ |
| :---: | :---: |
| 5. $C_{2}^{1}=\left[\begin{array}{lllll} 0 & 0 & 1 & 0 & 0 \\ 1 & 0 & 0 & 1 & 0 \\ 0 & 1 & 0 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0 \\ 1 & 3 & 0 & 1 & 0 \end{array}\right]$ | $C_{2}^{1}$ is obtained from definition <br> 2. At this point, we have a one 2-circuit. Let $\mu=2$-circuit 232 . |
| 6. $D_{1}^{\mu}=D_{1}^{\mu}=\left[\begin{array}{lllll}0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0\end{array}\right]$, | He obtain $D_{1}^{\mu}$ by eliminating rows 2 and 3 from $C_{1}$ i.e. by definition 4. |

Results
7.
$C_{3,1}=\left[\begin{array}{lllll}0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0\end{array}\right]$

Comments
From $D_{j}^{\mu}$, we obtain by keeping columns 2 and 3 , and setting the remainder columns to zero.
(Theorem 6)
Note: $\quad C_{\mu(3,1)}=C_{3,1}$ since there is only one 2-circuit.
8.
$C_{2}^{\prime} \cdot c_{1}^{\prime}=\left[\begin{array}{lllll}1 & 1 & 0 & 1 & 0 \\ 0 & 1 & 0 & 0 & 1 \\ 2 & 0 & 2 & 0 & 0 \\ 1 & 3 & 0 & 1 & 0 \\ 0 & 1 & 3 & 0 & 1\end{array}\right]$

|  |  |
| :--- | :--- |
| 9. | From theorem 4, |

$$
C_{3}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 0 \\
0 & 1 & 0 & 0 & 1 \\
2 & 0 & 2 & 0 & 0 \\
1 & 3 & 0 & 1 & 0 \\
0 & 1 & 2 & 0 & 1
\end{array}\right]
$$

$$
c_{3}=C_{2}^{\prime} \cdot C_{1}^{\prime}-C_{3,1}
$$

## Results

Comments
10.

$$
Z_{3}=\left[\begin{array}{lllll}
0 & 1 & 0 & 0 & 0 \\
0 & 0 & 1 & 0 & 0 \\
1 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 0 & 1 \\
0 & 0 & 1 & 0 & 0
\end{array}\right]
$$

From $z$, we obtain the
3 -circuits 1231 ard 3453.

Let $v$ be the 3-circuit 1231 and $\lambda$ be the 3 -circuit 3453. By definition 2.

Since $v$ is the 3 -circuit 1231, we obtain $D_{\mathcal{1}}^{\nu}$ by removing rows 1,2,3 from $C_{1}$. (From theorem 6.)

## Results

13. 

|  | $C_{v(4,1)}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 2 & 0 & 1 & 0 & 0\end{array}\right]$ | We obtain $c_{\nu}(4,1)$ by keeping columns 1,2,3, from $D_{j}^{\nu}$. |
| :---: | :---: | :---: |
| 14. | $D_{1}^{\lambda}=D_{1}^{\prime}{ }^{\lambda}=\left[\begin{array}{lllll}0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0\end{array}\right]$ | Since $\lambda=3$-circuit 3453 , we obtain $D_{1}^{\lambda}$ by removing rows $3,4,5$ from $C_{1}$ (Again, Theorem 6) |
| 15. | $C_{\lambda(4,1)}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0\end{array}\right]$ | From $D_{j}{ }^{\lambda}$ we obtain $C_{\lambda}(4,1)$ by keeping columns $3,4,5$ from $D q^{\lambda}$. |
| 16. | $C_{4,1}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 2 & 0 & 1 & 0 & 0\end{array}\right]$ | Hence, $C_{4,1}=C_{\nu(4,1)}+C_{\lambda(4,1)}$ <br> i.e. from definition 3 and theorem 6. |

## Results

Comments
17.
\(D_{2}^{\mu}=D_{2}^{\mu}=\left[\begin{array}{lllll}0 \& 0 \& 0 \& 0 \& 0 <br>
0 \& 0 \& 0 \& 0 \& 0 <br>
0 \& 0 \& 0 \& 0 \& 0 <br>
2 \& 0 \& 1 \& 0 \& 0 <br>

0 \& 2 \& 0 \& 0 \& 0\end{array}\right] \quad\)| From $D_{1}^{\mu}$, we obtain |
| :---: |
| $D_{2}^{\mu}=\left(D_{1}^{\mu}\right) \cdot\left(D_{1}^{\mu}\right)$ |
| (Theorem 5) |

18. 

| $C_{4,2}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 2 & 0 & 0 & 0\end{array}\right]$ | Hence, we can find $C_{4,2}$ from $\mathrm{D}_{2}^{\mu}$ by returning columns 2 and 3. |
| :---: | :---: |
| 19. $C_{3}^{\prime} \cdot C_{1}^{\prime}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 1 \\ 2 & 0 & 1 & 0 & 0 \\ 0 & 2 & 0 & 0 & 0 \\ 0 & 1 & 3 & 0 & 0 \\ 2 & 2 & 1 & 2 & 0\end{array}\right]$ |  |
| 20. $C_{4}=C_{4}^{1}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 1 \\ 2 & 0 & 0 & 0 & 0 \\ 0 & 2 & 0 & 0 & 0 \\ 0 & 1 & 2 & 0 & 0 \\ 0 & 0 & 0 & 2 & 0\end{array}\right]$ | From what has been obtained, we get, $C_{4}=C_{3}^{1} \cdot C_{1}^{1}-C_{4,1}-C_{4,2}$ <br> (Theorem 4) <br> $C_{4}=C_{4}^{\prime}$ since diagonal elements of $C_{4}$ are zero. |

Results
21. $C_{5,1}=[0]$

Comments
Since there are no 4-circuits.

Now, for 3-circuit $v$,

$$
D_{2}^{\nu}=D_{1}^{\nu} \cdot D_{1}^{\nu}
$$

(Theorem 5)

And, for 3-circuit $\lambda$,
$D_{2}^{\lambda}=D_{1}^{\lambda} \cdot D_{1}^{\lambda}$
(Theorem 5)

The same way $C_{4,1}$ was obtained.
Note however that we are doing this for all 3-circuits now, i.e. $v$ and $\lambda$ (left as an exercise).
(Theorem 6 and Definition 3)
25.

$$
D_{3}^{\mu}=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 2 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0
\end{array}\right]
$$

From $D_{1}^{\prime \mu}$ and $D_{2}^{\prime \mu}$,

$$
D_{3}^{\mu}=D_{2}^{\mu} \cdot D_{1}^{\prime \mu}-D_{3,1}^{\mu} \quad \text { (Theorem 5) }
$$

Note: $D_{3,1}^{\mu}=0$ because $D_{2}^{\mu}$ has no diagonal elements or no 2-circuit.
$\therefore D_{3}^{\mu}=D_{2}^{\mu} \cdot D_{1}^{\mu}$

Results
26.
$C_{5,3}=\left[\begin{array}{lllll}0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 2 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0\end{array}\right]$

Comments
From $D_{3}^{\mu}$, we obtain $C_{5,3}$ by keeping columns 2 and 3 corresponding to 2-circuit $\mu$. ( $\mu=2$-circuit 2,3,2) (Theorem 6)

$$
C_{5}=C_{4}^{\prime} \cdot C_{1}^{\prime}-\sum_{t=1}^{3} C_{5, t}
$$

(By Theorem 4)

By definition 5,

$$
\left(z_{5}\right)_{i j}=\left(c_{4}^{\prime}\right)_{j i} \cdot\left(c_{j}^{\prime}\right)_{i j}
$$

There are two 5-circuits, both of which are identical, 123451.
results from the permanent expansion of matrix $M$, where $M=C+I$ and $C$ is the variable adjacency matrix and $I$, the identity matrix. A new expansion, the "pseudopermanent," is defined by which the set of circuits can be formed directly. An extension of the method to find Hamiltonian circuits is also included. The method of Ardon and Malik offers improvements over all the other Connection Matrix Methods since the storage requirement is $0\left(n^{2}\right)$ as opposed to $O\left(n(\text { const })^{n}\right)$ for the others. We will mention more about the comparison between algorithms in Section 3.

### 2.4. Directed Graph Transformation Method

A directed graph can be transformed into a "line graph" where the properties of the "line graph" are useful for the purpose of circuit enumeration. Given a directed graph $G(V, E)$, where $e_{i} \varepsilon E$, the associated "line graph", $\Omega(G)$, is a graph where each arc in $G$ represents a vertex in $\Omega$ and each two adjacent arcs in $E$ form a vertex sequence connected by an arc in $\Omega(G)$, that is:


G
transforms to ,


The arc set of $G$ is then the vertex set of $\Omega$. Each p-path of G will correspond to a $(p-1)$ path in $\Omega$. However, each p-circuit of $G$ will correspond to a p-circuit in $\Omega$. There is a one-to-one correspondence between circuits in $G$ and $\Omega$. (See Cartwright and Gleason [3] for proof.) The elegance of this method is that we will be able to enumerate and delete the circuits in $\Omega$ without disrupting the cyclic nature of the original graph.

The algorithm lists all self loop first and eliminates them for G. For $G$, find $\Omega(G)$ and enumerate, then delete all arcs which are members of 2 -circuits in $\Omega(G)$. Let the resulting graph subgraph be $G^{\top}$. We then proceed to find $\Omega\left(G^{l}\right)$, enumerate, then delete all 3-circuits. Note that $\Omega\left(G^{1}\right)$ has only circuits of length greater or equal to 3. Call the resulting subgraphs $G^{2}$, find $\Omega\left(G^{2}\right)$, and so on ..., until $\Omega\left(G^{P}\right)$ for $p \leq n-2$ is empty. Example 4 will illustrate the method more clearly.

The method outlined above relied on the one-to-one correspondence between circuits in $G$ and $\Omega(G)$. It allows us to remove circuits as they are formed until eventually none are left, at which point the algorithm terminates. Observe that just as is the case of the Connection Matrix Methods, all circuits of identical cardinality are found simultaneously.

This method is well suited if the majority of the circuits in the graph we are studying have a small cardinality. Alternatively, we might be interested in circuits of a certain (small) cardinality, or circuits that do not exceed a certain cardinality. The reason for this is that whenever circuits are enumerated, they are also removed, thus the size of the graph is quickly reduced, and convergence might be faster as well. ${ }^{6}$ No other method allows us to remove circuits from the graph and test the resulting subgraph for circuits.

Example 4. Enumeration of circuits using Directed Graph Transformation Method.

Iteration 1.
Convert $G$ to $\Omega(G)$


List 2-circuit: $e_{3} e_{4} e_{3}$ in $\Omega(G)$.
Delete $\operatorname{arcs}\left(e_{3}, e_{4}\right)$ and $\left(e_{4}, e_{3}\right)$ from $\Omega(G)$.
The resulting subgraph is known as $G^{1}$.

## Iteration 2.

Transform $G^{l}$ to $\Omega\left(G^{1}\right)$


List 3 -circuits: $f_{1} f_{3} f_{2} f_{1}\left(e_{1} e_{2} e_{5} e_{1}\right)$ and

$$
f_{5} f_{6} f_{7} f_{5}\left(e_{4} e_{5} e_{6} e_{4}\right) \text { in } \Omega\left(G^{l}\right)
$$

Delete $\operatorname{arcs}\left(f_{1}, f_{3}\right),\left(f_{3}, f_{2}\right),\left(f_{2}, f_{1}\right),\left(f_{5}, f_{6}\right),\left(f_{6}, f_{7}\right)$

$$
\text { and }\left(f_{7}, f_{5}\right) \text { from } \Omega\left(G^{\prime}\right)
$$

The resulting subgraph is now known as $G^{2}$.
Iteration 3.
Transform $G^{2}$ to $\Omega\left(G^{2}\right)$


No 4-circuits are found.
$\Omega\left(G^{2}\right)=\emptyset$. This means that all the circuits have been enumerated.

Circuits found are:-

$$
\begin{array}{llll}
e_{3} & e_{4} & e_{3} & \\
& e_{1} & e_{2} & e_{5} \\
e_{1} \\
e_{4} & e_{5} & e_{6} & e_{4}
\end{array}
$$

Cartwright and Gleason [3] have proposed a way of listing circuits from the "line graph," after each transformation (and reduction). However, we could also use the method outlined in Section 2.3 (Kamae's Method) to enumerate circuits of a given cardinality from the "line graph." The problem still remains with manipulating such huge sparse matrices, which would incur huge storage and elaborate computations.

The transformation from a directed graph to a "line graph" involves a simple logical relationship which could be further exploited. Instead of representing the graph as an adjacency matrix, it could also be represented by arc listing, or other methods that are less storage incurring. 7 Operations upon arc listings remain difficult and unexplored and point to possible areas of research.

### 2.5. Obtaining All Simple Circuits from the Set of Elementary Circuits

In the preceding subsections, we have confined ourselves to enumerating elementary circuits. In this subsection, we shall present an algorithm for generating all simple circuits, given the set of elementary circuits obtained by any one of the methods discussed in Sections 2.2 to 2.4. This algorithm is applicable to undirected graphs as well, where we are interested in finding all the simple cycles. We have taken the initiative here for two main reasons:
i. The enumeration of all simple circuits from the original graph is complex and as a result inefficient. Furthermore, the number of elementary circuits found in a graph would help us determine whether it would be wise to proceed with the generation of all simple circuits. This is also because the algorithm that we are about to propose has a worst case time bound related to the number of elementary circuits.
ii. In some problems, the set of all simple circuits corresponds to a feasible set of solutions for those problems. Additional constraints placed on this set of feasible solutions yield the optimum solution, if one exists. A typical problem would be to list the cheapest simple circuit for each given cardinality. After we have obtained this set of simple circuits, we could then use it for dispatching of vehicles. Other examples are best shown by figs. 2.1 and 2.2 .

Figure 2.1 shows the relationships between simple circuits, elementary circuits and Hamiltonian circuit. It also shows that all solutions to the travelling salesman problem (TSP) are Hamiltonian circuits. In fig. 2.2 , we notice that if an Eulerian circuit exists, it corresponds to the solution for the Chinese postman problem (CPP). An Eulerian circuit is a simple circuit that covers all the arcs in the graph. Note that the solution for the CPP does not have to be simple circuits though. (TSP and CPP are discussed in more detail in Christofides [7].)
fig. 2.1 Relationship between Elementary and Simple Circuits

fig. 2.2 Simple, Eulerian Circuits and CCP


The algorithm which we will present shortly is not meant to solve some of these problems since other methods are available which are more efficient, but rather to illustrate the scope of this endeavor.

The following is an outline of the method:
Let there be q elementary circuits in a given graph defined by $S_{i}$, where $i=1,2, \ldots q . \quad S_{j}$ is an e-triple row vector where the $j{ }^{\text {th }}$ entry is 1 if the arc $j$ is contained in the circuit, and zero otherwise. We define $S_{i} \cap S_{k}=\phi$ for $l \leq i, k \leq q$ if $S_{i}$ and $S_{k}$ contains no arc in common, otherwise $S_{i} \bigcap S_{k} \neq \phi$. If $S_{i} \cap S_{k} \neq 0$, then the $S_{i}+S_{k}$ will not form a simple cycle. For example, if $S_{1}=(1,0,0,1), S_{2}=(1,0,0,0), S_{3}=(0,1,1,0)$, then $S_{1} \cap S_{2} \neq 0$ and $S_{1} \cap S_{3}, S_{2} \cap S_{3}=\phi$. (One way to find out is to see if the addition of two vectors contain any element with value greater than one.)

Now, if $S_{i} \cap S_{k}=\phi$, then $S_{i}+S_{k}$ would be an arc disjoint union of elementary circuits or a simple but non-elementary circuit. Note however, that if $P \cap S_{j}=\phi$, where $P$ is a general circuit which may have more than one circuit component. Specifically, $P \varepsilon M$, where $M=$ \{the set of all arc disjoint unions of elementary circuits or an arc-disjoint union of elementary and simple circuits, or an arc-disjoint union of simple circuits, or a simple but non-elementary circuit\}, then $P+S_{i} \varepsilon M$. To distinguish whether $P+S_{i}$ is a simple but non-elementary circuit, a few definitions are necessary.

We define $V\left(S_{i}\right)$ as an $n$-triple row vector (where $n$ is the total number of vertices in the graph) of circuit $S_{i}$ where the $j^{\text {th }}$ entry
(column) is 1 if vertex $j$ belongs to circuit $S_{i}$ and zero otherwise. Next, we define the operation $\odot$, where: $V(P) \bigcirc V\left(S_{j}\right) \triangleq$ sum of all positive elements of $\left\{\left(V(P)+V\left(S_{i}\right)\right)-\vec{\dagger}\right\}$; $\vec{T}$ is an $n$-triple vector of ones. This operation defines the number of vertex intersection at $P$ and $S_{i}$. We denote also the number of distinct element circuits in $P$ as $x_{p}$. For example, let $V\left(S_{1}\right)=(1,1,0,1,1), V\left(S_{2}\right)=(0,1,0,0,0)$, $V\left(S_{3}\right)=(1,1,0,1,0)$. If $P$ is $S_{1}+S_{3}$, then $V(P)=V\left(S_{1}\right)+V\left(S_{3}\right)$, 8 i.e. $x_{p}=2$ and $S_{i}=S_{2}$, then,

$$
\left\{\left(V(P)+V\left(S_{2}\right)-1\right\}=(2,3,0,2,1)-(1,1,1,1,1)=(1,2,-1,1,0)\right.
$$

and

$$
V(P) \odot V\left(S_{2}\right)=1+2+1=4
$$

Note that $V(P) \odot V\left(S_{2}\right) \geq x_{p}$.
Now, given that $P \cap S_{i}=\phi$, if also $V(P) \odot V\left(S_{i}\right) \geq x_{p}$, then $P+S_{i}$ forms a simple but non-elementary circuit. We claim here that if $x_{p}$ circuits are joined together such that they do not share any arc in common and they meet at least $x_{p}$ times, then a simple but non-e lementary circuit is formed.

If, however, $P \cap S_{i}=\phi$ and $V(P) \odot V\left(S_{i}\right)<x_{p}$, we must not discard $P+S_{i}$ from further comparisons, since the addition of $\left(P+S_{i}\right)$ and another elementary circuit might form a simple but
non-elementary circuit. (We store all these in set $M$ in the following ALGORITHM 4.)

But if at any point $P \cap S_{i} \notin \phi$, then any further comparisons, that is, additions with $P+S_{i}$ can be eliminated since these combinations can never form a simple circuit. This elimination rule reduces the possible outcomes we need to consider, which otherwise would be enormous.

The actual algorithm is presented in ALGORITHM 4.
In order to reduce the number of combinations that need to be considered, it is better to order the circuits in the set of elementary circuits with decreasing cardinality, that is, $S_{1}$ is the elementary circuit with the highest cardinality, followed by $S_{2}, S_{3}$, etc. As usual, we include an example to complete our illustration. We refer to the same graph used previously, and reproduced here for convenience in Example 5.

It is important to mention here that in the worst-case the algorithm requires $2^{q}-1$ combinations, where $a$ is the number of elementary circuits. However, the worst case is highly unlikely since this would mean that each combination would result in a distinct simple circuit. In that case, by the ordering procedure that we have recommended, the number of combinations that need to be considered can be reduced. The amount of reduction would depend on the nature of the set of elementary circuits. Even then, this algorithm requires alot of computing time. We make every effort to

## ALGORITHM 4. Algorithm to Find all the Simple Circuits in a Graph Given the Set of Elementary Circuits.

Let the set of elementary circuits be:-

$$
S_{i} ; i=1,2, \ldots q .
$$

Initialize: $1 \operatorname{Set} L=\left\{S_{j}\right\}, M=\left\{S_{j}\right\} i=2, I=\phi, J=\phi$
Separate: 2 For each $P$ in $M$
if $P \cap S_{i}=\phi$, place $P+S_{i}$ in $I ;\left(P, S_{i}\right)$ in $J$

Otherwise, continue until all $p$ in $M$ are considered.
$3 M \leftarrow M U I U S_{i}$
Test for : 4 For each pair ( $P, S_{j}$ ) in 1
Simple Circuit
if $V(P) \bigcirc V\left(S_{i}\right)<x_{p}$, set $I \leftarrow I-\left\{P+S_{j}\right\}$

Otherwise continue until all pairs in J are considered.
$5 L+L U S_{i} U I$
6 Reset I $\leftarrow \phi$; Reset J $\leftarrow \phi$
7 Set $\mathbf{i}=\mathbf{i}+1$. If $\mathbf{i} \leq q$ go to 2
otherwise, stop.
L contains all simple circuits in the graph.

Example 5. Generating All Simple Circuits From the Set of Elementary Circuits

Give.,

and,

|  |  | Arcs |  |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Elementary <br> Circuits | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
| $S_{1}$ | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| $S_{2}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| $S_{3}$ | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 |
| $S_{4}$ | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| $S_{5}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |
| $S_{6}$ | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |

Vertices

|  | 1 | 2 | 3 | 4 | 5 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $V\left(S_{1}\right)$ | 1 | 1 | 1 | 1 | 1 |
| $V\left(S_{2}\right)$ | 1 | 1 | 1 | 1 | 1 |
| $V\left(S_{3}\right)$ | 1 | 1 | 1 | 0 | 0 |
| $V\left(S_{4}\right)$ | 0 | 0 | 1 | 1 | 1 |
| $V\left(S_{5}\right)$ | 1 | 0 | 0 | 0 | 0 |
| $V\left(S_{6}\right)$ | 0 | 0 | 1 | 0 | 0 |

We have $S_{i}, i=1,2, \ldots 6$

1. $\operatorname{Set} L=\left\{S_{1}\right\} \quad M=\left\{S_{1}\right\} \quad i=2, I=\phi, J=\phi$.
2. $S_{1} \cap S_{2} \neq \phi, \quad M \leftarrow\left\{S_{1}, S_{2}\right\}, \quad L \leftarrow\left\{S_{1}, S_{2}\right\}, \quad i=3$
3. $S_{1} \cap S_{3} \neq \phi, S_{2} \cap S_{3} \neq \phi, \quad M \leftarrow\left\{S_{1}, S_{2}, S_{3}\right\}, L \leftarrow\left\{S_{1}, S_{2}, S_{3}\right\}, \quad i=4$
4. $S_{1} \cap S_{4} \neq \phi, S_{2} \cap S_{4} \neq \phi, S_{3} \quad S_{4}=\phi, I \leftarrow\left\{S_{3}+S_{4}\right\} ; J \leftarrow\left\{\left(S_{3}, S_{4}\right)\right\}$

$$
\begin{aligned}
& M+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}\right\}, \text { since } V\left(S_{3}\right) \odot v\left(S_{4}\right)=1=x_{p} \\
& L+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}\right\} \\
& i=5
\end{aligned}
$$

5. 

$$
\begin{aligned}
& S_{1} \cap S_{5}=\phi, S_{2} \cap S_{5}=\phi, S_{3} \cap S_{5}=\phi, S_{4} \cap S_{5}=\phi,\left(S_{3}+S_{4}\right) \cap S_{5}=\phi \\
& I+\left\{S_{1}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{4}+S_{5}, S_{3}+S_{4}+S_{5}\right\} \\
& J+\left\{\left(S_{1}, S_{5}\right),\left(S_{2}, S_{5}\right),\left(S_{3}, S_{5}\right),\left(S_{4}, S_{5}\right),\left(S_{3}+S_{4}, S_{5}\right)\right\} \\
& M+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}, S_{5}, S_{1}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{4}+S_{5}, S_{3}+S_{4}+S_{5}\right\}
\end{aligned}
$$

Since, all except $V\left(S_{4}\right) \odot V\left(S_{5}\right)<x_{p}=(2$ in this case $)$,

$$
\begin{aligned}
& I+\left\{S_{1}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{3}+S_{4}+S_{5}\right\} \\
& L+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}, S_{5}, S_{1}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{3}+S_{4}+S_{5}\right\} . i=6
\end{aligned}
$$

6. 

$$
\begin{aligned}
& S_{1} \cap S_{6}=\phi, S_{2} \cap S_{6}=\phi, S_{3} \cap S_{6}=\phi, S_{4} \cap S_{6}=\phi, S_{5} \cap S_{6}=\phi, \\
& \left(S_{3}+S_{4}\right) \cap S_{6}=\phi,\left(S_{1}+S_{5}\right) \cap S_{6}=\phi,\left(S_{2}+S_{5}\right) \cap S_{6}=\phi, \\
& \left(S_{3}+S_{5}\right) \cap S_{6}=\phi,\left(S_{4}+S_{5}\right) \cap S_{6}=\phi,\left(S_{3}+S_{4}+S_{5}\right) \cap S_{6}=\phi . \\
& I+\left\{S_{1}+S_{6}, S_{2}+S_{6}, S_{3}+S_{6}, S_{4}+S_{6}, S_{5}+S_{6}, S_{3}+S_{4}+S_{6}, S_{1}+S_{5}+S_{6}, S_{2}+S_{5}+S_{6},\right. \\
& \left.s_{3}+s_{5}+s_{6}, s_{4}+s_{5}+s_{6}, s_{3}+s_{4}+s_{5}+s_{6}\right\} \\
& J+\left\{\left(S_{1}, S_{6}\right),\left(S_{2}, S_{6}\right),\left(S_{3}, S_{6}\right),\left(S_{4}, S_{6}\right),\left(S_{5}, S_{6}\right),\left(S_{3}+S_{4}, S_{6}\right),\left(S_{1}+S_{5}, S_{6}\right),\right. \\
& \left.\left(S_{2}+S_{5}, S_{6}\right),\left(S_{3}+S_{5}, S_{6}\right),\left(S_{4}+S_{5}, S_{6}\right),\left(S_{3}+S_{4}+S_{5}, S_{6}\right)\right\} . \\
& M+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}, S_{5}, S_{7}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{4}+S_{5}, S_{3}+S_{4}+S_{5},\right. \\
& s_{7}+s_{6}, s_{2}+s_{6}, s_{3}+s_{6}, s_{4}+s_{6}, s_{5}+s_{6}, s_{3}+s_{4}+s_{6}, s_{7}+s_{5}+s_{6}, \\
& \left.S_{2}+S_{5}+S_{6}, S_{3}+S_{5}+S_{6}, s_{4}+S_{5}+S_{6}, S_{3}+S_{4}+S_{5}+S_{6}\right\}
\end{aligned}
$$

Since all except $V(5) \odot V(6)$ and $(V(4)+V(5)) \odot V(6)$ is not less than $x_{p}$,
$I+I-\left\{S_{5}+S_{6}, S_{2}+S_{5}+S_{6}\right\}$.
$L+\left\{S_{1}, S_{2}, S_{3}, S_{4}, S_{3}+S_{4}, S_{5}, S_{1}+S_{5}, S_{2}+S_{5}, S_{3}+S_{5}, S_{3}+S_{4}+S_{5}, S_{1}+S_{6}\right.$, $s_{2}+s_{6}, s_{3}+s_{6}, s_{4}+s_{6}, s_{3}+s_{4}+s_{6}, s_{7}+s_{5}+s_{6}, s_{2}+s_{5}+s_{6}$, $\left.S_{3}+S_{5}+S_{6}, S_{3}+S_{4}+S_{5}+S_{6}\right\} . i=7$. Since $i>q$. Stop.
$\underline{L}$ contains all the simple circuits of the graph.
reduce the kind of operations to include simple additions only.
Slight modifications of the algorithm could very effectively search for the existence of an Eulerian circuit if one exists, or to find the set of simple circuits that contains a specific number of elementary circuits. Restrictions on the kind of simple circuits we would be interested in is what makes the algorithm more appealing.

In the next subsection, we look at generation of elementary cycles and circuits in a planar graph, and look at some complications that arise.
2.6. Methods for Generating all Cycles and Circuits in a Planar Graph

The methods discussed thus far apply to all graphs. This subsection deals with a particular kind of graph - planar graphs. There are certain properties that planar graphs have and this subsection presents another perspective on circuit enumeration using these properties.

Before proceeding, we would like to know how to recognize a planar graph. ${ }^{9}$

A graph is planar if and only if it can be mapped onto the surface of a sphere such that no two edges or arcs meet except at the vertex or vertices, with which the edges or arcs are incident. Fig. 2.3 shows some regular polygons and their representations as planar graphs in fig. 2.4. A face of a planar graph is an area of the plane bounded by edges called contours which contains no edges, arcs, or vertices. A finite face is a face where the area
fig. 2.3 Some regular polygons

bounded is finite and an infinite face has infinite area. A planar graph then has an infinite face external to all edges. Two faces are adjacent if they share a common edge, and every edge is part of exactly two contours.

Another definition, more suitable for our purpose is presented as theorem 7.

Theorem 7 (MacLane): The set of contours of the finite faces of a planar undirected graph forms a basis of the cycle subspace of the graph.

Proof: A cycle of a planar graph encircles one or more than one face. The edges of a cycle are then equal to the ring sum of the set of contours of the encircled regions. Thus any cycle or edge disjoint union of cycles can be expressed as a linear combination of the contours of the finite faces. Moreover, no contour of a finite region can be formed by a linear combination of contours of other finite faces. This is because the ring sum of the contours of two or more finite faces is a cycle (or edge disjoint union of cycles) containing those areas of the finite faces.

There are e $-n+1$ finite faces and therefore the cycle basis has rank equals to $e-n+1$ (which is also equal to the cyclomatic number). Therefore, we can use the set of contours of the finite faces in place of a fundamental set of cycles as the cycle basis and
use the method of Section 2.1 (Cycle Vector Space Methods) to generate all the elementary cycles in the graph.

To apply theorem 7 however, we need to first ensure that the graph is planar and obtain a plane representation of the graph. This problem is solved by Hoftcraft and Tarjan [16], requiring computation time bounded by a polynomial in $n$.

The planar algorithm starts constructing the planar graph from a planar subgraph (usually a cycle) of the given graph. Gradually, the remaining edges are added to the selected planar subgraph, such that no edges cross. The way to know this is by testing if the number of edges and vertices satisfy Euler's condition, namely, if e > $3 n-3$, we know that the given graph is non planar. Hoftcroft and Tarjan [16] uses the depth-first-search method (see Tarjan [33]) for their algorithm. The graph is also represented as an adjacency list which incurs lesser storage and examination time. The program is written in Algol and when tested on an arbitrary graph with 900 vertices, it requires less than 12 seconds of running time.

Having an algorithm for testing and representing planarity of the graph, we now move on to introduce an algorithm that generates all the elementary circuits in a directed planar graph. Before doing so, we need to first acquaint ourselves with dual graphs.

Let $D$ be the dual graph of a planar undirected graph $G$. For each face in $G$, let there be a corresponding vertex in D. Also, for each edge common to two adjacent faces in $G$, let there be a
corresponding edge which joins the two vertices corresponding to the adjacent faces, in $D$.

Every graph that is planar has a dual, and the dual of a dual graph is the planar graph itself (Whitney). There is a one-to-one correspondence between the number of edges in $G$ and $D$. The contour of a face in $G$ corresponds to a cutset separating the corresponding vertex from other vertices in D. But this corresponding set of cutsets in $D$ is a basis of the cutset subspace in D. From theorem 7, we know that the set of contours of the finite faces is a basis of the cycle subspace of $G$. Thus, there exists a one-to-one correspondence between the vectors in the cycle subspace of a planar graph and the vectors in the cutset space of its dual and vice versa. As such, the problem of enumerating the cutsets of the dual graph is equivalent of enumerating the cycles in the primal graph.

These statements apply to undirected planar graphs. We are now ready to extend our understanding of dual graphs to generate all the elementary circuits in a directed planar graph.

Given a directed planar graph $G_{d}$, construct the dual $D_{d}$ as follows; first, obtain the dual of the undirected version of the directed graph. In addition, if an edge from a vertex in the dual intersects a planar arc which is oriented in a clockwise direction around the dual vertex, then the dual edge is directed outwards from it, otherwise, it is directed inwards. Consider the example in fig. 2.5 . Note that the graph, $G_{d}$ in fig. 2.5 is similar to that in Example 2,
except that we have removed the self loops.
fig. 2.5 Directed Graph $G_{d}$ and its Dual $D_{d}$

----- Dual Graph, $D_{d}$.
$\qquad$ Planar Graph, $G_{d}$.

We have labelled the faces in the planar directed graph $G_{d}, F_{1}$, $F_{2}, F_{3}, F_{4}, F_{5}, F_{6}$, (where $F_{6}$ is the infinite face) and the corresponding vertices in the dual graph, $D_{d}, F_{1}, F_{2}, F_{3}, F_{4}, F_{5}$ and $F_{6}$. In general, we shall always label faces in the planar directed graph and the vertices in the dual as $F_{i}=\left\{F_{1}, F_{2}, \ldots F_{e-n+2}\right\}$, where $F_{e-n+2}$ is the infinite face.

The method for generating all evaluation circuits in a directed planar graph is presented as a flowchart in fig. 2.6 and works
fig.2.6 Flowchart on obtaing all elementary circuits in a directed planar gaph, $G_{d}$, using the dual graph, $D_{d}$.

stricly on the dual graph $D_{d}$. It consists of three main blocks:
I. Vertex aggregation,
II. Arc removal, and
III. Circuit test.

Vertex aggregation involves taking distinct combinations of vertices in the dual that do not include vertex $F_{e-n+2}$. One of the ways of taking distinct combinations from the e $-n+1$ vertices has been introduced by the algorithm in the previous subsection. For a graph of $e-n+1$ faces, we need to consider $2^{e-n+1}-1$ combinations.

For each combinations of $x$ vertices, we have to ensure that we remove at least $x-1$ arcs following vertex aggregation. If this condition is satisfied, then block II, "arc removal" has been accomplished. For example, consider the dual graph:

after vertex aggregation

after arc removal,


Vertex aggregation and arc removal obtains a dual of the planar subgraph where those corresponding arcs are removed in the planar. Each arc so removed is common to two adjacent faces. Each vertex aggregation also forms a new dual vertex. If "arc removal" is successfully accomplished, then we proceed with circuit testing in block III.

Circuit testing involves vertex inspection. A circuit in the directed planar graph corresponds to a vertex in the dual graph with all incident arcs directed either inwards or outwards only. Note, circuit testing is only performed if "arc removal" is successful; that is, for $x$ vertices aggregated, at least $x$ - 1 arcs are removed.

Let us summarize our method. We start off with the dual graph, $D_{d}$, and aggregate on the vertices corresponding to the finite faces in the planar. Vertex aggregation is followed by "arc removal," which
essentially removes the arcs that are common to the corresponding faces associated with the vertices aggregated. With each vertex aggregation we obtain a new dual vertex, and providing "arc removal" is sucessful, we test to see if these combined faces (with common arcs removed) form an elementary circuit; that is, if all incident arcs are directed inwards or outwards from this new dual vertex, then we have formed a new elementary circuit.

We now use the graph in fig. 2.5 as an example to illustrate our method. The results are shown in Example 5. The example reveals the limitation of this method. For $e-n+1=5$, the number of vertex aggregation that have to be considered is $2^{5}-1=31$. Clearly, as the number of faces increases, the number of vertex aggregation increases exponentially. Note however, that the Cycle Vector Space Method of Gibbs-Welch discussed in Section 2.1 also requires $2^{e-n+1}-1$ combinations for comparisons in the worst case. Moreover, what we have presented here is applicable to a directed graph, even though it has to be planar. In essence, what we have really established is that the vertices (excluding $F_{e-n+2}$ ) in the dual planar graph forms a basis for finding the directed elementary circuits in the planar graph. Also, notice that, in most cases "arc removal" reduces the number of aggregation to be considered enormously. Another way of viewing "arc removal" is that the vertices that are aggregated must form connected components. The test for connected components is available (see Narsigh Deo [10]). Circuit testing via vertex inspection is done by

Example 5. Generating Elementary Circuits in a Directed Planar Graph Using the Dual
$\checkmark$ : Passed $x$ : Failed liA: Not Applicable NC: Not Connected Note: The procedure proceeds from left to right for each vertex aggregation.

| $\frac{\text { Vertex Aggregation }}{}$ <br> $\mathrm{F}_{1}$ | Arc Removal <br> $\checkmark$ | $\frac{\text { Circuit Test }}{x}$ | $\frac{\text { Circuit }}{\text { - }}$ |
| :---: | :---: | :---: | :---: |
| $F_{2}$ | $\checkmark$ | x | - |
| $\mathrm{F}_{1} \mathrm{~F}_{2}$ | $x: F_{1}, F_{2} N C$ | NA. | - |
| $\mathrm{F}_{3}$ | $\checkmark$ | $\checkmark$ | $\mathrm{F}_{3}: \begin{gathered}\text { contours of } \\ \text { face } \mathrm{F}_{3}\end{gathered}$ |
| $F_{1} F_{3}$ | $x: F_{1}, F_{3} N C$ | NA | - |
| $\mathrm{F}_{2} \mathrm{~F}_{3}$, | $x: F_{2}, F_{3} N C$ | NA | - |
| $\mathrm{F}_{1} \mathrm{~F}_{2} \mathrm{~F}_{3}$ | $x: F_{1}, F_{2}, F_{3} N C$ | NA | - |
| $\mathrm{F}_{4}$ | - $\quad \checkmark$ | $\checkmark$ | $F_{4}$ : contours of face $\mathrm{F}_{4}$ |
| $\mathrm{F}_{1} \mathrm{~F}_{4}$ | $x: F_{1}, F_{4} N C$ | NA |  |
| $\mathrm{F}_{2} \mathrm{~F}_{4}$ | $\checkmark$ | $\checkmark$ | $F_{2} F_{4}:$ contours of $F_{2}$ $\mathrm{F}_{4}$ excluding common arc |
| $F_{1} \mathrm{~F}_{2} \mathrm{~F}_{4}$ | $x: F_{1}, F_{2}, F_{4} N C$ | NA | - |
| $\mathrm{F}_{3} \mathrm{~F}_{4}$ | $x: F_{3}, F_{4} N C$ | NA | - |
| $F_{1} F_{3} F_{4}$ | $x: F_{1}, F_{3}, F_{4} N C$ | NA | - |
| $\mathrm{F}_{2} \mathrm{~F}_{3} \mathrm{~F}_{4}$ | $x: F_{2}, F_{3}, F_{4} N C$ | NA | - |
| $\mathrm{F}_{1} \mathrm{~F}_{2} \mathrm{~F}_{3} \mathrm{~F}_{4}$ | $x: F_{1}, F_{2}, F_{3}, F_{4} N C$ | NA | - |


| Vertex Aggregation | Arc Removal | Circuit Test | Circuit |
| :---: | :---: | :---: | :---: |
| $F_{5}$ | $\checkmark$ | x | - |
| $F_{7} \mathrm{~F}_{5}$ | $\checkmark$ | x | - |
| $\mathrm{F}_{1} \mathrm{~F}_{2} \mathrm{~F}_{5}$ | $\checkmark$ | $x$ | - |
| $\mathrm{F}_{3} \mathrm{~F}_{5}$ | $\checkmark$ | $x$ | - |
| $\mathrm{F}_{1} \mathrm{~F}_{3} \mathrm{~F}_{5}$ | $\checkmark$ | x | - |
| $\mathrm{F}_{2} \mathrm{~F}_{3} \mathrm{~F}_{5}$ | $\checkmark$ | x | - |
| $F_{1} F_{2} F_{3} F_{5}$ | $\checkmark$ | $x$ | - |
| $\mathrm{F}_{4} \mathrm{~F}_{5}$ | $x: F_{4}, F_{5} N C$ | NA | - |
| $F_{1} F_{4} F_{5}$ | $x: F_{1}, F_{4}, F_{5} N C$ | NA | - |
| $\mathrm{F}_{2} \mathrm{~F}_{4} \mathrm{~F}_{5}$ | $\checkmark$ | x | - |
| $F_{1} F_{2} F_{4} F_{5}$ | $\checkmark$ | x | - |
| $\mathrm{F}_{3} \mathrm{~F}_{5} \mathrm{~F}_{5}$ | $x: F_{3}, F_{4}, F_{5} N C$ | NA | - |
| $F_{1} F_{3} F_{4} F_{5}$ | $x: F_{7}, F_{3}, F_{4}, F_{5}$ | NA | - |
| $F_{2} F_{3} F_{4} F_{5}$ | $\checkmark$ | $\checkmark$ | $F_{2} F_{3} F_{4} F_{5}$ : contours of $F_{2}, F_{3}, F_{4}, F_{5}$ excluding. common arcs |
| $F_{1} F_{2} F_{3} F_{4} F_{5}$ | $\checkmark$ | $\checkmark$ | $F_{1} F_{2} F_{3} F_{4} F_{5}$ : contours of $F_{1}, F_{2}, F_{3}, F_{4}, F_{5}$ excluding common arcs |

finding whether there is one incident arc orientated in the opposite direction. The existence of one pair of opposite incident arcs in an aggregated vertex is sufficient to establish that no circuit is formed.

Everything we have discussed thus far works well provided we can easily obtain the dual from the planar graph. This remains a difficult problem since there is no algebraic representation of a face in the planar graph. As such, our ability to construct the dual is restricted to working on the planar geometric representation of the graph. Perhaps one way to facilitate this task is to keep track of when the path added in Hoftcroft and Taijan's algorithm forms a closed region. At that point we could then identify the dual vertex associated with that face.

Another possibility is to construct the dual from the planar displayed on the console of a computer terminal. We suspect that the complications would very much depend on how well we are able to represent our planar graph. In general, however, the planar graph allows us to "stretch" and "pull" the graph in order that faces are more easily identified.

It seems then that the choice of this method rests rather heavily on how easy it is to obtain the dual graph from the planar.

This concludes our review and suggestions on circuit and cycle enumeration methods.

In the next section, we compare some algorithms using the methods we have just reviewed and provide some recommendations.

Section 3

## Analysis of Algorithms

In the previous section, we presented the methods for geration of cycles or circuits ${ }^{10}$ in a graph. This section examines how one algorithm compares with another in terms of running time and storage requirements in the worst-case. Norst-case analysis is by no means indicative of the efficiency of an algorithm for an actual real-life problem. However, it does provide us with a means for comparison as well as an indication of the limitations of the algorithm. In effect, the performance of each algorithm depends strictly on the specific structure of each graph we are working with.

This section starts with ways of reducing and editing the graph without losing any cycle or circuit that belongs to the original graph. These reductions and editions help make circuit generation a more realistic and plausible choice as an approach to some problems where the problem of circuit enumeration would be enormous and intractable in every sense of the word.

Having reduced and edited the graph, we then proceed to compare the worst-case performance of all the algorithms that fall into the methods we have discussed. Each of the authors referenced has been cited previously. Worst-case analyses are done on graphs that have been reduced and edited under the rules in section 3.1.

Thus far, the connection between directed and undirected graphs
remains somewhat obscure. In the subsection following, we present a method suggested by Ardon and Malik [1] for converting an undirected graph to a directed graph but maintaining the one to one correspondence between cycles in the undirected and circuits in the directed graph. This method avoids having to enumerate each cycle twice in the corresponding directed version of the undirected graph. It also presents an option for enumerating cycles in an undirected graph using a directed circuit algorithm.

Finally, we suggest which algorithm is best in each of the methods discussed and from those, which would we recommend in general.

### 3.1 Graph Reduction and Edition

The problem of enumerating cycles or circuits is almost always intractable for an original graph before graph reduction and edition. The reason for this is that all the algorithms that we have presented are exponential to the size of the graph. Given a graph, it is possible to apply a set of rules to the graph in order to reduce the size of the graph in such a way that no cycles or circuits are omitted from the original graph. Although this does not guarantee that the computational problem can be reduced, it offers some improvements in most cases. . Moreover, the reduced graph is not only smaller but more manageable and suitable for the methods we have discussed. In fact, all algorithms work better with the reduced graph. Furthermore, all algorithms for worst-case analysis apply to graphs that are reduced and edited.

The rules for reducing and editing graphs are as follows:

1. Self loops can be enumerated first, afterwhich they need not
be considered anymore since no other elementary circuit can contain them. In algorithms that "grow" with e, we can reduce e by the number of self-loops in the graph.
2. A set of $p$ parallel edges or arcs can be replaced by a single edge or arc. Thereafter, whenever a circuit is found that contains this arc, p such circuits are enumerated. Again, this reduces the size of $e$ in the graph. Furthermore, parallel arcs are not easily distinguishable in the search procedures as discussed in section 2.2 .
3. Vertices of both indegree and outdegree of one can be deleted and replaced by a single arc or edge. This not only reduces the number of arcs or edges and vertices in the final graph, but also the cardinality of cycles or circuits. In algorithms where cycles or circuits of small cardinality are enumerated quickly and shortly after the start, this reduction is extremely helpful.
4. Vertices of zero indegree or zero outdegree are deleted together with their incident edges or arcs, because these cannot be part of a cycle or circuit. This process is continued until no such vertices remains. This way of pruning the graph can be visualized as chopping off the "branches" that stick out from the graph. As a result we have a more compact graph.
5. The classical "divide and conquer" rule: For a directed graph with "strong components", it is possible to decompose the problem into finding all the circuits for each "strong component."

In appendix $A$, we show how "strong components" can be obtained easily from a given graph. A maximal strongly connected subgraph of a graph is defined as a strong component of the graph. A subgraph is strongly connected if there is at least one directed path from every vertex to every other vertex in the subgraph. (See Christofides [7].) Thus, all circuits in a graph can be found in the strong components of the graph and no circuit exists which connects strong components. The usefulness and importance of this decompostion cannot be overlooked in enumerating elementary circuits in a graph. The strong components are subgraphs that are small enough hopefully so that even though our algorithms are exponential, we could generate all the circuits in these strong components quickly. Otherwise, having the strong components would tell us whether it would be wise to proceed with circuit enumeration if all strong components are large or, to enumerate all circuits from certain chosen strong components.

The reduction process is helpful since it only has steps of the order of (n+e).

### 3.2 Discussion of the Time and Space Bound of all Circuit and Cycle Enumeration Algorithms

We can now turn to a comparison of the performance of these algorithms, see table 1, where results from Matei and Deo [23] are presented.

Paths and circuits can be listed as edge, arc, or vertex sequences.

Table 1. Upper Bounds on Time and Space for Elementary Circuits and Cycle Generating Algorithms

| Algorithm Used | Time Bound | Space Bound | Method Used |
| :---: | :---: | :---: | :---: |
| Hsu and Honkanen Mateti and Deo Maxwell and Reed Rao and Murti Welch-Gibbs | $\begin{aligned} & n \cdot 2^{2 \mu} \\ & \mu^{2} \cdot 2^{2 \mu} \\ & n \cdot 2^{2 \mu} \\ & e \cdot \mu^{2} \cdot 2^{\mu} \\ & n \cdot 2^{2 \mu} \end{aligned}$ | $\begin{aligned} & e \cdot 2^{\mu} \\ & \mu^{2} \\ & e \cdot 2^{\mu} \\ & \mu \cdot n \\ & e \cdot 2^{\mu} \end{aligned}$ | Cycle Vector Space <br> 11 |
| Berztiss <br> Johnson <br> Ehrenfeucht <br> Read and Tarjan <br> Szwarcfiter + Lauer <br> Tarjan <br> Tiernan <br> Weinblatt | $\begin{aligned} & n(\text { const. })^{n} \\ & (n+e) c \\ & n^{3}+n \cdot e \cdot c \\ & (n+e) c \\ & (n+e) c \\ & n \cdot e \cdot c \\ & n(\text { const. })^{n} \\ & n(\text { const. })^{n} \end{aligned}$ | $\begin{aligned} & n+e \\ & n+e \\ & n+e \\ & n+e \\ & n+e \\ & n+e \\ & n+e \\ & n \cdot c \end{aligned}$ | Search and Backtrack <br> II <br> 11 <br> 11 <br> 11 <br> II <br> 11 <br> 11 |
| Ardon and Malik <br> Danielson <br> Kamae <br> Ponstein <br> Yau | $\begin{aligned} & n(\text { const. })^{n} \\ & n(\text { const. })^{n} \end{aligned}$ | $\begin{gathered} n^{2} \\ n(\text { const. })^{n} \\ n(\text { const. })^{n} \\ n(\text { const. })^{n} \\ n(\text { const. })^{n} \end{gathered}$ | Connection Matrix $"$ $"$ $"$ |
| Cartwright + Gleason | $n(\text { const. })^{n}$ | $n(\text { const. })^{n}$ | Directed Graph Transformation |

Note: $n=$ number of vertices
$\mathrm{e}=$ number of edges or arcs
$\mu=v(G)=$ cyclomatic number $=e-n+1$
$c=$ number of elementary circuits.
Source: Mateti and Deo [23]

Each vertex or arc (edge) counts as a unit of input. Space bounds or bounds on computer storage required are measure as units of input. Any operation on a vertex or edge (arc) counts as one time unit. For instance, in the Search and Backtrack liethods, whenever a path is extended to a vertex, we count that as one time unit. Time bounds for the algorithms are given in terms of time units.

The results given in table 1 are worst-case bounds. The worst-case graphs for different algorithms are in general different. It is also inportant to note that the effectiveness of an algorithm is very much graph dependent. For instance, it is easier to apply a cycle enumeration algorithm to an undirected graph instead of a circuit enumeration algorithm. In addition, the choice of the algorithm depends also on the problem we are interested in solving. An understanding of our input, or problem is almost as important as choosing the algorithm itself. Some algorithms that perform well for graphs of reasonable size might be very inefficient for graphs that are small.

From table 1, note that the Search and Backtrack Methods require the least storage. Other methods like the Vecter Space, Connection Matrix or Directed Graph Transformation method store the input as an adjacency matrix or slight variation thereof, instead of arc listings, or an adjacency list. In addition to storing the information in a huge memory, the examinations cannot stop without going through each element of the matrix. In this sense, a huge storage incurs a penalty on the running time as well

The Search and Backtrack Methods, ihouch not theoretically as elegant
as the Cycle Vector Space or the Connection Matrix Methods, are very suitable for computer implementation. Most of the algorithms in these methods, for example Tarjan [32] and Johnson [18], uses what is known as the "Depth-First-Search" Method, see Tarjan [33]. Depth-First-Search is a procedure to search exhaustively without traversing any path twice.

Even though in general inferior, the Connection Matrix Method could be used as effectively (and in some cases more so) to enumerate special circuits like the Hamiltonian circuits, see Ardon and Malik [1], Danielson [8] and Yau [37]. The main problem with the connection matrix method is that it remains difficult to sort out the circuits in the diagonal even if we are able to eliminate nonsimple paths. So, as long as sorting remains difficult it is unlikely that the Connection Matrix Methods would gain as much attention as the Search and Backtrack Methods. Although the algorithm of Cartwright and Gleason [3] allows for much flexibility in the way we enumerate circuits from line graphs, (see Section 3.4) it suffers almost the same problems as faced by Connection Matrix Method. Because of this, the Directed Graph Transformation Method remains relatively unexplored; and their space and time bound exhibits similarity with the Connection Matrix Method.

The Cycle Vector Space Methods consist actually of two distinct phases. Phase one generates the fundamental set of cycles, and phase two the elementary cycles of the graph. Different algorithms for generating fundamental cycles differ in both storage and running time capabilities. In Section 3.4 we recommend Paton [25]; however, this need not be. As a result, the storage requirements showed slight
fluctuations in the Cycle Vector Space Methods.
Before proceeding to compare algorithms individually, and making recommendations, we would like to point out that though it is not possible to use a Cycle Vector Space algorithm on a directed graph, without being terribly inefficient, the transformation of an undirected graph to a directed graph by Ardon and Malik [1] provides another option for enumerating cycles, should we remain unsatisfied with the Cycle Vector Space Methods. The following subsection discusses how this can be done cleverly.

### 3.3. Conversion of an Undirected Graph to a Directed Graph for Circuit Enumeration

Having observed in Section 3.2 that the Search and Backtrack Methods are generally faster than the Vector Space Methods (or for whatever reasons), we might be interested in enumerating cycles using a circuit enumeration algorithm. To do so, we have first to convert the undirected graph to a directed graph. Representing each edge as two arcs with opposing directions is inefficient since an edge in the undirected graph corresponds to a 2-circuit in the equivalent directed graph. We have to do better than that.

A method by Ardon and Malik [1] has been proposed so that we maintain a one to one correspondence between cycles in the undirected graph $G(V, E)$ and circuits in the equivalent directed graph $G^{\prime}\left(V^{\prime}, E^{\prime}\right)$. Consider an undirected graph with no parallel edges or self loops. An edge $e_{i j}$ connects vertices $i$ to $j$. We denote this edge $e_{i j} \in E$ as ( $e_{j i}^{\prime}$ and $e_{i j}^{\prime}$ ) $\varepsilon E^{\prime}$. For a given cycle in $G$, there is a corresponding pair of directed circuits
in $G^{\prime}$. In other words, if there are e edges and cycles in $G$, there would be $e+2 c$ circuits in $G^{\prime}$. We could improve on this. If we remove an arc $e_{i j}^{\prime}$ from $G^{\prime}$, all circuits in $G^{\prime}$ containing arc $e_{i j}^{\prime}$ would be discarded. However, there now exists a one-to-one correspondence between the cycles in $G$ containing edge $e_{i j}=e_{j i}$ and circuits in $G^{\prime}$ containing $e_{j i}^{\prime}$. That is, by deleting $e_{i j}^{\prime}$, all cycles in $G$ containing $e_{j i}$ or $e_{i j}$ are equivalent to circuits in $G^{\prime}$ with $e_{j i}^{\prime}$. Once all cycles in $G$ containing $e_{i j}$ or $e_{j i}$ are found, the arc $e_{j i}^{\prime}$ is removed from $G$ to form a new subgraph. The remaining cycles in $G$ are obtained from this subgraph by the same procedure.

By repeating the procedure, a subset of circuits are found which corresponds to all the cycles in the undirected graph. Since e is finite, the number of subgraphs considered is also finite.

As an illustration, suppose we are interested in generating elementary cycles in an undirected graph using the Search and Backtrack Method discussed earlier. First, we transform $G$ to $G^{\prime}$, then pick a vertex $i$, and remove an arc incident to $i t, e_{j i}^{i}$. Proceed by building a path from $i$ one arc at a time starting with $e_{i j}^{1}$. Test for circuits by Tiernan's [34] algorithm outlined in AEGORITHM 2, until we backtrack to vertex $i$ : All cycles that contain edge $e_{i j}$ would have been enumerated. Remove arc $e_{i j}^{\prime}$ and proceed as before from vertex $j$. When no arcs remain in $G^{\prime}$, all cycles in $G$ would be enumerated. Since Tiernan's [34] algorithm finds circuits as a vertex sequence, all cycles are then represented as vertex sequence as well.

The use of any Search and Backtrack Methods represent only one way of enumerating cycles in $G$ from circuits in $G^{\prime}$. However, we could also
apply the converted graph to the Connection Matrix Methods. This is done by Ardon and Malik [1]. In fact, we could use any method for enumerating circuits on the converted graph.

In the subsection that follows, we shall recommend which algorithm to use for circuit enumeration and the rationale for the selection.

### 3.4 Recommendations

The selection of an algorithm to use for circuit enumeration should be approached with much discretion. In general, the number of cycles or circuits are enormous and happily, for most practical purposes, we are only interested in generating cycles or circuits with particular properties. For example, in a complete directed graph, where every vertex is connected by an arc, there are $n(n-1)$ arcs and the number of circuits of length $i$ is equal to $\binom{n}{i}(i-1)$ !. Thus, the total number of circuits is $\sum_{i=2}^{n}\binom{n}{i}(i-1)!$. But $\sum_{i=2}^{n}\binom{n}{i}(i-1)!\geq 2^{n}-n-1$; this means that the number of circuits grows with the exponential $2^{\text {n }}$ for such graphs.

Like most problems then, it is essential to first understand and "visualize" the nature of the problem. Though this is not always possible, it would lead to substantial savings if we have an idea of what the original graph looks like, and what we want to do with it (i.e., do we need to enumerate cycles or circuits?) Indeed, the selection of an algorithm rests on such criteria alone. For instance if we have a complete graph, to enumerate circuits in such a graph using any algorithm would be impossible for large graphs. Also, we might be able to focus our attention in a subgraph of the original graph and identify all circuits
in that subgraph without incurring huge penalty to the original problem.
First, we note that an algorithm which is superior theoretically is not necessarily superior in practice. For instance, the simplex method is still better for solving linear programming problems than Khachiyan's algorithm even though the latter is polynomially bounded and the former is not.

Also, suppose two algorithms $\alpha$ and $\alpha_{p}$ solves a problem $Q$, where $\alpha_{p}$ is polynomially bounded and $\alpha$ is not. Then there is some family of instances $\left\{Q_{n}\right\}$ of $Q$ such that the running time of $\alpha$ on $\left\{Q_{n}\right\}$ increases faster than the polynomial function of $n$, while the running time of $\alpha_{p}$ on $\left\{Q_{n}\right\}$ is bounded by some polynomial function $f(n)$. For "large enough" values of $n, \alpha_{p}$ is guaranteed to run faster on $Q n$ than $\alpha$, and as $n$ increases, the discrepancy increases rapidly. This result is known as an asymptotic result. But, how large is "large enough?" In lieu of this, it is possible that the polynomial algorithm $\alpha$ might be preferable to $\alpha_{p}$ for all instances of $Q$.

Another point we like to make here is that polynomial boundedness is pathologically contrived such that they represent the most perverse problem instances in order to measure an algorithm's performance. Besides, how likely are we in practice to encounter problem instances like those in $\left\{0_{n}\right\}$ that causes $\alpha$ to behave badly. 11

Even so, since most polynomial-time algorithm for problens of interest to Operations Research are both efficient in theory and practice, a comparison on that basis would be beneficial.

Algorithms are compared under three criterias: worst-case performance,
clarity and programmability.
For an undirected graph, the author recommends the cycle Vector Space Methods and in particular, the Welch-Gibbs ${ }^{12}$ algorithm (with Paton's [25] algorithm for finding the fundamental cycle set). Paton's [25] algorithm has been shown to out perform other algorithms for finding the fundamental cycle set. Although the Welch-Gibbs algorithm does not perform any better or worse than the others in the same category, it is clearly expounded and easily programmed. It has been programmed in Fortran and checked for approximately 100 graphs of at most 25 vertices each. On the CDC 6500, it took about two minutes to generate all cycles of 25 12-point cubic graphs with the input in the form of a vertex adjacency matrix for each graph. ${ }^{13}$

For a directed graph, Johnson's algorithm is recommended. Though there are three other algorithms that are polynomially bounded (if the number of circuits is polynomial), Johnson's [13] algorithm has been shown to converge asymptotically fastest. The notion of asymptotic convergence has been discussed previously. The program is written in Algol and the running time for a graph of 80 vertices and 240 circuits takes 4.46 seconds on IBM 370/168. The method of Johnson builds upon the algorithm of Tiernan discussed in Section 2.2, but exploits the added features and capabilities of the computer.

Since the search procedures are not all that complicated, one suggestion would be to write the program for the algorithm in Assembler language, which would improve on the running time. (The same suggestion applies to

Welch-Gibbs algorithn.)
Though the Connection Matrix Methods incur huge storage requirements and examination time (since each element must be scanned), it is theoretically elegant and for a graph that is not sparse, it might be easier to use since we are dealing only and strictly with matrix manipulation in this method. For this category, Ardon and Malik [1] is recommended. No results on computations are available, but the treatment of circuit generation is not as elaborate as the others. Kamae's method for instance requires that we keep every matrix until the algorithm stops. The number of matrices fortunately does not depend on the size of the graph.

We do not recomrend Cartwright and Gleason [3] unless a better way of extracting circuits from line graph is available.

One important point arises from the previous discussion. The algorithms listed in table 1 seem to perform, in general better the younger they were. This leads us to believe that theoretically, the problems with circuit enumeration have reached a mature level but computationally there remains room for improvement. The improvement in computer technology has enhanced our ability to tackle these problems more efficiently and indeed would alter the preference with which we select our algorithm.

Now that we have recommended one algorithm for each method, the question remains as to, "If I have to use one algorithm to enumerate cycles or circuits which should I use?"

First determine whether the graph is directed or undirected. If
directed, we recommend Johnson [18], otherwise Welch-Gibbs [14], with Paton [25] for finding the fundamental cycle set. The reason should be obvious from previous discussion. For generating all simple cycles or circuits we recommend our algorithm. For a planar directed graph, we still recommend Johnson instead of our algorithm since it remains difficult to obtain the dual from the primal.

Let us now summarize our approach to the problem of enumerating all elementary circuit or cycles in the graph:

The algorithms to solve for all elementary circuits or cycles in a graph should be used only as a last resort for solving problems that requires these circuits or cycies as feasible solutions since it is an expensive and slow process. If there are no other options, then we should first try to understand the structure of the problem in order to better visualize the graph we are working with. In other words, we should decide whether we could either reduce or reformulate the problem, or better still could solving the problem on a partial graph provide us with meaninful results?

If the graph we are working on is directed, use Johnson's algorithm, otherwise, use Welch-Gibbs (with Paton [25] for finding the fundamental cycle set).

The enumeration of all elementary cycles or circuits remains a costly and difficult problem. It would be better if we could concern ourselves with generating cycle or circuits with particular properties. This is the topic of the next section which is more relevant from a practical viewpoint.

## Section 4

## Applications of Circuit Enumeration

We now take a look not at the very expensive and time-consuming task of enumerating all the circuits or cycles, but at more restricted problems which find a particular subset of circuits in the graph and suggest some applications pertaining to these classes of circuits. In Section 2.5, we showed how all simple circuits or cycles could be obtained from the set of elementary circuits. It is apparent that any classification of elementary circuits with particular properties could be extended to simple circuits as well. The same applies for an undirected graph. For convenience, we shail work with elementary circuits.

### 4.1. Elementary Circuits with Particular Properties

All classifications must have properties of vertices, arcs, circuits or cost. (If in addition we associate a cost with each vertex or arc.) An elementary circuit having $n$ vertices must have $n$ arcs. Thus, finding circuits that pass through $n$ arcs is equivalent to finding circuits passing through $n$ vertices.

The restricted problems we have identified are:
P1. Find all elementary circuits that pass through $k$ specific vertices.

P2. Find all elementary circuits that pass through $k$ specific arcs.
P3. Find all elementary circuits that consist of $p$ (or less than $p$ ) $\operatorname{arcs}$ (vertices).

P4. Find all elementary circuits less than a given fixed cost (with costs associated with arcs and/or vertices).

P5. Find a set of q disjoint elementary circuits which passes through a set of $k$ vertices.

P6. Elementary circuits that are cheaper than at least $r$ other circuits.

These six problems we have identified are mutually exclusive. Many more problems would be formulated by considering combinations of these six problems, P1 to P6. For example, if we consider P3 and P4, we would define the problem of finding elementary circuits that consist of $p$ (or less than p) arcs (vertices) and less than a given fixed cost. Furthermore, some actual practical problems are easily associated with one or more restricted problems. In P6, if we set $r=1$, and solve P6 repeatedly, we would get the optimal or least cost circuit in the graph. Remember that $r$ could be set arbitrarily. P3 and P6 could define the travelling salesman problems, and finding the Hamiltonian circuit would be a special case of P3 for $p=n$. Another example is to find the optimal circuit in a doubly weighted graph
(i.e. two costs are associated with each arc), see Dantzig et al.,[9] and Lawler [21].

In case of simple circuits, we might be interested to identify a simple circuit that consists of elementary circuits of cardinality $\ell$, with a common vertex.

Having proposed some restricted problems which find a particular subset of circuits in the graph, we move on next to see how some practical problems could fit into our classifications.

### 4.2. Some Suggested Applications

For Pl, we might be interested in locating a distribution depot for serving a set of $k$ cities (where the demand for a certain good/service is higher) such that all cities are served by one cyclic route. The assumption is that the demand is known and the cities are connected. Pl provides us with all possible circuits (but not more than we need) and choices of the location of the depot. Since the cities are connected, we could partition the network into strong components, where the set of $k$ cities lies in one of these. We enumerate circuits contained in this strong component. If no such circuit exists, then the method would inform us. Otherwise, it would identify all such circuits.

In addition, we could extend P1 to include cyclic production scheduling and job scheduling. We denote the beginning of a production run by a vertex, where an arc connects the job, represented
as a vertex, that must be completed or required before another is undertaken. We would then like to find all circuits that passes through a fixed vertex (the beginning of the production process or job assignment). Tiernan's [34] algorithm solves this problem, but we need only to restrict ourselves to the first iteration of the algorithms; namely, generating circuits that passes through vertex 1 where vertex 1 is the fixed starting vertex. (See Section 2.2.)

For P2, we might select the set of arcs with least penalty (i.e. congestion, tolls or length). Our problem would be to dispath vehicles from a depot, through these streets, such that they return to the depot upon completion of the job. Note that we have imposed a somewhat stringent condition that the vehicle should return to the depot. To solve P2, we transform P2 to P1 by finding the "line graph" associated with the original graph and represent the $k$ specific arcs as $k$ specific vertices, then solve it as $P 1$.

P3 could be solved more efficiently using the Connection Matrix Method or Directed Graph Transformation Method, since it generates all circuits of a given cardinality simultaneously. A simple scheduling problem might insist that we do not visit more than $p$ cities at a time. For example, we might be interested in scheduling buses so that they do not have more than $p$ stops. Other constraints might be included like the total trip length but this will be discussed later. Another interesting problem involves finding Hamiltonian circuits. This is discussed in detail in Appendix B (also included are Eulerian circuits).

An interesting extension to P3 is P4, where the total cost of a circuit is constrained to be less than a given time, or total trip length or total cost of production. If we assign weights to all arcs in the graph where weights can be negative (for example, if cost is a positive factor, then profit would be negative and vice-versa), the problem becomes, given a set of schedules or production strategies, find the schedules or strategies which do not exceed a certain time bound or do not exceed a certain variable cost. The algorithm for solving this P4 where arc costs are non negative is given in ALGORITHM 5, which is a modification of Tiernan's algorithm. We denote the fixed cost as $Q$. If some arc costs are negative, we suggest two approaches depending on the number of negative cost arcs:

Al. Divide the set of vertices into two disjoint sets. One set is the vertices which have negative cost arcs incident to them. Let this set contain $n^{\prime}$ elements, and the other set of vertices with non negative cost arcs incident contain $n^{\prime \prime}$ elements. Note that $n=n^{\prime}+n^{\prime \prime}$. Label the vertices from the first set $1,2, \ldots, n^{\prime}$ and the vertices in the latter set $n^{\prime}+1, n^{\prime}+2, \ldots, n$. Solve the first $n^{\prime}$ set of vertices using Tiernan's algorithm to obtain all the circuits. Note also that we need to use Tiernan's algorithm only until the vertex $n^{\prime}$ is updated or incremented in $B 6$.
(see ALGORITHMM2). No circuits formed after that would contain vertices 1 to $n '$ and its incident arcs (i.e. no negative cost arcs would be considered again). Discard any circuits that were found which exceeds cost $Q$. Using the modified algorithm in Algorithm 5, we continue with finding circuits which fall within the allowable cost. Observe that since the subgraph considered in the latter problem has no negative cost arcs, and once the path cost exceeds the fixed cost, we need not proceed further to build circuit. This approach is suitable if we have a small set of negative cost arcs, i.e., if $n^{\prime}$ is small.

A2. If most of the arc costs are negative, we propose a second approach. First, we find the arc with the least cost, say - $c_{i j}^{*}$. We add an additional cost $c_{i j}^{*}$ to all arcs. Then whenever an arc is extended in the path, we test to see if the total cost of the path is less than $Q+m c_{i j}^{*}$ where $m$ is the cardinality of the path (or circuit). The modification to Tiernan's algorithm has to include the above cost test and an array that keeps track of $m$, the cardinality of the path (i.e. everytime we backtrack, $m+m-1)$. In this case though, we enumerate only circuits that fall below cost $Q$.

One example of a problem with negative cost arcs is the scheduling of flights where some flights are profitable, i.e. with negative cost. This happens whenever there is a high demand from point $A$ to $B$ but not

ALGORITHM 5: Modified Tiernan's Algorithm - An algorithm for enumerating all elementary circuits that does not exceed cost 0 . (All edge cost are assumed to be positive.)

B1. Initialize
Read N, G, and C
$P+0$
$\mathrm{H} \leftarrow \mathrm{O}$
$k+1$
$P(1)+1$
$T+0$

B2. Path extension
Search $G(P(k), j)$ for $j=1,2, \ldots N$ such that the following four conditions are satisfied:

1. $G(P(k), j)>P(1)$
2. $G(P(k), j) \notin P$
3. $G(P(k), j) \notin H(P(k), m), \quad m=1,2, \ldots N$
4. $T+C(P(k), j)<Q$ If this $j$ is found, extend the path, $T \leftarrow T+\dot{C}(P(k), j)$ $k \leftarrow k+1$ $P(k) \leftarrow G(P(k-1), j)$ go to $B 2$. If no $j$ meets the above conditions, the path cannot be extended.

B3. Circuit confirmation
If $P(1) \notin G(P(k, j), j=1,2, \ldots N$ or $D=T+C(P(k), P())>Q$, then no circuit has been formed, go to $B 4$.

Otherwise a circuit is reported,
Print $P$, D.

B4. Vertex closure
If $k=1$, then all of the circuits containing vertex $P(1)$ has been considered,
go to $B 5$.
Otherwise,
$H(P(k), m) \leftarrow 0, \quad m=1,2, \ldots N$
For $m$ such that $H(P(k)-1), m)$ is the leftmost zero in the $P(k-1)$ - the row of $H$,
$H(P(k-1), m) \leftarrow P(k)$
$P(k) \leftarrow 0$
$T \leftarrow T-1$
$k+k-1$
go to $B 2$.

```
-99-
```

B5. Advance initial vertex If $P(1)=N$ then go to $B 6$.
otherwise,
$P(1)+P(1)+1$
$k+1$
$H \leftarrow 0$
go to $B 2$.

B6. Terminate
from $B$ to $A$. We would like to schedule flight routings that fall within a certain operating cost. Perhaps this example is not complete since the requirement that an aircraft returns to its homebase is not as stringent. In the hub and spoke network structure though, this requirement becomes more reasonable.

Instead of finding a single circuit that passes through $k$ vertices, P5 provides us with q disjoint elementary circuits, which passes through $k$ vertices. If we have $q$ vehicles of different capacities and/or specifications, we could dispatch each vehicle to serve each circuit. This is a deviation from finding the single least cost elementary circuit in the graph (TSP). In fact, it might be more efficient and meaningful to serve several independent disjoint tours instead of one single tour which could be too large (in terms of cardinality). Besides, we might have more than one vehicle (or server) at our disposal. We could easily identify disjoint circuits since they will never share any vertex in common. In addition, we could find one circuit that contains all $k$ vertices.

Finally, P6 provides an order of the cost of each circuit. If we let $r=1$, and perform P6 repeatedly, we get an ordering of circuits from most expensive to cheapest. This problem is of interest to us in the same way the $k$-shortest path is for shortest path problems. It allows us to settle for next, or next to next, etc., best circuit and know how far away from the optimal we are. The reason for selecting the second cheapest, instead of the cheapest circuit is often a
judgemental one. Whereas the $k$-shortest path problem is solved, the corresponding problem for circuits has not been attempted.

Combining restricted problems also define interesting areas of applications.

Let us consider a simple problem which results from combining Pl and P5. Suppose we are given an airline schedule map, and we try to determine how to schedule a crew such that they return to have base after a certain time period not exceeding $Q$ hours. This problem is analogous to scheduling of aircraft for maintenance at home base within a time period. One problem then is to find all circuits that fall within this constraint. But first let us understand what a schedule map is.

A particular schedule map is shown in fig. 4.1. The vertex corresponding to the vertical axis are time vertices at a given city (represented as vertical axis). The arcs connecting cities are called service arcs. Ground arcs connect one time instant at a given city to another time instant at the same city. Observe too, that in our particular schedule map, only the home base, which can be any city, has an overnight arc. For purpose of illustration, let $A$ be the home base. If we are interested in finding circuits that includes the home base and that do not exceed 0 hours, then we should extend the schedule map such that the vertical axis of the home base equals 0 hours. We then use the modified Tiernan's algorithm (Algorithm 5) to generate all circuits that fall within this time limit Q. If we denote our home base as vertex 1 , then we only need to find circuits that pass through vertex 1 only (i.e. no "advance vertex" is necessary).

## -102-

fig. 4.1 Schedule Map


Source : Simpson [30]

In the case where there are restrictions on routes or precedence relationship for visiting one (or some) vertex before visiting another, a graph transformation involving vertex splitting should be done prior to carrying out the algorithm. Vertex cost could also be represented on the arc between the split vertex.

The enumeration of all circuit and cycles have also been used to solve subproblems. For example, the airline crew scheduling problem uses the set of rotations as inputs. The set of rotations is obtained from the set of elementary cycles. Another example is the subtours in a tanker routing problem where the set of circuits represent the feasible set for selecting the cheapest tour. 14

## Section 5

Summary

We have shown in section 2 how to enumerate all elementary cycles or circuits from a graph. We have also shown how to obtain all simple cycles or circuits from a given set of elementary cycles or circuits. In addition, an approach using the dual graph to find all elementary circuits in a directed planar graph is introduced in section 2.6.

Next, we compared the running time and storage requirements of most cycle and circuit enumeration algorithms in table 1 . We then proceeded to make recommendations in section 3.4 based on these computational results.

However, we have seen that even though, theoretically, we can solve the circuit enumeration problem, it remains as one of those problems which requires exponential time to solve. For instance, if we are trying to find all the elementary cycles in the graph, given that the graph contains 60 fundamental cycles; and that each operation requires 1 micro second to compute, then to exhaustively consider all possible combinations of fundamental cycles would require $2^{60}-60-1$ micro seconds, which is about 366 centuries! Other algorithms are polynomially bounded, but only if we know a priori that the number of circuits is bounded. This is comforting, but knowing the number of
circuits in a graph is not always possible. No one seems to have an algorithm to do this.

In any case, if we need to find all elementary circuits or cycles using any of the algorithms referred to in section 2, then we recommend that the graph is first edited and reduced following the rules listed in section 3.1. This would save us much computational time, or indicate that the problem is too large for us to even try solving.

Where do we go from here?
We have isolated some circuit problems in Section 4.1 and suggested applications in Section 4.2. Though these problems could be solved using existing algorithms, and modifications, there are still room for improvements. We recommend developing algorithms for problems listed in Sections 4.1 and 4.2 and try to improve on computational efficiencies.

In addition, we might also try to find a subset of all cycles or circuits (e.g. the fundamental set of cycles) in polynomial or pseudo-polynomial time, then later to use this set as a surrogate for all the cycles or circuits in the graph for further analysis if needed. (Note that the subset of cycles provided by the fundamental set might not be satisfactory for further analysis.) One other example of finding subsets of all circuits would be to find all the circuits from selected strong components that are smaller than a given size.

Finally, it would be interesting to be able to simply count the number of elementary cycles or circuits in a graph efficiently. Having this knowledge would allow us to use Johnson's [18] algorithm, which
is polynomial to the number of circuits in the graph with more confidence.

Though application of most algorithms are constrained by the size of the problem, the ability to handle bigger and bigger problems expands with the continuous improvement in the capabilities of the computer and software as time goes on. Fortunately, problems do not get larger and larger with time. In this sense, we continue to move towards being able to solve practical problems which require cycle or circuit enumeration.

## Footnotes

${ }^{1}$ For the proof, the reader is referred to C.L. Liu [22].
${ }^{2}$ For a given spanning tree, the set of the $n-1$ cutsets corresponding to the $n-1$ branches of the spanning tree is called the set of fundamental cutsets relative to the spanning tree.
${ }^{3}$ A non-simple path uses an arc more than once. We have referred to them as infinite paths in our definitions in Section 1.
${ }^{4}\left(G_{\text {}}\right)$ ij denotes the ij element of matrix $C_{1}$, i.e. brackets identify the elements of the matrix.
${ }^{5} A$ vertex sequence $P$ is a flower if there exists a vertex $j$ in $P$ such that the subsequence of $P$ consisting of all vertices and arcs up to $j$ is a path, the subsequence of $P$ consisting of all vertices and arcs behind $j$, including $j$ is a circuit containing more than one arc, and that these subsequences have no vertices except $j$ in common. The vertex $j$ is known as the "joint" vertex.
${ }^{6}$ Of course, if there are alot more circuits of higher cardinality, convergence might still be slow, but in this case, the other methods would not get around this problem any easier either.
${ }^{7}$ For a listing of the ways of graph representation, see Narsingh Deo [10], pages 270 to 273.
$8_{\text {Note: }} \quad V\left(P+S_{j}\right)=V(P)+V\left(S_{j}\right)$

$$
\text { In particular, } V\left(S_{1}+S_{3}\right)=V\left(S_{1}\right)+V\left(S_{3}\right) \text {. }
$$

${ }^{9}$ For more definitions on planar graphs, see Harary [B5]. We present definitions here that serve the discussion that follows. There are several equivalent definitions of planar graphs.
${ }^{10}$ We refer to elemetary cycles and circuits in this section unless otherwise specified.
${ }^{11}$ For further discussion on computational complexity, refer to [B7].
${ }^{12}$ Welch-Gibbs algorithm actually refers to Gibb's algorithm. But Gibb's algorithm is merely a modification of Welch's.

13
$3_{\text {Gibb }}$ uses Gotlieb and Corneil's algorithm for generating the cycle set and we can expect the running time to improve as well since capabilities in computers have improved also.

14 The tanker routing problem have also been solved as a shortest route problem. See Dantzig et al. [9] and Christofides [7].

## Appendix A

Method for Finding Strong Components (Christofides [7])

Let $R=\left[r_{i j}\right]$ be a reachability vertex where,

$$
r_{i j}= \begin{cases}1, & \text { if vertex } x_{j} \text { is reachable from vertex } x_{i} \\ 0, & \text { otherwise }\end{cases}
$$

and $Q=\left[q_{i j}\right]$ be a reaching matrix where,

$$
q_{i j}= \begin{cases}1, & \text { if vertex } x_{j} \text { can reach vertex } x_{i} \\ 0, & \text { otherwise }\end{cases}
$$

Using our usual definition of $\Gamma(\cdot)$ and $\Gamma^{-1}(\cdot)$, we define $R\left(x_{j}\right)$ as the set of vertices that can be reached from a given vertex $x_{i}$. Specifically

$$
R\left(x_{i}\right)=\left\{x_{i}\right\} \cup \Gamma\left(x_{i}\right) \cup \Gamma^{2}\left(x_{i}\right) \cup \ldots \Gamma^{p}\left(x_{i}\right)
$$

where $\Gamma^{p}\left(x_{j}\right)$ is the set of vertices which are reachable from vertex $x_{i}$ along a path with cardinality $P$.

We define $Q\left(x_{i}\right)$ similarly as the set of vertices which can reach vertex $x_{i}$. Therefore,

$$
Q\left(x_{j}\right)=\left\{x_{i}\right\} \cup r^{-1}\left(x_{i}\right) \cup \Gamma^{-2}\left(x_{i}\right) \cup \ldots \cup \Gamma^{-p}\left(x_{i}\right)
$$

where $\Gamma^{-2}\left(x_{j}\right)=r^{-1}\left(\Gamma^{-1}\left(x_{j}\right)\right)$ etc.
Observe that $Q=R^{t}$, the transpose of the reachability matrix. (Column $x_{i}$ of matrix $Q$ can be found by setting $a_{i j}=1$ if $x_{j} \varepsilon Q\left(x_{j}\right)$, and $\mathrm{a}_{\mathrm{ij}}=0$ otherwise.)

The set $R\left(x_{j}\right) \cap Q\left(x_{j}\right)$ is the set of vertices which are on at least one path going from $x_{i}$ to $x_{j}$. Thus the set $R\left(x_{j}\right) \cap Q\left(x_{j}\right)$ is that set of vertices that can reach and can be reached from $x_{i}$ and from each other. Thus $R\left(x_{j}\right) \cap Q\left(x_{j}\right)$ defines the vertices of the unique strong component of $G$ containing vertex $x_{i}$. These vertices are then removed from $G$ to obtain the subgraph $G^{\prime}=\left\langle G-R\left(x_{j}\right) \cap Q\left(x_{i}\right)\right\rangle$. We find another strong component containing $x_{j} \in G-R\left(x_{j}\right) \cap Q\left(x_{j}\right)$ in the same way. This process is continued until all vertices in the graph belongs to one component. See example in fig. A.l.

Alternatively, we could find the strong components of the graph in fig. A.l by taking the element by element multiplication of $R$ and Q, i.e. $R \otimes Q$. The row $x_{i}$ of the matrix $R Q$ ? contains 1 in those columns of $x_{j}$ only if $x_{i}$ and $x_{j}$ are mutually reachable and 0 otherwise. Thus, two vertices are in the same strong component if and only if their corresponding rows (or columns) are identical. The vertices whose
fig. A. 1


Therefore the strong component containing $x_{1}$ is $R\left(x_{1}\right) \cap Q\left(x_{1}\right)=$ $\left\{x_{1}, x_{2}, x_{5}, x_{6}\right\}$. Similarly, the strong components containing vertices $x_{7}$ is $\left\{x_{4}, x_{7}, x_{9}\right\}, x_{8}$ is $\left\{x_{8}, x_{10}\right\}, x_{11}$ is $\left\{x_{11}, x_{12}, x_{13}\right\}$ and $x_{3}$ is $\left\{x_{3}\right\}$.
corresponding rows contain an element of 1 under column $x_{j}$, then forms the vertex set of the strong componentt containing $x_{j}$. By rearranging rows and columns, we could obtain a block diagonal form of the matrix $R \otimes Q$ such that each block corresponds to a strong component of $G$ containing only l's, see fig. A. 2 .

fig. A. 2

## Appendix B

## Eulerian and Hamiltonian Circuits and Cycles

## Eulerian Cycles and Circuits

Given a nondirected (directed) connected $s$, graph $G$ an Eulerian cycle (circuit) is a simple cycle (circuit) which traverses every edge of $G$ once and only once. An s-graph differs from a graph in that there may be as many as $s$ edges connecting two vertices. We are interested then to know under what conditions Eulerian cycles exist.

Theorem 9: A connected, non directed s-graph $G$ contains an Eulerian cycle if and only if the number of vertices of odd degree is zero.

Proof:
Necessity: Any Eulerian cycle must have one edge leaving a vertex and a different edge arriving at the same vertex since edges can be traversed only once. Hence, if $G$ contains an Eulerian cycle, the degrees of all vertices must be even. Sufficiency: Let $G$ have vertices of even degrees only. Starting from a vertex $v_{i}$ we build a path comprising of edges that have not been previously used, until we return to vertex $v_{i}$ again. If all edges have been used, then we would have formed an Eulerian cycle. Otherwise let $C^{\prime}$ denote the cycle we have first formed. Since $G$ is connected, there is at least one vertex $v_{j} \& C_{1}$ where $v_{j}$ is ther terminal or initial vertex of some edge, the subgraph obtained by removing $C_{1}$ from $G$ is
a connected graph where the vertices have even degrees, since $C_{f}$ uses only an even number of edges incident to its vertices. Another cycle can be generated using the same procedure as above starting from $v_{j}$ on the subgraph. If all edges are used then let us denote the new cycle by $C_{2}$. A simple cycle $C_{1} \cup C_{2}$ denotes an Eulerian cycle having a common vertex at $v_{j}$.

If some edges are left then we find $v_{k} \varepsilon C_{1} \cup C_{2}$ such that $v_{k}$ is the terminal or initial vertex of an edge and repeat the process. We do this until all edges are considered. The union of all the cycles formed in this way corresponds to our Eulerian cycle.

An important consideration is that $G$ is connected. If not then we would incur components of the graph which are not connected and thus no Eulerian cycle can be formed that includes all the edges.

Collorary: A connected directed s graph G contains an Eulerian circuit if and only if the indegree of a vertex is equal to the outdegree of the same vertex for all vertices in the graph.

If we represent an undirected graph by an adjacency matrix $A=\left[\left(a_{i j}\right)\right]$ where $\left(a_{i j}\right)$ is the number of edges from $i$ to $j$, if edges ( $i, j$ ) exist and 0 otherwise, the sum of the rows and columns of this matrix would tell us the in degree and out degree of each vertex, respectively. The sum of the $i^{\text {th }}$ row and $i^{\text {th }}$ column would denote the degree of vertex $i$.

The method to obtain an Eulerian circuit is now explained - very simple:

Start from any vertex $x_{i}$ and select an edge to traverse such that if deleted, the graph does not become two unconnected components.

## Hamiltonian Cycles and Circuits

A Hamiltonian cycle (circuit) is an elementary cycle (circuit) that contains all the vertices in the graph. Although the problem resembles that of finding Eulerian cycles (circuits), it is very different and only partial results for special classes of graphs exist. Some special results are listed here for interest:

1. For a complete graph, where each vertex is connected to every other vertices, there are an enormous number of Hamiltonian cycles (circuits).
2. No bipartite graph having odd number of vertices possesses a Hamiltonian cycle (circuit). A bipartite graph $G(N, A)$ is one where we could partition the set of $N$ into $N_{1}, N_{2}$ such that $N_{1} \cup N_{2}=N$ and $N_{1} \cap N_{2}=\phi$ and no edges connect vertices belonging to the same set of vertices, i.e. for (i,j) $\varepsilon A$, i $\varepsilon N_{i}, j \varepsilon N_{2}$ or i $\varepsilon N_{2}, j=N_{1}$. From this definition, we know that every elementary cycle in a bipartite graph has an even number of edges and hence is incident to an even number of vertices.
3. By definition of strong connectivity, if a Hamiltonian cycle (circuit) exists, then the graph is strongly connected. The reverse is not true. If two strong circuits exist, then Hamiltonian circuit cannot exist.

Given an undirected graph, a Hamiltonian cycle might or might not exist. For the case of directed graphs we would expect the existence of a Hamiltonian circuit to be rarer since orientation of edges also needs to be taken into account. If we assign an edge cost of one unit to every edge in the graph, then the elementary cycle (circuit) whose cost is $n$ would constitute a Hamiltonian cycle (circuit) i.e., if there are $n$ vertices in the graph, then there must be $n$ edges forming the Hamiltonian cycle (circuit). Using any of the methods discussed in Section 2, we would be able to enumerate the Hamiltonian cycles (circuits) if any exist. However, this would be rather tedious.

Thus far, two methods have been proposed that provide some improvements over the enumerative methods discussed in Section 2. These could be categorized under algebraic and enumerative procedures. These methods determine whether any Hamiltonian circuits exist and if so, to enumerate them. The algebraic method is based on the work by Yau [37], Danielson [8] and Dhawan [17] and involves the generation of all elementary paths by successive matrix manipulation. As such, it incurs much storage since it would have to store all paths that might conceivably form part of all Hamiltonian circuits.

The enumerative procedure considers one path at a time, which is continuously extended until such time as: either a Hamiltonian circuit is formed, or it becomes apparent that this path will not lead to a Hamiltonian circuit. The path is then modified to ensure that all possibilities will be included and the search continues. This procedure uses less storage and finds Hamiltonian circuits one at a
time (as opposed to the first method which attempts to find all Hamiltonian circuits at once). This method was suggested by Roberts and Flores [29].

## Method A: Algebraic Method

Define $B=[b(i, j)]$ as an $n \times n$ matrix where $b(i, j)=j$ if arc ( $i, j$ ) exists and zero otherwise. We define the internal vertex product of a path as the sequence of vertices of the path exsluding the initial and terminal vertices. We next define $B_{p}=\left[b_{\ell}(i, j)\right]$ as an $n \times n$ matrix where $b_{\ell}(i, j)$ is the sum of the internal vertex products of all elementary paths of length $\ell$ from $i$ to $j$ where $i \neq j$. Assume $b_{\ell}(i, j)=0$ for all $i$ and $A$ as the adjacency matrix. The matrix multiplication $B \cdot B_{\ell}=B_{\ell+1}^{\prime}=\left[b_{\ell+1}(s, t)\right]$, where $B_{\ell+1}^{\prime}(s, t)=\sum_{k} b(s, k) \cdot b_{\ell}(k, t)$. $B_{\ell+\rceil}(s, t)$ then is the sum of the inner products of all paths from $s$ to $t$ of length $\ell+1$. Since $b_{\ell}(k, t)$ represents all elementary paths of length $\ell$ from $k$ to $t$, non elementary paths can appear only when the inner vertex product contains vertex $s$. Thus, if all terms containing $s$ are eliminated from $B_{\ell+1}^{\prime}(s, t)$, we would get a matrix $B_{\ell+1}=\left[b_{\ell+1}(s, t)\right]$ where if we set all diagonal elements to 0 , then $B_{\ell+1}(s, t)$ gives us all elementary paths of cardinality $\ell+1$ from $s$ to $t$. Having $B_{\ell+1}$ we continue to take $B \cdot B_{\ell+1}$ to get $B_{\ell+2}$ after the proper reduction, etc., until a matrix $B_{n-1}$ is generated. This matrix gives us all Hamiltonian paths between pairs of vertices. We could then identify Hamiltonian circuits from the paths of $B_{n-1}$ since we need only to see if an arc
connects the terminal vertex to the initial vertex. Otherwise, we could take $B \cdot B_{n-1}$ to identify all Hamiltonian circuits from the non zero diagonal elements. An example is provided in Appendix Bl.

A slight modification of the above method reduces both the storage and running time. Since we are interested only in Hamiltonian circuits, we could obtain this from the diagonal elements of the matrix $B \cdot B_{n-1}$. We note here that since only the element $B_{n}(1,1)$ is needed, it is necessary only to store the first column of $B_{\ell}$, and eliminating non elementary elements we could obtain the first column of $B_{\ell+1}$. Continuing, we could obtain the first column of $B_{r_{1} 1}$. The matrix multiplication $B$ and the first column of $B_{n-1}$, would give us the required Hamiltonian circuit if any exists.

Method B: Enumerative Procedure
We shall first present the algorithm of Roberts and Flores and then show how we could make improvements for graphs with more than 20 vertices.

Define a $k \times n$ matrix $M=\left[m_{i j}\right]$ where $m_{i j}$ is the $i^{\text {th }}$ vertex ( $x_{q}$ say) for which an $\operatorname{arc}\left(x_{j}, x_{q}\right)$ exists in a graph $G(V, \Gamma)$. The vertices $x_{q} \varepsilon \Gamma\left(x_{j}\right)$ are compacted to form entries in the $j^{\text {th }}$ column of the $M$ matrix. The number of rows $k$ corresponds to the maximum outdegree of a vertex. See Appendix B2.

Choose an initial vertex $x_{1} . x_{1}$ is the first entry in set $S$ which represents a vertex sequence of elementary path. Build the path by adding the first element (a say) in the $x_{1}$ column to $S$. Proceed by
extending the first feasible vertex in the $a^{\text {th }}$ column to $S$. A vertex is feasible if it has not already been in $S$. Continue to extend the path until no further extension is possible. Let $S=\left\{x_{1}, a, b, c, \ldots, x_{r-1}, x_{r}\right\}$. Then either no vertex in column $x_{r}$ is feasible or the path has cardinality $n-1$. In the latter case, if there is an $\operatorname{arc}\left(x_{r}, x_{p}\right)$ then a Hamiltonian circuit is identified. Otherwise, no Hamiltonian circuit can be formed using this path.

In any case, we backtrack. Backtracking involves removing $x_{r}$ from $S$ and adding the first feasible vertex below $x_{r}$ to $S$ in column $x_{r-1}$. If no feasible vertex is formed, we backtrack further. The algorithm terminates when $x_{1}$ is the only element in $S$ and backtracking leaves S empty. All Hamiltonian circuits in the graph have been identified. Consider the simple example in Appendix B2.

In our path extension two conditions would enable us to build a path more effectively. Let us assume that at some point during the search the path is given by $S=\left\{x_{1}, x_{2}, \ldots, x_{r}\right\}$, and the next vertex to be included is $x^{\star} \notin S$. Let the original directed graph be $G(V, \Gamma)$, and $x$ be a vertex of the subgraph obtained by deleting all the vertices in $S$ from $V$.

1. If there exists a vertex $x \in V-S$ such that $x \in \Gamma\left(x_{r}\right)$, i.e. $\left(x_{r}, x\right)$ exists, and $\Gamma^{-1}(x) \subseteq S$, i.e. the set of all vertices with arcs directed towards $x$ are contained in $S$, then the extension vertex is $x$, i.e. next $\operatorname{arc}$ is $\left(x_{r}, x\right)$ where $x=x^{*}$. If a different vertex is chosen, then any path formed subsequently would not include $x$ and therefore cannot be a Hamiltonian
path. See fig. B.l.
2. If there exists a vertex $x \in V-S$ such that, $x \notin \Gamma^{-1}\left(x_{1}\right)$ i.e. $\operatorname{arc}\left(x_{1}, x\right)$ does not exist, and $\Gamma(x) \subset S \cup\left\{x^{\star}\right\}$, for some other vertex $x^{\star}$, i.e. set of vertices with arcs directed from $x$ must be contained in $S$ or in $\left\{x^{\star}\right\}$, then $x^{\star}$ cannot be included as the next vertex in the path since no paths between $x$ and $x_{1}$ would be possible. Another arc other than ( $x_{r}, x^{*}$ ) must be considered. (See fig. B.2.)

fig. B. 1

fig. B. 2

In the example of Appendix B2, condition 1 arises at step 2 when $S=\{a, b\}$. For vertex $e, \Gamma^{-1}(e)=\{b\} \subset S$ so that e must be the next vertex. Steps 3 to 8 could be skipped.

Given a weighted graph with cost associated with the arcs, the general traveling salesman problem attempts to find the minimum cost Hamiltonian cycle (circuit). For a discussion of the Traveling Salesman problem the reader is referred to Christofides [7].

Although the improved version of Robert and Flores [29] procedure would reduce running time by half for a randomly generated graph of more than 20 vertices, another method is available for a large scale graph which is superior. It reduces the graph by searching for paths that cannot possibly belong to a Hamiltonian cycle or circuit. The set of paths $S$ considered in Roberts and Flores [29] does not adequately consider the effects of path extension $S$ on the remaining portions of the graph. A detailed account of this reduction on the graph so that Hamiltonian cycles (circuits) would be more effectively searched is found in Christofides [7] and is called the Multi Path method. Although the methods discussed thus far apply to directed graphs, extension to the undirected case is also possible.

Relationship between Eulerian and Hamiltonian Cycles (Harary [B5])
For an undirected graph, the definitions of Eulerian and Hamiltonian cycles permit us to establish a relationship between them. We define a line graph of $G_{\ell}$ of $G$ as a graph having as many vertices as there are edges in the graph G. An edge between two vertices of $G_{\beta}$ exists if and only if the edges of $G$ corresponding to these two vertices are adjacent (i.e. incident to the same vertex in G).

Consider the graph $G$ and its corresponding line graph $G_{\ell}$ in fig. B.3.
fig. B. 3


Note: Vertices in $G$ and $G_{j}$, have even degree. (Eulerian cycle exists) $(1,2,5,4,8,3,6,7,1)$ is a Hamiltonian cycle in $G_{i}$.

It can be easily shown that: -

1. If $G$ has a Eulerian cycle, the $G$ has both Eulerian and Hamiltonian cycles.
2. If $G$ has a Hamiltonian cycle, then $G_{\hat{\lambda}}$ has a Hamiltonian cycle. The converse of both statements are not true.

## Appendix Bl

Enumeration of Hamiltonian Circuits Using the Algebraic Approach: An Example (Christofides [7])

Given


$A=$|  | $a$ | $b$ | $c$ | $d$ | $e$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $a$ | 0 | 1 | 0 | 0 | 0 |
| $b$ | 1 | 0 | 1 | 0 | 0 |
| $c$ | 0 | 0 | 0 | 0 | 1 |
| $d$ | 1 | 0 | 1 | 0 | 0 |
| $e$ | 0 | 0 | 0 | 1 | 0 |

Let $B_{1}=A$


$B_{4}^{\prime}=B \cdot B_{3}=$|  | $a$ | $b$ | $c$ | $d$ | $e$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $a$ | 0 | 0 | 0 | $b c e$ | 0 |
| $b$ | ced | 0 | 0 | 0 | $\frac{a b c}{}$ |$\quad$| 4-paths from $i$ to $j$ via |
| :--- |
| $c$ | $0 \quad$ is similar to $B_{4}^{\prime}$ with

$B_{4}$ contains all the elementary 4-paths from $i$ to $j$. A Hamiltonian path is given by $b_{4}(1,4)$, which is abced. Since from $B, b(4,1)=a$, i.e., there is an arc from $d$ to $a$, abceda is the required Hamiltonian circuit.

## Appendix B2

Enumeration of Hamiltonian Circuit Using Enumerative Procedure: An Example (Christofides [7])

Given:


$$
M=\begin{gathered}
1 \\
3
\end{gathered}\left[\begin{array}{llllll}
a & b & c & d & e & f \\
b & c & a & c & c & a \\
& e & d & f & d & b \\
& & & & & c
\end{array}\right]
$$

$k$ is equal to 3 corresponding to the maximum outdegree of vertex f.

The search to find all Hamiltonian circuits now proceeds as follows: (Vertex a is taken as the starting vertex.)

Set S Notes

1. a : Add first feasible vertex in column a (i.e. vertex b)
2. $a, b:$ Add first feasible vertex in column $b$ (i.e. vertex $c$ )
3. $a, b, c \quad:$ First vertex (a) in column $c$ is infeasible (a $\varepsilon$ S), add next vertex in column c (i.e. vertex d)
4. $a, b, c, d \quad:$ Add vertex $f$
5. $a, b, c, d, f$ : No feasible vertex in column fexists. Backtrack. Remove $f$ from $S$. Close $f$ in column $d$.
6. $a, b, c, d$ : No feasible vertex in column d exists. Backtrack. Remove $d$ from $S$. Close $d$ in column $c$.
7. $a, b, c \quad$ Similar to case above. Backtrack. Remove $c$ from S. Close c in column b.
8. $\mathrm{a}, \mathrm{b}$ : Add vertex e. Open all vertices.
9. $a, b, e \quad$ : Add vertex $c$
10. a,b,e,c: Add vertex d
11. a,b,e,c,d: Add vertex f
12. $a, b, e, c, d, f$ : Hamiltonian path. Hamiltonian circuit can be closed by arc(f,a). Backtrack
13. a,b,e,c,d : Backtrack
14. a,b,e,c : Backtrack
15. a,b,e: Add vertex d
16. a,b,e,d: Add vertex f
17. a,b,e,d,f: Add vertex c
18. $a, b, e, d, f, c$ : Hamiltonian path. Circuit closed by arc(c,a). Backtrack c is closed.

## Set S Notes

19. a,b,e,d,f: Backtrack $f$ is closed.
20. a,b,e,d : Backtrack $d$ is closed.
21. $a, b, e$ : Backtrack $e$ is closed.
22. $a, b \quad$ : Backtrack $b$ is closed.
23. a : Backtrack
24. $\emptyset \quad$ End of search.

## References

[1] M.T. Ardon and N.R. Malik, A recursive algorithm for generating circuits and related subgraphs, 5th Asilomar Conf. on circuits and systems 5, Pacific Grove, California, Nov. 1971, pp. 279-284.
[2] A.T. Berztiss, Data Structures: Theory and Practice, Academic Press, NY, 197T.
[3] D. Cartwright and T.C. Gleason, The number of paths and cycles in a digraph, Psychometrika, 31 (1966), pp. 179-199.
[4] S.G. Chan and W.T. Chang, On the determination of dicircuits and dipaths. Proc. 2nd Hawaii Internat. Conf. System Sci., Honolulu, Hawaii 1969, pp. 155-158.
[5] J.P. Char, Master circuit matrix, Proc. IEE (London) 115 (1968), pp. 762-770.
[6] N. Christofides, Graph Theory: An Algorithmic Approach, Academic Press, 1975.
[7] S.M. Chase, Analysis of algorithms for finding all spanning trees of a graph, Ph.D. thesis, Rep. 401, Dept. of Computer Sci., U. of Illinois, Urbana, Illinois, 1970.
[8] G.H. Danielson, On finding the simple paths and circuits in a graph, IEEE Trans. Circuit Theory, CT-15 (1968), pp. 294.
[9] G.B. Dantzig, W.O. Blattner and M.R. Rao, Finding a cycle in a graph with minimum cost to time ratio with applications to ship routing problem, in Int. Symp. on Theory of Graphs, Dunod, Paris, (1966), pp. 77.
[10] Narsingh Deo, Graph Theory with Applications to Engineering and Computer Science, Prentice Ha11, 1974.
[11] V. Dhawan, Hamiltonian circuit and related problems in graph theory, M.Sc. Report, Imperial College, London (1969).
[12] A. Ehrenfeucht, L. Fosdick and L. Osterweil, An algorithm for finding the elementary circuits of a directed graph, Tech. Rep. CU-CS-024-73, Dept. of Computer Sci., U. of Colorado, Boulder, 1973.
[13] R.W. Floyd, Nondeterminstic algorithms, JACM, 14 (1967), pp. 636-644.
[14] N.E. Gibbs, A cycle generation algorithm for finite undirected linear graphs, JACM 16 (1969), pp. 564-568.
[15] C.C. Gotlieb and Corniel, Algorithms for finding a fundamental set of cycles for an undirected linear graph, Comm. ACM 10 (1967), pp. 780-783.
[16] J.E. Hoftcroft and R.E. Tarjan, Efficient planarity testing, J ACM 21 (1974), pp. 549-558.
[17] H.T. Hsu and P.A. Honkanen, A fast minimal storage algorithm for determining all the elementary cycles of a graph, Computer Sci. Dept., Penn. State U., University Park, (1972).
[18] D.B. Johnson, Finding all the elementary circuits of a directed graph, SIAM J. Comp. 4 (1975), pp. 77-84.
[19] T. Kamae, A systematic method of finding all directed circuits and enumerating all directed paths, IEEE Trans. Circuit Theory, CT-14 2 (1967), pp. 166-171.
[20] J.W. Lapatra and B.R. Meyers, Algorithms for circuit enumeration, IEEE International Conv. Record, Part 1, 12 (1964), pp. 368-373.
[21] E.L. Lawler, Optimal cycle in doubly weighted graphs, in Int. Symp. on Theory of Graphs, Dunod, Paris (1966), p. 209.
[22] C.L. Liu, Introduction to Combinatorial Mathematics, McGraw-Hill, 1968.
[23] P. Mateti and N. Deo, On algorithm for enumerating all circuits of a graph, SIAM J. Comput., Vol. 5, No. 1, March 1976.
[24] L.M. Maxwell and G.B. Reed, Subgraph identification - Segs, circuits and paths, 8th Midwest Symp. on Circuit Theory, Colorado State U., Fort Collins, Colorado, June 1965, pp. 13-0-13-10.
[25] K. Paton, An algorithm for finding a fundamental set of cycles for an undirected linear graph, Comm. ACM 12 (1969), pp. 514-518.
[26] J. Ponstein, Self-avoiding paths and adjacency matrix of a graph, SIAM J. Appl. Math. 14 (1966), pp. 600-609.
[27] V.V.B. Rao and V.G.K. Murti, Enumeration of all circuits of a graph, Proc. IEEE 57 (1969), pp. 700-701.
[28] R.C. Read and R.E. Tarjan, Bounds on backtrack algorithms for listing cycles, paths and spanning trees, Networks: ERL Memo M433, Electronics Research Lab., U. of California Berkeley, 1973.
[29] S.M. Roberts and B. Flores, Systematic generation of Hamiltonian circuits, Comm. ACM 9 (1966), pp. 690-694.
[30] R.W. Simpson, Scheduling and routing models for airline systems. Report FTL-R68-3, Dept. Aeronautics and Astronautics, MIT, (1968).
[31] J.L. Szwarcfiter and P.E. Lauer, Finding the elementary cycles of a directed graph in $0(n+m)$ per cycle, No. 60, U. of Newcastle upon Tyne, England, May 1974.
[32] R. Tarjan, Enumeration of the elementary circuits of a directed graph, SIAM J Comp. 2 (1973), pp. 211-216.
[33] R. Tarjan, Depth-first search and linear graph algorithms, SIAM J. Computing 1 (1972), pp. 146-160.
[34] J.C. Tiernan, An efficient search algorithm to find the elementary circuits of a graph, Comm. ACM 13 (1970), pp. 722-726.
[35] H. Weinblatt, A new search algorithm for finding the simple cycles of a finite directed graph, JACM 19 (1972), pp. 43-56.
[36] J.T. Welch, A mechanical analysis of the cyclic structure of undirected linear grabhs, JACM 13 (1966), pp. 205-210.
[37] S.S. Yau, Generation of all Hamiltonian circuits, paths, and centers of a graph, and related problems, IEEE Trans. Circuit Theory, CT-14 (1967), pp. 79-81.

## Bibliography

[B1]. C. Berge, The Theory of Graphs and Its Applications, Methuen, Translated by A. Doig from original French edition, Dunod, 1962.
[B2] R.G. Busacker and T.L. Saaty, Finite Graphs and Networks: An Introduction with Applications, McGraw-Hill, 1965.
[B3] N. Christofides, Graph Theory: An Algorithmic Approach, Academic Press, London 1975.
[B4] N. Deo, Graph Theory with Applications to Engineering and Computer Science, Prentice-Hall, N.J. 1974.
[B5] F. Harary, Graph Theory, Addison-Wesley, Reading, MA, 1972.
[B6] C.L. Liu, Introduction to Combinatorial Mathematics, McGraw-Hill, 1968.
[B7] M.R. Garey and D.S. Johnson, Computers and Intractability: A Guide to the Theory of NP-completeness. San Francisco: W.H. Freeman \& Co., Publishers 1979.

