Counting Plane Graphs: Perfect Matchings, Spanning Cycles, and Kasteleyn’s Technique^{†}^{†}thanks: Work on this paper by the first two authors was partially supported by Grant 338/09 from the Israel Science Fund. Work by Micha Sharir was also supported by NSF Grant CCF0830272, by Grant 2006/194 from the U.S.Israel Binational Science Foundation, and by the Hermann Minkowski–MINERVA Center for Geometry at Tel Aviv University. Emo Welzl acknowledges support from the EuroCores/EuroGiga/ComPoSe SNF grant 20GG21_134318/1. Part of the work on this paper was done at the Centre Interfacultaire Bernoulli (CIB), during the Special Semester on Discrete and Computational Geometry, Fall 2010, and supported by the Swiss National Science Foundation
Abstract
We derive improved upper bounds on the number of crossingfree straightedge spanning cycles (also known as Hamiltonian tours and simple polygonizations) that can be embedded over any specific set of points in the plane. More specifically, we bound the ratio between the number of spanning cycles (or perfect matchings) that can be embedded over a point set and the number of triangulations that can be embedded over it. The respective bounds are for cycles and for matchings. These imply a new upper bound of on the number of crossingfree straightedge spanning cycles that can be embedded over any specific set of points in the plane (improving upon the previous best upper bound ). Our analysis is based on Kasteleyn’s linear algebra technique.
1 Introduction
Finding a Hamiltonian cycle in a graph is complete even if the graph is known to be planar [7]. Counting the number of Hamiltonian cycles that are contained in a graph is complete even if the graph is known to be planar and all of its vertices have degree three [15]. In this paper we consider a more general case (and thus, probably more difficult) concerning the number of all crossingfree straightedge Hamiltonian cycles that can be embedded over a specific set of points in the plane. That is, given a set of labeled points in the plane, we consider the number of Hamiltonian cycles that have a straightedge planar embedding over .
We only consider the problem of obtaining an upper bound for the number crossingfree straightedge Hamiltonian cycles that can be embedded over a set of points in the plane. To do this, we rely on Kasteleyn’s technique [14], and on edgeflipping techniques that were developed in a previous paper by the authors [9]. No familiarity with [9] is necessary, since we reintroduce all the notions that we require from it. We now give a detailed and more formal definition of the problem.
A planar graph is a graph that can be embedded in the plane in such a way that its vertices are embedded as points and its edges are embedded as Jordan arcs that connect the respective pairs of points and can meet only at a common endpoint. A crossingfree straightedge graph is a plane embedding of a planar graph such that its edges are embedded as noncrossing straight line segments. In this paper, we only consider crossingfree straightedge graphs. Moreover, we only consider embeddings where the points are in general position, that is, where no three points are collinear. (For upper bounds on the number of graphs, this involves no loss of generality, because the number of graphs can only grow when a degenerate point set is slightly perturbed into general position.) For simplicity, we sometimes refer to such graphs as plane graphs.
We focus on upper bounding the maximal number of plane spanning cycles (also known as Hamiltonian cycles, Hamiltonian tours, and simple polygonizations) that can be embedded over a fixed set of points in the plane. For a set of points in the plane, we denote by the set of all crossingfree straightedge spanning cycles of , and put . Moreover, we let . So, in other words, the main goal of this paper is to obtain sharp upper bounds on .
There are many similar variants of this problem, such as bounding the number of plane forests, spanning trees, triangulations, and general plane graphs. Recent work on some of these variants can be found in [1, 9, 21], and we try to keep a comprehensive list of the uptodate bounds in a dedicated webpage^{1}^{1}1http://www.cs.tau.ac.il/~sheffera/counting/PlaneGraphs.html (version of June 2010).. It seems that the case of spanning cycles is the most popular one, already considered in [2, 3, 4, 5, 6, 17, 24] and many others. Moreover, spanning cycles were the first case for which bounds were published, namely the bounds in [17]. A brief history of the steady progress on bounding the number of spanning cycles can be found in a dedicated webpage by Erik Demaine^{2}^{2}2http://erikdemaine.org/polygonization/ (version of June 2010).. Currently, the best known lower bound is , due to García, Noy, and Tejel [6], and the previous upper bound is by Dumitrescu et al. [5]. We derive the improved bound .
These problems have also been studied from an algorithmic point of view, deriving algorithms for enumeration or counting of the plane graphs (or other graph types) that can be embedded over a given point set (such as in [13, 19]). The combinatorial upper bounds are useful for analyzing the running times of such algorithms, and also to answer questions such as “how many bits are required to represent a triangulation (or any other kind of plane graphs)?”.
Our bound (as do some of the previous bounds) relies on triangulations. A triangulation of a set of points in the plane is a maximal plane graph on (that is, no additional straight edges can be inserted without crossing some of the existing edges). For a set of points in the plane, we denote by the set of all triangulations of , and put . Moreover, we let . Currently, the best known bounds for are [21], and [5].
The upper bound by Dumitrescu et al. [5] is obtained by proving that for every set of points in the plane . This has sharpened an earlier bound of Buchin et al. [4], who showed that every triangulation of contains at most spanning cycles (i.e., cycles whose edges belong to ), implying^{3}^{3}3The implication comes from the fact that every spanning cycle, and in fact every plane graph, is contained in at least one triangulation; see Section 2. that . Combining the above ratio with the bound directly implies the asserted bound. We derive our bound in a similar manner, showing that .
In spite of our improved bound, we strongly believe, and conjecture, that for every point set (of size at least , for some constant ) one has , and perhaps even a much sharper ratio holds. The best lower bound for this ratio that we know of is obtained from the double chain configuration, presented in [6] (and depicted in Figure 1). It is shown in [6] that when is a double chain configuration, and .^{4}^{4}4In the notations , , and , we neglect polynomial factors. Thus, in this case, . (It is stated in [1], albeit without proof, that , so this example supports our conjecture.)
In Section 2 we go over the preliminaries required for our analysis. These include, among others, the edgeflip techniques used in [9]. Section 3 derives the bound for any set of points in the plane. As part of this derivation, we describe Kasteleyn’s technique for counting perfect matchings and present a new way of applying it. In Section 4 we use the same methods to prove an upper bound on the ratio between the number of plane perfect matchings and the number of triangulations, showing that (where is the number of matchings that can be embedded over the point set ). Finally, Section 5 contains a more complex analysis of spanning cycles, implying the improved bound .
2 Preliminaries
In this section we establish some notations and lemmas that are required for the following sections.

