Misplaced Pages

Minkowski addition

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Minkowski difference) Sums vector sets A and B by adding each vector in A to each vector in B
The red figure is the Minkowski sum of blue and green figures.

In geometry, the Minkowski sum of two sets of position vectors A and B in Euclidean space is formed by adding each vector in A to each vector in B:

A + B = { a + b | a A ,   b B } {\displaystyle A+B=\{\mathbf {a} +\mathbf {b} \,|\,\mathbf {a} \in A,\ \mathbf {b} \in B\}}

The Minkowski difference (also Minkowski subtraction, Minkowski decomposition, or geometric difference) is the corresponding inverse, where ( A B ) {\textstyle (A-B)} produces a set that could be summed with B to recover A. This is defined as the complement of the Minkowski sum of the complement of A with the reflection of B about the origin.

B = { b | b B } A B = ( A + ( B ) ) {\displaystyle {\begin{aligned}-B&=\{\mathbf {-b} \,|\,\mathbf {b} \in B\}\\A-B&=(A^{\complement }+(-B))^{\complement }\end{aligned}}}

This definition allows a symmetrical relationship between the Minkowski sum and difference. Note that alternately taking the sum and difference with B is not necessarily equivalent. The sum can fill gaps which the difference may not re-open, and the difference can erase small islands which the sum cannot recreate from nothing.

( A B ) + B A ( A + B ) B A A B = ( A + ( B ) ) A + B = ( A ( B ) ) {\displaystyle {\begin{aligned}(A-B)+B&\subseteq A\\(A+B)-B&\supseteq A\\A-B&=(A^{\complement }+(-B))^{\complement }\\A+B&=(A^{\complement }-(-B))^{\complement }\\\end{aligned}}}

In 2D image processing the Minkowski sum and difference are known as dilation and erosion.

An alternative definition of the Minkowski difference is sometimes used for computing intersection of convex shapes. This is not equivalent to the previous definition, and is not an inverse of the sum operation. Instead it replaces the vector addition of the Minkowski sum with a vector subtraction. If the two convex shapes intersect, the resulting set will contain the origin.

A B = { a b | a A ,   b B } = A + ( B ) {\displaystyle A-B=\{\mathbf {a} -\mathbf {b} \,|\,\mathbf {a} \in A,\ \mathbf {b} \in B\}=A+(-B)}

The concept is named for Hermann Minkowski.

Example

Minkowski sum A + B

For example, if we have two sets A and B, each consisting of three position vectors (informally, three points), representing the vertices of two triangles in R 2 {\textstyle \mathbb {R} ^{2}} , with coordinates

A = { ( 1 , 0 ) , ( 0 , 1 ) , ( 0 , 1 ) } {\displaystyle A=\{(1,0),(0,1),(0,-1)\}}

and

B = { ( 0 , 0 ) , ( 1 , 1 ) , ( 1 , 1 ) } {\displaystyle B=\{(0,0),(1,1),(1,-1)\}}

then their Minkowski sum is

A + B = { ( 1 , 0 ) , ( 2 , 1 ) , ( 2 , 1 ) , ( 0 , 1 ) , ( 1 , 2 ) , ( 1 , 0 ) , ( 0 , 1 ) , ( 1 , 0 ) , ( 1 , 2 ) } , {\displaystyle A+B=\{(1,0),(2,1),(2,-1),(0,1),(1,2),(1,0),(0,-1),(1,0),(1,-2)\},}

which comprises the vertices of a hexagon and its center.

For Minkowski addition, the zero set, { 0 } , {\textstyle \{0\},} containing only the zero vector, 0, is an identity element: for every subset S of a vector space,

S + { 0 } = S . {\displaystyle S+\{0\}=S.}

The empty set is important in Minkowski addition, because the empty set annihilates every other subset: for every subset S of a vector space, its sum with the empty set is empty:

S + = . {\displaystyle S+\emptyset =\emptyset .}

