`ISRN Communications and NetworkingVolume 2012 (2012), Article ID 932456, 19 pageshttp://dx.doi.org/10.5402/2012/932456`
Review Article

## An Overview of Algorithms for Network Survivability

Faculty of Electrical Engineering, Mathematics and Computer Science, Delft University of Technology, P.O. Box 5031, 2600 GA Delft, The Netherlands

Received 4 September 2012; Accepted 25 September 2012

Academic Editors: H. Kubota and M. Listanti

Copyright © 2012 F. A. Kuipers. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

#### Abstract

Network survivability—the ability to maintain operation when one or a few network components fail—is indispensable for present-day networks. In this paper, we characterize three main components in establishing network survivability for an existing network, namely, (1) determining network connectivity, (2) augmenting the network, and (3) finding disjoint paths. We present a concise overview of network survivability algorithms, where we focus on presenting a few polynomial-time algorithms that could be implemented by practitioners and give references to more involved algorithms.

#### 1. Introduction

Given the present-day importance of communications systems and infrastructures in general, networks should be designed and operated in such a way that failures can be mitigated. Network nodes and/or links might for instance fail due to malicious attacks, natural disasters, unintentional cable cuts, planned maintenance, equipment malfunctioning, and so forth. Resilient, fault tolerant, survivable, reliable, robust, and dependable, are different terms that have been used by the networking community to capture the ability of a communications system to maintain operation when confronted with network failures. Unfortunately, the terminology has overlapping meanings or contains ambiguities, as pointed out by Al-Kuwaiti et al. [1]. In this paper, we will use the term survivable networks to refer to networks that, when a component fails, may “survive” by finding alternative paths that circumvent the failed component. Three ingredients are needed to reach survivability.(1) Network connectivity, that is, the network should be well connected (connectivity properties are discussed in Section 1.1).(2) Network augmentation, that is, new links may need to be added to increase the connectivity of a network.(3) Path protection, that is, a procedure to find alternative paths in case of failures.

These three ingredients will be explained in the following sections.

##### 1.1. Network Connectivity

A network is often represented as a graph , where is the set of nodes (which for instance represent routers) and is the set of links (which for instance represent optical fiber lines or radio channels). Links may be characterized by weights representing for instance their capacity, delay, length, cost, and/or failure probability. A graph is said to be connected if there exists a path between each pair of nodes in the graph, else the graph is said to be disconnected. In the context of survivability, the notion of connectivity may be further specified as -connectivity, where at least disjoint paths exist between each pair of nodes. Depending on whether these paths are node or link disjoint, we may discriminate between node and link connectivity. The link connectivity of a graph is the smallest number of links whose removal disconnects . Correspondingly, the node connectivity of a graph is the smallest number of nodes whose removal disconnects .

In 1927, Menger provided a theorem [2]—in German—that could be interpreted as follows.

