<!DOCTYPE html>
<html lang="en-us">

  <head>
  <link href="http://gmpg.org/xfn/11" rel="profile">
  <meta http-equiv="content-type" content="text/html; charset=utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">

  <title>
    
      How to Play the PCA Game &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/2021/12/01/How_to_PCA/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/css/custom.css">
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Serif:400,400italic,700%7CPT+Sans:400">

  <link rel="apple-touch-icon-precomposed" sizes="144x144" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/atom.xml">

  

  <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type="text/javascript" ></script>
 <!-- <script type="text/x-mathjax-config"> MathJax.Hub.Config({ TeX: { equationNumbers: { autoNumber: "AMS" } } }); </script> -->
  <script type="text/x-mathjax-config">
      MathJax.Hub.Config({
        tex2jax: { inlineMath: [ ['$','$'], ["\\(","\\)"] ],
         processEscapes: false
        }
      });
</script>
</head>


  <body>

    <!-- Target for toggling the sidebar `.sidebar-checkbox` is for regular
     styles, `#sidebar-checkbox` for behavior. -->
<input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox">
<!-- <input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox" > -->

<!-- Toggleable sidebar -->
<div class="sidebar" id="sidebar">
  <div class="sidebar-item">
    <p>For short-term, peer-sourced tests of time, generalizations, specializations, reproductions, etc.!</p>
  </div>

  <nav class="sidebar-nav">

    

    
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/tags/">Tags</a>
        
      
    

    <a class="sidebar-nav-item" href="https://github.com/iclr-blog-track/iclr-blog-track.github.io">GitHub project</a>
    <span class="sidebar-nav-item">Currently vICLR Spring 2021</span>
  </nav>

  <div class="sidebar-item">
    <p>
      &copy; 2022. All rights reserved.
    </p>
  </div>
</div>


    <!-- Wrap is the content to shift when toggling the sidebar. We wrap the
         content to avoid any CSS collisions with our real content. -->
    <div class="wrap">
      <div class="masthead">
        <div class="container">
          <h3 class="masthead-title">
            <a href="/" title="Home">The ICLR Blog Track</a>
            <small></small>
          </h3>
        </div>
      </div>

      <div class="container content">
        <div class="post">
  <h1 id="iclr-post-title" class="post-title">How to Play the PCA Game</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#pca"> PCA </a>
  
    <a class="content-tag" href="/tags/#eigengame"> EigenGame </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <h2 id="introduction">Introduction</h2>
<p>The paper <em>EigenGame: PCA as a Nash Equilibrium</em> was published at ICLR 2021. The authors, Ian Gemp, Brian McWilliams, Claire Vernade, and Thore Graepel, introduced a decentralized algorithm for PCA via a game-theoretic analysis. Not only is the approach novel, but the algorithm also has amazing scalability – able to perform PCA on ResNet-200 activations!</p>

<p>In short, the paper shows that with the right utility functions, PCA is the same as finding the Nash equilibrium.</p>

<p>Below we will first review ideas central to the paper, then motivate and explain the algorithms, and finally, we’ll highlight three takeaways from the paper.</p>
<h3 id="background">Background</h3>
<h4 id="pca">PCA</h4>
<p>PCA stands for Principal Component Analysis. It is a widely used technique for dimension reduction and data visualization. The goal of PCA is to find a lower-dimensional representation of the raw data. This is typically done by minimizing the reconstruction error.</p>

<p>There are two assumptions of PCA. One is linearity: the data can be mapped to a linear subspace. The other is orthogonality: the principal components (the basis of the linear subspace) are orthogonal.</p>

<p>Using these assumptions, traditionally, we can select the top eigenvectors of the covariance matrix of raw data as the principal components. To find the low dimensional representation, we simply put the principal components into a projection matrix and multiply the project matrix with the raw data.</p>

