<!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>
    
      From Generalization to Inner Activations &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/2021/12/01/from-generalization-to-inner-activations/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/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/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/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/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/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">From Generalization to Inner Activations</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#inner-representations"> inner-representations </a>
  
    <a class="content-tag" href="/tags/#activations"> activations </a>
  
    <a class="content-tag" href="/tags/#generalization"> generalization </a>
  
    <a class="content-tag" href="/tags/#perturbation"> perturbation </a>
  
    <a class="content-tag" href="/tags/#svd"> SVD </a>
  
    <a class="content-tag" href="/tags/#cca"> CCA </a>
  </span>

  <span id="iclr-post-authors" class="post-date">REDACTED</span>
  <p>One of the side effects of deep learning models becoming increasingly large is the amount of data that they intermediately generate which is then often ignored.  Researchers have used this information to create explainability methods which show importance relative to a specific input it is connected with, but often the intermediate values are disregarded and mostly underutilized.  Although this intermediate data can become increasingly unwieldily in size as the networks grow, the ability to monitor specific layers is a valuable tool that provides insight into how the model is learning as well as vague generalities about how the model performs overall (e.g. where are specific features begun to be extracted or where is noise filtered out).</p>

<p>These intermediate values follow every layer of the network and while they are related back to a specific input (and are well known for being superimposed back on something like the input or used to train a linear classifier like in <a href="https://arxiv.org/abs/1711.11279">TCAV</a>) some researchers are taking a different approach and using sets of these inputs to understand the inner workings of deep learning models and make observations about a variety of topics related to the model.  These observations include everything from how well does the model generalize to can these values be used to explain the class sensitivity at a layer.</p>

<p>This blog posts discusses a few different papers and the various methodologies they utilize as well as possible implications and future directions that we are pursuing.
We find that all of the work mentioned has impressive empirical results, but many of the most interesting aspects of the publications mentioned relate to how can we better understand how deep learning models models work and questions about what information is being disregarding by not utilizing these intermediate values.</p>

<p>This post is broadly split up into two sections followed by a brief section of some preliminary results and guidance of what we see may be of possible research interest.  The first section talks about the notion of generalization and how these intermediate values may allude to some greater understanding of how well a model is generalizing.  The second section consists of papers that are adjacent to this and utilize these inner representations to show how one might capture information that allows a researcher to compare differing layers or networks in a way that is only dependent on the input data.
While the connection may seem tenuous, the implications between the two are what help guide us on our current research focuses.</p>

<p>The full list of papers discussed are the following (although there is mention of other papers tangentially):</p>

<ul>
  <li><a href="https://arxiv.org/abs/1611.03530">Understanding deep learning requires rethinking generalization</a>
    <ul>
      <li>Accepted at ICLR 2017</li>
    </ul>
  </li>
  <li><a href="https://arxiv.org/abs/1803.06959">On the importance of single directions for generalization</a>
    <ul>
      <li>Accepted at ICLR 2018</li>
    </ul>
  </li>
  <li><a href="http://arxiv.org/abs/1706.05806">SVCCA: Singular Vector Canonical Correlation Analysis for Deep Learning Dynamics and Interpretability</a>
    <ul>
      <li>Accepted at NIPS 2017</li>
    </ul>
  </li>
  <li><a href="https://arxiv.org/abs/1806.05759">Insights on representational similarity in neural networks with canonical correlation</a>
    <ul>
      <li>Accepted at NIPS 2018</li>
    </ul>
  </li>
</ul>

<h1 id="generalization-to-single-directions---iclr-papers">Generalization to Single Directions - ICLR Papers</h1>

