CUR matrix approximation

A CUR matrix approximation is a set of three matrices that, when multiplied together, closely approximate a given matrix.[1][2][3] A CUR approximation can be used in the same way as the low-rank approximation of the singular value decomposition (SVD). CUR approximations are less accurate than the SVD, but they offer two key advantages, both stemming from the fact that the rows and columns come from the original matrix (rather than left and right singular vectors):

  • There are methods to calculate it with lower asymptotic time complexity versus the SVD.
  • The matrices are more interpretable; The meanings of rows and columns in the decomposed matrix are essentially the same as their meanings in the original matrix.

Formally, a CUR matrix approximation of a matrix A is three matrices C, U, and R such that C is made from columns of A, R is made from rows of A, and that the product CUR closely approximates A. Usually the CUR is selected to be a rank-k approximation, which means that C contains k columns of A, R contains k rows of A, and U is a k-by-k matrix. There are many possible CUR matrix approximations, and many CUR matrix approximations for a given rank.

The CUR matrix approximation is often [citation needed] used in place of the low-rank approximation of the SVD in principal component analysis. The CUR is less accurate, but the columns of the matrix C are taken from A and the rows of R are taken from A. In PCA, each column of A contains a data sample; thus, the matrix C is made of a subset of data samples. This is much easier to interpret than the SVD's left singular vectors, which represent the data in a rotated space. Similarly, the matrix R is made of a subset of variables measured for each data sample. This is easier to comprehend than the SVD's right singular vectors, which are another rotations of the data in space.

Matrix CUR

edit

Hamm[4] and Aldroubi et al.[5] describe the following theorem, which outlines a CUR decomposition of a matrix   with rank  :

Theorem: Consider row and column indices   with  . Denote submatrices     and  . If rank( ) = rank( ), then  , where   denotes the Moore–Penrose pseudoinverse.

In other words, if   has low rank, we can take a sub-matrix   of the same rank, together with some rows   and columns   of   and use them to reconstruct  .

Tensor CUR

edit

Tensor-CURT decomposition[6] is a generalization of matrix-CUR decomposition. Formally, a CURT tensor approximation of a tensor A is three matrices and a (core-)tensor C, R, T and U such that C is made from columns of A, R is made from rows of A, T is made from tubes of A and that the product U(C,R,T) (where the  -th entry of it is  ) closely approximates A. Usually the CURT is selected to be a rank-k approximation, which means that C contains k columns of A, R contains k rows of A, T contains tubes of A and U is a k-by-k-by-k (core-)tensor.

Algorithms

edit

The CUR matrix approximation is not unique and there are multiple algorithms for computing one. One is ALGORITHMCUR.[1]

The "Linear Time CUR" algorithm [7] simply picks J by sampling columns randomly (with replacement) with probability proportional to the squared column norms,  ; and similarly sampling I proportional to the squared row norms,  . The authors show that taking   and   where  , the algorithm achieves Frobenius error bound  , where   is the optimal rank k approximation.


See also

edit

References

edit
  1. ^ a b Michael W. Mahoney; Petros Drineas (2009). "CUR matrix decompositions for improved data analysis". Proceedings of the National Academy of Sciences. 106 (3): 697–702. doi:10.1073/pnas.0803205106. PMC 2630100.
  2. ^ Boutsidis, Christos; Woodruff, David P. (2014). Optimal CUR matrix decompositions. STOC '14 Proceedings of the forty-sixth annual ACM symposium on Theory of Computing.
  3. ^ Song, Zhao; Woodruff, David P.; Zhong, Peilin (2017). Low Rank Approximation with Entrywise L1-Norm Error. STOC '17 Proceedings of the forty-ninth annual ACM symposium on Theory of Computing. arXiv:1611.00898.
  4. ^ Keaton Hamm and Longxiu Huang. Perspectives on CUR decompositions. Applied and Computational Harmonic Analysis, 48(3):1088–1099, 2020.
  5. ^ Aldroubi, Akram and Hamm, Keaton and Koku, Ahmet Bugra and Sekmen, Ali. CUR decompositions, similarity matrices, and subspace clustering. Frontiers in Applied Mathematics and Statistics, 2019, Frontiers Media SA
  6. ^ Song, Zhao; Woodruff, David P.; Zhong, Peilin (2017). "Relative Error Tensor Low Rank Approximation". arXiv:1704.08246 [cs.DS].
  7. ^ Drineas, Petros; Kannan, Ravi; Mahoney, Michael W. (2006-01-01). "Fast Monte Carlo Algorithms for Matrices I: Approximating Matrix Multiplication". SIAM Journal on Computing. 36 (1): 132–157. doi:10.1137/S0097539704442684. ISSN 0097-5397.