<p>Consider the data:</p>
<table>
  <thead>
    <tr>
      <th>x</th>
      <th>y</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>7</td>
      <td>13.486</td>
    </tr>
    <tr>
        <td>1</td>
        <td>2.381</td>
    </tr>
    <tr>
        <td>24</td>
        <td>49.282</td>
    </tr>
    <tr>
      <td>49</td>
      <td>99.855</td>
    </tr>
    <tr>
      <td>25</td>
      <td>49.888</td>
    </tr>
    <tr>
      <td>40</td>
      <td>80.299</td>
    </tr>
    <tr>
      <td>3</td>
      <td>4.716</td>
    </tr>
    <tr>
      <td>6</td>
      <td>12.749</td>
    </tr>
    <tr>
      <td>17</td>
      <td>34.075</td>
    </tr>
    <tr>
      <td>38</td>
      <td>76.412</td>
    </tr>
  </tbody>
</table>
<p>Generated by $y = 2x + noise$, which looks like <img src="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/images/2021-12-01-How_to_PCA/simple_pca.png" alt="Download instructions image" />
So, the covariance matrix is \(\begin{bmatrix} 703 &amp; 1420.52\\ 1420.52 &amp; 2870.88\end{bmatrix}.\)
The two eigenvalues of this covariance matrix are 3573.78 and 0.098. 
The eigenvectors corresponding to the largest and second-largest eigenvalue are $\begin{bmatrix} 0.443 \ -0.896 \end{bmatrix}^{\top}$ and $\begin{bmatrix} -0.896 \ 0.443 \end{bmatrix}^{\top}$, respectively. 
Observe that the first principal component captures the direction of maximum variance (it is roughly parallel to $y=2x$), and the two principal components are orthogonal unit vectors.</p>

<h4 id="nash-equilibrium">Nash Equilibrium</h4>
<p>The Nash Equilibrium of a game is the outcome of the strategies that each player chooses when they are aware of the equilibrium strategies of the other players. So, none of the players can increase their utility by only changing their own strategy.</p>

<p>A famous example for understanding the Nash equilibrium is the Prisoner’s Delima:</p>
<table>
  <thead>
    <tr>
      <th> </th>
      <th>A-Confess</th>
      <th>A-Deny</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>B-Confess </td>
      <td>(-3,-3)</td>
      <td>(-10,-1)</td>
    </tr>
    <tr>
      <td>B-Deny</td>
      <td>(-1,-10)</td>
      <td>(-2,-2)</td>
    </tr>
  </tbody>
</table>
<p>In the matrix above, each pair (a,b) represents the pay-off that A receives utility a and B receives utility B. In this game, (-3,-3) is a Nash equilibrium because if either player changes their strategy from “confess” to “deny” while the other player still confesses, then their utility payoff decreases from -3 to -10. Moreover, this is the unique Nash equilibrium of the game, since in all other strategy combinations, at least one player is denying, and that player could increase the payoff by confessing.</p>

<h2 id="pca-as-an-eigen-game">PCA as an Eigen-Game</h2>
<h3 id="2-in-1-objective">2-in-1 Objective</h3>
<p>We start the analysis by thinking about the covariance matrix $ M = X^{\top} X $ and considering its eigendecomposition. If $V$ is a matrix of the orthonormal eigenvectors of $ M $, then $ MV=V\Lambda $ where $ \Lambda$  is diagonal. Hence, \(V^{\top}MV = V^{\top}V\Lambda=\Lambda\). Now, take $\hat{V}$ to be an estimation of $ V $, and define $ R(\hat{V}) $ to be $ \hat{V}^{\top}M\hat{V} $ then the equation above inspires the objective of minimizing the off-diagonal terms of $ R(\hat{V}) $, which can be expressed mathematically as</p>

\[\begin{equation}\min_{\hat{V}^{\top}\hat{V}=I}\sum_{i\neq j}R_{ij}^2. \end{equation}\]

<p>Note that this objective is satisfied as long as $\hat{V}$ is composed of orthonormal eigenvectors, regardless of their order or the corresponding eigenvalues.</p>

<p>Recall from the discussion of PCA above, one objective is to minimize the reconstruction error. The reconstruction of $X$ from $X\hat{V}$ is $X\hat{V}\hat{V}^{\top}$, so the square of the reconstruction error is \(\|X-X\hat{V}\hat{V}^{\top} \|^2.\)</p>