For another example, consider the Minkowski sums of open or closed balls in the field K , {\textstyle \mathbb {K} ,} which is either the real numbers R {\textstyle \mathbb {R} } or complex numbers C {\textstyle \mathbb {C} } . If B r := { s K : | s | r } {\textstyle B_{r}:=\{s\in \mathbb {K} :|s|\leq r\}} is the closed ball of radius r [ 0 , ] {\textstyle r\in } centered at 0 {\textstyle 0} in K {\textstyle \mathbb {K} } then for any r , s [ 0 , ] {\textstyle r,s\in } , B r + B s = B r + s {\textstyle B_{r}+B_{s}=B_{r+s}} and also c B r = B | c | r {\textstyle cB_{r}=B_{|c|r}} will hold for any scalar c K {\textstyle c\in \mathbb {K} } such that the product | c | r {\textstyle |c|r} is defined (which happens when c 0 {\textstyle c\neq 0} or r {\textstyle r\neq \infty } ). If r {\textstyle r} , s {\textstyle s} , and c {\textstyle c} are all non-zero then the same equalities would still hold had B r {\textstyle B_{r}} been defined to be the open ball, rather than the closed ball, centered at 0 (the non-zero assumption is needed because the open ball of radius 0 is the empty set). The Minkowski sum of a closed ball and an open ball is an open ball. More generally, the Minkowski sum of an open subset with any other set will be an open subset.

If G = { ( x , 1 / x ) : 0 x R } {\textstyle G=\{(x,1/x):0\neq x\in \mathbb {R} \}} is the graph of f ( x ) = 1 x {\textstyle f(x)={\frac {1}{x}}} and if and Y = { 0 } × R {\textstyle Y=\{0\}\times \mathbb {R} } is the y {\textstyle y} -axis in X = R 2 {\textstyle X=\mathbb {R} ^{2}} then the Minkowski sum of these two closed subsets of the plane is the open set G + Y = { ( x , y ) R 2 : x 0 } = R 2 Y {\textstyle G+Y=\{(x,y)\in \mathbb {R} ^{2}:x\neq 0\}=\mathbb {R} ^{2}\setminus Y} consisting of everything other than the y {\textstyle y} -axis. This shows that the Minkowski sum of two closed sets is not necessarily a closed set. However, the Minkowski sum of two closed subsets will be a closed subset if at least one of these sets is also a compact subset.

Convex hulls of Minkowski sums

Minkowski addition behaves well with respect to the operation of taking convex hulls, as shown by the following proposition:

For all non-empty subsets S 1 {\textstyle S_{1}} and S 2 {\textstyle S_{2}} of a real vector space, the convex hull of their Minkowski sum is the Minkowski sum of their convex hulls: Conv ( S 1 + S 2 ) = Conv ( S 1 ) + Conv ( S 2 ) . {\displaystyle \operatorname {Conv} (S_{1}+S_{2})=\operatorname {Conv} (S_{1})+\operatorname {Conv} (S_{2}).}

This result holds more generally for any finite collection of non-empty sets:

Conv ( S n ) = Conv ( S n ) . {\displaystyle \operatorname {Conv} \left(\sum {S_{n}}\right)=\sum \operatorname {Conv} (S_{n}).}

In mathematical terminology, the operations of Minkowski summation and of forming convex hulls are commuting operations.

If S {\textstyle S} is a convex set then μ S + λ S {\displaystyle \mu S+\lambda S} is also a convex set; furthermore

μ S + λ S = ( μ + λ ) S {\displaystyle \mu S+\lambda S=(\mu +\lambda )S}

for every μ , λ 0 {\textstyle \mu ,\lambda \geq 0} . Conversely, if this "distributive property" holds for all non-negative real numbers, μ {\textstyle \mu } and λ {\textstyle \lambda } , then the set is convex.

An example of a non-convex set such that A + A 2 A . {\textstyle A+A\neq 2A.}

The figure to the right shows an example of a non-convex set for which A + A 2 A . {\textstyle A+A\subsetneq 2A.}

An example in one dimension is: B = [ 1 , 2 ] [ 4 , 5 ] . {\textstyle B=\cup .} It can be easily calculated that 2 B = [ 2 , 4 ] [ 8 , 10 ] {\textstyle 2B=\cup } but B + B = [ 2 , 4 ] [ 5 , 7 ] [ 8 , 10 ] , {\textstyle B+B=\cup \cup ,} hence again B + B 2 B . {\textstyle B+B\subsetneq 2B.}

Minkowski sums act linearly on the perimeter of two-dimensional convex bodies: the perimeter of the sum equals the sum of perimeters. Additionally, if K {\textstyle K} is (the interior of) a curve of constant width, then the Minkowski sum of K {\textstyle K} and of its 180° rotation is a disk. These two facts can be combined to give a short proof of Barbier's theorem on the perimeter of curves of constant width.

Applications

