<!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>
    
      Are CNNs biased towards texture rather than object shape? &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/2020/12/01/Are-CNNs-biased-towards-texture-rather-than-object-shape/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/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/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/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/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/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">Are CNNs biased towards texture rather than object shape?</h1>
  <span class="post-date">01 Dec 2020 | 
    <a class="content-tag" href="/tags/#cnns"> CNNs </a>
  
    <a class="content-tag" href="/tags/#adversarial-examples"> Adversarial examples </a>
  
    <a class="content-tag" href="/tags/#robustness"> Robustness </a>
  
    <a class="content-tag" href="/tags/#explainability"> Explainability </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <h3 id="overview-of-the-paper--imagenet-trained-cnns-are-biased-towards-texture">Overview of the paper ‘ <a href="https://arxiv.org/pdf/1811.12231.pdf">ImageNet-trained CNNs are biased towards texture</a>’</h3>

<p>More than a decade ago, With the introduction of CNNs for classification tasks over few datasets available at the time, the field of deep learning and computer vision now has come a long way. We have seen many exciting applications, from detection, segmentation and 3D perception utilized in self-driving cars to understand their environment, tumor detection in medical imaging to <a href="https://medium.com/analytics-vidhya/top-5-gan-generative-adversarial-networks-projects-for-final-year-computer-science-students-ff35eab94e4f"><em>GAN-based picture inpainting, colorization, and style transfer.</em></a></p>
<html>
<head>
<style>
img {
  max-width: 100%;
  height: auto;
  margin-left: auto;  
  margin-right: auto;
}
</style>
</head>
<body>
<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/deep try on.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.1: GAN use-case: From the paper, <a href="https://arxiv.org/abs/2003.05863">DeepFashion Try on</a>
</figcaption>
</figure>
</body>
</html>

<p>Although we are seeing so many exciting research papers with advancements in CNN architectures and their application domains, we still have little to no understanding as to why these systems decide as they do. That’s why we consider these systems ‘black box’, we don’t know the ‘reasoning’ behind a particular decision. And such behaviors cannot be overlooked just because they are scoring high on predefined metrics. For example, <a href="http://gendershades.org/overview.html"><em>the Gender Shapes project</em></a> shows that various face recognition systems perform worse on minority classes(accuracy difference of up to 34% between lighter-skinned males and darker-skinned females). Now if such systems are used for law enforcement, airport, or employment screenings, <a href="https://sitn.hms.harvard.edu/flash/2020/racial-discrimination-in-face-recognition-technology/"><em>this bias can have major repercussions</em></a>. This highlights the importance of ‘explainability’ in computer vision systems.</p>

<p>‘Adversarial attacks’ demonstrates one such counter-intuitive behavior of CNNs. These examples are specially devised to fool the CNNs into predicting wrong labels, just by altering the image by a noise indistinguishable to the human eye.</p>

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/adversarial_example.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.2: FSGM attack adversarial example
</figcaption>
</figure>

<p>The above example demonstrate one such type of attack known as <em>“FSGM attack”</em>. This is known as a ‘white box’ adversarial attack as we have access to the weights of CNN. For training the CNNs, we minimize the loss towards the ground truth label given input image. On contrary, In FSGM attack, we calculate the input, or rather a noise to add to the input using gradients to optimize for maximum loss. As a result, we get the distortion unrecognizable to the human eye, while the CNNs predict wrong labels. There exists various such methods, such as ‘black box’ attack where we dont have any access to model parameters.</p>

<p>One such behavior is captured by the paper <a href="https://arxiv.org/pdf/1811.12231.pdf"><strong>‘ImageNet-trained CNNs are biased towards texture’</strong></a>. Let’s dive in…</p>

<h2 id="previous-indications-of-texture-bias">Previous indications of Texture Bias:</h2>