\[\begin{align*}
\|X-X\hat{V}\hat{V}^{\top}\|^2 &amp;= tr((X-X\hat{V}\hat{V}^{\top})(X-X\hat{V}\hat{V}^{\top})^{\top})\\
&amp;= tr((X-X\hat{V}\hat{V}^{\top})(X^{\top}-\hat{V}\hat{V}^{\top}X^{\top}))\\
&amp;= tr(XX^{\top})-2tr(X\hat{V}\hat{V}^{\top}X^{\top}) + tr(X\hat{V}\hat{V}^{\top}\hat{V}\hat{V}^{\top}X^{\top})\\
&amp;= tr(XX^{\top})-2tr(X\hat{V}\hat{V}^{\top}X^{\top}) + tr(X\hat{V}\hat{V}^{\top}X^{\top})\\
&amp;= tr(XX^{\top})-tr(X\hat{V}\hat{V}^{\top}X^{\top})\\
&amp;= tr(M) - tr(\hat{V}^{\top}X^{\top}X\hat{V})\\
&amp;= tr(M) - tr(\hat{V}^{\top}M\hat{V})\\
&amp;= tr(M) - tr(R(\hat{V}))
\end{align*}\]

<p>Since $tr(M)$ depends only on $X$, minimizing the reconstruction error is equivalent to maximizing the trace of $R$. This objective can be expressed as</p>

\[\max_{\hat{V}^{\top}\hat{V}=I} tr(R(\hat{V}))= \max_{\hat{V}^{\top}\hat{V}=I} \sum_{i} R_{ii}.\]

<p>This objective helps find the subspace spanned by the top eigenvectors, but does not recover the actual eigenvectors.</p>

<p>Seeing that the strength of the two objectives complement each other, it is natural to propose a two-in-one objective</p>

\[\max_{\hat{V}^{\top}\hat{V}=I}\sum_i R_{ii} - \sum_{i\neq j} R^2_{ij}\]

<p>As we’ll see below, this objective can be improved as well.</p>
<h3 id="eigenvector-hierarchy">Eigenvector Hierarchy</h3>
<p>Because we would like an ordered list of the principal components, each column of $\hat{V}$ should have different interpretations, but that distinction is lacking in the objective above. For example, we would like the first column of $\hat{V}$, $\hat{v_1}$, to be the direction of the largest eigenvector, but the objective penalizes $\hat{v_1}$ for aligning with $\hat{v_2}$. Similarly, for $\hat{v_2}$, it makes sense that $\hat{v_2}$ is penalized for aligning with $\hat{v_1}$, but $\hat{v_2}$ should be free to capture the variance independent of $\hat{v_3}$. For each $i&gt;1$, $\hat{v_i}$ should depend on its parents, $\hat{v_1},\cdots,\hat{v_{i-1}}$. We denote the parents of $\hat{v_i}$ by $\hat{v}_{j &lt; i}$. This hierarchy of eigenvectors prompts the assignment of different utility functions for each $\hat{v_i}$.</p>

<p>The Eigenvector hierarchy visualized for the top-5 eigenvectors:
<img src="https://iclr.iro.umontreal.ca/373B1402-EAA6-46FC-9FAA-A8EE8F7DE6CF_1641058688/public/images/2021-12-01-How_to_PCA/hierarchy.png" alt="Download instructions image" /></p>

<h3 id="utility-function">Utility Function</h3>
<p>Starting with $\hat{v_1}$. Since $\hat{v_1}$ should be independent of the other eigenvectors, we might as well take $\hat{V}$ to be $\hat{v_1}$. Then $R(\hat{V})=\langle \hat{v_1}, M\hat{v_1}\rangle$. Because there is no off-diagonal term, we simply maximize $\langle \hat{v_1}, M\hat{v_1}\rangle$ for $\hat{v_1}^{\top}\hat{v_1}=1$, and this is the utility function for $\hat{v_1}$.</p>

<p>For $ i&gt;1 $, given $ \hat{v}_{j &lt; i} $, the utility function for $ \hat{v_i} $ is</p>