Minkowski addition plays a central role in mathematical morphology. It arises in the brush-and-stroke paradigm of 2D computer graphics (with various uses, notably by Donald E. Knuth in Metafont), and as the solid sweep operation of 3D computer graphics. It has also been shown to be closely connected to the Earth mover's distance, and by extension, optimal transport.

Motion planning

Minkowski sums are used in motion planning of an object among obstacles. They are used for the computation of the configuration space, which is the set of all admissible positions of the object. In the simple model of translational motion of an object in the plane, where the position of an object may be uniquely specified by the position of a fixed point of this object, the configuration space are the Minkowski sum of the set of obstacles and the movable object placed at the origin and rotated 180 degrees.

Numerical control (NC) machining

In numerical control machining, the programming of the NC tool exploits the fact that the Minkowski sum of the cutting piece with its trajectory gives the shape of the cut in the material.

3D solid modeling

In OpenSCAD Minkowski sums are used to outline a shape with another shape creating a composite of both shapes.

Aggregation theory

Minkowski sums are also frequently used in aggregation theory when individual objects to be aggregated are characterized via sets.

Collision detection

Minkowski sums, specifically Minkowski differences, are often used alongside GJK algorithms to compute collision detection for convex hulls in physics engines.

Algorithms for computing Minkowski sums

Minkowski addition of four line-segments. The left-hand pane displays four sets, which are displayed in a two-by-two array. Each of the sets contains exactly two points, which are displayed in red. In each set, the two points are joined by a pink line-segment, which is the convex hull of the original set. Each set has exactly one point that is indicated with a plus-symbol. In the top row of the two-by-two array, the plus-symbol lies in the interior of the line segment; in the bottom row, the plus-symbol coincides with one of the red-points. This completes the description of the left-hand pane of the diagram. The right-hand pane displays the Minkowski sum of the sets, which is the union of the sums having exactly one point from each summand-set; for the displayed sets, the sixteen sums are distinct points, which are displayed in red: The right-hand red sum-points are the sums of the left-hand red summand-points. The convex hull of the sixteen red-points is shaded in pink. In the pink interior of the right-hand sumset lies exactly one plus-symbol, which is the (unique) sum of the plus-symbols from the right-hand side. The right-hand plus-symbol is indeed the sum of the four plus-symbols from the left-hand sets, precisely two points from the original non-convex summand-sets and two points from the convex hulls of the remaining summand-sets.
Minkowski addition and convex hulls. The sixteen dark-red points (on the right) form the Minkowski sum of the four non-convex sets (on the left), each of which consists of a pair of red points. Their convex hulls (shaded pink) contain plus-signs (+): The right plus-sign is the sum of the left plus-signs.

Planar case

Two convex polygons in the plane

For two convex polygons P and Q in the plane with m and n vertices, their Minkowski sum is a convex polygon with at most m + n vertices and may be computed in time O(m + n) by a very simple procedure, which may be informally described as follows. Assume that the edges of a polygon are given and the direction, say, counterclockwise, along the polygon boundary. Then it is easily seen that these edges of the convex polygon are ordered by polar angle. Let us merge the ordered sequences of the directed edges from P and Q into a single ordered sequence S. Imagine that these edges are solid arrows which can be moved freely while keeping them parallel to their original direction. Assemble these arrows in the order of the sequence S by attaching the tail of the next arrow to the head of the previous arrow. It turns out that the resulting polygonal chain will in fact be a convex polygon which is the Minkowski sum of P and Q.

Other

If one polygon is convex and another one is not, the complexity of their Minkowski sum is O(nm). If both of them are nonconvex, their Minkowski sum complexity is O((mn)).

Essential Minkowski sum

There is also a notion of the essential Minkowski sum +e of two subsets of Euclidean space. The usual Minkowski sum can be written as

A + B = { z R n | A ( z B ) } . {\displaystyle A+B=\left\{z\in \mathbb {R} ^{n}\,|\,A\cap (z-B)\neq \emptyset \right\}.}

Thus, the essential Minkowski sum is defined by

A + e B = { z R n | μ [ A ( z B ) ] > 0 } , {\displaystyle A+_{\mathrm {e} }B=\left\{z\in \mathbb {R} ^{n}\,|\,\mu \left>0\right\},}

where μ denotes the n-dimensional Lebesgue measure. The reason for the term "essential" is the following property of indicator functions: while

1 A + B ( z ) = sup x R n 1 A ( x ) 1 B ( z x ) , {\displaystyle 1_{A\,+\,B}(z)=\sup _{x\,\in \,\mathbb {R} ^{n}}1_{A}(x)1_{B}(z-x),}

