<!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>
    
      Why Does DARTS Miss the Target, and How Do We Aim to Fix It? &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="http://localhost:4000/2021/12/01/why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/">
  

  <link rel="stylesheet" href="http://localhost:4000/public/css/poole.css">
  <link rel="stylesheet" href="http://localhost:4000/public/css/syntax.css">
  <link rel="stylesheet" href="http://localhost:4000/public/css/lanyon.css">
  <link rel="stylesheet" href="http://localhost:4000/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="http://localhost:4000/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="http://localhost:4000/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="http://localhost:4000/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="http://localhost:4000/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="http://localhost:4000/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="http://localhost:4000/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="http://localhost:4000/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">Why Does DARTS Miss the Target, and How Do We Aim to Fix It?</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#nas"> NAS </a>
  
    <a class="content-tag" href="/tags/#darts"> DARTS </a>
  
    <a class="content-tag" href="/tags/#neural-architecture-search"> neural architecture search </a>
  
    <a class="content-tag" href="/tags/#neural-networks"> neural networks </a>
  
    <a class="content-tag" href="/tags/#deep-learning"> deep learning </a>
  
    <a class="content-tag" href="/tags/#differentiable-nas"> differentiable NAS </a>
  
    <a class="content-tag" href="/tags/#differentiable-neural-architecture-search"> differentiable neural architecture search </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <p>In this blog post, we will dissect and explain ‘Rethinking Architecture Selection in Differentiable NAS’ from ICLR 2021 <a href="#Wang">[Wang et al., 2021]</a>. This paper is closely tied to two prior works: DARTS <a href="#Liu">[Liu et al., 2019]</a> and a response to DARTS <a href="#Zela">[Zela et al., 2020]</a>. We will first establish context by examining these works. Then, we will return focus to <a href="#Wang">[Wang et al., 2021]</a>.</p>

<h2 id="neural-architecture-search-nas">Neural Architecture Search (NAS)</h2>
<p>NAS automates the process of discovering high performance architectures for Neural Networks. Though the popular state-of-the-art models are handcrafted, NAS aims to develop methods that eliminate this manual process. A few of the common approaches for NAS are Random Search, Evolutionary Algorithms, Reinforcement Learning and One Shot Learning algorithms. A popular One Shot Learning algorithm for NAS, which is discussed in detail in this post, is the Differentiable Architecture Search (DARTS) <a href="#Liu">[Liu et al., 2019]</a>.</p>

<h2 id="differentiable-architecture-search-darts">Differentiable Architecture Search (DARTS)</h2>

<p>DARTS represents the neural architecture (or just a cell) as a <strong>directed acyclic graph (DAG)</strong> and then introduces a <strong>continuous</strong> relaxation on each edge of this graph. This allows training of both the architecture structure and its weights via gradient descent.</p>

<h3 id="representing-the-neural-architecture-as-a-dag-in-darts">Representing the Neural Architecture as a DAG in DARTS</h3>

<p>The final neural architecture is built using smaller repeatable units known as a <strong>cell</strong>. Rather than finding the optimal structure for the entire model, DARTS only finds the best structure of the cell. The cell can then be stacked or recursively connected to form a convolutional network or recurrent network respectively.</p>

<p>A cell is represented as a directed acyclic graph consisting of an ordered sequence of nodes. Each node $ x^{(i)} $ is a latent representation (e.g. a feature map in a convolutional network) and each directed edge $ (i,j) $ is associated with some operation $ o^{(i,j)} $ (e.g., convolution, max pooling) that transforms $ x^{(i)} $ as:</p>

\[\begin{equation}
x^{(j)} = \sum_{i &lt; j} o^{(i,j)}(x^{(i)})
\end{equation}\]

<h3 id="continuous-relaxation-for-darts">Continuous Relaxation for DARTS</h3>

<p>The search space is made continuous by relaxing the categorical choice of a particular operation to a softmax over all possible operations for each edge. The operation mixing weights for an edge $ (i,j) $ is defined as:</p>

\[\begin{equation}
\bar{o}^{(i,j)}(x) = \sum_{o\in\mathcal{O}} \frac{\exp(\alpha_o^{(i,j)})}{\sum_{o'\in\mathcal{O}} \exp(\alpha_{o'}^{(i,j)})} o(x)
\end{equation}\]