\[\begin{equation}
u(\hat{v_i})=\hat{v_i}^{\top} M \hat{v_i} - \sum_{j &lt; i} \frac{(\hat{v_i}^{\top} M \hat{v_j})^2}{\hat{v_j}^{\top} M \hat{v_j}} = \|X\hat{v_i}\|^2 - \sum_{j &lt; i}\frac{\langle X\hat{v_i},X\hat{v_j}\rangle ^2}{\langle X\hat{v_j}, X\hat{v_j}}
\end{equation}\]

<p>The spirit of the utility function follows from the two-in-one objective, and the off-diagonal terms are scaled so that the gradient of the utility function has intuitive mathematical meanings:</p>

<p>The gradient for player $\hat{v_i}$ is</p>

\[2M\left[ \hat{v_i} -\sum_{j &lt; i}\frac{\hat{v_i}^{\top}M\hat{v_j}}{\hat{v_j}^{\top}M \hat{v_j}}\hat{v_j} \right]=2X^{\top}\left[ X\hat{v_i} -\sum_{j &lt; i}\frac{\langle X\hat{v_i}, X\hat{v_j}\rangle}{\langle X\hat{v_j}, X\hat{v_j}\rangle}X\hat{v_j} \right]\]

<p>This can be interpreted as performing a generalized Gram-Schmidt step and then applying techniques used in other successful methods for PCA.</p>

<h3 id="eigengame">EigenGame</h3>
<p>Using these utility functions, it remains to show that the eigenvectors are the unique Nash equilibrium of the game. Below is a sketch of the proof.</p>

<p>First, introduce the following assumption: the eigenvalues for the eigenvectors we seek are positive and distinct. Then, we again start the analysis with $\hat{v_1}$. Because $u(\hat{v_1})$ does not depend on the other $\hat{v_i}$’s and $ \langle \hat{v_1}, M\hat{v_1}\rangle = \frac{\langle \hat{v_1}, M\hat{v_1}\rangle}{\langle \hat{v_1}, \hat{v_1}\rangle} = \Lambda_{11}$ is maximized when $\Lambda_{11}$ is the largest eigenvalue. This shows that $\hat{v_1}$ would not deviate from the eigenvector corresponding to the largest eigenvalue.</p>

<p>For $i &gt; 1$, since the true eigenvectors form a basis (by the Spectral Theorem), let $\hat{v_i}$ be a linear combination of the true eigenvectors. So $\hat{v_i}=
\sum_{p=1}^d w_p v_p$ where $ || w || = 1$. Then,</p>

\[\begin{align}
u(\hat{v_i}) = \sum_{p\geq i} \Lambda_{pp}w_p^2
\end{align}\]

<p>So, maximizing the utility function can be seen as a linear optimization problem over the simplex, and the optimization problem has unique solutions up to a sign change. This makes sense because $v_i$ and $-v_i$ are both principal components. Therefore, if $\hat{v_i}$ deviates from the Nash equilibrium, then the utility would only decrease.</p>

<p>Therefore, using the utility functions defined above, PCA is equivalent to finding the Nash equilibrium.</p>

<h3 id="algorithm">Algorithm</h3>
<p>The EigenGame introduced above easily gives rise to a sequential algorithm that solves for each $v_i$ in order. This sequential algorithm provably converges to the principal components.</p>

<p>Needless to say, a sequential algorithm might not be suitable for large datasets with high dimensions. Observing that as the previous eigenvectors converge their values become relatively stable, the authors come up with a second, decentralized algorithm to speed up the calculations. The algorithm is decentralized in the sense that there is no master node, rather the worker nodes communicate according to the eigenvector hierarchy.</p>

<p>Here is the pseudo-code for the decentralized algorithm:</p>

<p>Given total iterations T and step size $\alpha$,</p>

