<!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>
    
      Evaluation of Feature-based explanations &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/2022/01/15/Urja/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/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/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/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">

<!-- 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/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/">Home</a>

    

    
    
      
        
      
    
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/about/">About</a>
        
      
    
      
    
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/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">Evaluation of Feature-based explanations</h1>
  <span class="post-date">15 Jan 2022 | 
    <a class="content-tag" href="/tags/#explainable-ai"> explainable AI </a>
  
    <a class="content-tag" href="/tags/#evaluations"> evaluations </a>
  
    <a class="content-tag" href="/tags/#feature-based-explanations"> feature-based explanations </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <!-- content -->

<p>The rising need of making Machine Learning (ML) models interpretable, fair and trustworthy has led the research community to come up with better explanations to enable interpretation, validation, and transparency while utilising these models in domains such as healthcare or finance. But, how do we judge whether the explanation is better or not? Different types of explanations require different evaluation metrics to get assessed. The most common type of explanation is feature importance explanations that are usually presented in the form of relative ranking of feature as per their importance in determining model’s output. Another common type is counterfactual explanations that tells us what minimum changes are required in the features that will result in different classification by the model.</p>

<p>For black-box classifiers Feature importance and counterfactuals are estimated using different techniques that involves either training an interpretable classifier to mimic black-box locally, or perturbations based on insertion and removal of features. A set of evaluation metrics are required to represent the faithfulness of explanations to truly represent the black-box model that is usually termed as “robustness” of explanations.</p>

<h3 id="contribution-of-the-paper">Contribution of the Paper</h3>
<p>This blog post describes contribution of the paper titled “EVALUATIONS AND METHODS FOR EXPLANATION THROUGH ROBUSTNESS ANALYSIS” by <a href="https://openreview.net/forum?id=Hye4KeSYDr">Cheng et. al</a> that discusses assessing robustness in a novel way and coming up with more robust explanation in the specific area of insertion and removal of explanations. This is because such explanations face two drawbacks:</p>
<ol>
  <li>When the feature importance is estimated by removing a feature by setting it to a baseline value, it has higher chance to attribute high importance if some values deflect a lot from baseline. An example would be setting RGB pixels to black, that will give bright pixels more importance.</li>
  <li>When the feature importance is estimated by removing a feature by giving it some value sampled from the distribution (using a generative model) , there is an inherent bias that goes from the generative model to this process and not all domains can have a proper generative models.</li>
</ol>

<p>To address this, the paper contributes towards two things:</p>
<ol>
  <li>Proposing a novel evaluation criteria to assess the robustness of feature based explanations -  feature importance and counterfactuals - based on small perturbations to understand how the model’s output changes with these small perturbations on different set of features.</li>
  <li>Optimising on the novel evaluation criteria to come up with better explanations</li>
</ol>

<h4 id="robustness">Robustness:</h4>
<p>In order to have an evaluation of the explanations, two key things are assumed:</p>
<ol>
  <li>Changing the values of only non-important features have a weak influence on model’s output</li>
  <li>Changing the values of only important features can easily change model’s output</li>
</ol>

<p>Based on the above set of assumptions, a robustness parameter ε<sup>*</sup> is defined as given by the following equation:</p>

<p>ε<sup><em>&lt;/sup&gt;<sub><strong>x</strong>s</sub> = *g(f,<strong>x</strong>, S)</em> = min<sub>δ</sub>|δ| *s.t. f(x+δ) != y, δ<sub>S<sup>*</sup></sub></sup></p>

<p>In the above equation, <em>f</em> id the model, <em>x</em> is the input, <em>U</em> is the set of all features and <em>S</em> is the subset of <em>U</em>. The term δ is the minimum adversarial perturbation that is performed on <em>S</em>. This minimum perturbation, when done on set of important features, should be <strong>low</strong> as per assumption 2. Similarly, minimising δ over a set of non-important features S<sup>c</sup> should give a higher δ value, as high pertubations are required to change model’s output by perturbing only non-important features.</p>

<blockquote>
  <p>Based on this, we can say: R(S) - where S is a set of important features - is given by ε<sup>*</sup><sub><strong>x</strong>s</sub> and,</p>
</blockquote>

<blockquote>
  <p>R(S<sup>c</sup>); where  S<sup>c</sup> is a set of non-important features - is given by ε<sup>*</sup><sub><strong>x</strong>s<sup>c</sup></sub>.</p>
</blockquote>

<p>With this evaluation metric R, we can also have a look at the AUC curve that is plotted against the top K features belonging to that subset.</p>

<p><img src="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/images/2022-01-15-Urja/rnimp.png" alt="AUC" /> 
<img src="https://iclr.iro.umontreal.ca/4f7d7869-9804-4ce5-bf63-403917c28947_1642248606/public/images/2022-01-15-Urja/rsimp.png" alt="AUC" /></p>

<h4 id="counterfactual-flavor">Counterfactual flavor</h4>
<p>If we optimise the previous equation of ε<sup>*</sup><sub><strong>x</strong>s</sub> from that to the following equation:</p>

<p>ε<sup><em>&lt;/sup&gt;<sub><strong>x</strong>s</sub> = *g(f,<strong>x</strong>, S)</em> = min<sub>δ</sub>|δ| *s.t. f(x+δ) = t, δ<sub>S<sup>*</sup></sub></sup></p>

<p>we can see that if the optimisation function can optimise for pertubations leading to another desired class <em>t</em>, it can provide us with the counterfactual use of the S subset of features.</p>

<h4 id="extracting-explanations">Extracting explanations</h4>

<p>Based on <em>g(f,<strong>x</strong>, S)</em>, we can extract a set of important and non important features by solving the follwing set of optimsation problems respectively:</p>

<blockquote>
  <table>
    <tbody>
      <tr>
        <td>minimise <em>g(f,<strong>x</strong>, S)</em> s.t.</td>
        <td>S</td>
        <td>&lt;= K</td>
      </tr>
    </tbody>
  </table>
</blockquote>

<blockquote>
  <table>
    <tbody>
      <tr>
        <td>maximise <em>g(f,<strong>x</strong>, S<sup>c</sup>)</em> s.t.</td>
        <td>S<sup>c</sup></td>
        <td>&lt;= K `</td>
      </tr>
    </tbody>
  </table>
</blockquote>

<p>where K is the number of features we intend to analyse or consider.</p>

<p>The above equations could be solved by a greedy approach where we initialise an empty set S (or S<sup>c</sup>) and keep on adding features that most optimises the corresponding optimisation function. However, there is a drawback of missing the interaction among features. Two feature might be very important when put together and not important in a standalone manner. For this, marginal contribution of a feature is also taken into consideration by analysing the change in model’s output when unchosen features are also included with this feature. The concept is based on game theory and can be used to optimally decide the contribution of feature on model’s output.</p>

<p>To avoid confusion, this evaluation criteria and explanations is different from SHAP in a way that SHAP considers removal of features by setting it to a baseline value, whereas here we are more interested in capturing change in model’s output by slightly changing the input space from their original value. This change can then be used for optimisation to have more deflection in output (for important features) or less deflection (for non-important features).</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/08/blog-posts-as-conference-contributions/">
            Blog Posts as Conference Contributions
            <small>08 Sep 2021 | 
    <a class="content-tag" href="/tags/#explainable-ai"> explainable AI </a>
  
    <a class="content-tag" href="/tags/#evaluations"> evaluations </a>
  
    <a class="content-tag" href="/tags/#feature-based-explanations"> feature-based explanations </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>