<p>where $ \mathcal{O} $ is the set of all candidate operations and $ \alpha_{o’}^{(i,j)} $ is the weight of a particular operation $ o’ $ in the edge $ (i,j) $.</p>

<p>At the end of search, the cell architecture can be obtained by replacing each mixed operation $ \bar{o}^{(i,j)} $ with the most likely operation, i.e.,</p>

\[\begin{equation}
o^{(i,j)} = \arg\max_{o\in\mathcal{O}} \alpha_{o'}^{(i,j)}
\end{equation}\]

<p>After the continuous relaxation, the goal is to learn the optimal architecture $ \alpha $ and the weight $ w $ for all the mixed operations. This is formulated as the bilevel optimization problem:</p>

\[\begin{align}
\min_\alpha \quad &amp; \mathcal{L}_\text{val} (w^*(\alpha), \alpha) \\
\text{s.t.} \quad &amp; w^*(\alpha) = \arg\min_w \mathcal{L}_\text{train} (w, \alpha)
\end{align}\]

<p>where \(\mathcal{L}_\text{val}\) and \(\mathcal{L}_\text{train}\) are the validation and training losses respectively.</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/darts_pseudocode.jpg" alt="DARTS Pseudocode image" /></p>

<p>The pseudo code of the iterative gradient descent procedure for the bilevel optimization problem is given above. (Image source: <a href="#Liu">[Liu et al., 2019]</a>)</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/darts_overview.jpg" alt="DARTS Overview image" /></p>

<p>An overview of DARTS is given above: (a) Initial unknown operations on the edges. (b) Continuous
relaxation of the search space by placing a mixture of candidate operations on each edge. (c) Solving the bilevel optimization problem to get optimal architecture and weights. (d) Deriving the final architecture from the learned probabilities (also known as discretization). (Image source: <a href="#Liu">[Liu et al., 2019]</a>)</p>

<h2 id="an-analysis-of-the-failure-modes-of-darts">An analysis of the Failure modes of DARTS</h2>

<p>While continuous relaxation of the search space allows gradient based learning of architecture, several researchers (<a href="#LiTalwalkar">[Li &amp; Talwalkar, 2019]</a>; <a href="#Sciuto">[Sciuto et al., 2019]</a>) have reported poor performance from DARTS.  In <a href="#Zela">[Zela et al., 2020]</a>, the authors analyze the reason for the poor performance of DARTS.</p>

<h3 id="overfitting-to-the-validation-set">Overfitting to the validation set</h3>

<p>Improvement on the validation loss is not a sufficient indicator to demonstrate performance of DARTS since it directly optimizes validation performance. Therefore, while DARTS successfully improves performance on validation loss with epochs, the model generalizes very poorly to test sets. This is similar to how training set performance of a Deep Learning model can be a misleading indicator of the ability of the model to generalize and perform well on examples from a held-out test set.</p>

<h3 id="relating-overfitting-to-curvature-of-loss-in-the-parameter-space">Relating overfitting to curvature of loss in the parameter space</h3>

<p>There has been past work correlating the generalization (reduced overfitting) ability of models to the curvature of the loss function in the parameter space. For instance, <a href="#Hochreiter">[Hochreiter &amp; Schmidhuber, 1997]</a> present that flat minima of training loss gives better generalization properties than sharp minima. This phenomenon has also been observed in the overfitting of hyperparameters to validation sets. For instance, <a href="#Nguyen">[Nguyen et al, 2018]</a> show that when the minima of the validation loss lie in a sharp region of the hyperparameter space, the model tends to generalize poorly.</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/curvature.png" alt="Curvature of loss function image" /></p>

<p>In the above figure, $\alpha^{\star}$ is the parameter value that minimizes the validation loss, and $\alpha^{disc}$ is the value that results after discretization of $\alpha^{\star}$. The figure shows the variation in performance before and after discretization for two different regions of validation loss with very different curvature. We see that for sharp curvature regions, the performance after discretization is very different from performance before discretization (Image source: <a href="#Zela">[Zela et al., 2019]</a>).</p>

<h3 id="failure-modes-of-darts">Failure modes of DARTS</h3>

<p>The authors construct different search spaces to demonstrate the poor architecture selection and test set performance of DARTS. We first start with 4 smaller subspaces.</p>

<p>These smaller search spaces are used to demonstrate the degenerate architectures selected by DARTS. The architecture space is composed of the same macro architecture of the standard DARTS paper (normal and reduction cells), but only a subset of the operations are considered on every edge. Three of these search spaces are natural subspaces of the original space and are also strict subspaces. This means that these spaces should be easier to search than the original space. The fourth subspace includes a Noise Operator, which is specifically included to show the failure mode of DARTS, i.e., selecting the harmful operator. Details on the 4 spaces are outlined as follows:</p>

<p><strong>S1 </strong>: This space uses only two operators per edge. These operators are selected using an offline process that iteratively drops operations from the original DARTS paper that have least importance. Therefore, this becomes a “pre-optimized” space which comes with the advantage that it is quite small but still supports many strong architectures.</p>

<p><strong>S2 </strong>:  In this space, the set of candidate operations per edge is {3 × 3 SepConv, SkipConnect}. These operations are chosen since they are the most frequent ones as reported in <a href="#Liu">[Liu et al., 2019]</a>.</p>

<p><strong>S3 </strong>: This space uses the following operations:  {3 × 3 SepConv, SkipConnect, Zero}, where the Zero operation replaces every value in the input feature map with zero.</p>

<p><strong>S4 </strong>: This is the only space that is not a strict subspace of the original space. This set consists of only two operations:  {3 × 3 SepConv, Noise}, where the Noise operation simply replaces every value from the input feature map by noise drawn from a standard normal distribution. This operation actively harms the distribution and should not be selected by the model.</p>

<p>Further, it is interesting to note that the only operation which includes parameters is the 3 x 3 SepConv operation.</p>

<p>Consider the learnt architecture when DARTS searches these spaces while training on the CIFAR-10 dataset. These architectures are presented in the figure below (Image source: <a href="#Zela">[Zela et al., 2020]</a>).</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/s1.png" alt="DARTS Learned Architectures image 1" />
<img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/s2.png" alt="DARTS Learned Architectures image 2" /></p>

<p>It is immediately apparent that the parameter less skip connections dominate most edge operations in search spaces S1-S3, and in S4 even the harmful Noise operation has been selected for 5 out of 8 operations.</p>

<p>Having demonstrated that DARTS chooses degenerate architectures, the authors now construct another space to showcase the hypothesis that DARTS overfits to the validation set while performing poorly on the test set.</p>

<p><strong>S5 </strong>: Very small search space with known global optimum: In this search space the authors use only one intermediate node in the normal cell as well as reduction cell, with three possible operations choices per edge: 3 × 3 SepConv, SkipConnection, and 3 × 3 MaxPooling. The main idea here is that the total number of possible architectures is only 81. This means that we can a priori evaluate the performance of all 81 architectures to find the global optimum. We would then be able to understand the “regret” (intuitively, the deviation from the optimal path) taken by the DARTS model.</p>

<p>In order to put the performance of DARTS in perspective, it is compared against a baseline of Random Search with weight sharing (RS-ws) by <a href="#LiTalwalkar">[Li &amp; Talwalkar, 2019]</a>. The authors run DARTS three times on this search space and examine the DARTS test regret, DARTS one-shot-val error, RS-ws test regret. While it seems that DARTS manages to find an architecture close to the global minimum, at around epoch 40 the test performance deteriorates. Yet, the search model validation error does not deteriorate but continues to converge. This indicates that the architectural parameters are overfitting to the validation set. However, the baseline RS-ws stays relatively constant throughout the search, eventually outperforming DARTS (Image source: <a href="#Zela">[Zela et al., 2019]</a>).</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/regret_plots.png" alt="Regret Plots Image" /></p>

<h3 id="role-of-dominant-eigenvalues-of-hessian-matrix-of-validation-loss">Role of dominant eigenvalues of Hessian matrix of validation loss</h3>

<p>Having demonstrated that DARTS overfits to the validation set, the authors further extend this idea by considering the growth of the dominant eigenvalue of the Hessian matrix of the validation loss with respect to the architectural parameters $\alpha$ . This is useful because the largest eigenvalue ($\lambda_{max}^{\alpha}$) of said Hessian matrix is a proxy for the curvature of the validation loss in that region of $\alpha$. It is observed that $\lambda_{max}^{\alpha}$ increases in standard DARTS, along with the test error (middle) of the final architectures, while the validation error still decreases (left) (Image source: <a href="#Zela">[Zela et al., 2019]</a>).</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/eigenvalue_plot.png" alt="Eigenvalue Plot Image" /></p>

<h2 id="alternate-failure-explanations-for-darts">Alternate failure explanations for DARTS</h2>

<p><a href="#Wang">[Wang et al., 2021]</a> also believed that DARTS has flaws, but they believe the main issues to be different than those proposed by <a href="#Zela">[Zela et al., 2020]</a>. While <a href="#Zela">[Zela et al., 2020]</a> were focused on showing the the optimization landscape for DARTS’ supernet lent itself to non-generalizable solutions, <a href="#Wang">[Wang et al., 2021]</a> focused on an implicit assumption in the DARTS concept (one that might have jumped out to you when first reading the breakdown of DARTS): the idea that a high architecture mixing weight indicates an important connection, and vice versa.</p>

<h3 id="assumptions">Assumptions</h3>

<p>It’s not at all uncommon, in the literature, to make the assumption that assigning large weight to a connection means it must represent a useful concept. As a brief aside, we can consider the field of <em>network pruning</em>: the discipline of removing components from already-trained neural networks in order to obtain compressed models that require less storage and computation but produce acceptably comparable results. <a href="#Han">[Han et al., 2015]</a> prune the smallest-weight connections in a network, while <a href="#LiHao">[Li et al., 2017]</a> remove convolutional filters with the smallest L1-norm (that is, the smallest sum of magnitudes of weights). <a href="#LiHao">[Li et al., 2017]</a> make the argument that filters with small magnitude weights produce output feature maps with small expected magnitude of activation. While these methods show good empirical results, they do hinge on the critical assumption that magnitude of activation in an intermediate layer indicates relevance of a layer to the overall computation of the final network prediction.</p>

<p>DARTS operates on the similar assumption that learning a large architecture parameter implies that the corresponding network connection must be critical to later calculation, and therefore key to strong network accuracy. But is this assumption really reasonable? And more important, does it lead to the best possible performance?</p>

<h3 id="evidence">Evidence</h3>

<p><a href="#Wang">[Wang et al., 2021]</a> present evidence to suggest that the connections with the largest architecture parameters are not necessarily the most important connections. From a pretrained DARTS supernet, they randomly choose three edges and compare the softmaxed magnitude of the architecture parameter assigned to each choice of operation to the final validation network accuracy obtained by using only that operation and removing the others. Results are shown below (Image source: <a href="#Wang">[Wang et al., 2021]</a>).</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/a_discretization_correlation.png" alt="Comparison between architecture parameters and post-train accuracy" /></p>

<p>There are a few striking takeaways from these plots. First, the best post-discretization accuracy was never obtained from the operation with the largest architecture parameter. Second, if one were to select the operation with the largest architecture parameter, in 2 out of 3 cases there would exist a different option with at least 1% potential validation accuracy improvement.</p>

<h3 id="deep-dive-skip-connections">Deep dive: skip connections</h3>

<p>Earlier, we showed that in several of the failure cases for DARTS, the learned cell architecture is full of skip connections. <a href="#Wang">[Wang et al., 2021]</a> wonder if this is not due to any inherent flaw with the subnet optimization but is instead fully due to the fact that skip connections are naturally very likely to learn large architecture parameters. If this were the case, then these failure modes could be addressed by halting reliance on the architecture-parameter-magnitude heuristic for operation selection.</p>

<p>The justification for why this occurs depends on an argument by <a href="#Greff">[Greff et al, 2017]</a> and <a href="#Veit">[Veit et al., 2016]</a> about the interpretation of networks that depend on skip connections (e.g., ResNets) as a form of ensemble model composed of different network paths. This concept is called <em>unrolled estimation</em>.</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/unroll_network_veit.png" alt="Demonstration of residual network as ensemble of network paths" /></p>

<p>The graphic above, from <a href="#Veit">[Veit et al., 2016]</a>, illustrates this concept clearly. Essentially, any time a skip connection exists alongside a parameterized connection (e.g., convolutional layer), these two routes represent different branches in a network path to the end of the network. By taking each distinct combination of branches as a different path, we can view the entire network as a combination or ensemble of different dataflow paths, each with different amounts of skip connection vs. convolutional connection. At the end, some combination of these network paths’ outputs is used as the final output.</p>

<p>We recall that traditional deep networks are believed to train stacked layers that have different ideal feature representations, potentially at different depths of abstraction. <a href="#Veit">[Veit et al., 2016]</a> and <a href="#Greff">[Greff et al., 2017]</a> argue that networks performing unrolled estimation work <em>differently</em>, in that each layer actually approximates the same optimal feature map. In other words, each cell’s ideal input and output feature map are similar, so the input-to-output change becomes quite small.</p>

<p>Imagine that we let a network performing unrolled estimation train to convergence. At convergence, we expect the input and output feature maps for each cell to be similar. We therefore can expect a certain degree of reliance on the skip connection, as it is the best operation for generating an output feature map like the input feature map. The connection that contributes more to the combined feature map (i.e. the feature with a larger architecture parameter) will often be that which produces similar output to input and minimizes introduced variance, which will typically be the skip connection (convolutional layers add in additional variance).</p>

<p>However, if we choose a skip connection <em>every time</em>, we will learn a degenerate network, as evidenced in the <a href="#Zela">[Zela et al., 2020]</a> failure modes. So we can’t rely on only choosing the highest architecture parameter in all circumstances.</p>

<h2 id="improvements-on-darts">Improvements on DARTS</h2>

<h3 id="perturbation">Perturbation</h3>

<p>In place of the original DARTS discretization strategy which selected those connections that had the largest architecture parameters, <a href="#Wang">[Wang et al., 2021]</a> propose a <em>perturbation</em> algorithm for discretization. The algorithm focuses on examining which connections, when removed, damage the network accuracy the most–these are deemed to be the most important connections.</p>

<p><img src="http://localhost:4000/public/images/2021-12-01-why-does-darts-miss-the-target-and-how-do-we-aim-to-fix-it/perturbation_algorithm.png" alt="Perturbation Algorithm image" /></p>

<p>The pseudocode above, from <a href="#Wang">[Wang et al., 2021]</a>, describes the perturbation algorithm in more detail. We’ll also summarize the algorithm in plain English:</p>

<h4 id="perturbation-algorithm-summary">Perturbation Algorithm summary</h4>

<ol>
  <li>
    <p>Optimize the DARTS supernet in the standard bilevel way.</p>
  </li>
  <li>
    <p>Discretize edges in a random order.</p>

    <ul>
      <li>
        <p>When discretizing an edge, examine how much the network validation accuracy drops when that edge is removed.</p>
      </li>
      <li>
        <p>Keep the edge that led to the <em>smallest</em> accuracy decrease when removed and discard the rest of the edges.</p>
      </li>
    </ul>
  </li>
</ol>

<h4 id="perturbation-algorithm-results">Perturbation Algorithm results</h4>

<p><a href="#Wang">[Wang et al., 2021]</a> describe the success of the perturbation algorithm in detail. We list here a small portion of the evaluation results, comparing performance of DARTS and several closely related NAS algorithms to the same algorithms with perturbation applied (perturbation is signified with +PT).</p>

<table>
  <thead>
    <tr>
      <th>Architecture</th>
      <th>Test Error (%)</th>
      <th>Params (M)</th>
      <th>Search Cost (GPU Days)</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>DARTS <a href="#Liu">[Liu et al., 2019]</a></td>
      <td>3.00 ± 0.14</td>
      <td>3.3</td>
      <td>0.4</td>
    </tr>
    <tr>
      <td>SDARTS-RS <a href="#Chen">[Chen &amp; Hsieh, 2020]</a></td>
      <td>2.67 ± 0.03</td>
      <td>3.4</td>
      <td>0.4</td>
    </tr>
    <tr>
      <td>SGAS (Cri 1. avg) <a href="#Li">[Li et al., 2020)]</a></td>
      <td>2.66 ± 0.24</td>
      <td>3.7</td>
      <td>0.25</td>
    </tr>
    <tr>
      <td>DARTS+PT (avg, four seeds)</td>
      <td>2.61 ± 0.08</td>
      <td>3.0</td>
      <td>0.8</td>
    </tr>
    <tr>
      <td>DARTS+PT (best)</td>
      <td>2.48</td>
      <td>3.3</td>
      <td>0.8</td>
    </tr>
    <tr>
      <td>SDARTS-RS+PT (avg, four seeds)</td>
      <td>2.54 ± 0.10</td>
      <td>3.3</td>
      <td>0.8</td>
    </tr>
    <tr>
      <td>SDARTS-RS+PT (best)</td>
      <td>2.44</td>
      <td>3.2</td>
      <td>0.8</td>
    </tr>
    <tr>
      <td>SGAS+PT (Crit.1 avg, four seeds)</td>
      <td>2.56 ± 0.10</td>
      <td>3.9</td>
      <td>0.29</td>
    </tr>
    <tr>
      <td>SGAS+PT (Crit.1 best)</td>
      <td>2.46</td>
      <td>3.9</td>
      <td>0.29</td>
    </tr>
  </tbody>
