The first two-dimensional convex hull algorithm was originally developed by R. A. Jarvis in 1973 {{ "jm1973" | cite }}. Though other convex hull algorithms exist, this algorithm is often called the gift-wrapping algorithm.
The idea behind this algorithm is simple. If we start with a random distribution of points, we can find the convex hull by first starting with the left-most point and using the origin to calculate an angle between every other point in the simulation. As a note, the "angle" can be roughly approximated with a cross-product or a dot product, which is common for some implementations here. Whichever point has the largest interior angle is chosen as the next point in the convex hull and we draw a line between the two points. From there, we use the two known points to again calculate the angle between all other points in the simulation. We then choose the point with the largest interior angle and move the simulation forward. We keep repeating this process until we have returned to our original point. The set of points chosen in this simulation will be the convex hull.
As we might expect, this algorithm is not incredibly efficient and has a runtime of
{% references %} {% endreferences %}
{% method %} {% sample lang="cs" %}
import, lang="csharp" {% sample lang="jl" %} import, lang:"julia" {% sample lang="hs" %} import, lang:"haskell" {% sample lang="c" %} import, lang:"c" {% sample lang="js" %} import, lang:"javascript" {% sample lang="py" %} import, lang:"python" {% sample lang="cpp" %} import, lang:"cpp" {% sample lang="lisp" %} import, lang:"lisp" {% sample lang="java" %} import, lang:"java" {% sample lang="go" %} import, lang:"go" {% sample lang="v" %} import, lang:"v" {% sample lang="rust" %} import, lang:"rust" {% sample lang="coco" %} import, lang:"coconut" {% endmethod %}
<script> MathJax.Hub.Queue(["Typeset",MathJax.Hub]); </script>The code examples are licensed under the MIT license (found in LICENSE.md).
The text of this chapter was written by James Schloss and is licensed under the Creative Commons Attribution-ShareAlike 4.0 International License.
After initial licensing (#560), the following pull requests have modified the text or graphics of this chapter:
- none