The Bentley–Ottmann algorithm finds all the intersections that occur in a set of line segments. Drag the endpoints of the line to move, click to add and right click to remove.
Instead of calculating the intersection of every pair of segments, which would require O(n²) comparisons for a set of n lines, the algorithm uses a sweep line. Starting at the top of the screen and moving down, it keeps track of the order of the lines' x positions at the current y position (represented by the figure on the right). As lines start, end or intersect, new pairs of lines become adjacent in the x ordering and are checked for intersections.
A set of lines with I intersections ends up only requiring O(n log n + I log n) operations. Computational Geometry: Algorithms and Applications, chapter 2 has a proof and a more detailed explanation.
xxxxxxxxxx
<meta charset="utf-8">
<style>
body{
max-width: 960px;
margin: 0px auto;
font-family: monospace;
}
.point{
stroke: black;
cursor: pointer;
}
.line{
stroke: black;
stroke-width: 2;
pointer-events: none;
}
.pairpath{
fill: none;
stroke: black;
pointer-events: none;
}
svg{
overflow: visible;
border: 1px solid #ccc;
}
</style>
<div id='graph'></div>
<script src='/1wheel/raw/67b47524ed8ed829d021/d3-3.5.5.js'></script>
<script src='/1wheel/raw/67b47524ed8ed829d021/lodash-3.8.0.js'></script>
<script src='/1wheel/raw/1b6758978dc2d52d3a37/d3-jetpack.js'></script>
<script src='/1wheel/raw/1b6758978dc2d52d3a37/d3-starterkit.js'></script>
<script src='geometry.js'></script>
<script src='intersection-drag.js'></script>