fbpx
Wikipedia

Outer product

In linear algebra, the outer product of two coordinate vectors is the matrix whose entries are all products of an element in the first vector with an element in the second vector. If the two coordinate vectors have dimensions n and m, then their outer product is an n × m matrix. More generally, given two tensors (multidimensional arrays of numbers), their outer product is a tensor. The outer product of tensors is also referred to as their tensor product, and can be used to define the tensor algebra.

The outer product contrasts with:

Definition edit

Given two vectors of size   and   respectively

 

their outer product, denoted   is defined as the   matrix   obtained by multiplying each element of   by each element of  :[1]

 

Or, in index notation:

 

Denoting the dot product by   if given an   vector   then   If given a   vector   then  

If   and   are vectors of the same dimension bigger than 1, then  .

The outer product   is equivalent to a matrix multiplication   provided that   is represented as a   column vector and   as a   column vector (which makes   a row vector).[2][3] For instance, if   and   then[4]

 

For complex vectors, it is often useful to take the conjugate transpose of   denoted   or  :

 

Contrast with Euclidean inner product edit

If   then one can take the matrix product the other way, yielding a scalar (or   matrix):

 

which is the standard inner product for Euclidean vector spaces,[3] better known as the dot product. The dot product is the trace of the outer product.[5] Unlike the dot product, the outer product is not commutative.

Multiplication of a vector   by the matrix   can be written in terms of the inner product, using the relation  .

The outer product of tensors edit

Given two tensors   with dimensions   and  , their outer product   is a tensor with dimensions   and entries

 

For example, if   is of order 3 with dimensions   and   is of order 2 with dimensions   then their outer product   is of order 5 with dimensions   If   has a component A[2, 2, 4] = 11 and   has a component B[8, 88] = 13, then the component of   formed by the outer product is C[2, 2, 4, 8, 88] = 143.

Connection with the Kronecker product edit

The outer product and Kronecker product are closely related; in fact the same symbol is commonly used to denote both operations.

If   and  , we have:

 

In the case of column vectors, the Kronecker product can be viewed as a form of vectorization (or flattening) of the outer product. In particular, for two column vectors   and  , we can write:

 

(The order of the vectors is reversed on the right side of the equation.)

Another similar identity that further highlights the similarity between the operations is

 

where the order of vectors needs not be flipped. The middle expression uses matrix multiplication, where the vectors are considered as column/row matrices.

Connection with the matrix product edit

Given a pair of matrices   of size   and   of size  , consider the matrix product   defined as usual as a matrix of size  .

Now let   be the  -th column vector of   and let   be the  -th row vector of  . Then   can be expressed as a sum of column-by-row outer products:

 

This expression has duality with the more common one as a matrix built with row-by-column inner product entries (or dot product):  

This relation is relevant[6] in the application of the Singular Value Decomposition (SVD) (and Spectral Decomposition as a special case). In particular, the decomposition can be interpreted as the sum of outer products of each left ( ) and right ( ) singular vectors, scaled by the corresponding nonzero singular value  :

 

This result implies that   can be expressed as a sum of rank-1 matrices with spectral norm   in decreasing order. This explains the fact why, in general, the last terms contribute less, which motivates the use of the truncated SVD as an approximation. The first term is the least squares fit of a matrix to an outer product of vectors.

Properties edit

The outer product of vectors satisfies the following properties:

 

The outer product of tensors satisfies the additional associativity property:

 

Rank of an outer product edit

If u and v are both nonzero, then the outer product matrix uvT always has matrix rank 1. Indeed, the columns of the outer product are all proportional to the first column. Thus they are all linearly dependent on that one column, hence the matrix is of rank one.

("Matrix rank" should not be confused with "tensor order", or "tensor degree", which is sometimes referred to as "rank".)

Definition (abstract) edit

Let V and W be two vector spaces. The outer product of   and   is the element  .

If V is an inner product space, then it is possible to define the outer product as a linear map VW. In this case, the linear map   is an element of the dual space of V, as this maps linearly a vector into its underlying field, of which   is an element. The outer product VW is then given by

 

This shows why a conjugate transpose of v is commonly taken in the complex case.

In programming languages edit

