In this page I show how to easily compute the minimal distance between two arbitrary lines.
Assume we have two lines, each represented by a point and a normalized
direction vector (first line is ) and second ().
For simplicity, we will use these definitions:
A pair of points (one on each line) can be obtained by using two real values
and , by substituion on the parametric equations of the lines.
These points are, obviously:
The squared
distance function is defined as:
Non parallel lines
When the two lines are not parallel, then is not . Note that and are normalized, thus in the
case of non-parallel lines, these two vectors are not collinear and their inner prodcut () cannot be (it is a value between and ).
It can be easily shown (by equating its derivate to cero) that, in this case,
function has its (unique) minimun value
for and , where:
The squared minimun distance () between these two lines can be obtained by
computing the pair of closest points ( and ) and then
the computing the squared distance between then, that is:
by expanding , this distance can also be written directly in terms of and , as follows:
by substituting and above and then simplifying, we arrive
to this expression:
Parallel lines
In the case then the two lines are parallel (). The squared distance can be computed
simply as the squared length of the component perpendicular to the lines. To obtain this value,
we observe the component of parallel to the lines (), and the component perpendicular to those lines ().
These vectors can be expressed as:
If we consider the triangle formed by , and , and by using Pythagoras theorem, we get this equality for the squared lengths:
in this expression, we can do these substitutions:
Thus we can finally get an expression for :
See also:
(this page uses
MathJax)