<p>The first paper of the ICLR publications, <em><a href="https://arxiv.org/abs/1611.03530">Understanding deep learning requires rethinking generalization</a></em>, is quite highly regarded already and has other blog posts specifically about it
(<a href="https://blog.acolyer.org/2017/05/11/understanding-deep-learning-requires-re-thinking-generalization/">1</a>,
<a href="https://danieltakeshi.github.io/2017/05/19/understanding-deep-learning-requires-rethinking-generalization-my-thoughts-and-notes">2</a>)
so we will not dive into it too deeply but mainly use it as a starting point.  The basis of the paper is that they are able to show that a network can memorize a random labeling of the data and can achieve no training error and at the time was broadly challenging and putting forth some conclusions about the generalization ability of deep learning models.  There are a range of views about this paper and are easily viewed on pages such as the <a href="https://openreview.net/forum?id=Sy8gdB9xx">openreview</a> of it, regardless the loose connection to the follow on topics that we discuss and other papers is what makes it of interest for this post.  Below we see an image of their results that show the convergence of train loss and test loss for various experiments they ran.</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/iclr2017_fig1.png" alt="Image from [Understanding deep learning requires rethinking generalization](https://arxiv.org/abs/1611.03530)" style="display:block; margin-left:auto; margin-right:auto" width="70%" /></p>

<p>While the paper is worth a read on its own, the reason it is contextually interesting in this blog post is in connection with a paper the following year.</p>

<p>In 2018, a paper titled <em><a href="https://arxiv.org/abs/1803.06959">On the importance of single directions for generalization</a></em> puts forth the idea of “single directions” which they define as <em>“the activation of a single unit or feature map or some linear combination of units in response to some input”</em>.  This is very similar in many regards to the inner representations which come from layer outputs in relation to a specific or set of inputs and they investigate many aspects of these “single directions” with various methods including perturbations.</p>

<p>One of the findings of the paper is clearly stated on the first page: <em>We find that networks which memorize the training set are substantially more dependent on single directions than those which do not, and that this difference is preserved even across sets of networks with identical topology trained on identical data, but with different generalization performance</em>.  This has direct overlap with the paper from the <a href="https://arxiv.org/abs/1611.03530">preceding year</a> and has very interesting implications that while many will first consider how well a model generalizes based on some test set, understanding if a deep learning model generalizes may be pursued as well via some understanding of the activation space or intermediate values.</p>

<p>They further go on to discuss that a possible usage of these single directions is for estimating generalization ability of the model and go on to have some preliminary results that show this but say that further research is needed for more complicated datasets.  This is a fascinating result from a practical and real-world use perspective where there may be necessary requirements to show in multiple ways that the model generalizes well or the inner workings are quantitatively monitor-able in some way.</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/iclr2018_fig1.png" alt="Image from [On the importance of single directions for generalization](https://arxiv.org/abs/1803.06959)" style="display:block; margin-left:auto; margin-right:auto" width="70%" /></p>

<h1 id="inner-representations">Inner Representations</h1>

<p>While the above papers come from from ICLR conference publications, the next group of papers investigates a very unique idea about how we can compare two inner representations from differing layers and networks to get values that provide numerical understanding via coefficients and how these coefficients give a similarity metric.  An example of this is shown below where a comparison is shown between layers of differing architectures as the method allows comparisons without natural alignment.</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/svcca_fig7.png" alt="SVCCA Model-Layer Comparison" style="display:block; margin-left:auto; margin-right:auto" width="99%" /></p>

<p>The authors of the paper, <em><a href="http://arxiv.org/abs/1706.05806">SVCCA: Singular Vector Canonical Correlation Analysis for Deep Learning Dynamics and Interpretability</a></em>, put forth a pretty unique and interesting way to examine and compare what they call “representations” that allow for comparisons between different layers and networks (as shown in the image above).  Generally when determining a way to compare the inner representation of differing networks it can be quite abstract and there is no clear one-to-one comparison from model to model.  For similar network architectures, the most basic approach would be to compare based on layers and then compare the neurons of those layers, but this does not work as easily if there is no general alignment from a neuron in one network to a neuron in another network (which means most different architectures).  The authors of this paper explain a methodology they call Singular Vector Canonical Correlation Analysis (<strong>SVCCA</strong>) which looks at two sets of neuron outputs from the same data input values and allows comparison between models which are not similar in a manner by comparing the subspaces of these inner representations.  The method combines Canonical Correlation Analysis (<strong>CCA</strong>) with a Singular Value Decomposition (<strong>SVD</strong>) for these two different sets of outputs to give a correlation coefficient that is “aligned” in some subspace.  To compare the values from the SVCCA they use baselines composed of random and maximum activation neurons.</p>

<p>While a bit of an oversimplification and ignoring some steps (the full methodology can be found <a href="https://github.com/google/svcca/blob/master/cca_core.py">here</a>) a brief sketch of the methodology is as follows:</p>

<div class="language-python highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="n">acts1</span> <span class="o">=</span> <span class="p">...</span> <span class="c1"># first group of activations
</span><span class="n">acts2</span> <span class="o">=</span> <span class="p">...</span> <span class="c1"># second group of activations
</span><span class="n">numx</span><span class="p">,</span> <span class="n">numy</span> <span class="o">=</span> <span class="n">acts1</span><span class="p">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">],</span> <span class="n">acts2</span><span class="p">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span>

<span class="n">covariance</span> <span class="o">=</span> <span class="n">np</span><span class="p">.</span><span class="n">cov</span><span class="p">(</span><span class="n">acts1</span><span class="p">,</span> <span class="n">acts2</span><span class="p">)</span>
<span class="n">sigmaxx</span><span class="p">,</span> <span class="n">sigmaxy</span> <span class="o">=</span> <span class="n">covariance</span><span class="p">[:</span><span class="n">numx</span><span class="p">,</span> <span class="p">:</span><span class="n">numx</span><span class="p">],</span> <span class="n">covariance</span><span class="p">[:</span><span class="n">numx</span><span class="p">,</span> <span class="n">numx</span><span class="p">:]</span>
<span class="n">sigmayx</span><span class="p">,</span> <span class="n">sigmayy</span> <span class="o">=</span> <span class="n">covariance</span><span class="p">[</span><span class="n">numx</span><span class="p">:,</span> <span class="p">:</span><span class="n">numx</span><span class="p">],</span> <span class="n">covariance</span><span class="p">[</span><span class="n">numx</span><span class="p">:,</span> <span class="n">numx</span><span class="p">:]</span>

<span class="c1"># rescale covariance to make cca computation more stable
</span><span class="n">xmax</span><span class="p">,</span> <span class="n">ymax</span> <span class="o">=</span> <span class="n">np</span><span class="p">.</span><span class="nb">max</span><span class="p">(</span><span class="n">np</span><span class="p">.</span><span class="nb">abs</span><span class="p">(</span><span class="n">sigmaxx</span><span class="p">)),</span> <span class="n">np</span><span class="p">.</span><span class="nb">max</span><span class="p">(</span><span class="n">np</span><span class="p">.</span><span class="nb">abs</span><span class="p">(</span><span class="n">sigmayy</span><span class="p">))</span>
<span class="n">sigmaxx</span> <span class="o">/=</span> <span class="n">xmax</span>
<span class="n">sigmayy</span> <span class="o">/=</span> <span class="n">ymax</span>
<span class="n">sigmaxy</span> <span class="o">/=</span> <span class="n">np</span><span class="p">.</span><span class="n">sqrt</span><span class="p">(</span><span class="n">xmax</span> <span class="o">*</span> <span class="n">ymax</span><span class="p">)</span>
<span class="n">sigmayx</span> <span class="o">/=</span> <span class="n">np</span><span class="p">.</span><span class="n">sqrt</span><span class="p">(</span><span class="n">xmax</span> <span class="o">*</span> <span class="n">ymax</span><span class="p">)</span>

<span class="p">...</span> <span class="c1"># intermediate scaling, checks and other slightly important steps
</span>
<span class="c1"># from this we then get the coefficients
</span><span class="n">u</span><span class="p">,</span> <span class="n">s</span><span class="p">,</span> <span class="n">v</span> <span class="o">=</span> <span class="n">np</span><span class="p">.</span><span class="n">linalg</span><span class="p">.</span><span class="n">svd</span><span class="p">(</span><span class="n">np</span><span class="p">.</span><span class="n">dot</span><span class="p">(</span><span class="n">invsqrt_xx</span><span class="p">,</span> <span class="n">np</span><span class="p">.</span><span class="n">dot</span><span class="p">(</span><span class="n">sigma_xy</span><span class="p">,</span> <span class="n">invsqrt_yy</span><span class="p">)))</span>

<span class="n">cca_coef1</span> <span class="o">=</span> <span class="n">cca_coef2</span> <span class="o">=</span> <span class="n">s</span>
</code></pre></div></div>

<p>A follow up to this research was in part a publication titled <a href="https://arxiv.org/abs/1806.05759">Insights on representational similarity in neural networks with canonical correlation</a>, which provides further insight into representational properties of deep learning models.  One of the conclusions in this follow up paper relates to how the representations that come from CCA and SVD contain both “signal” and “noise” components.  This is very elucidating from a standpoint of comparing networks (which they mention and show results as well related to work such as <a href="https://arxiv.org/abs/1912.05671">Linear Mode Connectivity and the Lottery Ticket Hypothesis</a> that takes quite a different approach using model weights) that generalize versus memorize, which is exactly what is discussed in the first two papers of this post.  Understanding how we might show these “signal” components both compared to other networks as well as throughout training and testing own would be very beneficial and possibly numerically measurable with some amount of further research.  Along with this, it would be incredibly helpful in providing a novel approach to showing if a network is generalizing well for production use cases where a model may need to be tested and verified in multiple differing ways.</p>

<h1 id="related-results-and-preliminary-findings">Related Results and Preliminary Findings</h1>

<p>Connecting the dots from these differing research publications, there seems to be a wealth of information contained within these intermediate values.  One of the difficulties with these values though is that they are obfuscated by complex network architectures and often being obtuse or difficult to deal with in that comparing the values from one model layer to another layer or differing model requires some amount of either mathematical justification or subjective explanation.</p>

<p>Before learning about and reading about some of these papers discussed above, we became interested in the idea of knowing how the inner workings of a deep learning model may have unintended side effects related to explainability and generalization.  While it is easy to understand the definite mathematical functions that apply to an input to create an output, having a qualitative comprehension about what the layers progressively do allows for more nuanced direction about how to not only build perhaps more predictive models, but create ways to explain and verify models that have more likelihood of being used in the real world.</p>

<p>The following preliminary results come from experiments where following every training epoch, an image has gaussian noise added to it (with $ \mu=0 $ and $ \sigma=0.2,0.1,0.01 $).  The images come from MNIST and while the gaussian noise is barely noticeable or even imperceptible to humans, the test and train accuracy are not drastically altered by this amount of noise.  While we use multiple images as a starting point, each of these images is individually analyzed with a group of itself that has been perturbed and then the SVD is calculated from this group and analyzed together with other instances from its class.</p>

<p>The initial belief that we had was that by looking at the singular values and the associated explained variance of these singular values, a network that is learning to not only memorize would be capable of filtering out more of this gaussian noise after activation functions throughout the network.</p>

<p>What we expected to see for a network that is capable of filtering the noise out (while not being explicitly trained to do so) would be more variance captured by the first component the more epochs we train.  Rather what we see in the image below of the explained variance of the first component is that it actually captures less of the variance and there is more noise being noticed during the convolutional layers although this becomes less so for the later layers in the network.  The labels for the lines in the charts bellow are labeled by the layer they follow and the $ \sigma $ of the noise added (also noted if it is during a hold-out test set as well).</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/explained_variance1_single_std0.1.png" alt="Explained Variance of 2nd SVD" style="display:block; margin-left:auto; margin-right:auto" width="99%" /></p>

<p>We see this even more so when examining the second component as well as the rest of the components and their associated explained variance as in the images below.  The second components in general continue to capture more and more of the variance, this presumably means our basic convolutional network and the associated feature maps are more susceptible to noise than we would anticipate for a model that we believe would be generalizing.  While we see these values somewhat plateau for the rest of the components around where the train and test loss converge (shown in the last image), we also find that this convergence is much more gradual for the later layers which could possibly mean that the model is learning to filter out more of this gaussian noise without being explicitly trained to do (and could have implications related to generalization as well as adversarial defenses).  Regardless more rigorious experimentation and evidence is needed to justify these claims.</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/explained_variance_1_single_std0.01.png" alt="Explained Variance of 2nd SVD" style="display:block; margin-left:auto; margin-right:auto" width="99%" /></p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/explained_variance2_all_single_std0.1.png" alt="Explained Variance of rest of singular values" style="display:block; margin-left:auto; margin-right:auto" width="99%" /></p>

<p>This last image is interesting in part due not the magnitudes of the singular values but rather their rate of change.  If we were using a group of images that were not perturbed we would see all but the first singular values be 0 and this singular value would increase with magnitude as the trained weights amplify this signal with no noise.  Rather what we see with a group of perturbed images is the first singular value dropping initially and more volatility in general for the initial epochs until it gradually begins to rise around where the train and test loss converge (train and test loss not to scale on SVD plot, superimposed only for clarity).  We take this to possibly mean that there is an almost gradual shift from the network changing from memorizing the input data to more gradually becoming generalizable.  Rather than the network being one or the other, there is a spectrum between these two and possibly ways to track this during training and testing.</p>

<p><img src="https://iclr.iro.umontreal.ca/7f8f3b20-bf4e-4895-a3ad-1d37b7d1e6e7_1642190150/public/images/2021-12-01-from-generalization-to-inner-activations/SVD_1st_2nd_3rd_single_std0.1.png" alt="SVD values during Train/Test" style="display:block; margin-left:auto; margin-right:auto" width="99%" /></p>

<p>The hope with the experiments thus far is to understand something about generalization and ability of the network to filter out something such as noise without being explicitly trained.  Thinking of how many adversarial attacks that once they are known of, they can be more easily trained against but can bypass human with ease (for instance the <a href="https://arxiv.org/abs/1608.04644">CW2 Attack</a>), we see a potential research avenue whereby monitoring the internal activations with approaches from traditional linear algebra as perhaps a way to tangentially monitor a network in the same way the single directions from one of the previous papers mentioned.  Further research is indeed needed with the intent to show some form of monitoring of a model or a layer with a perturbed input (and adversarial attacks) and how even though the input may be minimally perturbed, we can understand whether the models inner representations are noticeably different than expected for a model that generalizes well.</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>


<div class="related">
  <h2>Related posts</h2>
  <ul class="related-posts">
    
      <li>
        <h3>
          <a href="/2021/09/01/sample-submission/">
            Sample Submission
            <small>01 Sep 2021 | 
    <a class="content-tag" href="/tags/#inner-representations"> inner-representations </a>
  
    <a class="content-tag" href="/tags/#activations"> activations </a>
  
    <a class="content-tag" href="/tags/#generalization"> generalization </a>
  
    <a class="content-tag" href="/tags/#perturbation"> perturbation </a>
  
    <a class="content-tag" href="/tags/#svd"> SVD </a>
  
    <a class="content-tag" href="/tags/#cca"> CCA </a>
  </small>
          </a>
        </h3>
      </li>
    
      <li>
        <h3>
          <a href="/2020/04/02/example-content/">
            Example content (Basic Markdown)
            <small>02 Apr 2020 | 
    <a class="content-tag" href="/tags/#inner-representations"> inner-representations </a>
  
    <a class="content-tag" href="/tags/#activations"> activations </a>
  
    <a class="content-tag" href="/tags/#generalization"> generalization </a>
  
    <a class="content-tag" href="/tags/#perturbation"> perturbation </a>
  
    <a class="content-tag" href="/tags/#svd"> SVD </a>
  
    <a class="content-tag" href="/tags/#cca"> CCA </a>
  </small>
          </a>
        </h3>
      </li>
    
  </ul>
</div>


<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>