Given two plane graphs and over the same point set , if every edge of is also an edge of , we write .

Hull edges and vertices (resp., interior edges and vertices) of a graph embedded on a point set are those that are part of the boundary of the convex hull of (resp., not part of the convex hull boundary).

Given a set of points in the plane, we denote by the number of hull vertices of , and put , which is the number of vertices in interior to its convex hull.
2.1 The support of a graph
Let us denote by the maximal number of plane spanning cycles that can be contained in any fixed triangulation of a set of points in the plane. Moreover, denote the set of spanning cycles contained in a triangulation by , so .
Any spanning cycle (or, for that matter, any plane graph) is contained in at least one triangulation. Therefore, we can upper bound the number of spanning cycles of a set of points in the plane by going over every triangulation and counting the number of spanning cycles contained in . This implies the bound . Applying the bounds from [21] and from [4], we obtain .
This bounding method seems rather weak since it potentially counts some spanning cycles many times. For example, consider a spanning cycle consisting of two convex chains facing each other, as depicted in the lefthand side of Figure 1. García, Noy, and Tejel [6] show that such a spanning cycle is contained in triangulations of its point set. Therefore, the above method will count this spanning cycle times. However, as stated in [1], this point set has only spanning cycles.
In order to deal with this inefficiency, we define the notion of support (the same notion was also used in [5, 9, 21, 22, 25]). Given a plane edge graph embedded over a set of points in the plane, we say that has a support of if is contained in (exactly) triangulations of ; we write . Notice that
(1) 
because every spanning cycle contributes exactly one to the right side of the equation (it appears in terms of the first sum, and contributes in every appearance). We will use (1) to obtain better upper bounds for , by showing that, on average, is large.
2.2 Psflippable edges
An edge in a triangulation is said to be flippable, if its two incident triangles form a convex quadrilateral. A flippable edge can be flipped, that is, removed from the graph of the triangulation and replaced by the other diagonal of the corresponding quadrilateral. Such an operation is depicted in Figure 2(a), where the edge can be flipped to the edge .
In [9], we present the concept of pseudo simultaneously flippable edges (or psflippable edges, for short). Given a triangulation , we say that a subset of its edges is a set of psflippable edges if the edges of are diagonals of interiordisjoint convex polygons (whose boundaries are also parts of ). For example, in Figure 2(b), the three dashed edges form a set of psflippable edges, since they are diagonals of interiordisjoint convex quadrilateral and convex pentagon (another set of psflippable edges, in a different triangulation, is depicted in Figure 2(c)).
Psflippable edges are related to convex decompositions. A convex decomposition of a point set is a crossingfree straightedge graph on such that (i) includes all the hull edges, (ii) each bounded face of is a convex polygon, and (iii) no point of is isolated in . See Figure 2(c) for an illustration. For additional information about convex decompositions, see, for example, [10]. Notice that if is a triangulation that contains , the edges of form a set of psflippable edges, since they are the diagonals of the interiordisjoint convex polygons of (again, consider the dashed edges in Figure 2(c) for an illustration). Thus, finding a large set of psflippable edges in a triangulation is equivalent to finding a convex decomposition with a small number of faces (or edges) in .
In [9], we prove the two following lemmas.
Lemma 2.1
Every triangulation over a set of points in the plane contains a set of psflippbale edges. Also, there are triangulations with no larger sets of psflippable edges.
Lemma 2.2
Consider a triangulation , a set of psflippable edges in , and a graph . If does not contain edges from then .
Proof sketch. Consider the set of psflippable edges. The convex faces of can be triangulated in at least ways (the bound is tight when every edge of is a diagonal of a distinct quadrangular face of ), and each of the resulting triangulations contains . See [9] for more details.
We now describe another property of convex decompositions (not discussed in [9]). Consider a set of points in the plane and a crossingfree straightedge graph embedded on . We say that an interior point has a valid triple of edges in if there exist three points such that is contained in the convex hull of and the edges , , and belong to . To simplify the notation, we refer to vertices with valid triples as valid (with respect to ), and to the other interior vertices as nonvalid.
Lemma 2.3
Let be a set of points in the plane and let be a crossingfree straightedge graph over that contains all the edges of the convex hull of . Then is a convex decomposition of if and only if every interior vertex of is valid with respect to .
Proof . An interior vertex is a reflex vertex of some face of if and only if is nonvalid (an example is depicted in Figure 3(a)). The lemma follows by observing that is a convex decomposition if and only if no bounded face of has a reflex vertex.
2.3 Spanning cycles and perfect matchings
Our analysis, as most of the previous works dealing with the number spanning cycles, heavily relies on the number of plane perfect matchings on (for example, see [4, 5, 24]). To see the connection between the two problems, notice that if is even, every spanning cycle is the union of two edgedisjoint perfect matchings on ; namely, the matching consisting of the evenindexed edges of , and the matching consisting of the oddindexed edges. An illustration of this property is depicted in Figure 3(b). Denote by the set of all plane perfect matchings on , and put . We also set . Hence, a simple upper bound on is . In general, the union of two edgedisjoint perfect matchings is not always a spanning cycle, but it is a cover of by vertexdisjoint evensized cycles.
To deal with point sets of odd size, we use the following lemma:
Lemma 2.4
Let be a constant such that every set of an even number of points in the plane satisfies . Then also holds for sets of an odd number of points.
Proof . Consider a set of points in the plane, where is odd. Pick a new point outside the convex hull of , and put . Let be a plane spanning cycle of . Then there exists an edge of such that can be connected to the two endpoints of without crossing . Indeed, this is a projective variant of the property, noted in [8], that every finite collection of noncrossing straight segments in the plane contains a segment such that no other segment lies vertically above any point of (see also [18, Section 8.7]). By replacing with the edges and , we obtain a crossingfree spanning cycle of . This implies that we can map every spanning cycle of to a distinct spanning cycle of , and thus, . The lemma then follows since .
Bounding the number of perfect matchings on within a fixed triangulation can be done by the beautiful linearalgebra technique of Kasteleyn [14], described in detail in [16, Section 8.3]; see Section 3 for more details. Buchin et al. [4] have used this technique to show that any triangulation of contains at most perfect matchings, and at most spanning cycles. We also note that Sharir and Welzl [24] showed that , completely bypassing the approach of counting matchings (or other graphs) within a triangulation.
3 A first bound
In this section we first review an enhanced variant of Kasteleyn’s technique and then use it to derive the following initial upper bound on .
Theorem 3.1
For any set of points in the plane,
Proof . First, by Lemma 2.4, we may assume that is even. Consider a triangulation of . As already observed, every spanning cycle contained in is the union of two edgedisjoint perfect matchings contained in . Given a plane graph , we denote by the set of all perfect matchings that are contained in . Recalling (1), we have
(The inequality comes from the fact that not every pair of matchings, as in the sum, necessarily yields a spanning cycle.) Let us fix the “first” perfect matching ; as mentioned above, Buchin et al. [4] prove that , so there are at most choices of . Next, we construct a convex decomposition such that , as follows. We start with and add all the missing hull edges; let us denote the resulting graph as . By Lemma 2.3, it suffices to ensure that every interior point is connected in to (at least) three points , such that is inside the convex hull of . Every interior vertex of has degree 1 in , so we start by setting , and then, for each interior point , we add to two additional edges of adjacent to , so as to create a valid triple. To do so, let be the edge of (that is, of ) incident to , and let be the ray emanating from in the opposite direction. Let (resp., ) be the first edge of incident to encountered in clockwise (resp., counterclockwise) direction from ; see Figure 4(a). Then is a valid triple of edges, and we add to . After applying this step to each interior point , the resulting graph is indeed a convex decomposition of .
We denote by the set of edges that are in but not in . The edges of are diagonals of interiordisjoint convex polygons, and thus is a set of psflippable edges. By Euler’s formula, the triangulation contains interior edges, and contains at most interior edges (at most edges of and added edges to form valid triples). Therefore,
Remark. Note the strength of this bound: Lemma 2.1 has a rather involved proof, given in [9], and it yields a set of psflippable edges in the entire triangulation. In contrast, here we get the same number (minus 1) after we remove from an arbitrary perfect matching, with a considerably simpler analysis. Thus the significance of the analysis in [9] (involving Lemma 2.1) is only for triangulations which contain no perfect matching on . For example, any triangulation with more than interior vertices of degree 3 cannot contain a perfect matching, since, as is easily checked, two interior vertices of degree 3 cannot share an edge.
Without loss of generality, we assume that consists of exactly edges. We now proceed to bound the number of ways to choose the second matching while taking the supports of the resulting graphs into account. Since and have to be edgedisjoint, we can remove the edges of from , and remain with a subgraph that has fewer than edges. Next, we define a weight function over the edges of , such that every edge in has a weight of 1 and every other edge has a weight of . We define the weight of a perfect matching as the product of the weights of its edges. Therefore, if contains exactly edges of , then . Moreover, for such a matching , we have . Clearly, is also a set of psflippable edges, none of which belongs to . We thus have
which implies that, given a specific triangulation and a specific perfect matching ,
(2) 
with , as above.
Kasteleyn’s technique: An enhanced version.
We now apply an extension of Kasteleyn’s technique to estimate the sum in the righthand side of (2). Here is a brief overview of the technique being used (where instead of the original technique, we apply a weighted extension of it). Given an oriented graph^{5}^{5}5We follow here the notation used in [16] to denote a digraph obtained from an underlying undirected graph by giving each of its edges an orientation. with no antiparallel edges and a weight function over the edges, we define the following weighted adjacency matrix of ,
(where , and the rows and columns of correspond to an arbitrary fixed enumeration of the vertices).
An easy extension of Kasteleyn’s theorem states that every planar graph can be oriented into some digraph such that, for any realvalued weight function on its edges, we have
(3) 
(recall that ). In the “pure” form of Kasteleyn’s theorem (i.e., is unweighted) and the lefthand side is just the squared number of perfect matchings in . A detailed presentation of Kasteleyn’s theorem can be found in [16, Section 8.3]. The extension to weighted graphs is given in Exercise 8.3.9 therein.
We denote by the column vectors of , for , and estimate the above determinant using Hadamard’s inequality
(4) 
Applying the above machinery to our plane graph (i.e., using (3) and (4)), with the edge weights as defined above, we have
(5)  
(where we have used the arithmeticgeometric mean inequality and the fact that every edge of has two corresponding matrix entries). We note that the bound on the number of perfect matchings in a triangulation is obtained in [4] by applying the unweighted version of Kasteleyn’s theorem to the entire . In this case is the number of edges of , which is at most , and the bound follows.
By noting that
and combining this with (2) and (5), we obtain
(6)  
Recalling once again that a triangulation contains at most perfect matchings [4] (that is, there are ways of choosing ), and combining this with (6), we obtain
as asserted.
Corollary 3.2
.
4 Perfect matchings and triangulations
In this section we apply the machinery of the previous section to derive an upper bound on the ratio between the number of plane perfect matchings and the number of triangulations. As already mentioned in Section 2, Kasteleyn’s technique implies that a triangulation of a set of points can contain at most perfect matchings (see [4]). This implies that for every set of points in the plane, . We will improve this bound, using lower bounds on the supports of perfect matchings, in a manner similar to that in Section 3.
Before proceeding, we note the following lower bound on the ratio . Let be a double circle configuration, depicted in Figure 4(b), consisting of points (see [11] for a precise definition). An inclusionexclusion argument implies that (see [11, 20]). Moreover, Aichholzer et al. [1] proved that . Therefore, in this case, .
We now present an improved upper bound for this ratio.
Theorem 4.1
For any set of points in the plane,
Proof . The exact value of is
(7) 
Consider a triangulation and a perfect matching . As shown in the proof of Theorem 3.1, there exists a set of psflippable edges in . Therefore, the support of is at least . Combining this with (7) implies
As already mentioned above, this does not imply a new bound on , since Sharir and Welzl [24] showed that , bypassing the approach of counting matchings within a triangulation. We are not aware of any construction for which , and offer the conjecture that there exists a constant such that for every finite set of points in the plane. (See also the conjecture concerning spanning cycles, made in the introduction.)
5 An improved bound
In this section we present a more complex analysis for the number of spanning cycles, obtaining a slightly better bound than the one presented in Section 3. The analysis has three parts, each presented in a separate subsection.
Let us denote the number of interior vertices of degree 3 in the triangulation as . Moreover, let us denote the number of flippable edges in as . In Subsection 5.1 we give an upper bound for that depends on . In Subsection 5.2 we give an upper bound for that depends on . Finally, in Subsection 5.3 we combine these two bounds to obtain
5.1 A sensitive bound
In this subsection we derive the following bound, which is a function of and .
Lemma 5.1
Let be a triangulation over a set of points in the plane, such that is even and has a triangular convex hull; also, let . Then
Proof . As before, we treat every spanning cycle as the union of two edgedisjoint perfect matchings . We start by bounding the number of ways to choose the first perfect matching . For this, we use the standard variant of Kasteleyn’s technique, with the weight function (i.e., is unweighted).
Recall the inequality obtained in Equation (5), where the (for ) are the column vectors of the adjacency matrix of the oriented graph . Substituting , the left hand side becomes the number of perfect matchings in , and the squared norm of each column vector is the degree of the vertex corresponding to that column. Since every column that corresponds to a vertex of degree 3 has a squared norm of 3, the product of the squared norms of these is .
For the remaining columns, we use, as in Section 3, the arithmeticgeometric mean inequality to bound the product of their squared norms (as in Equation (5)). This yields the bound
(8) 
where is the sum of the degrees of all vertices other than those counted in . The sum of the degrees over the vertices of any specific triangulation is smaller than , and the sum of the degrees of the interior degree3 vertices in is . Therefore, we have
(9) 
Combining (8), (9), and the product of the squared norms that correspond to interior vertices of degree 3, implies that the number of ways to choose is less than
(10) 
Next, let us fix a specific perfect matching . As shown in the beginning of the proof of Theorem 3.1, there exists a set of psflippable edges in , none of which belongs to .
We continue as in the proof of Theorem 3.1, by assigning a weight of 1 to the edges of and a weight of to the rest of the edges of , and then applying Kaseteleyn’s technique to bound the sum
where are the column vectors of the oriented adjacency matrix of (recall (2)).
An interior vertex of degree 3 in has only two edges adjacent to it in , both not in (since an edge adjacent to an interior vertex of degree 3 cannot be flippable). Therefore, the squared norm of a matrix column that corresponds to such a vertex is , and the product of the squared norms of all such columns is .
For the remaining columns, we may once again use the arithmeticgeometric mean inequality to obtain a bound similar to the one in (8). However, this time we get a different value for , since (i) some of the edges of were removed, and (ii) some of the remaining edges were reweighted. The edges of have remained and still have a weight of 1 each, so they contribute at most to . Every other edge contributes if it is not incident to an interior vertex of degree 3 in , and otherwise. Since a triangulation has fewer than edges, there are fewer than edges in , and we get
By combining this with the rest of the squared norms and with the present version of (8), we have
(11) 
Finally, to complete the proof, we combine (10) and (11), and obtain
Remark.
5.2 A sensitive bound
Hurtado, Noy, and Urrutia [12] prove that that , and that this bound is tight in the worst case (the upper bound is also implied by Lemma 2.1; see also [9]). In this subsection we obtain a bound as a function of , which improves our initial bound of when is larger than by some positive fraction of . We start by mentioning two basic properties of triangulated polygons.
Ears.
Given a triangulated polygon , an ear of is a bounded face of the triangulation with two of its edges on the boundary of . It can easily be shown that every triangulated simple polygon with at least four edges contains at least two ears (whose boundary edges are all distinct). For example, the two ears of the triangulated polygon in Figure 5(a) are shown shaded.
Catalan numbers.
The th Catalan number is . It is well known that a convex polygon with vertices has triangulations (e.g., see [23, Section 5.3]). Therefore, the number of triangulations of a convex polygon with diagonals is
(12) 
(the inequality can easily be verified by induction).
Next, we define as the maximum real number satisfying the following property. Every simple polygon that has a triangulation with of its diagonals flippable and with of these diagonals forming a psflippable set, has at least triangulations. Notice that the triangulations under consideration, including , are triangulations of the polygon , and not of its vertex set.
Lemma 5.2
with the unique real root of the polynomial . That is, every simple polygon that has a triangulation with of its diagonals flippable and with of these diagonals forming a psflippable set, has at least triangulations.
Proof . Figure 5(b) depicts a polygon that implies the upper bound.
We prove the lower bound by induction on and . To have some base case for this induction, notice that when , has at least triangulations.
Next, consider a polygon and a triangulation of , such that contains a maximal set of psflippable edges, and flippable edges not in . Let be the nontriangular faces of the convex subdivision . (Notice that is a convex subdivision of a polygon, and not of the convex hull of a point set.) Each is a convex polygon with sides and diagonals, and thus, .
A flippable edge not in must be on the boundary of some , since otherwise is not maximal. We say that such a flippable edge is covered by a face if (i) is on the boundary of , and (ii) the triangle in that is contained in and incident to has two edges in (so is the only edge of on the boundary of ). Ears are incident to two edges of their containing , and thus, cannot cover any edge. Since any triangulated polygon contains at least two ears, with four distinct boundary edges, a polygon with sides (and diagonals) can cover at most edges. Therefore, if all flippable edges not in are covered, then . By multiplying the number of triangulations of the ’s and applying (12), we get that the number of triangulations of that contain is at least
We are left with the case where there is a flippable edge that is not covered by any . Let be the edge obtained by flipping . We now derive a lower bound on the number of triangulations of that contain and on the number of triangulations of that contain . To bound the number of triangulations that contain , we partition into two interior disjoint simple polygons by “cutting” at . More precisely, we consider the two triangulated polygons . Together, these two triangulated polygons contain diagonals that are flippable. Moreover, the set remains a set of psflippable edges which are diagonals of the two polygons. Thus, the induction hypothesis implies that there are at least triangulations of that contain . To obtain a similar bound for the number of triangulations containing , we produce at most four triangulated subpolygons of by removing the two triangles incident to (which cover the same quadrilateral covered by the two triangles incident to in the new triangulation). Such a case is illustrated in Figure 6(a), where the triangles incident to are shaded. This partitioning may cancel the flippability of at most five edges (those incident to the two triangles adjacent to ). At most two out of the five edges may be psflippable, since can only be incident to ears of polygons of . Using the induction hypothesis again, we get that there are at least triangulations that contain (and the four edges around it). Therefore, has at least
triangulations, as asserted (recall that is the root of the polynomial ).
Next, we show how to use and to bound .
Lemma 5.3
Consider a triangulation with , for some , and let be the constant presented in Lemma 5.2. Then
where
Proof . Once again, we treat every spanning cycle as the union of a pair of edgedisjoint perfect matchings , and use Kasteleyn’s technique (as presented in Section 3) to bound the number of such pairs. We start by fixing some perfect matching and denote the number of flippable edges of that are in as . As shown in the proof of Theorem 3.1, there is a set of at least psflippable edges in . We restrict our attention to a set of exactly psflippable edges in .
For the choice of , we define a weight function on the edges of , such that
Notice that any spanning cycle partitions the convex hull of its point set into interiordisjoint simple polygons; an example of such a partition is illustrated in Figure 5(b). The support of the spanning cycle is the product of the number of triangulations of each of these polygons. For a fixed choice of (and of ), denote by the polygons in the partition produced by . For each , let be the number of flippable diagonals of , and let be the number of those diagonals (among the flippable ones) that belong to . If uses flippable edges of , of which are in , then and . Applying Lemma 5.2 to each and multiplying the resulting bounds, we obtain a total of at least triangulations. Hence,
Next, notice that , so we have
(13) 
By combining (13) with Kasteleyn’s method, we obtain