Theorem 1 (Menger's theorem). The maximum number of link/node-disjoint paths between A and B is equal to the minimum number of links/nodes that would separate A and B.

Menger's theorem clearly relates to the link/node connectivity of a graph, in the sense that a link/node-connected graph has at least link/node-disjoint paths between any pair of nodes in the graph. The minimum number of links/nodes separating two nodes or sets of nodes is referred to as a minimum cut. In order to assess the link/node connectivity of a network, we therefore need to find its minimum cut.

A somewhat less intuitive notion of connectivity stems from the spectrum of the Laplacian matrix of a graph and is denoted as algebraic connectivity. The algebraic connectivity was introduced by Fiedler in 1973 [3] and is defined as follows.

Definition 2 (algebraic connectivity). The algebraic connectivity equals the value of the second smallest eigenvalue of , where is the Laplacian matrix , with an adjacency matrix with elements if there is a link between nodes and , else , and an diagonal matrix with the degree of node .

The algebraic connectivity has many interesting properties that characterize how strongly a graph is connected (e.g., see [4, 5]). Moreover, the multiplicity of the smallest eigenvalue (of value 0) of the Laplacian is equal to the number of components in the graph . Hence, if the algebraic connectivity is larger than 0, the network is connected, else the algebraic connectivity is 0, and the network is disconnected. We have that where is the minimum degree in the network. For ease of notation, when is not specified, we use , , , and .

Connectivity properties, may be less obvious when applied to multilayered networks [6, 7], like IP over WDM networks, where a 2-link-connected IP network operated on top of an optical WDM network, with multiple IP links sharing (e.g., groomed on) the same WDM link, could still be disconnected by a single-link failure at the optical layer.

In probabilistic networks, links and/or nodes are available with a certain probability , which is often computed as , with the mean time to failure of and the mean repair time of . Often the term network availability is used to denote the probability that the network is connected (e.g., see [8]). When the node probabilities are all one and all the link probabilities are independent and of equal value , then a reliability polynomial (a special case of the Tutte polynomial, e.g., see [9]) is a polynomial function in that gives the probability that the network remains connected after its links fail with probability .

##### 1.3. Path Protection

Network protocols like OSPF are deployed in the internet to obtain a correct view of the topology and in case of changes (like the failure of a link) to converge the routing towards the new (perturbed) situation. Unfortunately, this process is not fast, and applications may still face unacceptable disruptions in performance. In conjunction with MPLS, an MPLS fast reroute mechanism can be used that, as the name suggests, provides the ability to switch over in subsecond time from a failed primary path to an alternate (backup) path. This fast reroute mechanism is specified in RFC 4090 [13], May 2005, and has already been implemented by several vendors. The concept has also been extended to pure IP networks and is referred to as IP fast reroute [14]. RFC 4090 defines RSVP-TE extensions to establish backup label-switched path (LSP) tunnels for local repair of LSP tunnels. The backup path can either be configured to protect against a link or a node failure. Since the backup paths are precomputed, no time is lost in computing backup paths or performing signalling in the event of a failure. The fast reroute mechanism as described in RFC 4090 assumes that MPLS (primary and backup) paths are computed and explicitly routed by the network operator. Hence, there is a strong need for efficient algorithms to compute disjoint paths.

Depending on whether backup paths are computed before or after a failure of the primary path, survivability techniques can be broadly classified into restoration or protection techniques.(i) Protection scheme: protection is a proactive scheme, where backup paths are precomputed and reserved in advance. In 1 : 1 protection, traffic is rerouted along the backup path upon the failure of the primary path. In 1+1 protection, the data is duplicated and sent concurrently over the primary and backup paths.(ii) Restoration scheme: restoration is a reactive mechanism that handles a failure after it occurs. Thus, the backup path is not known a priori. Instead, a backup path is computed only after the failure in the primary path is sensed.

In general, protection has a shorter recovery time since the backup path is precomputed, but it is less efficient in terms of capacity utilization and less flexible. Restoration, on the other hand, provides increased flexibility and efficient resource utilization, but it may take a longer time for recovery, and there is no guarantee that a backup path will be found. As a compromise between the two schemes, Banner and Orda [15] considered designing a low-capacity backup network (using spare capacity or by installing new resources) that is fully provisioned to reroute traffic on the primary network in case of a failure. The backup network itself is not used to transport “primary” traffic. Backup networks with specific topological features have also been addressed in the literature, for instance protection [16] and preconfigured [17] cycles or redundant trees [18].

Depending on whether sharing of resources is allowed among backup paths, protection schemes can be of two types:(i) Dedicated protection: in this scheme, resources (e.g., links, wavelength channels, etc.) are not shared among backup paths and are exclusively reserved for a given path request.(ii) Shared protection: in this scheme, backup paths may share resources as long as their primary paths do not share links. In  :  protection, backup paths are used to protect primary paths. The shared scheme provides a better resource utilization; however, it is more complicated and requires more information, such as the shareability of each link.

In general, path protection requires less capacity than link protection, while shared protection requires less capacity than dedicated protection. However, path protection is more vulnerable to multiple link failures than link protection, and so is shared protection compared to dedicated protection.

##### 1.4. Paper Outline and Objective

The remainder of this paper is structured as follows. In Section 2, we give an overview of several methods for determining the connectivity properties of a network. In case a network is found to be insufficiently connected from a survivability perspective, links may have to be added to increase the connectivity. In Section 3, we list key results in network connectivity augmentation. Once a network is designed to withstand some failures, proper path protection/restoration schemes should be in place that can quickly defer traffic to alternate routes in case of a failure. In Section 4, we survey work on finding disjoint paths in a network. We conclude in Section 5.

Throughout the paper, the objective is not to list and explain all the relevant algorithms. Rather, we aim to briefly explain some fundamental concepts and some polynomial-time algorithms that could easily be deployed by practitioners or which can be (and have been) used as building blocks for more advanced algorithms, and to provide pointers to further reading.

#### 2. Determining Network Connectivity

In Section 1.1, we indicated that Menger's theorem implies that finding a minimum cut corresponds to finding the connectivity of a network. In this section, we will look further at finding cuts in a network.

Definition 3 (link (edge) cut). A link cut refers to a set of links whose removal separates the graph into two disjoint subgraphs, and where all links in the removed cut-set have an end-point in both subgraphs.

The two subgraphs need not be connected themselves.

Definition 4 (node (vertex) cut). A node cut refers to a set of nodes whose removal separates the graph into two disjoint subgraphs, and where all nodes in the removed cut-set have at least one adjacent link to both subgraphs.

Definition 5 (minimum link/node cut). A minimum cut is a cut whose cardinality is not larger than that of any other cut in the network.

Definitions for a cut also have a variant in which a source node and a terminating node need to be separated.

Definition 6 ( cut). An cut refers to a cut that separates two nodes and in the graph such that both belong to different subgraphs.

Often, when referring to a cut, a link cut is meant. In the remainder of this paper, we will use the same convention and only specify the type of cut for node cuts.

Definition 7 (maximum cut). A maximum cut is a cut whose cardinality is not exceeded by that of any other cut in the network.

Definition 8 (sparsest cut). The sparsest cut (sometimes also referred to as the (Cheeger) isoperimetric constant) is a cut for which the ratio of the number of links in the cut-set divided by the number of nodes in the smaller subgraph is not larger than that of any other cut in the network.

Finding a maximum or sparsest cut is a hard problem (the maximum-cut problem is APX-hard [20] and the sparsest-cut problem is NP-hard [21, 22]), but fortunately a minimum cut, and consequently the network's connectivity, can be computed in polynomial time as will be indicated below. The algebraic connectivity could be used to approximate the sparsest cut as [4, 21]. Dinh et al. [23] investigated the notion of pairwise connectivity (the number of connected pairs, which bears similarities to the sparsest-cut problem), and proved that finding the smallest set of nodes/links whose removal degrades the pairwise connectivity to certain degree is NP-complete.

In the celebrated paper from Ford and Fulkerson [24] (and independently by Elias et al. [25]) a maximum flow from a source to a terminal in a network, where the links have a given capacity, is shown to be equal to the minimum-weight - link cut in that network, where the weight of the cut is the sum of the capacities of the links in the cut-set; the so-called max-flow min-cut theorem. By using a max-flow algorithm and setting the capacity of all links to 1, one can therefore compute the minimum - link cut, or the minimum link cut when repeated over all possible - pairs. It is not our goal to overview all maximum-flow algorithms (an excellent discourse of the subject is presented in the book by Ahuja et al. [26]), but we will present Dinitz's algorithm, which can be used to determine the minimum - link cut in time. We will subsequently present the algorithm of Matula for determining the minimum link cut in time.

###### 2.1.1. Dinitz' Algorithm

Dinitz' algorithm, published in 1970 by Yefim Dinitz, was the first maximum-flow algorithm to run in polynomial time (contrary to the pseudopolynomial running time of the Ford-Fulkerson algorithm [24]). The algorithm is sometimes referred to as Dinic's or Dinits' algorithm, and also different variants are known. A historical perspective of the different variants is presented by Dinitz himself in [27]. In order to describe Dinitz' algorithm, as presented in Algorithm 1, some definitions are given.

Algorithm 1: Dinitz-Max-Flow .

Definition 9. The residual capacity of a link is interpreted in two directions as follows: where the flow over a link cannot exceed the capacity of that link.

Definition 10. The residual graph of is the graph in which a directed link exists if .

Definition 11. A blocking flow is an - flow such that any other - flow would have to traverse a link already saturated by .

A blocking flow could be obtained by repeatedly finding (via Depth-First-Search [28]) an augmenting flow along an - path (or pruning the path from the graph in unit-capacity networks). In unit-capacity networks, the algorithm runs in , which therefore also is the time complexity to determine a minimum - link cut with Dinitz' algorithm (for unit node capacities, a complexity of can be obtained [29]).

For further reference, in Table 1, we present some key achievements in computing minimum - link cuts.

Table 1: Related work on computing minimum s-t link cuts.

###### 2.1.2. Matula's Algorithm

In this section, we describe the algorithm from Matula [43] for determining the link connectivity of an undirected network. Matula's algorithm is based on the following lemma.

Lemma 12. Let be a graph with a minimum cut of size that partitions the graph into two subgraphs and , then any dominating set of contains nodes of both and (a dominating set is a subset of the nodes in , such that every node in is either in or adjacent to a node in ).

Proof. For subgraph , , holds that the sum of the nodal degrees in is bounded by The upper bound occurs if all nodes in are connected to each other and some of the nodes have a link that is part of the cut-set. The lower bound stems from each node having a degree larger or equal than the minimum degree . From the bounds in (3), we can derive that Since is assumed, and consequently both terms on the left-hand side cannot be smaller than 1. Hence, , which means that, under the assumption that , there is at least one node in that does not have a neighbor in (and vice versa). In other words, any dominating set of should contain nodes of both and .

The algorithm of Matula (see Algorithm 2) starts with a node of minimum degree (e.g., node in ) and gradually builds a dominating set by adding nodes not yet part of or adjacent to the growing set. Since at one point a node, for example , from needs to be added, keeping track of the minimum cut between newly added dominating nodes, and will result in finding the overall minimum cut. The algorithm is presented below.

Algorithm 2: Matula-Min-Cut .

In the algorithm of Matula, an augmenting path is a path in the residual network, where a residual network is the network that remains after pruning the links of a previous augmenting path. There are no 1-hop paths from to , because then . If has neighbors that belong to , then there exist 2-hop paths from to , for which either the first hop from to or the second hop from to is part of the minimum cut. These paths form the first augmenting paths, after which remains. These remaining augmenting paths can be found in time each and since there are at most such paths, the complexity of the algorithm is bounded by . Finally, if , then the initialization guarantees that that value would be found.

For directed multigraphs, Shiloach [44] provided a theorem that is stronger than Menger's theorem, namely.

Theorem 13. Let be a directed -link-connected multigraph, then for all , (not necessarily distinct) there exist link-disjoint paths from to for .

We refer to Mansour and Schieber [45] for an -time algorithm for determining the link connectivity in directed networks.

For further reference, in Table 2 we present some key achievements in computing minimum link cuts.

Table 2: Related work on computing minimum link cuts.
##### 2.2. Determining Node Connectivity

Maximum-flow algorithms can also be used to determine the node connectivity, as demonstrated by Dantzig and Fulkerson [46] (and also discussed in [47]), by transforming the undirected graph to a directed graph as follows.

For every node place two nodes and in and connect them via a directed link , using the convention that the link starts at and ends at . For every undirected link place directed links and in . All links are assigned unit capacity.

The - node connectivity in can be computed by finding a maximum flow from to in . This can be seen as follows. Assume that there are node-disjoint paths between and , then there are also corresponding node-disjoint paths from to in . Since each link has unit capacity, there thus exists a flow of at least . Since each link entering a node has to traverse a single unit-capacity link at most one unit of flow can pass through a node, which corresponds to a node-disjoint path. Since there are only node-disjoint paths, the maximum flow in is equal to .

By using Dinitz' algorithm, one may compute the - node connectivity in time, and by using the algorithm of Mansour and Schieber [45], the node connectivity can be determined in time. We refer to Henzinger et al. [48] and Gabow [49] for more advanced algorithms to compute the node connectivity in directed and undirected graphs and to Yoshida and Ito [50] for a -node-connectivity property testing algorithm (in property testing the objective is to decide, with high probability, whether the input graph is close to having a certain property. These algorithms typically run in sub-linear time).

#### 3. Network Connectivity Augmentation

In this section, we consider the following link augmentation problem.

Problem 1 (the link connectivity augmentation (LCA) problem). Given a graph consisting of nodes and links, link connectivity and an integer , the link connectivity augmentation problem is to add a minimum-weight set of links, such that the link connectivity of the graph is increased from to .

We can discriminate several variants based on the graph (directed, simple, planar, etc.) or if link weights are used or not (i.e., in the unweighted case all links have weight 1). Let us start with the weighted link connectivity augmentation problem.

Theorem 14. The weighted LCA problem is NP-hard.

We will use the proof due to Frederickson and JáJá [53] to show that the 3-dimensional matching (3DM) problem is reducible to the weighted LCA problem (an earlier proof has been provided by Eswaran and Tarjan [54], but since it aims to augment a network without any links to one that is 2 connected and has links (a cycle), it has the characteristics of a design rather than an augmentation problem).

Problem 2 (3-dimensional matching (3DM)). Given a set of triplets, where , , and are disjoint sets of elements each, is there a matching subset that contains all elements, such that , and thus no two elements of agree in any coordinate?

Proof. For a 3DM instance , with , , , and , we create the graph of the corresponding instance of the weighted LCA problem as follows: The graph as constructed above forms a tree and therefore is 1 connected. Links from the complement of can be used to augment the graph to 2-link connectivity. The weights of the links in are for , and for the remaining links in , the weight is 2.

Frederickson and JáJá also used the construction of this proof to prove that the node-connectivity and strong-connectivity variants of the weighted LCA problem are NP-hard (in a directed graph strong connectivity is used, which means that there is a directed path from each node to every other node in the graph). We remark that the unweighted simple graph preserving LCA problem was claimed to be NP-hard by Jordán (reproduced in [55]) by using a reduction to one of the problems treated by Frederickson and JáJá. However, Jordán appears to be using an unweighted problem of which only (in the paper [53] referred to) the weighted version is proved to be NP-hard, and it is therefore not clear whether the unweighted problem is indeed NP-hard. For fixed , the unweighted simple graph preserving problem can be solved in polynomial time [55].

Eswaran and Tarjan [54] were the first to report on augmentation problems. They considered augmenting a network towards either 2-link connectivity, 2-node connectivity or strong connectivity, and provided for each unweighted problem variant an algorithm of complexity (Raghavan [56] pointed out an error in the strong connectivity algorithm and provided a fix for it). Since most protection schemes only focus on protecting against one single failure at a time (by finding two disjoint paths as discussed in Section 4), we will first present the 2-link-connectivity augmentation algorithm of Eswaran and Tarjan [54].

###### 3.1.1. Eswaran and Tarjan Algorithm

The algorithm of Eswaran and Tarjan as presented in Algorithm 6 makes use of preorder (Algorithm 4) and postorder (Algorithm 3) numbering of nodes in a tree (the label of node denotes its number as a result of the ordering) and a procedure (Algorithm 5) to find 2-link-connected components.

Algorithm 3: PostOrder .

Algorithm 4: PreOrder .

Algorithm 5: Tarjan-2-link-components , developed by Tarjan [57].

We have assumed that the initial graph was connected. Eswaran and Tarjan's algorithm also allows to start with disconnected graphs, by augmenting the forest of condensed 2-link-connected components to a tree.

###### 3.1.2. Cactus Representation of All Minimum Cuts

The algorithm of Eswaran and Tarjan uses a tree representation of all the 2-link-connected components in , which is subsequently used to find a proper augmentation. By using a so-called cactus representation of all minimum cuts in a network, a similar strategy could be deployed to augment a network to a connectivity >2. A graph is defined to be a cactus graph if any two distinct simple cycles in have at most one node in common (or equivalently, any link of belongs to at most one cycle). In this section, we will present the cactus representation.

We will use the notation to represent a set of links that connect nodes in to nodes in . The link-set , with , refers to a cut-set of links whose removal separates the graph into two subgraphs of nodes and nodes . Dinitz et al. [58] have proposed a cactus structure to represent all the minimum cuts of a graph (possibly with parallel links) and have shown that there can be at most such minimum cuts. The structure possesses the following properties.(1) is a cactus graph, that is, any two distinct simple cycles of have at most one node in common.(2) Each proper cut in is a minimum cut (a cut is called proper if the removal of the links in that cut partitions the graph in precisely two subgraphs. A minimum cut is always proper).(3) For any link that is part of a cycle in the weight , else .(4), where represents the minimum-weight link cut of .

A cactus graph without cycles is a tree, and if is odd, then is a tree. Cycles in the cactus graph reflect so-called crossing cuts in .

Definition 15. Two cuts and , with , are crossing cuts, if all four sets , , , and are non-empty.

Karzanov and Timofeev [59] have outlined an algorithm to compute that consists of two parts: (1) computing all minimum cuts and (2) constructing the corresponding cactus representation. However, Nagamochi and Kameda [60] reported that their cactus representation may not be unique. We assume that all minimum cuts are already known (e.g., by computing minimum - cuts between all possible source-destination pairs, by the Gomory-Hu tree algorithm [61], or with Matula's algorithm as explained in [62]) and focus on explaining—by following the description of Fleischer [63]—how to build a unique cactus graph for the graph .

Karzanov and Timofeev [59] observe that for a link , any two minimum cuts and that separate and are nested, which means that (or vice versa). If we assign the nodes of a preorder labelling , such that node is adjacent to a node in the set , and define to be the set of minimum cuts that contain but not , then it follows that all cuts in are noncrossing for each . For instance, consider a 4-node ring , where three minimum cuts separate nodes and , namely, , , and . Clearly , which allows us to represent them as a path graph . The three possibilities to cut this chain correspond to the three minimum cuts that separate and in the ring graph. For each there is a corresponding path graph . These path graphs are used to create a single cactus graph. We proceed to present the algorithm as described by Fleischer [63] (for an alternative description we refer to [64]), see Algorithm 7. We define to be the function that maps nodes of to nodes in , and we define to be the graph with nodes contracted to a single node (and any resulting self-loops removed). Let be the smallest graph that has a minimum cut of value , where corresponds to the largest index of such a graph. is a path graph. The algorithm builds from until is obtained.

Algorithm 7: Build-Cactus .

Figure 1 gives an example of the execution of the algorithm on a 4-node ring.

Figure 1: Example of a cactus construction for a 4-node ring topology. The top “row” gives the graphs , for . The second row gives the paths , for . The third row presents the first iteration of the for loop in algorithm Build-Cactus, while the fourth row presents the last iteration. The last row presents the cactus representation of the ring, which is a ring itself.
###### 3.1.3. Naor-Gusfield-Martel Algorithm

Naor et al. [65] have proposed a polynomial-time algorithm to augment the link connectivity of a graph from to , by adding the smallest number of (possibly parallel) links. The authors first demonstrate how to augment the link connectivity by one in time, after which it is explained how executing this algorithm times could optimally augment the graph towards link connectivity (Cheng and Jordán [66] further discuss link connectivity augmentation by adding one link at a time). In practice, as a result of the costs in network augmentation, a network's connectivity is likely not augmented with . We will therefore only present the algorithm to augment the link connectivity by one, see Algorithm 9, and refer to [65] for the extended algorithm. The algorithm uses the cactus structure that was presented in the previous section to represent all the minimum cuts of a graph . The algorithm is similar in approach to the Eswaran-Tarjan algorithm, since a cactus representation of a 1-connected network is the tree representation used by Eswaran and Tarjan, and the algorithm connects “leafs” as Eswaran and Tarjan have done. Naor et al., however, use a different definition of leafs for cactus graphs.

Definition 16 (cactus leaf). A node in a cactus representation is a cactus leaf if it has degree 1 or is a cycle node of degree 2.

Similarly to a tree, if the cactus has leafs, then links need to be added to increase the connectivity by 1.

The algorithm uses a Depth-First-Search-like procedure, see Algorithm 8, to label the nodes of the cactus graph.

Algorithm 8: Cactus-DFS .

Algorithm 9: Naor-Gusfield-Martel-Aug-1 .

For further reference, in Table 3, we present some key achievements in augmenting link connectivity in unweighted graphs.

Table 3: Related work on augmenting link connectivity in unweighted graphs.

Splitting off a pair of links and refers to deleting those links and adding a new link . A pair of links is said to be splittable if the - min-cut values remain unaffected after splitting off the pair of links and is considered in the context of Mader's theorem.

Theorem 17 (Mader [68, 69]). Let be a connected undirected graph where for some node the degree , and the removal of one of the adjacent links of does not disconnect the graph, then has a pair of splittable links.

Mader's theorem has been used by for instance Cai and Sun [75] and Frank [77] in developing network augmentation algorithms. The algorithms (as already outlined in 1976 by Plesník [84]) attach a new node to the graph with parallel links between and all other nodes in the graph and subsequently proceed to split off splittable links.

As indicated by Theorem 14, the weighted LCA problem is NP-complete for both undirected graphs and directed graphs. Frederickson and JáJá [53] provided an algorithm to make a weighted graph 2 connected. The algorithm is a 2-approximation algorithm if the starting graph is connected, else it is a 3-approximation algorithm. Khuller and Thurimella [85] proposed a 2-approximation algorithm for increasing the connectivity of a weighted undirected graph to that has a complexity of . Taoka et al. [86] compare via simulations several approximation and heuristic algorithms, including their own maximum-weight-matching-based algorithm.

Under specific conditions, the weighted LCA problem may be polynomially solvable, as shown by Frank [77] for the case that link weights are derived from node weights.

##### 3.2. Node Connectivity Augmentation

In this section, we consider the following node augmentation problem.

Problem 3. The Node Connectivity Augmentation (NCA) problem. Given a graph consisting of nodes and links, node connectivity and an integer , the node connectivity augmentation problem is to add a minimum-weight set of links, such that the node connectivity of the graph is increased from to .

Like for the LCA problem.

Theorem 18. The weighted NCA problem is NP-hard.

Proof. The proof of Theorem 14 also applies here.

The unweighted undirected NCA problem has received most attention. The specific case of making a graph 2-node connected was treated by Eswaran and Tarjan [54], Rosenthal and Goldner [87] (a correction to this algorithm has been made by Hsu and Ramachandran [88]). Watanabe and Nakamura [89] and Jordán [90] solved the case for achieving 3-node-connectivity, while Hsu [91] developed an algorithm to upgrade a 3-node connected graph to a 4-node-connected one. Increasing the connectivity of a -node-connected graph (where can be any integer) by 1 was studied by many researchers [90, 9297], since it was long unknown whether the problem was polynomially solvable. In 2010, Végh [98] provided a polynomial-time algorithm to increase the connectivity of any -node-connected unweighted undirected graph by .

Augmenting the node connectivity of directed graphs has been treated by Frank and Jordán [99]. They found a min-max formula that finds the minimum number of required new links to make an unweighted digraph -node connected. Frank and Végh [100] developed a polynomial-time algorithm to make a -node-connected directed graph -node connected.

As the weighted NCA problem is NP-complete, special cases have been considered [8891, 98, 101]. Most of these articles discuss specific connectivity targets ( and/or have specific values) or specific topologies, like trees. Also heuristic and approximation algorithms have been proposed [85, 102107].

#### 4. Disjoint Paths

When a network is (made to be) robust, algorithms should be in place that can find link- or node-disjoint paths to protect against a link or node failure. There can be several objectives associated with finding link- or node-disjoint paths.

Problem 4. Given a graph , where and , a weight and a capacity associated with each link , a source node and a terminal node , and two bounds and find a pair of disjoint paths from to such as the following.

Min-Sum Disjoint Paths Problem
The total weight of the pair of disjoint paths is minimized.

Min-Max Disjoint Paths Problem
The maximum path weight of the two disjoint paths is minimized.

Min-Min Disjoint Paths Problem
The smallest path weight of the two disjoint paths is minimized.

Bounded Disjoint Paths Problem
The weight of the primary path should be less than or equal to , and the weight of the backup path should be less than or equal to .

Widest Disjoint Paths Problem
The smallest capacity over all links in the two paths is maximized.

The most common and simpler one is the min-sum disjoint paths problem. If the two paths are used simultaneously for load-balancing purposes (or protection), then the min-max objective is desirable. Unfortunately, the min-max disjoint paths problem is NP-hard [108]. If failures are expected to occur only sporadically (and in case of 1 : 1 protection), then it may be desirable to minimize the weight of the primary (shorter) path (min-min objective), which also leads to an NP-hard problem [109]. The min-max and min-min disjoint paths problems could be considered as extreme cases of the bounded disjoint paths problem, which was shown to be NP-hard [110] and later proven to be APX-hard by Bley [111] (the graph structure referred to as lobe that was used by Itai et al. [110] to prove NP-completeness has since often been used to prove that other disjoint paths problems are NP-complete, e.g., [112114]). Finding widest disjoint paths can easily be done by pruning “low-capacity” links from the graph and finding disjoint paths. When the capacity requirements for the primary and backup paths are different, disjoint paths problems usually become NP-complete [115].

Beshir and Kuipers [116] investigated the min-sum disjoint paths problem with min-max, min-min, bounded, and widest, as secondary objectives in case multiple min-sum paths exist between and . From these variants, only the widest min-sum link-disjoint paths problem is not NP-hard.

Li et al. [112] studied the min-sum disjoint paths problem, where the link-weight functions are different for the primary and backup paths and showed that this problem is hard to approximate. Bhatia [117] demonstrated that the problem remains hard to approximate in the case that the weights for the links of the backup path are a fraction of the normal link weights (for the primary path).

Sherali et al. [118] investigated the time-dependent min-sum disjoint paths problem, where the link weights are time-dependent. They proved that the problem is NP-hard, even if only one link is time-dependent and all other links are static.

##### 4.1. Min-Sum Disjoint Paths

Finding min-sum disjoint paths is equivalent to finding a minimum-cost flow in unit-capacity networks [26]: a minimum-cost flow of will traverse disjoint paths. In fact, Suurballe's algorithm, which is most often cited as an algorithm to compute two disjoint paths, is an algorithm that uses augmenting paths, like in several max-flow algorithms. The original Suurballe algorithm as presented in [119] allows to compute node (or link) disjoint paths between a single source-destination pair, by using shortest path computations. Later, this approach was used by Suurballe and Tarjan [120] to find two link (or node) disjoint paths from a source to all other nodes in the network (i.e., source-destination pairs), by using only two shortest-paths computations, that is, in time. Both papers focus on directed networks, but can also be applied to undirected networks.

In directed networks, a link-disjoint paths algorithm can be used to compute node-disjoint paths, if we split each node into two nodes and , with a directed link , and the incoming links of connected to and the outgoing links of departing from .

In undirected networks, a link-disjoint paths algorithm can be used to compute node-disjoint paths by the transformation described in Section 2.2.

We will present the Suurballe-Tarjan algorithm, see Algorithm 10, for computing two link-disjoint paths between and every other node in the network.

Instead of finding an augmenting path for each source-destination pair, Suurballe and Tarjan have found a way to combine these augmenting flow computations into two Dijkstra-like shortest-paths computations. First a shortest paths tree is computed in line 1, and based on the computed shortest path lengths, the link weights are modified in line 2. This link weight modification was also used by Suurballe and is to assure that for all links, with equality if is in . In Suurballe's original algorithm the direction of the links on the shortest path from to was reversed, after which a shortest (augmenting) path in the newly modified graph was computed. In Suurballe-Tarjan's algorithm the links maintain their direction, but an additional parameter is used instead. The algorithm proceeds in a Dijkstra-like fashion. Lines 3–6 correspond to the initialization of the smallest length from to found so far, its corresponding predecessor list and . The algorithm repeatedly extracts a node of minimum length (in line 8) and removes that node from the tree (in line 9). A slightly different relaxation procedure is used (lines 10–12). Upon termination of the algorithm, the disjoint paths between the source and a destination can be retrieved via the lists and with Algorithm 11.

Taft-Plotkin et al. [121] extended the approach of Suurballe and Tarjan in two ways: (1) they return maximally disjoint paths, and (2) they also take bandwidth into account. Their algorithm, called MADSWIP, computes maximum-bandwidth maximally disjoint paths and minimizes the total weight as a secondary objective. Consequently, by assigning all links equal bandwidth, the MADSWIP algorithm returns the min-sum maximally disjoint paths.

For a distributed disjoint paths algorithm, we refer to the work of Ogier et al. [122] and Sidhu et al. [123].

Roskind and Tarjan [124] presented an algorithm for finding link-disjoint spanning trees of minimum total weight. Xue et al. [125, 126] have considered quality of service and quality of protection issues in computing two disjoint trees (quality of Protection (QoP) as used by Xue et al. refers to the amount of link failures that can be survived. QoP sometimes is used to refer to probabilistic survivability, as discussed in the following section or protection differentiation as overviewed by Cholda et al. [127]). Ramasubramanian et al. [128] proposed a distributed algorithm for computing two disjoint trees. Guo et al. [129] considered finding two link-disjoint paths subject to multiple Quality-of-Service constraints.

##### 4.2. Probabilistic Survivability

When two disjoint primary and backup paths are reserved for a connection, any failure on the primary path can be survived by using the backup path. The backup path therefore provides 100% survivability guarantee against a single failure. When no backup paths are available, that is, unprotected paths are used, then the communication along a path will fail if there is a failure on that path. Banner and Orda [130] have introduced the term -survivable connection to denote a connection for which there is a probability that all its links are operational (the related notion of Quality of Protection (QoP), as defined by Gerstel and Sasaki [131], was argued to be difficult to apply to general networks). The previous two cases correspond to and , respectively. Banner and Orda proved that, under the single-link failure model, at most two paths are needed to establish a -survivable connection, if it exists. Based on this observation, they studied and proposed algorithms for several problem variants, namely establishing -survivable--bandwidth, most survivable, and widest -survivable connections for 1 : 1 and protection architectures (the MADSWIP algorithm [121] can also be used to find the most survivable connection). The -survivable--bandwidth problem asks for a connection with survivability and bandwidth and solving it provides a foundation for solving the other problems. We will therefore discuss the solution proposed by Banner and Orda for the -survivable--bandwidth problem.

Figure 2: Graph transformation for the -survivable--bandwidth problem. For each link with capacity and failure probability , the new links consist of a bandwidth-weight pair.

In the transformed graph, a minimum-cost flow of units corresponds to two maximally disjoint paths of each bandwidth. The minimum-cost flow could, for instance, be found with the cycle-canceling algorithm of Goldberg and Tarjan [132], while the corresponding maximally disjoint paths could be returned via a flow-decomposition algorithm [26].

Luo et al. [133] studied the min-sum -survivable connection problem, where each link is characterized by a weight and a failure probability, and the problem is to find a connection of least weight and survivability ≥. Contrary to the min-sum maximally-disjoint paths problem, this problem is NP-hard, since it contains the NP-hard restricted shortest paths problem (e.g., see [134]). Luo et al. proposed an ILP and two approximation algorithms for this problem. Chakrabarti and Manimaran [135] studied the min-sum -survivable--bandwidth problem, for which they considered a segment-based protection strategy.

#### 5. Conclusion

We have provided an overview of algorithms for network survivability. We have considered how to verify that a network has certain connectivity properties, how to augment an existing network to reach a given connectivity, and, lastly, how to find alternative paths in case network failures occur. Our focus has been on algorithms for general networks, although much work has also been done for specific networks, such as optical networks, where additional constraints like wavelength continuity and signal impairments induce an increased complexity, for example, see our work [149151]. We have not discussed how to design a survivable network from scratch. Typically network design problems are hard to solve and involve many constraints, but since they only need to be solved sporadically, longer computation times are permitted. Predominantly, integer programming is used to design a network, as we have done in [152].

#### Acknowledgment

The author would like to thank Professor Piet Van Mieghem for his constructive comments on an earlier version of this paper.

#### References

1. M. Al-Kuwaiti, N. Kyriakopoulos, and S. Hussein, “A comparative analysis of network dependability, fault-tolerance, reliability, security, and survivability,” IEEE Communications Surveys and Tutorials, vol. 11, no. 2, pp. 106–124, 2009.
2. K. Menger, “Zur allgemeinen kurventheorie,” Fundamenta Mathematicae, vol. 10, pp. 96–115, 1927.
3. M. Fiedler, “Algebraic connectivity of graphs,” Czechoslovak Mathematical Journal, vol. 23, pp. 298–305, 1973.
4. P. Van Mieghem, Graph Spectra for Complex Networks, Cambridge University Press, 2011.
5. N. M. M. de Abreu, “Old and new results on algebraic connectivity of graphs,” Linear Algebra and Its Applications, vol. 423, no. 1, pp. 53–73, 2007.
6. K. Lee, E. Modiano, and H. W. Lee, “Cross-layer survivability in WDM-based networks,” IEEE/ACM Transactions on Networking, vol. 19, no. 4, pp. 1000–1013, 2011.
7. K. Lee, H. W. Lee, and E. Modiano, “Reliability in layered networks with random link failures,” IEEE/ACM Transactions on Networking, vol. 19, no. 6, pp. 1835–1848, 2011.
8. W. Zou, M. Janic, R. Kooij, and F. A. Kuipers, “On the availability of networks,” in Proceedings of the BroadBand Europe, Antwerp, Belgium, December 2007.
9. C. J. Colbourn, The Combinatorics of Network Reliability, Oxford University Press, New York, NY, USA, 1987.
10. P. Van Mieghem, H. Wang, X. Ge, S. Tang, and F. A. Kuipers, “Influence of assortativity and degree-preserving rewiring on the spectra of networks,” European Physical Journal B, vol. 76, no. 4, pp. 643–652, 2010.
11. D. Mosk-Aoyama, “Maximum algebraic connectivity augmentation is NP-hard,” Operations Research Letters, vol. 36, no. 6, pp. 677–679, 2008.
12. M. Yanakakis, “Computing the minimum fill-in is NP-complete,” SIAM Journal on Algebraic and Discrete Methods, vol. 2, no. 1, pp. 77–79, 1981.
13. P. Pan, G. Swallow, and A. Atlas, “Fast reroute extensions to RSVP-TE for LSP tunnels,” IETF Request for Comments RFC 4090, 2005.
14. M. Shand and S. Bryant, “IP fast reroute framework,” IETF Request for Comments RFC 5714, 2010.
15. R. Banner and A. Orda, “Designing low-capacity backup networks for fast restoration,” in Proceedings of the IEEE INFOCOM, San Diego, Calif, USA, March 2010.
16. G. Ellinas, A. G. Hailemariam, and T. E. Stern, “Protection cycles in mesh WDM networks,” IEEE Journal on Selected Areas in Communications, vol. 18, no. 10, pp. 1924–1937, 2000.
17. R. Asthana, Y. N. Singh, and W. D. Grover, “p-cycles: an overview,” IEEE Communications Surveys and Tutorials, vol. 12, no. 1, pp. 97–111, 2010.
18. M. Médard, S. G. Finn, R. A. Barry, and R. G. Gallager, “Redundant trees for preplanned recovery in arbitrary vertex-redundant or edge-redundant graphs,” IEEE/ACM Transactions on Networking, vol. 7, no. 5, pp. 641–652, 1999.
19. K. P. Gummadi, M. J. Pradeep, and C. S. R. Murthy, “An efficient primary-segmented backup scheme for dependable real-time communication in multihop networks,” IEEE/ACM Transactions on Networking, vol. 11, no. 1, pp. 81–94, 2003.
20. C. H. Papadimitriou and M. Yannakakis, “Optimization, approximation, and complexity classes,” Journal of Computer and System Sciences, vol. 43, no. 3, pp. 425–440, 1991.
21. B. Mohar, “Isoperimetric numbers of graphs,” Journal of Combinatorial Theory, Series B, vol. 47, no. 3, pp. 274–291, 1989.
22. D. W. Matula and F. Shahrokhi, “Sparsest cuts and bottlenecks in graphs,” Discrete Applied Mathematics, vol. 27, no. 1-2, pp. 113–123, 1990.
23. T. N. Dinh, Y. Xuan, M. T. Thai, E. K. Park, and T. Znati, “On approximation of new optimization methods for assessing network vulnerability,” in Proceedings of the IEEE INFOCOM, San Diego, Calif, USA, March 2010.
24. D. R. Fulkerson and G. B. Dantzig, “Computation of maximal flows in networks,” Naval Research Logistics, vol. 2, no. 4, pp. 277–283, 1955.
25. P. Elias, A. Feinstein, and C. E. Shannon, “A note on the maximum flow through a network,” IRE Transactions on Information Theory, vol. 2, pp. 117–119, 1956.
26. R. K. Ahuja, T. L. Magnanti, and J. B. Orlin, Network Flows: Theory, Algorithms, and Applications, Prentice Hall, Upper Saddle River, NJ, USA, 1st edition, 1993.
27. Y. Dinitz, “Dinitz' algorithm: the original version and Even's version,” in Essays in Memory of Shimon Even, O. Goldreich, A. L. Rosenberg, and A. L. Selman, Eds., vol. 3895 of Lecture Notes in Computer Science, pp. 218–240, Springer, Berlin, Germany, 2006.
28. T. H. Cormen, C. E. Leiserson, R. L. Rivest, and C. Stein, Introduction to Algorithms, MIT Press, Cambridge, Mass, USA, 3rd edition, 2009.
29. S. Even and R. E. Tarjan, “Network flow and testing graph connectivity,” SIAM Journal on Computing, vol. 4, pp. 507–518, 1975.
30. G. B. Dantzig, “Application of the simplex method to a transportation problem,” in Activity Analysis of Production and Allocation, pp. 359–373, John Wiley & Sons, New York, NY, USA, 1951.
31. L. R. Ford and D. R. Fulkerson, “Maximal flow through a network,” Canadian Journal of Mathematics, vol. 8, pp. 399–404, 1956.
32. A. V. Karzanov, “Determining the maximal flow in a network by the method of preflows,” Soviet Mathematics-Doklady, no. 15, pp. 434–437, 1974.
33. R. E. Tarjan, “A simple version of Karzanov's blocking flow algorithm,” Operations Research Letters, vol. 2, no. 6, pp. 265–268, 1984.
34. Z. Galil and A. Naamad, “An O(EV log2V) algorithm for the maximal flow problem,” Journal of Computer and System Sciences, vol. 21, pp. 203–217, 1980.
35. Y. Shiloach and U. Vishkin, “An O(n2log n) parallel max-flow algorithm,” Journal of Algorithms, vol. 3, no. 2, pp. 128–146, 1982.
36. D. D. Sleator and R. E. Tarjan, “A data structure for dynamic trees,” Journal of Computer and System Sciences, vol. 26, no. 3, 1983.
37. A. V. Goldberg and R. E. Tarjan, “A new approach to the maximum-flow problem,” Journal of the ACM, vol. 35, no. 4, pp. 921–940, 1988.
38. R. K. Ahuja, J. B. Orlin, and R. E. Tarjan, “Improved time bounds for the maximum flow problem,” SIAM Journal on Computing, vol. 18, no. 5, pp. 939–954, 1989.
39. J. Cheriyan and T. Hagerup, “Randomized maximum-flow algorithm,” SIAM Journal on Computing, vol. 24, no. 2, pp. 203–226, 1995.
40. N. Alon, “Generating pseudo-random permutations and maximum flow algorithms,” Information Processing Letters, vol. 35, no. 4, pp. 201–204, 1990.
41. A. V. Goldberg and S. Rao, “Beyond the flow decomposition barrier,” Journal of the ACM, vol. 45, no. 5, pp. 783–797, 1998.
42. P. Christiano, J. A. Kelner, A. Madry, D. A. Spielman, and S. H. Teng, “Electrical flows, laplacian systems, and faster approximation of maximum flow in undirected graphs,” in Proceedings of The 43rd ACM Symposium on Theory of Computing, STOC' 11, pp. 273–281, San Jose, CA, USA, June 2011.
43. D. W. Matula, “Determining edge connectivity in $O\left(\text{nm}\right)$,” in Proceedings of the 28th Symposium on Foundations of Computer Science (FOCS '87), pp. 249–251, Los Angeles, Calif, USA, October 1987.
44. Y. Shiloach, “Edge-disjoint branching in directed multigraphs,” Information Processing Letters, vol. 8, no. 1, pp. 24–27, 1979.
45. Y. Mansour and B. Schieber, “Finding the edge connectivity of directed graphs,” Journal of Algorithms, vol. 10, no. 1, pp. 76–85, 1989.
46. G. B. Dantzig and D. R. Fulkerson, “On the max-flow min-cut theorem of networks,” in Linear Inequalities and Related Systems, Annals of Mathematics Studies, Study 38, pp. 215–221, Princeton University Press, Princeton, NJ, USA, 1956.
47. S. Even, Graph Algorithms, Computer Science Press, 1979.
48. M. R. Henzinger, S. Rao, and H. N. Gabow, “Computing vertex connectivity: new bounds from old techniques,” Journal of Algorithms, vol. 34, no. 2, pp. 222–250, 2000.
49. H. N. Gabow, “Using expander graphs to find vertex connectivity,” Journal of the ACM, vol. 53, no. 5, pp. 800–844, 2006.
50. Y. Yoshida and H. Ito, “Property testing on k-vertex-connectivity of graphs,” Algorithmica, vol. 62, no. 3-4, pp. 701–712, 2012.
51. P. Van Mieghem, D. Stevanović, F. A. Kuipers et al., “Decreasing the spectral radius of a graph by link removals,” Physical Review E, vol. 84, no. 1, 2011.
52. A. Natanzon, R. Shamir, and R. Sharan, “Complexity classification of some edge modification problems,” Discrete Applied Mathematics, vol. 113, no. 1, pp. 109–128, 2001.
53. G. Frederickson and J. JáJá, “Approximation algorithms for several graph augmentation problems,” SIAM Journal on Computing, vol. 10, no. 2, pp. 270–283, 1981.
54. K. P. Eswaran and R. E. Tarjan, “Augmentation problems,” SIAM Journal on Computing, vol. 5, no. 4, pp. 653–665, 1976.
55. J. Jensen and T. Jordán, “Edge-connectivity augmentation preserving simplicity,” in Proceedings of the 9th Annual ACM/SIAM Symposium On Discrete Algorithms (SODA '97), pp. 306–315, 1997.
56. S. Raghavan, “A note on Eswaran and Tarjan's algorithm for the strong connectivity augmentation problem,” in The Next Wave in Computing, Optimization, and Decision Technologies, vol. 29 of Operations Research/Computer Science Interfaces Series, pp. 19–26, Springer, 2005.
57. R. E. Tarjan, “A note on finding the bridges of a graph,” Information Processing Letters, vol. 2, no. 6, pp. 160–161, 1974.
58. E. A. Dinitz, A. V. Karzanov, and M. V. Lomonosov, “On the structure of the system of minimum edge cuts of a graph,” in Issledovaniya po Diskretnoi Optimizatsii, A. A. Fridman, Ed., pp. 290–306, Nauka, Moscow, Russia, 1976.
59. A. V. Karzanov and E. A. Timofeev, “Efficient algorithm for finding all minimal edge cuts of a nonoriented graph,” Cybernetics and Systems Analysis, vol. 22, no. 2, pp. 156–162, 1986.
60. H. Nagamochi and T. Kameda, “Canonical cactus representation for minimum cuts,” Japan Journal of Industrial and Applied Mathematics, vol. 11, no. 3, pp. 343–361, 1994.
61. R. E. Gomory and T. C. Hu, “Multi-terminal network flows,” Journal of the Society for Industrial and Applied Mathematics, vol. 9, no. 4, pp. 551–570, 1961.
62. D. Gusfield and D. Naor, “Extracting maximal information about sets of minimum cuts,” Algorithmica, vol. 10, no. 1, pp. 64–89, 1993.
63. L. Fleischer, “Building chain and cactus representations of all minimum cuts from Hao-Orlin in the same asymptotic run time,” Journal of Algorithms, vol. 33, no. 1, pp. 51–72, 1999.
64. H. Nagamochi, “Graph algorithms for network connectivity problems,” Journal of the Operations Research Society of Japan, vol. 4, no. 4, pp. 199–223, 2004.
65. D. Naor, D. Gusfield, and C. Martel, “A fast algorithm for optimally increasing the edge connectivity,” SIAM Journal on Computing, vol. 26, no. 4, pp. 1139–1165, 1997.
66. E. Cheng, “Successive edge-connectivity augmentation problems,” Mathematical Programming B, vol. 84, no. 3, pp. 577–593, 1999.
67. R. E. Tarjan, “Depth-first search and linear graph algorithms,” SIAM Journal on Computing, vol. 1, no. 2, pp. 146–160, 1972.
68. W. Mader, “A reduction method for edge-connectivity in graphs,” Annals of Discrete Mathematics, vol. 3, pp. 145–164, 1978.
69. A. Frank, “On a theorem of Mader,” Discrete Mathematics, vol. 101, no. 1–3, pp. 49–57, 1992.
70. V. D. Podderyugin, “An algorithm for determining edge-connectivity of a graph,” in Proceedings of the Seminar on Combinatorial Mathematics, Moscow, Russia, 1971, Doklady Akademii Nauk SSSR, Scientiffic Council on the Complex Problem “Cybernetics”, pp. 136–141, 1973.
71. H. Nagamochi and T. Ibaraki, “Computing edge-connectivity in multigraphs and capacitated graphs,” SIAM Journal on Discrete Mathematics, vol. 5, no. 1, pp. 54–66, 1992.
72. Z. Galil and G.F. Italiano, “Reducing edge connectivity to vertex connectivity,” ACM SIGACT News, vol. 22, no. 1, pp. 57–61, 1991.
73. H. N. Gabow, “A matroid approach to finding edge-connectivity and packing arborescences,” Journal of Computer and System Sciences, vol. 50, no. 2, pp. 259–273, 1995.
74. D. R. Karger, “Minimum cuts in near-linear time,” Journal of the ACM, vol. 47, no. 1, pp. 46–76, 2000.
75. G. Cai and Y. Sun, “The minimum augmentation of any graph to a K-edge-connected graph,” Networks, vol. 19, no. 1, pp. 151–172, 1989.
76. T. Watanabe and A. Nakamura, “Edge-connectivity augmentation problems,” Journal of Computer and System Sciences, vol. 35, no. 1, pp. 96–144, 1987.
77. A. Frank, “Augmenting graphs to meet edge-connectivity requirements,” SIAM Journal on Discrete Mathematics, vol. 5, no. 1, pp. 25–53, 1992.
78. H. N. Gabow, “Applications of a poset representation to edge connectivity and graph rigidity,” in Proceedings of the 32nd Annual Symposium on Foundations of Computer Science (FOCS '91), pp. 812–821, October 1991.
79. A. A. Benczúr, “Augmenting undirected connectivity in RNC and in randomized Õ(n3) time,” in Proceedings of the 26th Annual ACM Symposium on Theory of Computing (STOC '94), pp. 658–667, New York, NY, USA, May 1994.
80. H. Nagamochi and T. Ibaraki, “Deterministic Õ(nm) time edge-splitting in undirected graphs,” Journal of Combinatorial Optimization, vol. 1, no. 1, pp. 5–46, 1997.
81. A. A. Benczúr and D. R. Karger, “Augmenting undirected edge connectivity in Õ(n2) time,” Journal of Algorithms, vol. 37, no. 1, pp. 2–36, 2000.
82. H. Nagamochi and T. Ibaraki, “Graph connectivity and its augmentation: applications of MA orderings,” Discrete Applied Mathematics, vol. 123, pp. 447–472, 2002.
83. Z. Nutov, “Approximating connectivity augmentation problems,” ACM Transactions on Algorithms, vol. 6, no. 1, article 5, 2009.
84. J. Plesník, “Minimum block containing a given graph,” Archiv der Mathematik, vol. 27, no. 1, pp. 668–672, 1976.
85. S. Khuller and R. Thurimella, “Approximation algorithms for graph augmentation,” Journal of Algorithms, vol. 14, no. 2, pp. 214–225, 1993.
86. S. Taoka, T. Watanabe, and T. Mashima, “Maximum weight matching-based algorithms for k-edge-connectivity augmentation of a graph,” in Proceedings of the IEEE International Symposium on Circuits and Systems (ISCAS '05), pp. 2231–2234, May 2005.
87. A. Rosenthal and A. Goldner, “Smallest augmentation to biconnect a graph,” SIAM Journal on Computing, vol. 6, no. 1, pp. 55–66, 1977.
88. T. S. Hsu and V. Ramachandran, “Finding a smallest augmentation to biconnect a graph,” SIAM Journal on Computing, vol. 22, no. 5, pp. 889–912, 1993.
89. T. Watanabe and A. Nakamura, “A minimum 3-connectivity augmentation of a graph,” Journal of Computer and System Sciences, vol. 46, no. 1, pp. 91–128, 1993.
90. T. Jordán, “On the optimal vertex-connectivity augmentation,” Journal of Combinatorial Theory B, vol. 63, no. 1, pp. 8–20, 1995.
91. T. Hsu, “On four-connecting a triconnected graph,” in Proceedings of the 33rd Annual Symposium on Foundations of Computer Science (FOCS '92), pp. 70–79, IEEE Computer Society, Washington, DC, USA, October 1992.
92. T. Jordán, “A note on the vertex-connectivity augmentation problem,” Journal of Combinatorial Theory B, vol. 71, no. 2, pp. 294–301, 1997.
93. B. Jackson and T. Jordán, “A near optimal algorithm for vertex-connectivity augmentation,” in Proceedings of the 11th International Conference on Algorithms and Computation (ISAAC '00), pp. 312–325, Springer, London, UK, December 2000.
94. B. Jackson and T. Jordán, “Independence free graphs and vertex connectivity augmentation,” Journal of Combinatorial Theory B, vol. 94, no. 1, pp. 31–77, 2005.
95. G. Kortsarz and Z. Nutov, “Approximating minimum-cost connectivity problems,” in Handbook of Approximation Algorithms and Metaheuristics, Chapter 58, Chapman & Hall/CRC, 2007.
96. G. Liberman and Z. Nutov, “On shredders and vertex connectivity augmentation,” Journal of Discrete Algorithms, vol. 5, no. 1, pp. 91–101, 2007.
97. J. Cheriyan and R. Thurimella, “Fast algorithms for k-shredders and k-node connectivity augmentation,” Journal of Algorithms, vol. 33, no. 1, pp. 15–50, 1999.
98. L. A. Végh, “Augmenting undirected node-connectivity by one,” SIAM Journal on Discrete Mathematics, vol. 25, no. 2, pp. 695–718, 2011.
99. A. Frank and T. Jordán, “Minimal edge-coverings of pairs of sets,” Journal of Combinatorial Theory, Series B, vol. 65, no. 1, pp. 73–110, 1995.
100. A. Frank and L. A. Végh, “An algorithm to increase the node-connectivity of a digraph by one,” Discrete Optimization, vol. 5, no. 4, pp. 677–684, 2008.
101. A. Frank, “Connectivity augmentation problems in network design,” in Mathematical Programming: State of the Art 1994, J. R. Bridge and K. G. Murty, Eds., University of Michigan, Ann Arbor, Mich, USA, 1994.
102. M. Grötschel, C. L. Monma, and M. Stoer, “Design of survivable networks,” in Handbooks in Operations Research and Management Science, vol. 7, pp. 617–672, 1995.
103. M. Penn and H. Shasha-Krupnik, “Improved approximation algorithms for weighted 2- and 3-vertex connectivity augmentation problems,” Journal of Algorithms, vol. 22, no. 1, pp. 187–196, 1997.
104. S. Khuller, “Approximation algorithms for finding highly connected subgraphs,” in Approximation Algorithms for NP-Hard Problems, D. S. Hochbaum, Ed., pp. 236–265, PWS Publishing, Boston, Mass, USA, 1997.
105. S. Khuller and B. Raghavachari, “Improved approximation algorithms for uniform connectivity problems,” Journal of Algorithms, vol. 21, no. 2, pp. 434–450, 1996.
106. R. Ravi and D. P. Williamson, “An approximation algorithm for minimum-cost vertex-connectivity problems,” Algorithmica, vol. 18, no. 1, pp. 21–43, 1997.
107. G. N. Frederickson and J. JáJá, “On the relationship between the biconnectivity augmentation and travelling salesman problems,” Theoretical Computer Science, vol. 19, no. 2, pp. 189–201, 1982.
108. C.-L. Li, S. T. Mccormick, and D. Simchi-Levi, “The complexity of finding two disjoint paths with min-max objective function,” Discrete Applied Mathematics, vol. 26, no. 1, pp. 105–115, 1990.
109. B. Yang, S. Q. Zheng, and S. Katukam, “Finding two disjoint paths in a network with min-min objective function,” in Proceedings of the 15th IASTED International Conference on Parallel and Distributed Computing and Systems, November 2003.
110. A. Itai, Y. Perl, and Y. Shiloach, “The complexity of finding maximum disjoint paths with length constraints,” Networks, vol. 12, no. 3, pp. 277–286, 1982.
111. A. Bley, “On the complexity of vertex-disjoint length-restricted path problems,” Computational Complexity, vol. 12, no. 3-4, pp. 131–149, 2003.
112. C.-L. Li, S. T. Mccormick, and D. Simchi-Levi, “Finding disjoint paths with different path costs: complexity and algorithms,” Networks, vol. 22, no. 7, pp. 653–667, 1992.
113. D. Xu, Y. Chen, Y. Xiong, C. Qiao, and X. He, “On finding disjoint paths in single and dual link cost networks,” in Proceedings of the IEEE INFOCOM, March 2004.
114. Q. She, X. Huang, and J. P. Jue, “How reliable can two-path protection be?” IEEE/ACM Transactions on Networking, vol. 18, no. 3, pp. 922–933, 2010.
115. B. H. Shen, B. Hao, and A. Sen, “On multipath routing using widest pair of disjoint paths,” in Proceedings of the High Perfomance Switching and Routing (HPSR '04), pp. 134–140, April 2004.
116. A. A. Beshir and F. A. Kuipers, “Variants of the min-sum link-disjoint paths problem,” in Proceedings of the 16th Annual IEEE Symposium on Communications and Vehicular Technology (IEEE SCVT '09), IEEE/SCVT, Louvain-la-Neuve, Belgium, November 2009.
117. R. Bhatia, M. Kodialam, and T. V. Lakshman, “Finding disjoint paths with related path costs,” Journal of Combinatorial Optimization, vol. 12, no. 1-2, pp. 83–96, 2006.
118. H. D. Sherali, K. Ozbay, and S. Subramanian, “The time-dependent shortest pair of disjoint paths problem: complexity, models, and algorithms,” Networks, vol. 31, no. 4, pp. 259–272, 1998.
119. J. W. Suurballe, “Disjoint paths in a network,” Networks, vol. 4, no. 2, pp. 125–145, 1974.
120. J. W. Suurballe and R. E. Tarjan, “A quick method for finding shortest pairs of disjoint paths,” Networks, vol. 14, pp. 325–336, 1984.
121. N. Taft-Plotkin, B. Bellur, and R. Ogier, “Quality-of-service routing using maximally disjoint paths,” in Proceedings of the 7th International Workshop on Quality of Service (IWQoS), pp. 119–128, London, UK, May 1999.
122. R. G. Ogier, V. Rutenburg, and N. Shacham, “Distributed algorithms for computing shortest pairs of disjoint paths,” IEEE Transactions on Information Theory, vol. 39, no. 2, pp. 443–455, 1993.
123. D. Sidhu, R. Nair, and S. Abdallah, “Finding disjoint paths in networks,” ACM SIGCOMM Computer Communication Review, vol. 21, no. 4, pp. 43–51, 1991.
124. J. Roskind and R. E. Tarjan, “Note on finding minimum-cost edge-disjoint spanning trees,” Mathematics of Operations Research, vol. 10, no. 4, pp. 701–708, 1985.
125. G. Xue, L. Chen, and K. Thulasiraman, “Quality-of-service and quality-of-protection issues in preplanned recovery schemes using redundant trees,” IEEE Journal on Selected Areas in Communications, vol. 21, no. 8, pp. 1332–1345, 2003.
126. W. Zhang, G. Xue, J. Tang, and K. Thulasiraman, “Faster algorithms for construction of recovery trees enhancing QoP and QoS,” IEEE/ACM Transactions on Networking, vol. 16, no. 3, pp. 642–655, 2008.
127. P. Cholda, A. Mykkeltveit, B. E. Helvik, O. J. Wittner, and A. Jajszczyk, “A survey of resilience differentiation frameworks in communication networks,” IEEE Communications Surveys & Tutorials, vol. 9, no. 4, pp. 32–55, 2007.
128. S. Ramasubramanian, M. Harkara, and M. Krunz, “Linear time distributed construction of colored trees for disjoint multipath routing,” Computer Networks, vol. 51, no. 10, pp. 2854–2866, 2007.
129. Y. Guo, F. A. Kuipers, and P. Van Mieghem, “A link-disjoint paths algorithm for reliable QoS routing,” International Journal of Communication Systems, vol. 16, no. 9, pp. 779–798, 2003.
130. R. Banner and A. Orda, “The power of tuning: a novel approach for the efficient design of survivable networks,” IEEE/ACM Transactions on Networking, vol. 15, no. 4, pp. 737–749, 2007.
131. O. Gerstel and G. Sasaki, “Quality of protection (QoP): a quantitative unifying paradigm to protection service grades,” Optical Networks Magazine, vol. 3, no. 3, pp. 40–49, 2002.
132. A. V. Goldberg and R. E. Tarjan, “Finding minimum-cost circulations by canceling negative cycles,” Journal of the ACM, vol. 36, no. 4, pp. 873–886, 1989.
133. H. Luo, L. Li, and H. Yu, “Routing connections with differentiated reliability requirements in WDM mesh networks,” IEEE/ACM Transactions on Networking, vol. 17, no. 1, pp. 253–266, 2009.
134. F. A. Kuipers, A. Orda, D. Raz, and P. Van Mieghem, “A comparison of exact and $\epsilon$-approximation algorithms for constrained routing,” in Proceedings of the 5th IFIP Networking Conference, Coimbra, Portugal, May 2006.
135. A. Chakrabarti and G. Manimaran, “Reliability constrained routing in QoS networks,” IEEE/ACM Transactions on Networking, vol. 13, no. 3, pp. 662–675, 2005.
136. D. Coudert, P. Datta, S. Perennes, H. Rivano, and M. E. Voge, “Shared risk resource group: complexity and approximability issues,” Parallel Processing Letters, vol. 17, no. 2, pp. 169–184, 2007.
137. J. Q. Hu, “Diverse routing in optical mesh networks,” IEEE Transactions on Communications, vol. 51, no. 3, pp. 489–494, 2003.
138. R. Bhandari, Survivable Networks: Algorithms for Diverse Routing, Kluwer Academic Publishers, New York, NY, USA, 1999.
139. P. Datta and A. K. Somani, “Graph transformation approaches for diverse routing in shared risk resource group (SRRG) failures,” Computer Networks, vol. 52, no. 12, pp. 2381–2394, 2008.
140. X. Luo and B. Wang, “Diverse routing in WDM optical networks with shared risk link group (SRLG) failures,” in Proceedings of the 5th IEE International Workshop on Design of Reliable Communication Networks (DRCN '05), Island of Ischia, Naples, Italy, October 2005.
141. H. W. Lee, E. Modiano, and K. Lee, “Diverse routing in networks with probabilistic failures,” IEEE/ACM Transactions on Networking, vol. 18, no. 6, pp. 1895–1907, 2010.
142. W. D. Grover, Mesh-Based Survivable Transport Networks: Options and Strategies for Optical, MPLS, SONET and ATM Networking, Prentice Hall PTR, London, UK, 2003.
143. D. Xu, Y. Xiong, C. Qiao, and G. Li, “Trap avoidance and protection schemes in networks with shared risk link groups,” Journal of Lightwave Technology, vol. 21, no. 11, pp. 2683–2693, 2003.
144. H. Zang, C. S. Ou, and B. Mukherjee, “Path-protection routing and wavelength assignment (RWA) in WDM mesh networks under duct-layer constraints,” IEEE/ACM Transactions on Networking, vol. 11, no. 2, pp. 248–258, 2003.
145. A. Sen, S. Murthy, and S. Banerjee, “Region-based connectivity—a new paradigm for design of fault-tolerant networks,” in Proceedings of the 15st International Conference on High Performance Switching and Routing (HPSR '09), Paris, France, June 2009.
146. P. K. Agarwal, A. Efrat, S. Ganjugunte, D. Hay, S. Sankararaman, and G. Zussman, “The resilience of WDM networks to probabilistic geographical failures,” in Proceedings of the IEEE INFOCOM, pp. 1521–1529, Shanghai, China, April 2011.
147. S. Neumayer, A. Efrat, and E. Modiano, “Geographic max-flow and mincut under a circular disk failure model,” in Proceedings of the 31st Annual IEEE International Conference on Computer Communications (INFOCOM '12), March 2012.
148. S. Trajanovski, F. A. Kuipers, P. Van Mieghem, A. Ilić, and J. Crowcroft, “Critical regions and region-disjoint paths in a network”.
149. A. A. Beshir, F. A. Kuipers, P. Van Mieghem, and A. Orda, “On-line survivable routing in WDM networks,” in Proceedings of the 21st International Teletraffic Congress (ITC '21), Paris, France, September 2009.
150. A. A. Beshir, F. A. Kuipers, A. Orda, and P. Van Mieghem, “Survivable impairment-aware traffic grooming in WDM rings,” in Proceedings of the 23rd International Teletraffic Congress, San Francisco, Calif, USA, September 2011.
151. A. A. Beshir, F. A. Kuipers, A. Orda, and P. Van Mieghem, “Survivable routing and regenerator placement in optical networks,” in Proceedings of the 4th International Workshop on Reliable Networks Design and Modeling (RNDM '12), Petersburg, Russia, October 2012.
152. A. A. Beshir, R. Nuijts, R. Malhotra, and F. A. Kuipers, “Survivable impairment-aware traffic grooming,” in Proceedings of the 16th European Conference on Networks and Optical Communications (NOC '11), Northumbria University, Newcastle upon Tyne, UK, July 2011.