Vector projection#Vector projection

{{Short description|Concept in linear algebra}}

{{For|more general concepts|Projection (linear algebra)|Projection (mathematics)}}

{{Lead too long|date=September 2024}}

The vector projection (also known as the vector component or vector resolution) of a vector {{math|a}} on (or onto) a nonzero vector {{math|b}} is the orthogonal projection of {{math|a}} onto a straight line parallel to {{math|b}}.

The projection of {{math|a}} onto {{math|b}} is often written as \operatorname{proj}_\mathbf{b} \mathbf{a} or {{math|ab}}.

The vector component or vector resolute of {{math|a}} perpendicular to {{math|b}}, sometimes also called the vector rejection of {{math|a}} from {{math|b}} (denoted \operatorname{oproj}_{\mathbf{b}} \mathbf{a} or {{math|ab}}),{{cite book |first=G. |last=Perwass |year=2009 |url=https://books.google.com/books?id=8IOypFqEkPMC&pg=PA83 |title=Geometric Algebra With Applications in Engineering |page=83 |publisher=Springer |isbn=9783540890676 }} is the orthogonal projection of {{math|a}} onto the plane (or, in general, hyperplane) that is orthogonal to {{math|b}}. Since both \operatorname{proj}_{\mathbf{b}} \mathbf{a} and \operatorname{oproj}_{\mathbf{b}} \mathbf{a} are vectors, and their sum is equal to {{math|a}}, the rejection of {{math|a}} from {{math|b}} is given by: \operatorname{oproj}_{\mathbf{b}} \mathbf{a} = \mathbf{a} - \operatorname{proj}_{\mathbf{b}} \mathbf{a}.

File:Projection and rejection.svg

File:Projection and rejection 2.svg

To simplify notation, this article defines \mathbf{a}_1 := \operatorname{proj}_{\mathbf{b}} \mathbf{a} and \mathbf{a}_2 := \operatorname{oproj}_{\mathbf{b}} \mathbf{a}.

Thus, the vector \mathbf{a}_1 is parallel to \mathbf{b}, the vector \mathbf{a}_2 is orthogonal to \mathbf{b}, and \mathbf{a} = \mathbf{a}_1 + \mathbf{a}_2.

The projection of {{math|a}} onto {{math|b}} can be decomposed into a direction and a scalar magnitude by writing it as \mathbf{a}_1 = a_1\mathbf{\hat b}

where a_1 is a scalar, called the scalar projection of {{math|a}} onto {{math|b}}, and {{math|}} is the unit vector in the direction of {{math|b}}. The scalar projection is defined as{{Cite web|title=Scalar and Vector Projections| url=https://www.ck12.org/book/ck-12-college-precalculus/section/9.6/|access-date=2020-09-07|website=www.ck12.org}}

a_1 = \left\|\mathbf{a}\right\|\cos\theta = \mathbf{a}\cdot\mathbf{\hat b}

where the operator denotes a dot product, ‖a‖ is the length of {{math|a}}, and θ is the angle between {{math|a}} and {{math|b}}.

The scalar projection is equal in absolute value to the length of the vector projection, with a minus sign if the direction of the projection is opposite to the direction of {{math|b}}, that is, if the angle between the vectors is more than 90 degrees.

The vector projection can be calculated using the dot product of \mathbf{a} and \mathbf{b} as:

\operatorname{proj}_{\mathbf{b}} \mathbf{a} = \left(\mathbf{a} \cdot \mathbf{\hat b}\right) \mathbf{\hat b} = \frac {\mathbf{a} \cdot \mathbf{b}} {\left\|\mathbf{b}\right\| } \frac {\mathbf{b}} {\left\|\mathbf{b}\right\|} = \frac {\mathbf{a} \cdot \mathbf{b}} {\left\|\mathbf{b}\right\|^2}{\mathbf{b}} = \frac {\mathbf{a} \cdot \mathbf{b}} {\mathbf{b} \cdot \mathbf{b}}{\mathbf{b}} ~ .

Notation

This article uses the convention that vectors are denoted in a bold font (e.g. {{math|a1}}), and scalars are written in normal font (e.g. a1).

The dot product of vectors {{math|a}} and {{math|b}} is written as \mathbf{a}\cdot\mathbf{b}, the norm of {{math|a}} is written ‖a‖, the angle between {{math|a}} and {{math|b}} is denoted θ.

Definitions based on angle ''alpha''

=Scalar projection=

{{Main|Scalar projection}}

The scalar projection of {{math|a}} on {{math|b}} is a scalar equal to

a_1 = \left\|\mathbf{a}\right\| \cos \theta ,

where θ is the angle between {{math|a}} and {{math|b}}.

A scalar projection can be used as a scale factor to compute the corresponding vector projection.

=Vector projection=

The vector projection of {{math|a}} on {{math|b}} is a vector whose magnitude is the scalar projection of {{math|a}} on {{math|b}} with the same direction as {{math|b}}. Namely, it is defined as

\mathbf{a}_1 = a_1 \mathbf{\hat b} = (\left\|\mathbf{a}\right\| \cos \theta) \mathbf{\hat b}

where a_1 is the corresponding scalar projection, as defined above, and \mathbf{\hat b} is the unit vector with the same direction as {{math|b}}:

\mathbf{\hat b} = \frac {\mathbf{b}} {\left\|\mathbf{b}\right\|}

=Vector rejection=

By definition, the vector rejection of {{math|a}} on {{math|b}} is:

\mathbf{a}_2 = \mathbf{a} - \mathbf{a}_1

Hence,

\mathbf{a}_2 = \mathbf{a} - \left(\left\|\mathbf{a}\right\| \cos \theta\right) \mathbf{\hat b}

Definitions in terms of a and b

When {{mvar|θ}} is not known, the cosine of {{mvar|θ}} can be computed in terms of {{math|a}} and {{math|b}}, by the following property of the dot product {{math|ab}}

\mathbf{a} \cdot \mathbf{b} = \left\|\mathbf{a}\right\| \left\|\mathbf{b}\right\| \cos \theta

=Scalar projection=

By the above-mentioned property of the dot product, the definition of the scalar projection becomes:

In two dimensions, this becomes

a_1 = \frac {\mathbf{a}_x \mathbf{b}_x + \mathbf{a}_y \mathbf{b}_y} {\left\|\mathbf{b}\right\|}.

=Vector projection=

Similarly, the definition of the vector projection of {{math|a}} onto {{math|b}} becomes:

\mathbf{a}_1 = a_1 \mathbf{\hat b} = \frac {\mathbf{a} \cdot \mathbf{b}} {\left\|\mathbf{b}\right\| } \frac {\mathbf{b}} {\left\|\mathbf{b}\right\|},

which is equivalent to either

\mathbf{a}_1 = \left(\mathbf{a} \cdot \mathbf{\hat b}\right) \mathbf{\hat b},

or{{cite web|url=http://www.math.oregonstate.edu/home/programs/undergrad/CalculusQuestStudyGuides/vcalc/dotprod/dotprod.html | title=Dot Products and Projections}} {{Dead link|date=January 2025}}

\mathbf{a}_1 = \frac {\mathbf{a} \cdot \mathbf{b}} {\left\|\mathbf{b}\right\|^2}{\mathbf{b}} = \frac {\mathbf{a} \cdot \mathbf{b}} {\mathbf{b} \cdot \mathbf{b}}{\mathbf{b}} ~ .

=Scalar rejection=

In two dimensions, the scalar rejection is equivalent to the projection of {{math|a}} onto \mathbf{b}^\perp = \begin{pmatrix}-\mathbf{b}_y & \mathbf{b}_x\end{pmatrix}, which is \mathbf{b} = \begin{pmatrix}\mathbf{b}_x & \mathbf{b}_y\end{pmatrix} rotated 90° to the left. Hence,

a_2 = \left\|\mathbf{a}\right\| \sin \theta = \frac {\mathbf{a} \cdot \mathbf{b}^\perp} {\left\|\mathbf{b}\right\|} = \frac {\mathbf{a}_y \mathbf{b}_x - \mathbf{a}_x \mathbf{b}_y} {\left\|\mathbf{b}\right\| }.

Such a dot product is called the "perp dot product."

=Vector rejection=

By definition,

\mathbf{a}_2 = \mathbf{a} - \mathbf{a}_1

Hence,

\mathbf{a}_2 = \mathbf{a} - \frac {\mathbf{a} \cdot \mathbf{b}} {\mathbf{b} \cdot \mathbf{b}}{\mathbf{b}}.

By using the Scalar rejection using the perp dot product this gives

\mathbf{a}_2 = \frac{\mathbf{a}\cdot\mathbf{b}^\perp}{\mathbf{b}\cdot\mathbf{b}}\mathbf{b}^\perp

Properties

Image:Dot Product.svg of {{math|a}} on {{math|b}} coincides with the length of the vector projection.|center]]

=Scalar projection=

{{Main|Scalar projection}}

The scalar projection {{math|a}} on {{math|b}} is a scalar which has a negative sign if 90 degrees < θ180 degrees. It coincides with the length {{math|‖c‖}} of the vector projection if the angle is smaller than 90°. More exactly:

  • {{math|1=a1 = ‖a1‖}} if {{math|0° ≤ θ ≤ 90°}},
  • {{math|1=a1 = −‖a1‖}} if {{math|90° < θ ≤ 180°}}.

=Vector projection=

The vector projection of {{math|a}} on {{math|b}} is a vector {{math|a1}} which is either null or parallel to {{math|b}}. More exactly:

  • {{math|1=a1 = 0}} if {{math|1=θ = 90°}},
  • {{math|a1}} and {{math|b}} have the same direction if {{math|0° ≤ θ < 90°}},
  • {{math|a1}} and {{math|b}} have opposite directions if {{math|90° < θ ≤ 180°}}.

=Vector rejection=

The vector rejection of {{math|a}} on {{math|b}} is a vector {{math|a2}} which is either null or orthogonal to {{math|b}}. More exactly:

  • {{math|1=a2 = 0}} if {{math|1=θ = 0°}} or {{math|1=θ = 180°}},
  • {{math|1=a2}} is orthogonal to {{math|b}} if {{math|1=0 < θ < 180°}},

Matrix representation

The orthogonal projection can be represented by a projection matrix. To project a vector onto the unit vector {{math|1=a = (ax, ay, az)}}, it would need to be multiplied with this projection matrix:

Uses

The vector projection is an important operation in the Gram–Schmidt orthonormalization of vector space bases. It is also used in the separating axis theorem to detect whether two convex shapes intersect.

Generalizations

Since the notions of vector length and angle between vectors can be generalized to any n-dimensional inner product space, this is also true for the notions of orthogonal projection of a vector, projection of a vector onto another, and rejection of a vector from another.

=Vector projection on a plane=

In some cases, the inner product coincides with the dot product. Whenever they don't coincide, the inner product is used instead of the dot product in the formal definitions of projection and rejection. For a three-dimensional inner product space, the notions of projection of a vector onto another and rejection of a vector from another can be generalized to the notions of projection of a vector onto a plane, and rejection of a vector from a plane. M.J. Baker, 2012. [http://www.euclideanspace.com/maths/geometry/elements/plane/lineOnPlane/index.htm Projection of a vector onto a plane.] Published on www.euclideanspace.com. The projection of a vector on a plane is its orthogonal projection on that plane. The rejection of a vector from a plane is its orthogonal projection on a straight line which is orthogonal to that plane. Both are vectors. The first is parallel to the plane, the second is orthogonal.

For a given vector and plane, the sum of projection and rejection is equal to the original vector. Similarly, for inner product spaces with more than three dimensions, the notions of projection onto a vector and rejection from a vector can be generalized to the notions of projection onto a hyperplane, and rejection from a hyperplane. In geometric algebra, they can be further generalized to the notions of projection and rejection of a general multivector onto/from any invertible k-blade.

See also

References

{{reflist}}