<p>By maximizing the activation values at different levels for a CNN architecture, we visualize the input that activates that particular neuron the most. Based on these visualizations, it is widely accepted intuition that a CNN combines low-level features (lines, edges) and learns more complex features (wheels, face, tree trunks) hierarchically. To put it differently, the predictions at the last layer will depend more on the global shape of the object rather than the local texture. But there are some contradictory findings, I am listing them below.</p>

<blockquote>
<ul> <li> “CNNs can still classify texturized images perfectly well, even if the global shape structure is completely destroyed” (Gatys et al., 2017; Brendel &amp; Bethge, 2019).</li>
      
<li> “Standard CNNs are bad at recognizing object sketches where object shapes are preserved yet all texture cues are missing” (Ballester &amp; de Araujo, 2016).</li>
      
<li> “Gatys et al. (2015) discovered that a linear classifier on top of a CNN’s texture representation (Gram matrix) achieves hardly any classification performance loss compared to original network performance”.</li>
      
<li> “Brendel &amp; Bethge (2019) demonstrated that CNNs with explicitly constrained receptive field sizes throughout all layers are able to reach surprisingly high accuracies on ImageNet, even though this effectively limits a model to recognizing small local patches rather than integrating object parts for shape recognition.”</li>  
</ul>
</blockquote>

<p>So, the paper pindown this particular behavior of CNNs, which will explain the above observations. This behavior can be summed up in the following image.</p>

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/cue conflict.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.3: Texture-shape cue conflict, from the paper
</figcaption>
</figure>

<p>Here we can clearly see even if the global structure of the cat is there, all the top predictions are based on texture i.e., elephant skin.</p>

<h2 id="psychophysical-experiment">Psychophysical Experiment:</h2>
<p>To extensively study this behavior, the authors proposed psychophysical experiments to test the CNNs against human counterparts. To understand the bias, we first have to disentangle the shape and texture information, to see where the subjects are inclined towards. This is done by swapping the original texture information through various means, namely the datasets for the psychophysical experiment.</p>
<h3 id="datasets">Datasets:</h3>
<ul>
    <li> <b>Original:</b> 160 natural colored images with white background(to avoid any information coming from background).</li>
<li> <b>Greyscale:</b> Images converted to greyscale, for CNNs stacked across 3 channels.</li>
<li> <b>Silhouette:</b> Black image on white background, similar to semantic segmentation map.</li>
<li> <b>Edges:</b> Edge-based representation through Canny Edge detector.</li>
<li> <b>Texture:</b> 48 natural texture images or by having a repetition of the same object
Cue Conflict: Images generated using <a href="https://www.tensorflow.org/tutorials/generative/style_transfer">Style Transfer algorithm</a>, using original (Content) and texture (Style).</li>
</ul>

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/dataset.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.4: Experimental datasets, from the paper
</figcaption>
</figure>

<p>Here, greyscale, silhouette, edges, and cue conflict forms the experimental setup. The predictions on these images can either be shape-based or texture-based. Using multiple ways to swap out the texture, we can be sure that results are not due to a particular source texture.
Now, as for labels, authors use 16 imagenet classes through wordnet hierarchy as labels. The authors chose 4 CNN networks trained on the imagenet namely VGG16, GoogleLeNet, AlexNet, and ResNet50. For the participants of the trial, they have to choose 1 of 16 labels for each image shown.</p>

<h2 id="solution-stylized-imagenet">Solution: Stylized Imagenet</h2>
<p>Now the texture bias is confirmed, the next step would be to try to nudge CNNs towards shape-bias, as exhibited by human counterparts. Authors explain that the imagenet task itself does not necessitate the CNNs to learn shape-based representations, integrations of local features work great for maximizing accuracy. Based on this hypothesis, The authors proposed a novel dataset as a solution: <em>Stylised Imagenet (SIN)</em>. The goal is to strip the texture of the original image and replace it with a randomized style. This serves as both training data for robust models and test for robustness, which would be difficult for models to solve with shape bias.</p>

<p>The benefits of these SIN-trained models and the robustness test for the traditional models are discussed below.</p>