In some programming languages, given a two-argument function f (or a binary operator), the outer product, f, of two one-dimensional arrays, A and B, is a two-dimensional array C such that C[i, j] = f(A[i], B[j]). This is syntactically represented in various ways: in APL, as the infix binary operator ∘.f; in J, as the postfix adverb f/; in R, as the function outer(A, B, f) or the special %o%;[7] in Mathematica, as Outer[f, A, B]. In MATLAB, the function kron(A, B) is used for this product. These often generalize to multi-dimensional arguments, and more than two arguments.

In the Python library NumPy, the outer product can be computed with function np.outer().[8] In contrast, np.kron results in a flat array. The outer product of multidimensional arrays can be computed using np.multiply.outer.

Applications edit

As the outer product is closely related to the Kronecker product, some of the applications of the Kronecker product use outer products. These applications are found in quantum theory, signal processing, and image compression.[9]

Spinors edit

Suppose s, t, w, zC so that (s, t) and (w, z) are in C2. Then the outer product of these complex 2-vectors is an element of M(2, C), the 2 × 2 complex matrices:

 

The determinant of this matrix is swtzsztw = 0 because of the commutative property of C.

In the theory of spinors in three dimensions, these matrices are associated with isotropic vectors due to this null property. Élie Cartan described this construction in 1937,[10] but it was introduced by Wolfgang Pauli in 1927[11] so that M(2,C) has come to be called Pauli algebra.

Concepts edit

The block form of outer products is useful in classification. Concept analysis is a study that depends on certain outer products:

When a vector has only zeros and ones as entries, it is called a logical vector, a special case of a logical matrix. The logical operation and takes the place of multiplication. The outer product of two logical vectors (ui) and (vj) is given by the logical matrix  . This type of matrix is used in the study of binary relations, and is called a rectangular relation or a cross-vector.[12]

See also edit

Products edit

Duality edit

References edit

  1. ^ Lerner, R. G.; Trigg, G. L. (1991). Encyclopaedia of Physics (2nd ed.). VHC. ISBN 0-89573-752-3.
  2. ^ Lipschutz, S.; Lipson, M. (2009). Linear Algebra. Schaum’s Outlines (4th ed.). McGraw-Hill. ISBN 978-0-07-154352-1.
  3. ^ a b Keller, Frank (February 23, 2020). "Algebraic Properties of Matrices; Transpose; Inner and Outer Product" (PDF). inf.ed.ac.uk. (PDF) from the original on 2017-12-15. Retrieved September 6, 2020.
  4. ^ James M. Ortega (1987) Matrix Theory: A Second Course, page 7, Plenum Press ISBN 0-306-42433-9
  5. ^ Stengel, Robert F. (1994). Optimal Control and Estimation. New York: Dover Publications. p. 26. ISBN 0-486-68200-5.
  6. ^ Trefethen, Lloyd N.; Bau III, David (1997). Numerical linear algebra. Philadelphia: Society for Industrial and Applied Mathematics. ISBN 978-0-89871-361-9.
  7. ^ "outer function | R Documentation". rdocumentation.org. Retrieved 2020-09-07.
  8. ^ "numpy.outer — NumPy v1.19 Manual". numpy.org. Retrieved 2020-09-07.
  9. ^ Steeb, Willi-Hans; Hardy, Yorick (2011). "Applications (Chapter 3)". Matrix Calculus and Kronecker Product: A Practical Approach to Linear and Multilinear Algebra (2 ed.). World Scientific. ISBN 978-981-4335-31-7.
  10. ^ Élie Cartan (1937) Lecons sur la theorie des spineurs, translated 1966: The Theory of Spinors, Hermann, Paris
  11. ^ Pertti Lounesto (1997) Clifford Algebras and Spinors, page 51, Cambridge University Press ISBN 0-521-59916-4
  12. ^ Ki Hang Kim (1982) Boolean Matrix Theory and Applications, page 37, Marcel Dekker ISBN 0-8247-1788-0

Further reading edit

  • Carlen, Eric; Canceicao Carvalho, Maria (2006). "Outer Products and Orthogonal Projections". Linear Algebra: From the Beginning. Macmillan. pp. 217–218. ISBN 9780716748946.

outer, product, confused, with, exterior, product, linear, algebra, outer, product, coordinate, vectors, matrix, whose, entries, products, element, first, vector, with, element, second, vector, coordinate, vectors, have, dimensions, then, their, outer, product. Not to be confused with Exterior product In linear algebra the outer product of two coordinate vectors is the matrix whose entries are all products of an element in the first vector with an element in the second vector If the two coordinate vectors have dimensions n and m then their outer product is an n m matrix More generally given two tensors multidimensional arrays of numbers their outer product is a tensor The outer product of tensors is also referred to as their tensor product and can be used to define the tensor algebra The outer product contrasts with The dot product a special case of inner product which takes a pair of coordinate vectors as input and produces a scalar The Kronecker product which takes a pair of matrices as input and produces a block matrix Standard matrix multiplication Contents 1 Definition 1 1 Contrast with Euclidean inner product 1 2 The outer product of tensors 1 3 Connection with the Kronecker product 1 4 Connection with the matrix product 2 Properties 2 1 Rank of an outer product 3 Definition abstract 4 In programming languages 5 Applications 5 1 Spinors 5 2 Concepts 6 See also 6 1 Products 6 2 Duality 7 References 8 Further readingDefinition editGiven two vectors of size m 1 displaystyle m times 1 nbsp and n 1 displaystyle n times 1 nbsp respectively u u 1 u 2 u m v v 1 v 2 v n displaystyle mathbf u begin bmatrix u 1 u 2 vdots u m end bmatrix quad mathbf v begin bmatrix v 1 v 2 vdots v n end bmatrix nbsp their outer product denoted u v displaystyle mathbf u otimes mathbf v nbsp is defined as the m n displaystyle m times n nbsp matrix A displaystyle mathbf A nbsp obtained by multiplying each element of u displaystyle mathbf u nbsp by each element of v displaystyle mathbf v nbsp 1 u v A u 1 v 1 u 1 v 2 u 1 v n u 2 v 1 u 2 v 2 u 2 v n u m v 1 u m v 2 u m v n displaystyle mathbf u otimes mathbf v mathbf A begin bmatrix u 1 v 1 amp u 1 v 2 amp dots amp u 1 v n u 2 v 1 amp u 2 v 2 amp dots amp u 2 v n vdots amp vdots amp ddots amp vdots u m v 1 amp u m v 2 amp dots amp u m v n end bmatrix nbsp Or in index notation u v i j u i v j displaystyle mathbf u otimes mathbf v ij u i v j nbsp Denoting the dot product by displaystyle cdot nbsp if given an n 1 displaystyle n times 1 nbsp vector w displaystyle mathbf w nbsp then u v w v w u displaystyle mathbf u otimes mathbf v mathbf w mathbf v cdot mathbf w mathbf u nbsp If given a 1 m displaystyle 1 times m nbsp vector x displaystyle mathbf x nbsp then x u v x u v T displaystyle mathbf x mathbf u otimes mathbf v mathbf x cdot mathbf u mathbf v operatorname T nbsp If u displaystyle mathbf u nbsp and v displaystyle mathbf v nbsp are vectors of the same dimension bigger than 1 then det u v 0 displaystyle det mathbf u otimes mathbf v 0 nbsp The outer product u v displaystyle mathbf u otimes mathbf v nbsp is equivalent to a matrix multiplication u v T displaystyle mathbf u mathbf v operatorname T nbsp provided that u displaystyle mathbf u nbsp is represented as a m 1 displaystyle m times 1 nbsp column vector and v displaystyle mathbf v nbsp as a n 1 displaystyle n times 1 nbsp column vector which makes v T displaystyle mathbf v operatorname T nbsp a row vector 2 3 For instance if m 4 displaystyle m 4 nbsp and n 3 displaystyle n 3 nbsp then 4 u v u v T u 1 u 2 u 3 u 4 v 1 v 2 v 3 u 1 v 1 u 1 v 2 u 1 v 3 u 2 v 1 u 2 v 2 u 2 v 3 u 3 v 1 u 3 v 2 u 3 v 3 u 4 v 1 u 4 v 2 u 4 v 3 displaystyle mathbf u otimes mathbf v mathbf u mathbf v textsf T begin bmatrix u 1 u 2 u 3 u 4 end bmatrix begin bmatrix v 1 amp v 2 amp v 3 end bmatrix begin bmatrix u 1 v 1 amp u 1 v 2 amp u 1 v 3 u 2 v 1 amp u 2 v 2 amp u 2 v 3 u 3 v 1 amp u 3 v 2 amp u 3 v 3 u 4 v 1 amp u 4 v 2 amp u 4 v 3 end bmatrix nbsp For complex vectors it is often useful to take the conjugate transpose of v displaystyle mathbf v nbsp denoted v displaystyle mathbf v dagger nbsp or v T displaystyle left mathbf v textsf T right nbsp u v u v u v T displaystyle mathbf u otimes mathbf v mathbf u mathbf v dagger mathbf u left mathbf v textsf T right nbsp Contrast with Euclidean inner product edit If m n displaystyle m n nbsp then one can take the matrix product the other way yielding a scalar or 1 1 displaystyle 1 times 1 nbsp matrix u v u T v displaystyle left langle mathbf u mathbf v right rangle mathbf u textsf T mathbf v nbsp which is the standard inner product for Euclidean vector spaces 3 better known as the dot product The dot product is the trace of the outer product 5 Unlike the dot product the outer product is not commutative Multiplication of a vector w displaystyle mathbf w nbsp by the matrix u v displaystyle mathbf u otimes mathbf v nbsp can be written in terms of the inner product using the relation u v w u v w displaystyle left mathbf u otimes mathbf v right mathbf w mathbf u left langle mathbf v mathbf w right rangle nbsp The outer product of tensors edit Given two tensors u v displaystyle mathbf u mathbf v nbsp with dimensions k 1 k 2 k m displaystyle k 1 k 2 dots k m nbsp and l 1 l 2 l n displaystyle l 1 l 2 dots l n nbsp their outer product u v displaystyle mathbf u otimes mathbf v nbsp is a tensor with dimensions k 1 k 2 k m l 1 l 2 l n displaystyle k 1 k 2 dots k m l 1 l 2 dots l n nbsp and entries u v i 1 i 2 i m j 1 j 2 j n u i 1 i 2 i m v j 1 j 2 j n displaystyle mathbf u otimes mathbf v i 1 i 2 dots i m j 1 j 2 dots j n u i 1 i 2 dots i m v j 1 j 2 dots j n nbsp For example if A displaystyle mathbf A nbsp is of order 3 with dimensions 3 5 7 displaystyle 3 5 7 nbsp and B displaystyle mathbf B nbsp is of order 2 with dimensions 10 100 displaystyle 10 100 nbsp then their outer product C displaystyle mathbf C nbsp is of order 5 with dimensions 3 5 7 10 100 displaystyle 3 5 7 10 100 nbsp If A displaystyle mathbf A nbsp has a component A 2 2 4 11 and B displaystyle mathbf B nbsp has a component B 8 88 13 then the component of C displaystyle mathbf C nbsp formed by the outer product is C 2 2 4 8 88 143 Connection with the Kronecker product edit The outer product and Kronecker product are closely related in fact the same symbol is commonly used to denote both operations If u 1 2 3 T displaystyle mathbf u begin bmatrix 1 amp 2 amp 3 end bmatrix textsf T nbsp and v 4 5 T displaystyle mathbf v begin bmatrix 4 amp 5 end bmatrix textsf T nbsp we have u Kron v 4 5 8 10 12 15 u outer v 4 5 8 10 12 15 displaystyle begin aligned mathbf u otimes text Kron mathbf v amp begin bmatrix 4 5 8 10 12 15 end bmatrix amp mathbf u otimes text outer mathbf v amp begin bmatrix 4 amp 5 8 amp 10 12 amp 15 end bmatrix end aligned nbsp In the case of column vectors the Kronecker product can be viewed as a form of vectorization or flattening of the outer product In particular for two column vectors u displaystyle mathbf u nbsp and v displaystyle mathbf v nbsp we can write u Kron v vec v outer u displaystyle mathbf u otimes text Kron mathbf v operatorname vec mathbf v otimes text outer mathbf u nbsp The order of the vectors is reversed on the right side of the equation Another similar identity that further highlights the similarity between the operations is u Kron v T u v T u outer v displaystyle mathbf u otimes text Kron mathbf v textsf T mathbf u mathbf v textsf T mathbf u otimes text outer mathbf v nbsp where the order of vectors needs not be flipped The middle expression uses matrix multiplication where the vectors are considered as column row matrices Connection with the matrix product edit Given a pair of matrices A displaystyle mathbf A nbsp of size m p displaystyle m times p nbsp and B displaystyle mathbf B nbsp of size p n displaystyle p times n nbsp consider the matrix product C A B displaystyle mathbf C mathbf A mathbf B nbsp defined as usual as a matrix of size m n displaystyle m times n nbsp Now let a k col displaystyle mathbf a k text col nbsp be the k displaystyle k nbsp th column vector of A displaystyle mathbf A nbsp and let b k row displaystyle mathbf b k text row nbsp be the k displaystyle k nbsp th row vector of B displaystyle mathbf B nbsp Then C displaystyle mathbf C nbsp can be expressed as a sum of column by row outer products C A B k 1 p A i k B k j 1 i m 1 j n a 1 col a p col b 1 row b p row k 1 p a k col b k row displaystyle mathbf C mathbf A mathbf B left sum k 1 p A ik B kj right begin matrix 1 leq i leq m 20pt 1 leq j leq n end matrix begin bmatrix amp amp mathbf a 1 text col amp cdots amp mathbf a p text col amp amp end bmatrix begin bmatrix amp mathbf b 1 text row amp amp vdots amp amp mathbf b p text row amp end bmatrix sum k 1 p mathbf a k text col otimes mathbf b k text row nbsp This expression has duality with the more common one as a matrix built with row by column inner product entries or dot product C i j a i row b j col displaystyle C ij langle mathbf a i text row mathbf b j text col rangle nbsp This relation is relevant 6 in the application of the Singular Value Decomposition SVD and Spectral Decomposition as a special case In particular the decomposition can be interpreted as the sum of outer products of each left u k displaystyle mathbf u k nbsp and right v k displaystyle mathbf v k nbsp singular vectors scaled by the corresponding nonzero singular value s k displaystyle sigma k nbsp A U S V T k 1 rank A u k v k s k displaystyle mathbf A mathbf U Sigma V T sum k 1 operatorname rank A mathbf u k otimes mathbf v k sigma k nbsp This result implies that A displaystyle mathbf A nbsp can be expressed as a sum of rank 1 matrices with spectral norm s k displaystyle sigma k nbsp in decreasing order This explains the fact why in general the last terms contribute less which motivates the use of the truncated SVD as an approximation The first term is the least squares fit of a matrix to an outer product of vectors Properties editThe outer product of vectors satisfies the following properties u v T v u v w u v u w u u v w u v u w c v u c v u v c u displaystyle begin aligned mathbf u otimes mathbf v textsf T amp mathbf v otimes mathbf u mathbf v mathbf w otimes mathbf u amp mathbf v otimes mathbf u mathbf w otimes mathbf u mathbf u otimes mathbf v mathbf w amp mathbf u otimes mathbf v mathbf u otimes mathbf w c mathbf v otimes mathbf u amp c mathbf v otimes mathbf u mathbf v otimes c mathbf u end aligned nbsp The outer product of tensors satisfies the additional associativity property u v w u v w displaystyle mathbf u otimes mathbf v otimes mathbf w mathbf u otimes mathbf v otimes mathbf w nbsp Rank of an outer product edit If u and v are both nonzero then the outer product matrix uvT always has matrix rank 1 Indeed the columns of the outer product are all proportional to the first column Thus they are all linearly dependent on that one column hence the matrix is of rank one Matrix rank should not be confused with tensor order or tensor degree which is sometimes referred to as rank Definition abstract editLet V and W be two vector spaces The outer product of v V displaystyle mathbf v in V nbsp and w W displaystyle mathbf w in W nbsp is the element v w V W displaystyle mathbf v otimes mathbf w in V otimes W nbsp If V is an inner product space then it is possible to define the outer product as a linear map V W In this case the linear map x v x displaystyle mathbf x mapsto langle mathbf v mathbf x rangle nbsp is an element of the dual space of V as this maps linearly a vector into its underlying field of which v x displaystyle langle mathbf v mathbf x rangle nbsp is an element The outer product V W is then given by w v x v x w displaystyle mathbf w otimes mathbf v mathbf x left langle mathbf v mathbf x right rangle mathbf w nbsp This shows why a conjugate transpose of v is commonly taken in the complex case In programming languages editIn some programming languages given a two argument function f or a binary operator the outer product f of two one dimensional arrays A and B is a two dimensional array C such that C i j f A i B j This is syntactically represented in various ways in APL as the infix binary operator span class na span span class nv f span in J as the postfix adverb span class nv f span span class o span in R as the function span class nf outer span span class p span span class n A span span class p span span class w span span class n B span span class p span span class w span span class n f span span class p span or the special span class o o span 7 in Mathematica as span class n Outer span span class p span span class n f span span class p span span class w span span class n A span span class p span span class w span span class n B span span class p span In MATLAB the function span class nb kron span span class p span span class n A span span class p span span class w span span class n B span span class p span is used for this product These often generalize to multi dimensional arguments and more than two arguments In the Python library NumPy the outer product can be computed with function np outer 8 In contrast np kron results in a flat array The outer product of multidimensional arrays can be computed using np multiply outer Applications editAs the outer product is closely related to the Kronecker product some of the applications of the Kronecker product use outer products These applications are found in quantum theory signal processing and image compression 9 Spinors edit Suppose s t w z C so that s t and w z are in C2 Then the outer product of these complex 2 vectors is an element of M 2 C the 2 2 complex matrices s w t w s z t z displaystyle begin pmatrix sw amp tw sz amp tz end pmatrix nbsp The determinant of this matrix is swtz sztw 0 because of the commutative property of C In the theory of spinors in three dimensions these matrices are associated with isotropic vectors due to this null property Elie Cartan described this construction in 1937 10 but it was introduced by Wolfgang Pauli in 1927 11 so that M 2 C has come to be called Pauli algebra Concepts edit The block form of outer products is useful in classification Concept analysis is a study that depends on certain outer products When a vector has only zeros and ones as entries it is called a logical vector a special case of a logical matrix The logical operation and takes the place of multiplication The outer product of two logical vectors ui and vj is given by the logical matrix a i j u i v j displaystyle left a ij right left u i land v j right nbsp This type of matrix is used in the study of binary relations and is called a rectangular relation or a cross vector 12 See also editDyadics Householder transformation Norm mathematics Ricci calculus Scatter matrix Products edit Cartesian product Cross product Exterior product Hadamard product matrices Duality edit Bra ket notation for outer product Complex conjugate Conjugate transpose TransposeReferences edit Lerner R G Trigg G L 1991 Encyclopaedia of Physics 2nd ed VHC ISBN 0 89573 752 3 Lipschutz S Lipson M 2009 Linear Algebra Schaum s Outlines 4th ed McGraw Hill ISBN 978 0 07 154352 1 a b Keller Frank February 23 2020 Algebraic Properties of Matrices Transpose Inner and Outer Product PDF inf ed ac uk Archived PDF from the original on 2017 12 15 Retrieved September 6 2020 James M Ortega 1987 Matrix Theory A Second Course page 7 Plenum Press ISBN 0 306 42433 9 Stengel Robert F 1994 Optimal Control and Estimation New York Dover Publications p 26 ISBN 0 486 68200 5 Trefethen Lloyd N Bau III David 1997 Numerical linear algebra Philadelphia Society for Industrial and Applied Mathematics ISBN 978 0 89871 361 9 outer function R Documentation rdocumentation org Retrieved 2020 09 07 numpy outer NumPy v1 19 Manual numpy org Retrieved 2020 09 07 Steeb Willi Hans Hardy Yorick 2011 Applications Chapter 3 Matrix Calculus and Kronecker Product A Practical Approach to Linear and Multilinear Algebra 2 ed World Scientific ISBN 978 981 4335 31 7 Elie Cartan 1937 Lecons sur la theorie des spineurs translated 1966 The Theory of Spinors Hermann Paris Pertti Lounesto 1997 Clifford Algebras and Spinors page 51 Cambridge University Press ISBN 0 521 59916 4 Ki Hang Kim 1982 Boolean Matrix Theory and Applications page 37 Marcel Dekker ISBN 0 8247 1788 0Further reading editCarlen Eric Canceicao Carvalho Maria 2006 Outer Products and Orthogonal Projections Linear Algebra From the Beginning Macmillan pp 217 218 ISBN 9780716748946 Retrieved from https en wikipedia org w index php title Outer product amp oldid 1209747228, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.