</table>

<p>The takeaway is that the perturbation algorithm improves test error for each of these approaches, while requiring fewer parameters (except for in the case of SGAS, in which the parameter number increases). The cost is some increased GPU computation time.</p>

<h3 id="reflections-on-the-perturbation-algorithm">Reflections on the Perturbation Algorithm</h3>

<p>The perturbation algorithm features a few heuristics that might leave us a little uneasy. The most important of these is the greediness of it. We recall that the algorithm selects the operation for a given connection by fixing the rest of the architecture, testing the different options to see which leads to the best accuracy, and then fine-tunes before repeating. Essentially, the algorithm finds locally optimal choices for operations, instead of considering choices of multiple operations in conjunction. There is also some potential suboptimality in the randomized order in which operation choices are made (maybe it might be worthwhile, for example, to make the most clear-cut operation decisions first and get to the tougher choices later, hoping they might by that point become clearer).</p>

<h3 id="future-improvements-on-darts">Future improvements on DARTS</h3>

<p>There may be a fix for this bias towards local greedy optimization: consider combinations of operation selections! We might think of trying to pick 2 or even 3 operations at once by considering joint optimality, at the cost of some computational complexity. If we had compute to spend, we could scale up the number of operations until we’re jointly selecting every operation in the network at once. The trouble, however, is that the further one goes down this path, the closer one gets to the computationally expensive discretized neural architecture search of the past. In this way, we might lose what was truly efficient about DARTS: the continuous relaxation.</p>

