Finding a Maximum-Weight Convex Set in a Chordal Graph
Total Page:16
File Type:pdf, Size:1020Kb
Finding a Maximum-Weight Convex Set in a Chordal Graph Jean Cardinal, Jean-Paul Doignon, Keno Merckx Abstract We consider a natural combinatorial optimization problem on chordal graphs, the class of graphs with no induced cycle of length four or more. A subset of vertices of a chordal graph is (monophonically) convex if it contains the vertices of all chordless paths between any two vertices of the set. The problem is to find a maximum-weight convex subset of a given vertex-weighted chordal graph. It generalizes previously studied special cases in trees and split graphs. It also happens to be closely related to the closure problem in partially ordered sets and directed graphs. We give the first polynomial-time algorithm for the problem. 1 Introduction In many practical optimization problems, feasible solutions consist of one or more sets that are required to satisfy some kind of convexity constraint. They can take the form of geometrically convex sets, such as in spatial planning problems [35], electoral district design [23], or underground mine design [30]. Alternatively, convexity can be defined in a combinatorial fashion. In the closure problem [32], we are given a directed graph with (positive or nega- tive) vertex weights, and we are asked to find a maximum-weight vertex subset with no outgoing edges. In the case where the directed graph is acyclic, this amounts to find a maximum-weight downset of a partial order. Here, convexity is interpreted as the property of being downward closed. Again, many practical applications are related to the closure problem. For instance, military targeting [28], transportation network design [33] and job scheduling [34]. Recently, a parametric version of the closure problem has been studied by Eppstein [10]. In their seminal paper, Farber and Jamison [13] developed the foundations of a com- binatorial abstraction of convexity in graphs. In particular, they defined convex sets in graphs as subsets of vertices which contain the vertices of all chordless paths between arXiv:1806.09992v1 [cs.DS] 26 Jun 2018 any two vertices of the subset. This particular way of defining convexity in a graph is referred to as monophonic convexity. The collection of monophonic convex sets of a graph has specific nice properties and forms a convex geometry exactly if the graph is chordal. We consider the problem of finding a maximum-weight convex subset of a vertex-weighted chordal graph. We give a polynomial-time algorithm to solve the problem. Until now, only the special cases of trees [1, 24] and split graphs [5] were known to be polynomial-time solvable. Our algorithm for chordal graphs makes use of an algorithm due to Picard [32] for the similar problem on ordered sets. Its design relies on a better understanding of the structure of a chordal graph from the point of view of its convex geometry. The results can be seen as a generalization of two algorithmic results for trees and split graphs, to all chordal graphs. 1 1.1 Previous works The notion of a convex geometry appears in various contexts in mathematics and computer science. Dilworth [7] first examined structures very close to convex geometries in terms of lattice theory. The convex geometries were formally introduced by Jamison [21, 22] and Edelman and Jamison [8] in 1985. Later, Korte, Lov´asz and Schrader [25] considered antimatroids, which is the dual concept to the one of a convex geometry, as a subclass of greedoids. Today, the concept of a convex geometry (or antimatroid) appears in many fields of mathematics such as formal language theory (Boyd and Faigle [4]), choice theory (Koshevoy [26]), game theory (Algaba [2]) and mathematical psychology (Falmagne and Doignon [12]) among others. When weights are assigned to the points of the convex geometry, the natural question of finding a convex set with maximum-weight arises. Particular subproblems are the closure problem [32], the maximum-weight subtree problem [1, 24], the maximum-weight path-closed set [17], or in a more geometrical setting, some variants of the minimum k- gons problem [11]. A more recent example is the problem of finding a maximum-weight convex set in a split graph [5]. For all of these problems, polynomial-time algorithms were published. We also mention that, without focusing on algorithms, Korte and Lov´asz [24] gives linear characterizations of the convex set polytope for certain classes of antimatroids. Searching for a general efficient algorithm to obtain a maximum-weight convex set in convex geometries seems hopeless because the problem is NP -hard even for special cases, see Eppstein [9] and Cardinal, Doignon and Merckx [5]. However, searching for a polynomial-time algorithm for certain classes of convex geometries could reveal bridges between mathematical areas and lead to better understanding of the underlying mathe- matical objects. Chordal graphs and their representations have generated an extensive literature. See for instance Blair and Peyton [3], McKee and McMorris [27] or Golumbic [16] for theoretical and practical applications in various fields such as computational biology, phylogenetic, database, sparse matrix computation and statistics. But, despite a significant number of results about chordal graphs, there was to our knowledge, no polynomial-time algorithm to find a maximum-weight convex set. 1.2 Structure of the paper In the next section, we give basic definitions and notation regarding convex geometries, graphs and posets, and formally define the optimization problem we consider. We also give the definition of the clique-separator graph of a chordal graph, which will be instrumental in what follows. In Section 3, we give a procedure solving the problem in a special family of instances. For this family, the problem is reduced to the closure problem in a partially ordered set. In Section 4 we generalize the algorithm to handle arbitrary chordal graphs and argue that it runs in polynomial time. 2 Preliminaries We review here some basic notation and results for graphs and convex geometries, we also formally define the problems we investigate. 2 2.1 Notation for graphs A (simple) graph G is a pair (V, E) where V is the (finite) set of vertices and E the set of edges, for a background on graph theory we recommend the book by Diestel [6]. A path is a sequence of distinct vertices (v1, . , vn) such that {vi, vi+1} ∈ E for all i in {1,...,n − 1}. The path is chordless if no two vertices are connected by an edge that is not in the path. From a path p = (v1, . , vn) we can extract a chordless path by taking a shortest path between v1 and vn in the subgraph induced by the vertices in p. The graph is connected if for any u, v in V there is a path (u, . , v). A connected component of G is a maximal connected subgraph of G. Each vertex belongs to exactly one connected component, as does each edge. A cycle is a path (v1, . , vn) such that {vn, v1} is an edge. A cycle is chordless if no two vertices of the cycle are connected by an edge that does not itself belong to the cycle. A graph is chordal if every chordless cycle in the graph has at most three vertices. For V ′ ⊆ V we denote by N(V ′) the set of vertices w in V \ V ′ such that {w, v}∈ E for some v in V ′. We write N(v) for N({v}). A clique K of G is a set of pairwise adjacent vertices, we say that K is a maximal ′ ′ clique if there is no clique K of G such that K ⊂ K . We denote by KG the set of all maximal cliques in G. A separator S of G is a set of vertices such that there exist two vertices u, v in V \ S connected by a path in the graph but not in G − S. We say that S is a minimal separator if there is no separator S′ of G such that S′ ⊂ S. For u, v in V , a subset S of V \ {u, v} is a uv-separator if u and v are connected in G but not in G − S. The set S is a minimal vertex separator of G if S is a uv-separator for some u, v in V and S does not strictly contain any uv-separator. Note that any minimal separator is also a minimal vertex separator, but the converse does not hold in general. We denote by SG the set of all minimal vertex separators in G. Note that in chordal graphs, every minimal vertex separator is a clique. We observe that for any chordal graph G = (V, E) we have |KG| 6 |V | and |SG| 6 |V |− 1, the proofs of those inequalities can be found in Fulkerson and Gross [14], and Ho and Lee [18] respectively. 2.2 Convex geometries on posets and chordal graphs A set system (V, C), where V is a finite set of elements and C ⊆ 2V , is a convex geometry when ∅ ∈C, ∀C1,C2 ∈C : C1 ∩ C2 ∈C, ∀C ∈C\{V }, ∃ c ∈ V \ C : C ∪ {c}∈C. The convex sets of the convex geometry (V, C) are the members of C. The feasible sets are the complements in V of the convex sets. An antimatroid (or learning space [12]) is a pair (V, F) such that (V, F ∁) is a convex geometry where F ∁ = {V \ F : F ∈ F}. All results on antimatroids have their counterpart for convex geometries. We recall that a partially ordered set (or poset) P is a pair (V, 6) formed of a finite set V and a binary relation 6 over V which is reflexive, antisymmetric, and transitive.