it can be seen that

1 A + e B ( z ) = e s s s u p x R n 1 A ( x ) 1 B ( z x ) , {\displaystyle 1_{A\,+_{\mathrm {e} }\,B}(z)=\mathop {\mathrm {ess\,sup} } _{x\,\in \,\mathbb {R} ^{n}}1_{A}(x)1_{B}(z-x),}

where "ess sup" denotes the essential supremum.

L Minkowski sum

For K and L compact convex subsets in R n {\textstyle \mathbb {R} ^{n}} , the Minkowski sum can be described by the support function of the convex sets:

h K + L = h K + h L . {\displaystyle h_{K+L}=h_{K}+h_{L}.}

For p ≥ 1, Firey defined the L Minkowski sum K +p L of compact convex sets K and L in R n {\displaystyle \mathbb {R} ^{n}} containing the origin as

h K + p L p = h K p + h L p . {\displaystyle h_{K+_{p}L}^{p}=h_{K}^{p}+h_{L}^{p}.}

By the Minkowski inequality, the function hK+pL is again positive homogeneous and convex and hence the support function of a compact convex set. This definition is fundamental in the L Brunn-Minkowski theory.

See also

Notes

  1. Hadwiger, Hugo (1950), "Minkowskische Addition und Subtraktion beliebiger Punktmengen und die Theoreme von Erhard Schmidt", Mathematische Zeitschrift, 53 (3): 210–218, doi:10.1007/BF01175656, S2CID 121604732, retrieved 2023-01-12
  2. Li, Wei (Fall 2011). GPU-Based Computation of Voxelized Minkowski Sums with Applications (PhD). UC Berkeley. pp. 13–14. Retrieved 2023-01-10.
  3. Lozano-Pérez, Tomás (February 1983). "Spatial Planning: A Configuration Space Approach" (PDF). IEEE Transactions on Computers. C-32 (2): 111. doi:10.1109/TC.1983.1676196. hdl:1721.1/5684. S2CID 18978404. Retrieved 2023-01-10.
  4. Theorem 3 (pages 562–563): Krein, M.; Šmulian, V. (1940). "On regularly convex sets in the space conjugate to a Banach space". Annals of Mathematics. Second Series. 41 (3): 556–583. doi:10.2307/1968735. JSTOR 1968735. MR 0002009.
  5. For the commutativity of Minkowski addition and convexification, see Theorem 1.1.2 (pages 2–3) in Schneider; this reference discusses much of the literature on the convex hulls of Minkowski sumsets in its "Chapter 3 Minkowski addition" (pages 126–196): Schneider, Rolf (1993). Convex bodies: The Brunn–Minkowski theory. Encyclopedia of mathematics and its applications. Vol. 44. Cambridge: Cambridge University Press. pp. xiv+490. ISBN 978-0-521-35220-8. MR 1216521.
  6. Chapter 1: Schneider, Rolf (1993). Convex bodies: The Brunn–Minkowski theory. Encyclopedia of mathematics and its applications. Vol. 44. Cambridge: Cambridge University Press. pp. xiv+490. ISBN 978-0-521-35220-8. MR 1216521.
  7. The Theorem of Barbier (Java) at cut-the-knot.
  8. Kline, Jeffery (2019). "Properties of the d-dimensional earth mover's problem". Discrete Applied Mathematics. 265: 128–141. doi:10.1016/j.dam.2019.02.042. S2CID 127962240.
  9. Zelenyuk, V. (2015). "Aggregation of scale efficiency". European Journal of Operational Research. 240 (1): 269–277. doi:10.1016/j.ejor.2014.06.038.
  10. Mayer, A.; Zelenyuk, V. (2014). "Aggregation of Malmquist productivity indexes allowing for reallocation of resources". European Journal of Operational Research. 238 (3): 774–785. doi:10.1016/j.ejor.2014.04.003.
  11. Firey, William J. (1962), "p-means of convex bodies", Mathematica Scandinavica, 10: 17–24, doi:10.7146/math.scand.a-10510

References

External links

Convex analysis and variational analysis
Basic concepts
Topics (list)
Maps
Main results (list)
Sets
Series
Duality
Applications and related
Functional analysis (topicsglossary)
Spaces
Properties
Theorems
Operators
Algebras
Open problems
Applications
Advanced topics
Topological vector spaces (TVSs)
Basic concepts
Main results
Maps
Types of sets
Set operations
Types of TVSs
Categories: