Finding the Shortest Distance between two Skew Lines

In my previous post on the topic, i clarified that the shortest path between a pair of skew lines is the line segment that is perpendicular to both the skew lines. 


Now the next ask is determining a way to find the length of the shortest path, i.e. the length of the line segment perpendicular to both the skew lines. Let’s take an example of a pair of skew lines.


L1 : i^+j^+0k^+u(2i^j^+k^)

L2 : 2i^+j^k^+v(3i^5j^+2k^)



From equation of L1, position and direction vectors of L1 are 


p1=i^+j^+0k^

d1=2i^j^+k^



From equation of L2, position and direction vectors of L2 are


p2=2i^+j^k^

d2=3i^5j^+2k^


Direction vector of a line is simply a vector arrow parallel to that line. Or, we can also say it is a vector arrow pointing in any one of the two opposite directions of the line.


The above figure is the graph of the two given lines L1 & L2 along with direction vectors d1 & d2 parallel to L1 & L2. AB is the shortest path perpendicular to both the lines, and we want to find its length. I have created this image using 3D calculator on Geogebra. Below this para, a gif image might provide a little more clearer picture than the static image above. 



Some texts use terms such as ‘Direction Ratios’ or ‘Direction Numbers’ for Direction vector, but all these terms essentially imply the same. For example, 3, -5 and 2 are direction ratios of line L2 basically means that 3i^5j^+2k^ is the direction vector of L2 pointing in one of the two directions of L2. 

Position vector of a line is a vector arrow specifying the position of a point on the line relative to the origin, i.e. how much farther away a point on the line is from the origin, and in which direction the point is from the origin. It is an arrow drawn from the origin to the point on the line. A position vector could be given for any point on the line.


In the figure below, arrows p1 & p2 are position vectors of points C (1,1,0) & D (2,1,-1) on lines L1 & L2. The position vectors are shown by blue coloured arrows from origin O to points C & D. 


(I have kept the three coordinate axes hidden this time so that we are only looking at what we want to.)

Our aim is to find the shortest distance AB, highlighted in yellow colour in the picture above. But the shortest distance is a scalar quantity; how will the four given vectors help us find a scalar? 


Well, not exactly. The four given vectors help us find the magnitude of a vector along AB. This vector has the magnitude equal to the length of AB - the shortest distance - and direction either from A to B or from B to A. So we can call it AB or BA depending on which direction we choose it to be in. I will define it in the direction from A to B. 


So ultimately our goal is to find the magnitude of this new vector from given pairs of position and direction vectors. 

Now, the segment AB is perpendicular to line L1, and d1 is parallel to L1. So the vector along AB, AB, is perpendicular to d1


Segment AB is perpendicular to Line L2 as well, and d2 is parallel to L2. So that means vecAB is also perpendicular to d2


So it is clear that AB is perpendicular to both the direction vectors.


The cross product d1×d2 is another vector that’s perpendicular to both d1 & d2. Hence, the cross product must be parallel to AB


The cross product can be either parallel and in the same direction as AB, or parallel but in the opposite direction of AB

We could have also gone with d2×d1 which is of the same magnitude as d1×d2 but in the opposite direction. Any of the two cross products will work. 


We will need to define one more vector along the segment CD, but first we will put a segment between C and D if we haven’t done so before. CD is just any other path between the lines(not the shortest path) and its length is required to find the length of the shortest path AB. 


Now define CD or DC. Again, any of them will work. I am going with CD. We can easily find the length of segment CD, or the magnitude of CD, from given position vectors using the triangle law of vector addition

CD=p2p1=2i^+j^k^(i^+j^+0k^)


CD=i^k^

Magnitude of CD = |CD| = 2

We have done a lot of random pickings so far. We have a choice to go with either AB or BA.....p2p1(CD) or p1p2(DC).....d2×d1 or d1×d2


It will not entirely be true if i tell you that different choices will not lead to different answers. Different choices WILL alter the answers but the difference will only be in the sign. Some choices will give us a positive value, while some will lead to the same value but with a negative sign before it. More on this later. 


Is there any relation between vectors AB & CD


Yes, there is; we will be able to see that clearly if we draw two parallel planes, each containing one of the two skew lines. In my previous post on the topic I mentioned that for any pair skew lines there exists a unique pair of parallel planes, each containing one of the two lines. 


Drop the perpendicular from point C onto the parallel plane, let it meet the plane at point E. This perpendicular CE will have the same length as AB. Connecting E and D to form a right triangle. Let angle DCE be θ


Here’s a gif image just in case….


(I have kept the position vectors and the origin O hidden for clarity purposes)


So cos θ = CECD


For CD, we can write |CD|


So, CE = AB = |CD| cos θ …(1)

                     = 2 cosθ


Now how do we find cos θ?


The way we do it is by using the dot product formula for vectors. If we define CE, then θ is the angle between vectors CD & CE. But CE is parallel to AB which in turn is parallel to d1×d2


So θ is also the angle between vectors CD and d1×d2. Using the dot product formula, cosine of θ is equal to the dot product of these two vectors, divided by the magnitude of CD multiplied by the magnitude of d1×d2


cosθ=CD(d1×d2)|CD||d1×d2|


Substituting for cos θ in equation (1), 


AB = |CD| cosθ 


= |CD|CD(d1×d2)|CD||d1×d2|       


Which further simplifies to, 


= CD(d1×d2)|d1×d2| …(2)


CD(d1×d2)=(1)(3)+(0)(1)+(1)(7

=30+7

=10


|d1×d2|=32+(1)2+(7)2

                                                                         =9+1+49        

                                                                         =59

                   

Hence,


Shortest distance between = AB  =1059 units

               L1 & L2         

 

Equation (2) is close to the standard formula found in many textbooks for the shortest distance between skew lines. Replacing CD with p2p1 or p1p2, whichever was your choice, to express the formula entirely in terms of the given parameters. 


Shortest distance = p2p1(d1×d2)|d1×d2|

        

Going back to the point i made earlier, for a certain choice of vectors we will end up getting negative final answer. For instance, if we would have taken the cross product d2×d1 instead, the final answer would then be -1059. You can verify it yourself. 


We can use the line of reasoning that the distance cannot be negative, and simply discard the negative sign, as if it was never there. That’ll work. 


Textbooks solve this issue of negative sign by taking the absolute value of the entire term on the right hand side of the formula. 


Shortest distance = |p2p1(d1×d2)|d1×d2||


Regardless of whether the term is positive or negative, its absolute value will always be positive. This is an effective way to get rid of the negative sign!






Comments