<p>Earlier, we drew a connection between pruning the supernet of DARTS and the more general field of network pruning and compression. As a final note, we suggest that future methods to improve DARTS, without reverting too far into expensive discretized NAS, might draw from different approaches to network pruning. For example, in the vein of the work of <a href="#Kameyama">[Kameyama &amp; Kosugi, 1991]</a>, who chose to merge same-layer neurons with highly correlated output activation, we might consider eliminating supernet connections on the basis of statistical redundancy with one another. Alternately, as inspired by ThiNet <a href="#Luo">[Luo et al., 2017]</a>, one might try a variation of the perturbation algorithm focused on pruning connections in the supernet in order to minimize reconstruction error from each layer to the next. If one successfully minimizes reconstruction error after the discretized layer, finetuning might be even more computationally efficient–allowing for even further strides in the journey toward computationally tractable NAS.</p>

<h2 id="bibliography">Bibliography</h2>

<p><a name="Chen"> Xiangning Chen and Cho-Jui Hsieh. Stabilizing differentiable architecture search via perturbation-based regularization. In Hal Daume III and Aarti Singh (eds.), Proceedings of the 37th International Conference on Machine Learning, volume 119 of Proceedings of Machine Learning Research, pp. 1554–1565. PMLR, 13–18 Jul 2020. URL http://proceedings.mlr.press/v119/chen20f.html. </a></p>

