(Still refinining... this blog entry. More images will be added to aid understanding... hopefully)
Introduction:
In the following discussion, Voronoi diagram and halfplane intersection refer to the 2D case, unless otherwise specified.I hope I can list some nice properties of as well as some relationships between the following three structures in computational geometry:
- Voronoi diagram
[You need to understand what is going on on the right image.The left and the middle will be discussed below.] - Delaunay triangulation
- 3D convex hull
Listed are some assumed knowledge before proceeding:
- Dual of a graph
- 3D geometry intuition
- Idea of halfplane intersection (just an idea is enough)
- Idea of tangent plane to a 3D surface
- Idea of Voronoi diagram
If you have no idea, play along with this applet to get a feeling!
1) Voronoi Diagram and Delaunay Triangulation
For a point set, P, (each point also known as a site) define:
- V(P) := Voronoi diagram
- D(P) := Delaunay triangulation := Straight line dual of V(P)
- V(p) := Region of site p in V(P)
(e.g., Property 2. will be broken)
A) Properties:
- (Intuitive) V(P) is composed of (not all) segments of perpendicular bisectors between sites.
- V(P) and D(P) are dual to each other.
- Every face of the D(P) is a triangle.
(Or we cant name it as triangulation, but this property is not trivial) - Following are correspondences between V(P) and D(P) :
- Vertex ↔ Triangle
- Edge ↔ Edge
- Node ↔ Region
- Let v be a vertex on V(P), s.t., it is at the junction of V(p1) , V(p2), V(p3).
Then v is the center of the circumcircle of p1, p2, p3.
Let C(v) := this circle. - The interior of C(v) (in 5.) has no sites, i.e., C(v) is an empty circle.
- If some circle through p1, p2 contains no other sites, then (p1, p2) is an edge of D(P). The reverse also holds.
- Delaunay triangulation maximizes the minimum angle: (最小角最大化)
Let T be a triangulation of a point set S. Let its angle sequence {αi} be list of angles of triangles, sorted from smallest to largest. Let {βi} be the angle sequence for a Delaunay triangulation. Then, we have {βi} ≥ {αi} for all T.
Note 1: Here, "≥" means lexicographically greater than.
Note 2: D(P) maximizes the 2nd minimum angle, in case the smallest angle ties.
Note 3: Intuitively, D(P) gives "fatter" triangles - we prefer fatter triangles for its higher numerical stability in other applications.
- Nearest neighbors
The nearest neighbor graph (NNG) is a subset of D(P):
i.e., if p1 is nearest neighbor to p2, then (p1, p2) is an edge of D(P). - Euclidean MST
The minimum spanning tree of the complete graph for P is a subset of D(P).
- By halfplane intersection - O(N2 lg N)
For a fixed site p, for each other site q, define halfplane hq := {Points closer to p than q}. Then, V(p) is the intersection of all hq's, and it can be found in O(N lg N) time. The number of V(p) is O(N), so the overall complexity for computing V(P) is O(N2 lg N). - Fortune's plane sweep algorithm - Inverted cones intersection - O(N lg N)
Idea: For each site p, erect a cone whose apex is at p, with sides slope at 45 degree. The Voronoi diagram can be thought as expanding circles from each site. Imagine you cut these (solid) cones with z = c and observe the intersection, you get a moment when the circles are expanding. If you gradually increase c from 0 to ∞, you actually simulate the expansion of these circles. Therefore, when viewing down from z = ∞, you see the Voronoi diagram!
Note 1: For real implementation, we need to maintain a parabolic front.
Note 2: That's also why Voronoi diagram can be computed quite quickly using GPU. - By 3D convex hull - O(N2) / expected O(N lg N)
The time complexity is due to 3D convex hull algorithm. See next section.
- Furthest point Voronoi diagram
- Medial axis / Skeleton of a polygon
= Voronoi diagram, when a site is an edge of a polygon
2) 3D Convex Hull VS Voronoi Diagram=Delaunay Triangulation
For a point set, P, (each point also known as a site) define:
- V(P) := Voronoi diagram
- D(P) := Delaunay triangulation := Straight line dual of V(P)
- V(p) := Region of site p in V(P)
- H(P) := 3D convex hull of { f(p) | p ∈ P }
Paraboloid transformation: f(x, y) := x2 + y2
A) Properties:
- Projecting the "lower" part of H(P) onto the x-y plane, we get D(P)
- Let Tp = the tangent plane at the converted point f(p) to the paraboloid f.
For site p1, p2, when the intersection of Tp1, Tp2 (a straight line) is projected onto the x-y plane, we get the perpendicular bisector of p1 and p2. - If we put tangnet planes of all sites (Tp 's) to the space, and view them from z = ∞, according to Property 2., we will see V(P)!
- Extension to higher dimension of Property 2.
3) *Extension - Arrangements of lines:
Together with convex hull and Voronoi diagram (= Delaunay triangulation), arrangement of lines are the third important structures used in computaional geomtry, and there are many beautiful properties linking them together. (We already go through some between the former two.)
Furthermore, most of these properties and relationships perserve in higher dimension.
Some topics about arrangement of lines listed below:
- Zone's theorem
- Point / line duality
There are different possible mappings, but the most convenient one is:
L : y = 2ax - b ⇔ p : (a, b)
This mapping is intimately related to the paraboloid transformation, and therefore fullfills many beautiful properties. - Relationship between halfplane intersection and convex hull
4) External links:
- Voronoi/Delaunay Applet
- CS 497: Computational Geometry
A schedule of a CG course, listing various topics in CG - Is there anything new to say about Voronoi diagrams?
About Voronoi digram in higher dimension - Furthest Point Voronoi Diagram
Discuss the construction algorithm - Point/Line duality
Applet - http://acm-kn.xanga.com/716525481/duality-in-cg/
When I started to think I really have to know about this for ACM...
沒有留言:
發佈留言