Jump to content
 







Main menu
   


Navigation  



Main page
Contents
Current events
Random article
About Wikipedia
Contact us
Donate
 




Contribute  



Help
Learn to edit
Community portal
Recent changes
Upload file
 








Search  

































Create account

Log in
 









Create account
 Log in
 




Pages for logged out editors learn more  



Contributions
Talk
 



















Contents

   



(Top)
 


1 Definition  





2 Properties  





3 Schur product theorem  





4 In programming languages  





5 Applications  





6 See also  





7 References  














Hadamard product (matrices)






العربية
Català
Čeština
Deutsch
فارسی
Français

Magyar
Nederlands

Română
Русский
ி
Українська

 

Edit links
 









Article
Talk
 

















Read
Edit
View history
 








Tools
   


Actions  



Read
Edit
View history
 




General  



What links here
Related changes
Upload file
Special pages
Permanent link
Page information
Cite this page
Get shortened URL
Download QR code
Wikidata item
 




Print/export  



Download as PDF
Printable version
 




Print/export  



















Appearance
   

 






From Wikipedia, the free encyclopedia
 


This is an old revision of this page, as edited by Nikai (talk | contribs)at11:07, 24 August 2013 (added "An Introduction to R" as reference). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.
(diff)  Previous revision | Latest revision (diff) | Newer revision  (diff)

Inmathematics, the Hadamard product (also known as the Schur product [1] or the entrywise product[2]) is a binary operation that takes two matrices of the same dimensions, and produces another matrix where each element ij is the product of elements ij of the original two matrices. It should not be confused with the more common matrix product. It is attributed to, and named after, either French mathematician Jacques Hadamard, or German mathematician Issai Schur.

The Hadamard product is associative and distributive, and unlike the matrix product it is also commutative.

Definition

For two matrices, , of the same dimension, the Hadamard product, , is a matrix, of the same dimension as the operands, with elements given by

.

For matrices of different dimensions ( and , where or or both) the Hadamard product is undefined.

Properties

The Hadamard product is commutative, associative and distributive over addition. That is,

The identity matrix under Hadamard multiplication of two m-by-n matrices is m-by-n matrix where all elements are equal to 1. This is different from the identity matrix under regular matrix multiplication, where only the elements of the main diagonal are equal to 1. Furthermore, a matrix has an inverse under Hadamard multiplication if and only if none of the elements are equal to zero.[3]

For vectors and , and corresponding diagonal matrices and with these vectors as their leading diagonals, the following identity holds:[4]

,

where denotes the conjugate transposeof. In particular, using vectors of ones, this shows that the sum of all elements in the Hadamard product is the traceof. A related result for square and , is that the row-sums of their Hadamard product are the diagonal elements of [5]

The Hadamard product is a principal submatrix of the Kronecker product.

Schur product theorem

The Hadamard product of two positive-semidefinite matrices is positive-semidefinite.[5] This is known as the Schur product theorem,[3] after German mathematician Issai Schur. For positive-semidefinite matrices A and B, it is also known that

[5]

In programming languages

Hadamard multiplication is built into certain programming languages under various names. In MATLAB, it is known as array multiplication, with the symbol .*.[6] GAUSS uses the same approach. In Fortran and Mathematica, it is done through simple multiplication operator *, whereas the matrix product is done through the function matmul and the . operator, respectively. In Python with the numpy numerical library or the sympy symbolic library, multiplication of array objects as a1*a2 produces the Hadamard product, but with otherwise identical matrix objects m1*m2 will produce a matrix product. (There are mappings between arrays and matrices: sympy and numpy provide a .A attribute for matrix objects, sympy provides a .M attribute for array objects, and numpy.asmatrix(a1) will produce a matrix view of the array a1.) The Eigen C++ library provides a cwiseProduct member function for the Matrix class (a.cwiseProduct(b)), while the Armadillo library use the operator % to make compact expressions (a % b; a * b is a matrix product). In R the Hadamard product is computed by default, with matrix.A%*%matrix.B giving the standard matrix product.[7]

Applications

The Hadamard product appears in lossy compression algorithms such as JPEG. The decoding step involves an entry-for-entry product, i.e., Hadamard product.

See also

References

  1. ^ Davis, Chandler. "The norm of the Schur product operation." Numerische Mathematik 4.1 (1962): 343-344.
  • ^ (Horn & Johnson 1985, Ch. 5)
  • ^ a b Million, Elizabeth. "The Hadamard Product" (PDF). Retrieved 2 January 2012.
  • ^ (Horn & Johnson 1991)
  • ^ a b c (Styan 1973)
  • ^ "Arithmetic Operators + - * / \ ^ ' -". MATLAB documentation. MathWorks. Retrieved 2 January 2012.
  • ^ "Matrix multiplication". An Introduction to R. The R Project for Statistical Computing. 16 May 2013. Retrieved 24 August 2013.

  • Retrieved from "https://en.wikipedia.org/w/index.php?title=Hadamard_product_(matrices)&oldid=569980073"

    Category: 
    Matrix theory
     



    This page was last edited on 24 August 2013, at 11:07 (UTC).

    This version of the page has been revised. Besides normal editing, the reason for revision may have been that this version contains factual inaccuracies, vandalism, or material not compatible with the Creative Commons Attribution-ShareAlike License.



    Privacy policy

    About Wikipedia

    Disclaimers

    Contact Wikipedia

    Code of Conduct

    Developers

    Statistics

    Cookie statement

    Mobile view



    Wikimedia Foundation
    Powered by MediaWiki