# Plücker coordinates

This article includes a list of references, related reading or external links, but its sources remain unclear because it lacks inline citations. (February 2011) (Learn how and when to remove this template message) |

In geometry, **Plücker coordinates**, introduced by Julius Plücker in the 19th century, are a way to assign six homogeneous coordinates to each line in projective 3-space, **P**^{3}. Because they satisfy a quadratic constraint, they establish a one-to-one correspondence between the 4-dimensional space of lines in **P**^{3} and points on a quadric in **P**^{5} (projective 5-space). A predecessor and special case of Grassmann coordinates (which describe *k*-dimensional linear subspaces, or *flats*, in an *n*-dimensional Euclidean space), Plücker coordinates arise naturally in geometric algebra. They have proved useful for computer graphics, and also can be extended to coordinates for the screws and wrenches in the theory of kinematics used for robot control.

## Geometric intuitionEdit

A line *L* in 3-dimensional Euclidean space is determined by two distinct points that it contains, or by two distinct planes that contain it. Consider the first case, with points * x* = (

*x*

_{1},

*x*

_{2},

*x*

_{3}) and

*= (*

**y***y*

_{1},

*y*

_{2},

*y*

_{3}). The vector displacement from

*to*

**x***is nonzero because the points are distinct, and represents the*

**y***direction*of the line. That is, every displacement between points on

*L*is a scalar multiple of

*=*

**d***−*

**y***. If a physical particle of unit mass were to move from*

**x***to*

**x***, it would have a moment about the origin. The geometric equivalent is a vector whose direction is perpendicular to the plane containing*

**y***L*and the origin, and whose length equals twice the area of the triangle formed by the displacement and the origin. Treating the points as displacements from the origin, the moment is

*=*

**m***×*

**x***, where "×" denotes the vector cross product. For a fixed line,*

**y***L*, the area of the triangle is proportional to the length of the segment between

*and*

**x***, considered as the base of the triangle; it is not changed by sliding the base along the line, parallel to itself. By definition the moment vector is perpendicular to every displacement along the line, so*

**y***⋅*

**d***= 0, where "⋅" denotes the vector dot product.*

**m**Although neither * d* nor

*alone is sufficient to determine*

**m***L*, together the pair does so uniquely, up to a common (nonzero) scalar multiple which depends on the distance between

*and*

**x***. That is, the coordinates*

**y**- (
:**d**) = (**m***d*_{1}:*d*_{2}:*d*_{3}:*m*_{1}:*m*_{2}:*m*_{3})

may be considered homogeneous coordinates for *L*, in the sense that all pairs (*λ d*:

*λ*), for

**m***λ*≠ 0, can be produced by points on

*L*and only

*L*, and any such pair determines a unique line so long as

*is not zero and*

**d***⋅*

**d***= 0. Furthermore, this approach extends to include points, lines, and a plane "at infinity", in the sense of projective geometry.*

**m****Example.**Let= (2,3,7) and**x**= (2,1,0). Then (**y**:**d**) = (0:−2:−7:−7:14:−4).**m**

Alternatively, let the equations for points * x* of two distinct planes containing

*L*be

- 0 =
*a*+⋅**a****x** - 0 =
*b*+⋅**b**.**x**

Then their respective planes are perpendicular to vectors * a* and

*, and the direction of*

**b***L*must be perpendicular to both. Hence we may set

*=*

**d***×*

**a***, which is nonzero because*

**b***and*

**a***are neither zero nor parallel (the planes being distinct and intersecting). If point*

**b***satisfies both plane equations, then it also satisfies the linear combination*

**x**0 = *a*(*b*+⋅**b**) −**x***b*(*a*+⋅**a**)**x**= ( *a*−**b***b*) ⋅**a**.**x**

That is, * m* =

*a*

*−*

**b***b*

*is a vector perpendicular to displacements to points on*

**a***L*from the origin; it is, in fact, a moment consistent with the

*previously defined from*

**d***and*