<p><a name="Greff"> Klaus Greff, Rupesh K. Srivastava, and Jurgen Schmidhuber. Highway and residual networks learn unrolled iterative estimation. In International Conference on Learning Representations (ICLR), 2017. </a></p>

<p><a name="Han"> Song Han, Jeff Pool, John Tran, and William J. Dally. Learning both Weights and Connections for Efficient Neural Networks. In C. Cortes, N. Lawrence, D. Lee, M. Sugiyama, and R. Garnett (eds.), Advances in Neural Information Processing Systems 28. Curran Associates, Inc., 2015. </a></p>

<p><a name="Hochreiter"> Sepp Hochreiter and Jurgen Schmidhuber. Flat minima. Neural Comput., 9(1):1–42, January 1997.</a></p>

<p><a name="Kameyama"> Keisuke Kameyama and Yukio Kosugi. Automatic Fusion and Splitting of Artificial Neural Elements in Optimizing the Network Size. In IEEE International Conference on Systems, Man, and Cybernetics, 1991. </a></p>

<p><a name="Li"> Guohao Li, Guocheng Qian, Itzel C. Delgadillo, Matthias Muller, Ali Thabet, and Bernard Ghanem. Sgas: Sequential greedy architecture search. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR), pp. 1620–1630, 2020. </a></p>

