Kernel (linear algebra)
Template:Short description Script error: No such module "other uses".
In mathematics, the kernel of a linear map, also known as the null space or nullspace, is the part of the domain which is mapped to the zero vector of the co-domain; the kernel is always a linear subspace of the domain.[1] That is, given a linear map L : V → WScript error: No such module "Check for unknown parameters". between two vector spaces Template:Mvar and Template:Mvar, the kernel of Template:Mvar is the vector space of all elements vScript error: No such module "Check for unknown parameters". of Template:Mvar such that L(v) = 0Script error: No such module "Check for unknown parameters"., where 0Script error: No such module "Check for unknown parameters". denotes the zero vector in Template:Mvar,[2] or more symbolically:
Properties
The kernel of Template:Mvar is a linear subspace of the domain Template:Mvar.[3][2]
In the linear map two elements of Template:Mvar have the same image in Template:Mvar if and only if their difference lies in the kernel of Template:Mvar, that is,
From this, it follows by the first isomorphism theorem that the image of Template:Mvar is isomorphic to the quotient of Template:Mvar by the kernel: Script error: No such module "anchor".In the case where Template:Mvar is finite-dimensional, this implies the rank–nullity theorem: where the term Template:Em refers to the dimension of the image of Template:Mvar, while Template:Em refers to the dimension of the kernel of Template:Mvar, [4] That is, so that the rank–nullity theorem can be restated as
When Template:Mvar is an inner product space, the quotient can be identified with the orthogonal complement in Template:Mvar of . This is the generalization to linear operators of the row space, or coimage, of a matrix.
Generalization to modules
Script error: No such module "Labelled list hatnote". The notion of kernel also makes sense for homomorphisms of modules, which are generalizations of vector spaces where the scalars are elements of a ring, rather than a field. The domain of the mapping is a module, with the kernel constituting a submodule. Here, the concepts of rank and nullity do not necessarily apply.
In functional analysis
Script error: No such module "Labelled list hatnote". If Template:Mvar and Template:Mvar are topological vector spaces such that Template:Mvar is finite-dimensional, then a linear operator L: V → WScript error: No such module "Check for unknown parameters". is continuous if and only if the kernel of Template:Mvar is a closed subspace of Template:Mvar.
Representation as matrix multiplication
Consider a linear map represented as a m × nScript error: No such module "Check for unknown parameters". matrix Template:Mvar with coefficients in a field Template:Mvar (typically or ), that is operating on column vectors xScript error: No such module "Check for unknown parameters". with Template:Mvar components over Template:Mvar. The kernel of this linear map is the set of solutions to the equation Ax = 0Script error: No such module "Check for unknown parameters"., where 0Script error: No such module "Check for unknown parameters". is understood as the zero vector. The dimension of the kernel of A is called the nullity of A. In set-builder notation, The matrix equation is equivalent to a homogeneous system of linear equations: Thus the kernel of A is the same as the solution set to the above homogeneous equations.
Subspace properties
The kernel of a m × nScript error: No such module "Check for unknown parameters". matrix Template:Mvar over a field Template:Mvar is a linear subspace of KnScript error: No such module "Check for unknown parameters".. That is, the kernel of Template:Mvar, the set Null(A)Script error: No such module "Check for unknown parameters"., has the following three properties:
- Null(A)Script error: No such module "Check for unknown parameters". always contains the zero vector, since A0 = 0Script error: No such module "Check for unknown parameters"..
- If x ∈ Null(A)Script error: No such module "Check for unknown parameters". and y ∈ Null(A)Script error: No such module "Check for unknown parameters"., then x + y ∈ Null(A)Script error: No such module "Check for unknown parameters".. This follows from the distributivity of matrix multiplication over addition.
- If x ∈ Null(A)Script error: No such module "Check for unknown parameters". and Template:Mvar is a scalar c ∈ KScript error: No such module "Check for unknown parameters"., then cx ∈ Null(A)Script error: No such module "Check for unknown parameters"., since A(cx) = c(Ax) = c0 = 0Script error: No such module "Check for unknown parameters"..
The row space of a matrix
Script error: No such module "Labelled list hatnote". The product Ax can be written in terms of the dot product of vectors as follows:
Here, a1, ... , amScript error: No such module "Check for unknown parameters". denote the rows of the matrix Template:Mvar. It follows that xScript error: No such module "Check for unknown parameters". is in the kernel of Template:Mvar, if and only if xScript error: No such module "Check for unknown parameters". is orthogonal (or perpendicular) to each of the row vectors of Template:Mvar (since orthogonality is defined as having a dot product of 0).
The row space, or coimage, of a matrix Template:Mvar is the span of the row vectors of Template:Mvar. By the above reasoning, the kernel of Template:Mvar is the orthogonal complement to the row space. That is, a vector xScript error: No such module "Check for unknown parameters". lies in the kernel of Template:Mvar, if and only if it is perpendicular to every vector in the row space of Template:Mvar.
The dimension of the row space of Template:Mvar is called the rank of A, and the dimension of the kernel of Template:Mvar is called the nullity of Template:Mvar. These quantities are related by the rank–nullity theorem[4]
Left null space
The left null space, or cokernel, of a matrix Template:Mvar consists of all column vectors xScript error: No such module "Check for unknown parameters". such that xTA = 0TScript error: No such module "Check for unknown parameters"., where T denotes the transpose of a matrix. The left null space of Template:Mvar is the same as the kernel of ATScript error: No such module "Check for unknown parameters".. The left null space of Template:Mvar is the orthogonal complement to the column space of Template:Mvar, and is dual to the cokernel of the associated linear transformation. The kernel, the row space, the column space, and the left null space of Template:Mvar are the four fundamental subspaces associated with the matrix Template:Mvar.
Nonhomogeneous systems of linear equations
The kernel also plays a role in the solution to a nonhomogeneous system of linear equations: If uScript error: No such module "Check for unknown parameters". and vScript error: No such module "Check for unknown parameters". are two possible solutions to the above equation, then Thus, the difference of any two solutions to the equation Ax = bScript error: No such module "Check for unknown parameters". lies in the kernel of Template:Mvar.
It follows that any solution to the equation Ax = bScript error: No such module "Check for unknown parameters". can be expressed as the sum of a fixed solution vScript error: No such module "Check for unknown parameters". and an arbitrary element of the kernel. That is, the solution set to the equation Ax = bScript error: No such module "Check for unknown parameters". is Geometrically, this says that the solution set to Ax = bScript error: No such module "Check for unknown parameters". is the translation of the kernel of Template:Mvar by the vector vScript error: No such module "Check for unknown parameters".. See also Fredholm alternative and flat (geometry).
Illustration
The following is a simple illustration of the computation of the kernel of a matrix (see Template:Slink, below for methods better suited to more complex calculations). The illustration also touches on the row space and its relation to the kernel.
Consider the matrix The kernel of this matrix consists of all vectors (x, y, z) ∈ R3Script error: No such module "Check for unknown parameters". for which which can be expressed as a homogeneous system of linear equations involving Template:Mvar, Template:Mvar, and Template:Mvar:
The same linear equations can also be written in matrix form as:
Through Gauss–Jordan elimination, the matrix can be reduced to:
Rewriting the matrix in equation form yields:
The elements of the kernel can be further expressed in parametric vector form, as follows:
Since Template:Mvar is a free variable ranging over all real numbers, this can be expressed equally well as: The kernel of Template:Mvar is precisely the solution set to these equations (in this case, a line through the origin in R3Script error: No such module "Check for unknown parameters".). Here, the vector (−1,−26,16)TScript error: No such module "Check for unknown parameters". constitutes a basis of the kernel of Template:Mvar. The nullity of Template:Mvar is therefore 1, as it is spanned by a single vector.
The following dot products are zero: which illustrates that vectors in the kernel of Template:Mvar are orthogonal to each of the row vectors of Template:Mvar.
These two (linearly independent) row vectors span the row space of Template:Mvar—a plane orthogonal to the vector (−1,−26,16)TScript error: No such module "Check for unknown parameters"..
With the rank 2 of Template:Mvar, the nullity 1 of Template:Mvar, and the dimension 3 of Template:Mvar, we have an illustration of the rank-nullity theorem.
Examples
- If L: Rm → RnScript error: No such module "Check for unknown parameters"., then the kernel of LScript error: No such module "Check for unknown parameters". is the solution set to a homogeneous system of linear equations. As in the above illustration, if LScript error: No such module "Check for unknown parameters". is the operator: then the kernel of LScript error: No such module "Check for unknown parameters". is the set of solutions to the equations
- Let C[0,1]Script error: No such module "Check for unknown parameters". denote the vector space of all continuous real-valued functions on the interval [0,1], and define L: C[0,1] → RScript error: No such module "Check for unknown parameters". by the rule Then the kernel of LScript error: No such module "Check for unknown parameters". consists of all functions f ∈ C[0,1]Script error: No such module "Check for unknown parameters". for which f(0.3) = 0Script error: No such module "Check for unknown parameters"..
- Let C∞(R)Script error: No such module "Check for unknown parameters". be the vector space of all infinitely differentiable functions R → RScript error: No such module "Check for unknown parameters"., and let D: C∞(R) → C∞(R)Script error: No such module "Check for unknown parameters". be the differentiation operator: Then the kernel of DScript error: No such module "Check for unknown parameters". consists of all functions in C∞(R)Script error: No such module "Check for unknown parameters". whose derivatives are zero, i.e. the set of all constant functions.
- Let R∞Script error: No such module "Check for unknown parameters". be the direct product of infinitely many copies of RScript error: No such module "Check for unknown parameters"., and let s: R∞ → R∞Script error: No such module "Check for unknown parameters". be the shift operator Then the kernel of sScript error: No such module "Check for unknown parameters". is the one-dimensional subspace consisting of all vectors (x1, 0, 0, 0, ...)Script error: No such module "Check for unknown parameters"..
- If Template:Mvar is an inner product space and Template:Mvar is a subspace, the kernel of the orthogonal projection V → WScript error: No such module "Check for unknown parameters". is the orthogonal complement to Template:Mvar in Template:Mvar.
Computation by Gaussian elimination
A basis of the kernel of a matrix may be computed by Gaussian elimination.
For this purpose, given an m × nScript error: No such module "Check for unknown parameters". matrix Template:Mvar, we construct first the row augmented matrix where IScript error: No such module "Check for unknown parameters". is the n × nScript error: No such module "Check for unknown parameters". identity matrix.
Computing its column echelon form by Gaussian elimination (or any other suitable method), we get a matrix A basis of the kernel of Template:Mvar consists in the non-zero columns of Template:Mvar such that the corresponding column of Template:Mvar is a zero column.
In fact, the computation may be stopped as soon as the upper matrix is in column echelon form: the remainder of the computation consists in changing the basis of the vector space generated by the columns whose upper part is zero.
For example, suppose that Then
Putting the upper part in column echelon form by column operations on the whole matrix gives
The last three columns of Template:Mvar are zero columns. Therefore, the three last vectors of Template:Mvar, are a basis of the kernel of Template:Mvar.
Proof that the method computes the kernel: Since column operations correspond to post-multiplication by invertible matrices, the fact that reduces to means that there exists an invertible matrix such that with in column echelon form. Thus , , and . A column vector belongs to the kernel of (that is ) if and only if where . As is in column echelon form, , if and only if the nonzero entries of correspond to the zero columns of . By multiplying by , one may deduce that this is the case if and only if is a linear combination of the corresponding columns of .
Numerical computation
The problem of computing the kernel on a computer depends on the nature of the coefficients.
Exact coefficients
If the coefficients of the matrix are exactly given numbers, the column echelon form of the matrix may be computed with Bareiss algorithm more efficiently than with Gaussian elimination. It is even more efficient to use modular arithmetic and Chinese remainder theorem, which reduces the problem to several similar ones over finite fields (this avoids the overhead induced by the non-linearity of the computational complexity of integer multiplication).Script error: No such module "Unsubst".
For coefficients in a finite field, Gaussian elimination works well, but for the large matrices that occur in cryptography and Gröbner basis computation, better algorithms are known, which have roughly the same computational complexity, but are faster and behave better with modern computer hardware.Script error: No such module "Unsubst".
Floating point computation
For matrices whose entries are floating-point numbers, the problem of computing the kernel makes sense only for matrices such that the number of rows is equal to their rank: because of the rounding errors, a floating-point matrix has almost always a full rank, even when it is an approximation of a matrix of a much smaller rank. Even for a full-rank matrix, it is possible to compute its kernel only if it is well conditioned, i.e. it has a low condition number.[5]Script error: No such module "Unsubst".
Even for a well conditioned full rank matrix, Gaussian elimination does not behave correctly: it introduces rounding errors that are too large for getting a significant result. As the computation of the kernel of a matrix is a special instance of solving a homogeneous system of linear equations, the kernel may be computed with any of the various algorithms designed to solve homogeneous systems. A state of the art software for this purpose is the Lapack library.Script error: No such module "Unsubst".
See also
<templatestyles src="Div col/styles.css"/>
Notes and references
<templatestyles src="Reflist/styles.css" />
- ↑ Script error: No such module "citation/CS1".
- ↑ a b Script error: No such module "citation/CS1".
- ↑ Linear algebra, as discussed in this article, is a very well established mathematical discipline for which there are many sources. Almost all of the material in this article can be found in Script error: No such module "Footnotes"., Script error: No such module "Footnotes"., and Strang's lectures.
- ↑ a b Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
Script error: No such module "Check for unknown parameters".
Bibliography
Script error: No such module "Labelled list hatnote".
<templatestyles src="Refbegin/styles.css" />
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
External links
Script error: No such module "Navbox".