<h2 id="results">Results:</h2>
<p>The authors explain the results of the paper in 3 steps.</p>
<ul>
<b><li> The shape vs texture bias in the CNNs and humans. </li></b>

As explained in the psychophysical experiment section, the authors tested out if CNN predicts labels in accordance with shape information or textural information. The same experiment was conducted with human participants. The results show high texture bias in the models, whereas humans demonstrated high shape bias.

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/psychophysical experiment.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.5: Texture bias in CNNs results, from the paper
</figcaption>
</figure>

<b><li> Overcoming the texture bias using Stylized Imagenet</li> </b>

The authors show that by training on the stylized imagenet, we see improvements towards shape bias.

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/SIN improved results.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.6: SIN: shape bias results, from the paper
</figcaption>
</figure>

The paper also proposes <em>Shape-ResNet</em>, a ResNet-50 variant which is jointly trained on SIN and IN, with finetuning on IN. Shape-ResNet achieves higher accuracy in terms of Imagenet as well as on object detection task in Pascal VOC than its vanilla counterpart.

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/shaperesnet results.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.7: ShapeResNet benchmarks, from the paper
</figcaption>
</figure>

<b><li> The robustness of models trained on Stylized Imagenet</li></b>

The paper tests SIN vs IN trained models for various distortions(uniform noise, high-pass and low-pass filtering, contrast, etc.), on which SIN models outperform their counterparts. On <a href="https://arxiv.org/pdf/1807.01697.pdf"><em>ImageNet-C</em></a>, a standard benchmark dataset for corruption and robustness, SIN shows lower corruption errors than its vanilla counterparts, again proving the hypothesis that a more shape-oriented representation can help demonstrate robustness.

<figure>
<img src="https://iclr.iro.umontreal.ca/3317e093-2e19-476d-90a0-4c9a216fea4c_1642240633/public/images/2020-12-01-Are-CNNs-biased-towards-texture-rather-than-object-shape/INC test results.png" alt="Trulli" />
<figcaption style="text-align:center"> 
    Fig.8: ImageNet C results, from the paper
</figcaption>
</figure>
</ul>

<h2 id="conclusion">Conclusion:</h2>
<p>This paper hypothesizes the texture bias as a way to explain the scattered findings which couldn’t be explained by our previous intuition of how CNNs works. For the scope of the paper, authors examine texture bias for ImageNet trained models found this behavior consistent across models. To nudge the models to learn shape bias, the authors present a novel dataset of stylized imagenet, whose results on texture bias were examined through various distorted images.</p>

<h2 id="further-discussion">Further Discussion:</h2>
<p>Now, this leaves us with 2 questions…</p>

<blockquote>Does this behavior occur for only Imagenet trained images i.e., is it a dataset property?</blockquote>

<p>As explained above, solving the imagenet does not require models to learn shape-based representations. A similar line of thought is discussed in <a href="https://papers.nips.cc/paper/2019/file/e2c420d928d4bf8ce0ff2ec19b371514-Paper.pdf">another paper</a>, which dives deeper into explaining adversarial examples, answering this question and others such as adversarial transferability.</p>

<blockquote>If our previous understanding is wrong, what causes such behavior in CNNs?</blockquote>

<p>This comes under the research paradigm of explainability in CNNs, which is an active research field. To learn more about this topic, you can give <a href="https://distill.pub/2017/feature-visualization/">try this</a> and <a href="https://distill.pub/2018/building-blocks/">this blog</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/#cnns"> CNNs </a>
  
    <a class="content-tag" href="/tags/#adversarial-examples"> Adversarial examples </a>
  
    <a class="content-tag" href="/tags/#robustness"> Robustness </a>
  
    <a class="content-tag" href="/tags/#explainability"> Explainability </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/#cnns"> CNNs </a>
  
    <a class="content-tag" href="/tags/#adversarial-examples"> Adversarial examples </a>
  
    <a class="content-tag" href="/tags/#robustness"> Robustness </a>
  
    <a class="content-tag" href="/tags/#explainability"> Explainability </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>