<p><a name="LiHao"> Hao Li, Asim Kadav, Igor Durdanovic, Hanan Samet, and Hans Peter Graf. Pruning Filters for Efficient ConvNets. In International Conference on Learning Representation (ICLR), 2017. </a></p>

<p><a name="LiTalwalkar"> Liam Li and Ameet Talwalkar. Random Search and Reproducibility for Neural Architecture Search, 2019.</a></p>

<p><a name="Liu"> Hanxiao Liu, Karen Simonyan, and Yiming Yang. DARTS: Differentiable architecture search. In
International Conference on Learning Representations (ICLR), 2019. </a></p>

<p><a name="Luo"> Jian-Hao Luo, Jianxin Wu and Weiyao Lin. ThiNet: A Filter Level Pruning Method for Deep Neural Network Compression. In International Conference on Computer Vision (ICCV), 2017. </a></p>

<p><a name="Nguyen"> Thanh Dai Nguyen, Sunil Gupta, Santu Rana, and Svetha Venkatesh. Stable bayesian optimization. International Journal of Data Science and Analytics, 6(4):327–339, Dec 2018.</a></p>

<p><a name="Sciuto"> Christian Sciuto, Kaicheng Yu, Martin Jaggi, Claudiu Musat, and Mathieu Salzmann. Evaluating the search phase of neural architecture search. arXiv preprint, 2019.</a></p>