**a***.*

**b***Proof 1*: Need to show that * m* =

*a*

*−*

**b***b*

*=*

**a***×*

**r***=*

**d***× (*

**r***×*

**a***).*

**b**Without loss of generality, let * a* ⋅

*=*

**a***⋅*

**b***= 1.*

**b**Point *B* is the origin. Line *L* passes through point *D* and is orthogonal to the plane of the picture. The two planes pass through *CD* and *DE* and are both orthogonal to the plane of the picture. Points *C* and *E* are the closest points on those planes to the origin *B*, therefore angles *BCD* and *BED* are right angles and so the points *B*, *C*, *D*, *E* lie on a circle (due to a corollary of Thales's theorem). *BD* is the diameter of that circle.

:= BE/ ||BE||,**a**:= BC/ ||BC||，**b**:= BD, −**r***a*= ||BE|| = ||BF||，−*b*= ||BC|| = ||BG||,=**m***a*−**b***b*= FG, ||**a**|| = ||**d**×**a**|| = sin(FBG)**b**

Angle *BHF* is a right angle due to the following argument. Let . Since (by side-angle-side congruence), then . Since , let . By the inscribed angle theorem, , so . ; , therefore . Then *DHF* must be a right angle as well.

Angles *DCF* and *DHF* are right angles, so the four points C, D, H, F lie on a circle, and (by the intersecting secants theorem)

||BF|| ||BC|| = ||BH|| ||BD||, that is *ab* sin(FBG) = ||BH|| ||* r*|| sin(FBG), 2(area of triangle BFG) =

*ab*sin(FBG) = ||BH|| ||FG|| = ||BH|| ||

*|| sin(FBG), ||*

**r***|| = ||FG|| = ||*

**m***|| sin(FBG) = ||*

**r***|| ||*

**r***||, check direction and*

**d***=*

**m***×*

**r***. ∎*

**d***Proof 2*:

Let * a* ⋅

*=*

**a***⋅*

**b***= 1. This implies that*

**b***a*= −||BE||,*b*= −||BC||.

According to the vector triple product formula,

× (**r**×**a**) = (**b**·**r**)**b**− (**a**·**r**)**a****b**

Then

× (r × a)
b |
= | ||a|| ||r|| cos(∠DBC) − b ||b|| ||r|| cos(∠DBE)
a |

= | ||a|| cos(∠DBC) − r ||b|| cos(∠DBE)
r | |

= | ||BC|| − a ||BE||
b | |

= | −b − (−aa) b | |

= | a − bb ∎
a |

When ||* r*|| = 0, the line

*L*passes the origin with direction

*. If ||*

**d***|| > 0, the line has direction*

**r***; the plane that includes the origin and the line*

**d***L*has normal vector

*; the line is tangent to a circle on that plane (normal to*

**m***and perpendicular to the plane of the picture) centered at the origin and with radius ||*

**m***||.*

**r****Example.**Let*a*_{0}= 2,= (−1,0,0) and**a***b*_{0}= −7,= (0,7,−2). Then (**b**:**d**) = (0:−2:−7:−7:14:−4).**m**

Although the usual algebraic definition tends to obscure the relationship, (* d*:

*) are the Plücker coordinates of*

**m***L*.

## Algebraic definitionEdit

### Primal coordinatesEdit

In a 3-dimensional projective space **P**^{3}, let *L* be a line through distinct points **x** and **y** with homogeneous coordinates (*x*_{0}:*x*_{1}:*x*_{2}:*x*_{3}) and (*y*_{0}:*y*_{1}:*y*_{2}:*y*_{3}).
The Plücker coordinates *p*_{ij} are defined as follows:

(the skew symmetric matrix whose elements are *p*_{ij} is also called the Plücker matrix )

This implies *p*_{ii} = 0 and *p*_{ij} = −*p*_{ji}, reducing the possibilities to only six (4 choose 2) independent quantities. The sextuple

is uniquely determined by *L* up to a common nonzero scale factor. Furthermore, not all six components can be zero.
Thus the Plücker coordinates of *L* may be considered as homogeneous coordinates of a point in a 5-dimensional projective space, as suggested by the colon notation.

To see these facts, let *M* be the 4×2 matrix with the point coordinates as columns.

The Plücker coordinate *p*_{ij} is the determinant of rows *i* and *j* of *M*.
Because **x** and **y** are distinct points, the columns of *M* are linearly independent; *M* has rank 2. Let *M′* be a second matrix, with columns **x′** and **y′** a different pair of distinct points on *L*. Then the columns of *M′* are linear combinations of the columns of *M*; so for some 2×2 nonsingular matrix Λ,

In particular, rows *i* and *j* of *M′* and *M* are related by

Therefore, the determinant of the left side 2×2 matrix equals the product of the determinants of the right side 2×2 matrices, the latter of which is a fixed scalar, det Λ. Furthermore, all six 2×2 subdeterminants in *M* cannot be zero because the rank of *M* is 2.

### Plücker mapEdit

Denote the set of all lines (linear images of **P**^{1}) in **P**^{3} by *G*_{1,3}. We thus have a map:

where

### Dual coordinatesEdit

Alternatively, a line can be described as the intersection of two planes. Let *L*
be a line contained in distinct planes **a** and **b** with homogeneous coefficients (*a*^{0}:*a*^{1}:*a*^{2}:*a*^{3}) and (*b*^{0}:*b*^{1}:*b*^{2}:*b*^{3}), respectively. (The first plane equation is ∑_{k} *a*^{k}*x*_{k}=0, for example.) The dual Plücker coordinate *p*^{ij} is

Dual coordinates are convenient in some computations, and they are equivalent to primary coordinates:

Here, equality between the two vectors in homogeneous coordinates means that the numbers on the right side are equal to the numbers on the left side up to some common scaling factor . Specifically, let (*i*,*j*,*k*,*ℓ*) be an even permutation of (0,1,2,3); then

### GeometryEdit

To relate back to the geometric intuition, take *x*_{0} = 0 as the plane at infinity; thus the coordinates of points *not* at infinity can be normalized so that *x*_{0} = 1. Then *M* becomes

and setting * x* = (

*x*

_{1},

*x*

_{2},

*x*

_{3}) and

*= (*

**y***y*

_{1},

*y*

_{2},

*y*

_{3}), we have

*= (*

**d***p*

_{01},

*p*

_{02},

*p*

_{03}) and

*= (*

**m***p*

_{23},

*p*

_{31},

*p*

_{12}).

Dually, we have * d* = (

*p*

^{23},

*p*

^{31},

*p*

^{12}) and

*= (*

**m***p*

^{01},

*p*

^{02},

*p*

^{03}).

## Bijection between lines and Klein quadricEdit

### Plane equationsEdit

If the point **z** = (*z*_{0}:*z*_{1}:*z*_{2}:*z*_{3}) lies on *L*, then the columns of

are linearly dependent, so that the rank of this larger matrix is still 2. This implies that all 3×3 submatrices have determinant zero, generating four (4 choose 3) plane equations, such as

The four possible planes obtained are as follows.

Using dual coordinates, and letting (*a*^{0}:*a*^{1}:*a*^{2}:*a*^{3}) be the line coefficients, each of these is simply *a*^{i} = *p*^{ij}, or

Each Plücker coordinate appears in two of the four equations, each time multiplying a different variable; and as at least one of the coordinates is nonzero, we are guaranteed non-vacuous equations for two distinct planes intersecting in *L*. Thus the Plücker coordinates of a line determine that line uniquely, and the map α is an injection.

### Quadratic relationEdit

The image of α is not the complete set of points in **P**^{5}; the Plücker coordinates of a line *L* satisfy the quadratic Plücker relation

For proof, write this homogeneous polynomial as determinants and use Laplace expansion (in reverse).

Since both 3×3 determinants have duplicate columns, the right hand side is identically zero.

Another proof may be done like this: Since vector

is perpendicular to vector

(see above), the scalar product of *d* and *m* must be zero! q.e.d.

### Point equationsEdit

Letting (*x*_{0}:*x*_{1}:*x*_{2}:*x*_{3}) be the point coordinates, four possible points on a line each have coordinates *x*_{i} = *p*_{ij}, for *j* = 0...3. Some of these possible points may be inadmissible because all coordinates are zero, but since at least one Plücker coordinate is nonzero, at least two distinct points are guaranteed.

### BijectivityEdit

If (*q*_{01}:*q*_{02}:*q*_{03}:*q*_{23}:*q*_{31}:*q*_{12}) are the homogeneous coordinates of a point in **P**^{5}, without loss of generality assume that *q*_{01} is nonzero. Then the matrix

has rank 2, and so its columns are distinct points defining a line *L*. When the **P**^{5} coordinates, *q*_{ij}, satisfy the quadratic Plücker relation, they are the Plücker coordinates of *L*. To see this, first normalize *q*_{01} to 1. Then we immediately have that for the Plücker coordinates computed from *M*, *p*_{ij} = *q*_{ij}, except for

But if the *q*_{ij} satisfy the Plücker relation *q*_{23}+*q*_{02}*q*_{31}+*q*_{03}*q*_{12} = 0, then *p*_{23} = *q*_{23}, completing the set of identities.

Consequently, α is a surjection onto the algebraic variety consisting of the set of zeros of the quadratic polynomial

And since α is also an injection, the lines in **P**^{3} are thus in bijective correspondence with the points of this quadric in **P**^{5}, called the Plücker quadric or Klein quadric.

## UsesEdit

Plücker coordinates allow concise solutions to problems of line geometry in 3-dimensional space, especially those involving incidence.

### Line-line crossingEdit

Two lines in **P**^{3} are either skew or coplanar, and in the latter case they are either coincident or intersect in a unique point. If *p*_{ij} and *p*′_{ij} are the Plücker coordinates of two lines, then they are coplanar precisely when * d*•

*′+*

**m***•*

**m***′ = 0, as shown by*

**d**When the lines are skew, the sign of the result indicates the sense of crossing: positive if a right-handed screw takes *L* into *L*′, else negative.

The quadratic Plücker relation essentially states that a line is coplanar with itself.

### Line-line joinEdit

In the event that two lines are coplanar but not parallel, their common plane has equation

- 0 = (
•**m**′)**d***x*_{0}+ (×**d**′)•**d**,**x**

where * x* = (

*x*

_{1},

*x*

_{2},

*x*

_{3}).

The slightest perturbation will destroy the existence of a common plane, and near-parallelism of the lines will cause numeric difficulties in finding such a plane even if it does exist.

### Line-line meetEdit

Dually, two coplanar lines, neither of which contains the origin, have common point

- (
*x*_{0}:) = (**x****d**•**m**′:**m**×**m**′) .

To handle lines not meeting this restriction, see the references.

### Plane-line meetEdit

Given a plane with equation

or more concisely 0 = *a*^{0}*x*_{0}+* a*•

*; and given a line not in it with Plücker coordinates (*

**x***:*

**d***), then their point of intersection is*

**m**- (
*x*_{0}:) = (**x**•**a**:**d**×**a**−**m***a*_{0}) .**d**

The point coordinates, (*x*_{0}:*x*_{1}:*x*_{2}:*x*_{3}), can also be expressed in terms of Plücker coordinates as

### Point-line joinEdit

Dually, given a point (*y*_{0}:* y*) and a line not containing it, their common plane has equation

- 0 = (
•**y**)**m***x*_{0}+ (×**y**−**d***y*_{0})•**m**.**x**

The plane coordinates, (*a*^{0}:*a*^{1}:*a*^{2}:*a*^{3}), can also be expressed in terms of dual Plücker coordinates as

### Line familiesEdit

Because the Klein quadric is in **P**^{5}, it contains linear subspaces of dimensions one and two (but no higher). These correspond to one- and two-parameter families of lines in **P**^{3}.

For example, suppose *L* and *L*′ are distinct lines in **P**^{3} determined by points **x**, **y** and **x**′, **y**′, respectively. Linear combinations of their determining points give linear combinations of their Plücker coordinates, generating a one-parameter family of lines containing *L* and *L*′. This corresponds to a one-dimensional linear subspace belonging to the Klein quadric.

#### Lines in planeEdit

If three distinct and non-parallel lines are coplanar; their linear combinations generate a two-parameter family of lines, all the lines in the plane. This corresponds to a two-dimensional linear subspace belonging to the Klein quadric.

#### Lines through pointEdit

If three distinct and non-coplanar lines intersect in a point, their linear combinations generate a two-parameter family of lines, all the lines through the point. This also corresponds to a two-dimensional linear subspace belonging to the Klein quadric.

#### Ruled surfaceEdit

A ruled surface is a family of lines that is not necessarily linear. It corresponds to a curve on the Klein quadric. For example, a hyperboloid of one sheet is a quadric surface in **P**^{3} ruled by two different families of lines, one line of each passing through each point of the surface; each family corresponds under the Plücker map to a conic section within the Klein quadric in **P**^{5}.

### Line geometryEdit

During the nineteenth century, *line geometry* was studied intensively. In terms of the bijection given above, this is a description of the intrinsic geometry of the Klein quadric.

#### Ray tracingEdit

Line geometry is extensively used in ray tracing application where the geometry and intersections of rays need to be calculated in 3D. An implementation is described in Introduction to Plücker Coordinates written for the Ray Tracing forum by Thouis Jones.

## See alsoEdit

## ReferencesEdit

- Hodge, W. V. D.; D. Pedoe (1994) [1947].
*Methods of Algebraic Geometry, Volume I (Book II)*. Cambridge University Press. ISBN 978-0-521-46900-5. - Behnke, H.; F. Bachmann; K. Fladt; H. Kunle, eds. (1984).
*Fundamentals of Mathematics, Volume II: Geometry*. trans. S. H. Gould. MIT Press. ISBN 978-0-262-52094-2.

From the German:*Grundzüge der Mathematik, Band II: Geometrie*. Vandenhoeck & Ruprecht. - Guilfoyle, B.; W. Klingenberg (2004). "On the space of oriented affine lines in R^3".
*Archiv der Mathematik*. Birkhäuser.**82**(1): 81–84. doi:10.1007/s00013-003-4861-3. ISSN 0003-889X. - Kuptsov, L.P. (2001) [1994], "P/p072890", in Hazewinkel, Michiel (ed.),
*Encyclopedia of Mathematics*, Springer Science+Business Media B.V. / Kluwer Academic Publishers, ISBN 978-1-55608-010-4 - Mason, Matthew T.; J. Kenneth Salisbury (1985).
*Robot Hands and the Mechanics of Manipulation*. MIT Press. ISBN 978-0-262-13205-3. - Hartley, R.~I.; Zisserman A. (2004).
*Multiple View Geometry in Computer Vision*. Cambridge University Press. ISBN 0521540518. - Hohmeyer, M.; S. Teller (1999). "Determining the Lines Through Four Lines" (PDF).
*Journal of Graphics Tools*. A K Peters.**4**(3): 11–22. doi:10.1080/10867651.1999.10487506. ISSN 1086-7651. - Shafarevich, I. R.; A. O. Remizov (2012).
*Linear Algebra and Geometry*. Springer. ISBN 978-3-642-30993-9. - Jia, Yan-Bin (2017). Plücker Coordinates for Lines in the Space (PDF) (Report).
- Shoemake, Ken (1998). "Plücker Coordinate Tutorial". Ray Tracing News. Retrieved 4 July 2018.