Minkowski Sums Minkowski Sum—definition, complexity, construction, applications Efi Fogel Tel Aviv University, Israel Algorithmic Robotics and Motion Planning March 14th, 2011 Outline 1 Minkowski Sums Minkowski-sum Definition Minkowski-sum Complexity Constructing 2D Minkowski Sums Constructing 3D Minkowski Sums Applications Literature Minkowski Sums 2 Minkowski Sum Definition Definition (Minkowski sum) d Hermann Minkowski Let P and Q be two point sets in R . The Minkowski 1864–1909 sum of P and Q, denoted as P ⊕ Q, is the point set {p + q | p ∈ P, q ∈ Q}. Applies to every dimension d. Applies to arbitrary point sets. Minkowski Sums 3 Minkowski Sum Examples in IR2 1 p = p + o −2 −1 1 2 3 o −1 q + p p q Minkowski Sums 4 Minkowski Sum Examples in R3 [VM06] Minkowski Sums 5 Minkowski Sum Properties The Minkowski sum of two (non-parallel) line segments in R2 is a convex polygon. The Minkowski sum of two (non-parallel) polygons in R3 is a convex polyhedron. P = P ⊕ {o}, where o is the origin. If P and Q are convex, then P ⊕ Q is convex. P ⊕ Q = Q ⊕ P. λ(P ⊕ Q)= λP ⊕ λQ, where λP = {λp | p ∈ P}. 2P ⊆ P ⊕ P,3P ⊆ P ⊕ P ⊕ P, etc. P ⊕ (Q ∪ R) = (P ⊕ Q) ∪ (P ⊕ R). Minkowski Sums 6 Minkowski-Sum Construction Approaches Decomposition Decompose P and Q into convex sub-polygons P1,..., Pk and Q1,..., Qℓ ℓ ⋆ k = = Si=1 Pi P and Sj=1 Qj Q. Calculate the pairwise sums Sij = Pi ⊕ Qj of the convex sub-polygons. Compute the union P ⊕ Q = Sij Sij . Convolution, denoted P ⊗ Q. Description is deferred. Minkowski Sums 7 Outline 1 Minkowski Sums Minkowski-sum Definition Minkowski-sum Complexity Constructing 2D Minkowski Sums Constructing 3D Minkowski Sums Applications Literature Minkowski Sums 8 Minkowski-sum Complexity: Convex Polygons P, Q — convex polygons with m and n vertices (edges), respectively. M = P ⊕ Q — the Minkowski sum. M is bounded by copies of the m + n edges translated and ordered according to the 3 angle they form with the x-axis. 4 2 M can be computed using an operation 5 1 similar to the merge step of the merge-sort algorithm in O(m + n) time. Start from the two bottommost vertices in P and in Q and merge the ordered list of edges. Computing the overlay of 2 1D arrangements. Minkowski Sums 9 Minkowski-sum Complexity: Arbitrary Simple Polygons P — a simple polygon with m vertices (edges). Q — a simple polygon with n vertices (edges). Upper Bound m−2 P n−2 Q Triangulate P = ∪i=1 Ti and Q = ∪i=1 Ti . Compute the pairwise Minkowski sums P Q M = {Ti ⊕ Tj | 1 ≤ i ≤ m − 2, 1 ≤ j ≤ n − 2}. Compute the union M = S M = P ⊕ Q. Mi ∈M i The number of constant-complexity polygons in M is O(mn) =⇒ the complexity of the union is O(m2n2). Lower Bound 3 — number of blue spikes. 2 — number of red spikes. 22 × 32 = 36 — number of white squares in the Minkowski sum. Minkowski Sums 10 Pseudodiscs Definition (A pair of pseudodiscs) A pair of two planar connected point sets o1 and o2 is called a pair of pseudodiscs if ∂o1 ∩ int(o2) is connected and ∂o2 ∩ int(o1) is connected. The boundaries ∂o1 and ∂o2 intersect in at most two points. pseudodiscs not pseudodiscs Minkowski Sums 11 Gasusian Map (Normal Diagram) in 2D Definition (Gasusian map or normal diagram) The Gaussian map of a convex polygon P is the decomposition of S into maximal connected arcs so that the extremal point of P is the same for all directions Carl Friedrich Gauss within one region. 1777–1855 ⇐⇒ ~ d1 ~ d2 Directions between ~ ~ d1 and d2. ⇐⇒ Generalizes to higher dimensions. Minkowski Sums 12 Minkowski sums and Pseudodiscs Theorem Let P and Q be two convex polygons that are interior disjoint, and let R be another convex polygon. The two Minkowski sums P ⊕ R and Q ⊕ R are pseudodiscs. ~ P is more extreme. d2 Q is more extreme. ~ Q d2 ~ P and Q are equally extreme. d1 ~ d1 ~ d3 P ~ d3 P and Q are interior disjoint convex polygons =⇒ P and Q are extreme in continuous ranges, respectively. Minkowski Sums 13 Minkowski sums and Pseudodiscs (Cont.) An extreme point in direction ~d on P ⊕ R is the sum of extreme points in direction d~ on P and R. M1 = P ⊕ R, M2 = Q ⊕ R Assume ∂M1 ∩ int(M2) is not connected. M1 (resp. M2) is more extreme than M2 (resp. M1) in 2 ranges =⇒ Contradiction! Theorem Let S be a collection of convex polygon that are pairwise pseudodiscs and let n be the total number of edges of the polygons. The complexity of the union of all polygons in S is at most 2n. Minkowski Sums 14 Minkowski-sum Complexity: A convex and an Arbitrary Polygons P — a convex polygon with m vertices (edges). Q — a simple polygon with n vertices (edges). Upper Bound m−2 Triangulate P = ∪i=1 Ti . m−2 P ⊕ Q = ∪i=1 Ti ⊕ Q. Ti ⊕ Q has at most n + 3 vertices. {Ti } is a collection of convex pairwise disjoint interior polygons (triangles) =⇒ {Ti ⊕ Q} is a collection of pairwise pseudodiscs. The complexity of the union is at most 2(m − 2)(n + 3). Lower Bound Minkowski Sums 15 Minkowski-Sum Complexities P, Q — polytopes of m and n complexity. Space Type Complexity convex, convex Θ(m + n) IR2 convex, arbitrary Θ(mn) arbitrary, arbitrary Θ(m2n2) convex, convex Θ(mn) IR3 convex, arbitrary O(ℓk log k) (*) arbitrary, arbitrary Θ(m3n3) convex, convex O((mn)⌊d/2⌋) IRd , d>3 convex, arbitrary ? arbitrary, arbitrary Θ(md nd ) = k * k — the number of convex polytopes Qi that compose Q Si=1 Qi . * ℓ — the total complexity of the individual Minkowski sums P ⊕ Qi . Minkowski Sums 16 Outline 1 Minkowski Sums Minkowski-sum Definition Minkowski-sum Complexity Constructing 2D Minkowski Sums Constructing 3D Minkowski Sums Applications Literature Minkowski Sums 17 Minkowski-sum Construction: Decomposition 1 Decompose P and Q into convex sub-polygons P1,..., Pk and Q1,..., Qℓ 2 Calculate the pairwise sums Sij = Pi ⊕ Qj of the convex sub-polygons. 3 Compute the union P ⊕ Q = Sij Sij . Issues Which union strategy. How to handle degeneracies. Which decomposition algorithm. Addressing of the issues is based on emprical results. The oddity of computing the union. Minkowski Sums 18 The Union of Many Polygons Definition (3SUM) 3SUM is the following computational problem conjectured to require roughly quadratic time: Given a set S of n integers, are there elements a, b, c ∈ S such that a + b + c = 0? A problem is called 3SUM-hard if solving it in subquadratic time implies a subquadratic-time algorithm for 3SUM. Computing the union of polygons is 3SUM-hard. Union Algorithms: Aggregate. Incremental. Divide-and-conquer. Minkowski Sums 19 Divide and Conquer Union Algorithm Definition (Divide and Conquer) A divide and conquer algorithm works by recursively breaking down a problem into two or more sub-problems of the same (or related) type. P — a set of n polygons. Compute the union of each pair of polygons in P to yield n/2 polygons. Use the arrangement-union algorithm. Repeat recursively log n times. Minkowski Sums 20 Computing the Union: Handling Degeneracies Tight passage. Tight placement. 2 1 2 3 Maintain a boundary count for each edge and an inside count for each face. Compare boundary counts with inside counts to identify boundary edges. Minkowski Sums 21 Minkowski-sum Construction: Convex Decomposition No Steiner points Minimize the number of convex sub-polygons, O(n4) time, O(n3) space. [Gre83] Approximate the minimum number of convex sub-polygons, O(n) after triangulation. [HM85] Approximate the minimum number of convex sub-polygons, O(n log n) time, O(n) space. [Gre83] Small side angle-bisector decomposition. [AFH02] Triangulation Naive triangulation. Minimizing the maximum degree triangulation. 2 Minimizing Σdi triangulation. Allowing Steiner points Slab decomposition. Angle-bisector decomposition. [DC85] KD decomposition. Minkowski Sums 22 Minkowski-sum Construction: Convolution P, Q — polygons with vertices (p0,..., pm−1) and (q0,..., qn−1). P and Q have positive orientations P ⊗ Q — the convolution of P and Q is a collection of line segments: −−−→ −−−→ −−−→ [pi + qj , pi+1 + qj ], where pi pi+1 lies between qj−1qj and qj qj+1. −−−→ −−−→ −−−→ [pi + qj , pi + qj+1], where qj qj+1 lies between pi−1pi and pi pi+1. The segments of the convolution form a number of closed polygonal curves called convolution cycles. P (or Q) is convex =⇒ 1 convolution cycle. The Minkowski sum P ⊕ Q is the set of points having a non-zero winding number in the arrangement of convolution cycles. Minkowski Sums 23 Minkowski-sum Construction: Convolution Efficiency The convolution cycle of a convex polygon and a non-convex polygon and the winding numbers it induces. [0] [2] [0] [2] [2] [1] The number of segments in the convolution is usually smaller than the number of segments of the sub-sums of the decomposition. Both approaches construct the arrangement of these segments and extract the sum from this arrangement. Computing Minkowski sums using the convolution approach usually generates a smaller intermediate arrangement. The convolution approach is faster and consumes less space. Minkowski Sums 24 Movie: Exact Minkowski Sums and Applications Minkowski Sums 25 Outline 1 Minkowski Sums Minkowski-sum Definition Minkowski-sum Complexity Constructing 2D Minkowski Sums Constructing 3D Minkowski Sums Applications Literature Minkowski Sums 26 Polytope Definition Definition (convex polyhedron) A convex set Q ⊆ Rd given as an intersection of finite number of closed half-spaces H = {h ∈ Rd | Ah ≤ B} is called convex polyhedron.
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages54 Page
-
File Size-