<p><a name="Veit"> Andreas Veit, Michael Wilber, and Serge Belongie. Residual networks behave like ensembles of relatively shallow networks. In S. Bengio, H. Wallach, H. Larochelle, K. Grauman, N. CesaBianchi, and R. Garnett (eds.), Advances in Neural Information Processing Systems 29, pp. 550—-558. Curran Associates, Inc., 2016. </a></p>

<p><a name="Wang"> Ruochen Wang, Minhao Cheng, Xiangning Chen, Xiaocheng Tang, and Cho-Jui Hsieh. Rethinking Architecture Selection in Differentiable NAS. In International Conference on Learning Representations (ICLR), 2021. </a></p>

<p><a name="Zela"> Arber Zela, Thomas Elsken, Tonmoy Saikia, Yassine Marrakchi, Thomas Brox, and Frank Hutter. Understanding and robustifying differentiable architecture search. In International Conference on Learning Representations (ICLR), 2020. </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>


<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/#nas"> NAS </a>
  
    <a class="content-tag" href="/tags/#darts"> DARTS </a>
  
    <a class="content-tag" href="/tags/#neural-architecture-search"> neural architecture search </a>
  
    <a class="content-tag" href="/tags/#neural-networks"> neural networks </a>
  
    <a class="content-tag" href="/tags/#deep-learning"> deep learning </a>
  
    <a class="content-tag" href="/tags/#differentiable-nas"> differentiable NAS </a>
  
    <a class="content-tag" href="/tags/#differentiable-neural-architecture-search"> differentiable neural architecture search </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/#nas"> NAS </a>
  
    <a class="content-tag" href="/tags/#darts"> DARTS </a>
  
    <a class="content-tag" href="/tags/#neural-architecture-search"> neural architecture search </a>
  
    <a class="content-tag" href="/tags/#neural-networks"> neural networks </a>
  
    <a class="content-tag" href="/tags/#deep-learning"> deep learning </a>
  
    <a class="content-tag" href="/tags/#differentiable-nas"> differentiable NAS </a>
  
    <a class="content-tag" href="/tags/#differentiable-neural-architecture-search"> differentiable neural architecture search </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>