<dl>
  <dt>Initiallize the vectors by $\hat{v_i}\leftarrow v_i^0$ </dt>
  <dt>for t=1 to T do</dt>
  <dd>rewards $\leftarrow X\hat{v_i}$</dd>
  <dd>penalites $\leftarrow \sum_{j &lt; i}\frac{\langle X\hat{v_i},X\hat{v_j}\rangle}{\langle X\hat{v_j},X\hat{v_j}\rangle}X\hat{v_j}$</dd>
  <dd>$\nabla \hat{v_i} \leftarrow 2X^{\top}$[rewards -penalities]</dd>
  <dd>$\nabla_{\hat{v_i}}^R \leftarrow \nabla\hat{v_i}-\langle \nabla\hat{v_i},\hat{v_i}\rangle \hat{v_i}$</dd>
  <dd>$\hat{v_i}\leftarrow$ normalize($\hat{v_i}+\alpha\nabla_{\hat{v_i}}^R$)</dd>
  <dd>broadcast $\hat{v_i}$</dd>
  <dt> return $\hat{v_i}$ </dt>
</dl>

<h2 id="takeaways">Takeaways</h2>
<ol>
  <li>
    <p>The authors combine two PCA objectives and take advantage of the natural hierarchy of the eigenvectors to create the utility function for each player. The objectives are (a) minimizing the off-diagonal entries and (b) maximizing the diagonal entries.</p>
  </li>
  <li>
    <p>The combined objective helps ensure that the top eigenvectors are recovered in addition to the subspace they span, which is an advantage of this algorithm over some other PCA algorithms, such as Krasulina’s.</p>
  </li>
  <li>
    <p>Since there is a broadcast step in the decentralized algorithm, systems with fast interconnects are required for the algorithm to run efficiently.</p>
  </li>
</ol>

<h2 id="citation">Citation</h2>
<p><a href="https://openreview.net/forum?id=NzTU59SYbNq"> Ian Gemp, Brian McWilliams, Claire Vernade, and Thore Graepel. EigenGame: PCA as a Nash Equilibrium. International Conference on Learning Representations, 2021.</a></p>

</div>

<div id="bibtex-container" class="related">
  For attribution in academic contexts, please cite this work as
  <pre id="bibtex-academic-attribution">

  </pre>

  BibTeX citation
  <pre id="bibtex-box">

  </pre>
</div>
<script>
  let authorsSpan = document.getElementById("iclr-post-authors");
  let authorsText = authorsSpan.textContent;
  let lnameFnameInstitution = authorsText.split(";");
  let lfiList = lnameFnameInstitution.map(lfi => lfi.split(",").map(item => item.trim()));
  let bibtexLFI = lfiList.map(lfi => lfi[0] + ", " + lfi[1]).join(" and ")
  let academicLFI = lfiList.map(lfi => lfi[0]);
  {
    if(academicLFI.length > 2) academicLFI = academicLFI[0] + ", et al.";
    else if(academicLFI.length == 2) academicLFI = academicLFI[0] + " & " + academicLFI[1];
    else academicLFI = academicLFI[0];
  }

  let titleSpan = document.getElementById("iclr-post-title");
  let titleText = titleSpan.textContent.trim();
  let bibtexTitleShorthand = (lfiList[0][1]+
    "2022"+
    titleText.split(" ").slice(0, 3).join("")
  ).replace(" ", "").replace(/[\p{P}$+<=>^`|~]/gu, '').toLowerCase().trim();

  let bibtexTemplate = `
@inproceedings{${bibtexTitleShorthand}},
  author = {${bibtexLFI}},
  title = {${titleText}},
  booktitle = {ICLR Blog Track},
  year = {2022},
  note = {${window.location.href}},
  url  = {${window.location.href}}
}
  `.trim();
  document.getElementById("bibtex-box").innerText = bibtexTemplate;

  let academicTemplate = `
${academicLFI}, "${titleText}", ICLR Blog Track, 2022.
`.trim();
  document.getElementById("bibtex-academic-attribution").innerText = academicTemplate;

</script>



<script src="https://utteranc.es/client.js"
        repo="iclr-blog-track/iclr-blog-track.github.io"
        issue-term="pathname"
        label="utterance"
        theme="boxy-light"
        crossorigin="anonymous"
        >
</script>


      </div>
    </div>

    <label for="sidebar-checkbox" class="sidebar-toggle"></label>

    <script src='/public/js/script.js'></script>
  </body>
</html>
