<!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>
    
      FCDD - Explainable Anomaly Detection &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/2021/12/01/fcdd-explainable-anomaly-detection/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/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/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/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/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/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">FCDD - Explainable Anomaly Detection</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#anomaly-detection"> anomaly-detection </a>
  
    <a class="content-tag" href="/tags/#explainability"> explainability </a>
  
    <a class="content-tag" href="/tags/#one-class-classification"> one-class classification </a>
  </span>

  <span id="iclr-post-authors" class="post-date">1, Anonymous (Institution 1); 2, Anonymous (Institution 2)</span>
  <p>FCDD achieves SOTA performance on MVTec-AD and comparable performances on other
standard datasets for anomaly detection, while providing inbuilt explanations.</p>

<ul>
  <li><a href="#introduction">Introduction</a></li>
  <li><a href="#prior-work">Prior Work</a></li>
  <li><a href="#explainable-deep-one-class-classification-with-fcdd">Explainable Deep One-class classification with FCDD</a>
    <ul>
      <li><a href="#fully-convolutional-architecture">Fully Convolutional architecture</a></li>
      <li><a href="#training-objective-based-on-a-hypersphere-classifier">Training objective based on a Hypersphere Classifier</a></li>
      <li><a href="#gaussian-kernel-based-upsampling">Gaussian Kernel based upsampling</a></li>
    </ul>
  </li>
  <li><a href="#semi-supervised-fcdd-for-mvtec-ad">Semi-supervised FCDD for MVTec-AD</a></li>
  <li><a href="#clever-hans">Clever Hans</a></li>
  <li><a href="#references">References</a></li>
</ul>

<h2 id="introduction">Introduction</h2>

<p>“Anomaly detection (AD) is the task of identifying anomalies in a corpus of
data.” Everytime I read this, I get the Among Us image in my head. If you aren’t
familiar, it is a game where there is an impostor (usually one, sometimes more)
among a group of regular characters, and the regular ones have to find which one
is the impostor (anomaly) hidden among them.</p>

<table>
  <tbody>
    <tr>
      <td>Among Us</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/1-impostor.png" alt="Among-Us" /></td>
    </tr>
  </tbody>
</table>

<h2 id="prior-work">Prior Work</h2>

<p>There are many real-life applications where we find anomalies. Finding tumors
for cancer, cracks inside metal bars, fraud detection are a few of the very
common applications. However, in case of the first two applications, the task of
AD could be of two types - Anomaly Classification and Anomaly Segmentation. An
Anomaly Detector model could simply look at a CT scan image and output a label
of anomalous (contains malignant growth) or normal. This would be similar to a
binary classification problem. The Anomaly Detector could further segment the
malignant pixels in the CT scan image to predict a mask of the anomalous pixels,
which would be the task of Anomaly Segmentation. For all of these problems,
several solutions have been developed over the years. Deep learning based
approaches, particularly, have become popular in recent years.</p>

<table>
  <tbody>
    <tr>
      <td>Prior Work</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/2-prior-work.png" alt="Prior-Work" /></td>
    </tr>
  </tbody>
</table>

<p>One set of approaches use <strong>autoencoders</strong>. These are usually trained on a nominal
(no anomalies present) dataset and used to reconstruct anomalous samples, which
it is then expected to reconstruct poorly. The drawback to this is of course
that we can’t incorporate known ground-truth anomalies during the training
process itself. The advantage of this method is that we can use the
reconstruction error as an anomaly score and the pixel-wise difference directly
as an anomaly heatmap, providing a natural explanation without having the
explicit need to include attention mechanisms in the model. Some recent works
have however incorporated attention into the autoencoders itself as an
explanation mechanism, providing an alternative to the natural solution.</p>

<p><strong>One-class classification</strong> methods map nominal data to a concentrated feature
space and map anomalous data to other locations. While this is done
unsupervised, the methods usually rely on a separate attention mechanism or
model-agnostic explanation methods for generating an explanation, instead of it
being inbuilt.</p>

<p>The best performing methods use <strong>self-supervision</strong>. These methods apply some
transformation to nominal samples. Then a model is trained for predicting the
transformation used and then an anomaly score is generated via the confidence
score of the prediction. The advantage of this method is mainly that it provides
good results while not requiring supervision. But the disadvantage is that it is
inherently not explainable yet, meaning that we cannot use them for sensitive
applications like healthcare.</p>

<p>In this particular paper, the authors adopt a one-class classifier based
approach, and then add some innovations for inbuilt explainability for them.</p>

<h2 id="explainable-deep-one-class-classification-with-fcdd">Explainable Deep One-class classification with FCDD</h2>

<table>
  <tbody>
    <tr>
      <td>FCDD</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/3-method.png" alt="FCDD-method" /></td>
    </tr>
  </tbody>
</table>

<h3 id="fully-convolutional-architecture">Fully Convolutional architecture</h3>

<p>The paper adopts a fully convolutional network (FCN) architecture with
alternating convolutional and pooling layers. The datasets used in the paper are
Fashion-MNIST, CIFAR-10, ImageNet, MVTex-AD and Pascal VOC. For each dataset a
slightly different (larger) network is used, but the overall convolutional
nature of the networks remains the same.</p>

<table>
  <tbody>
    <tr>
      <td>Model Architectures for different datasets</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/4-model-architecture.png" alt="Architectures" /></td>
    </tr>
  </tbody>
</table>

<p>Another important property of a convolutional layer is that each pixel in the
output depends on a small region of the input, because the values are calculated
by moving a small kernel (filter) across the input. The small region is known as
the output pixel’s receptive field. This property allows the networks used to
preserve spatial information.</p>

<p>The authors have performed an analysis by varying the size of the receptive
field to see its effect on the final heatmap produced. In the figure below,
where this analysis is shown for a small set of examples from MVTec-AD, we can
see that for smaller receptive field sizes the heatmaps are more concentrated
and closer to the shapes in the ground truth heatmaps.</p>

<table>
  <tbody>
    <tr>
      <td>Sensitivity Analysis for receptive field size for MVTec-AD</td>
    </tr>
    <tr>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/5-receptive-field-size.png" alt="Receptive-field-size-sensitivity-analysis" /></td>
    </tr>
  </tbody>
</table>

<h3 id="training-objective-based-on-a-hypersphere-classifier">Training objective based on a Hypersphere Classifier</h3>

<p>With the given FCN architecture, the next task is to decide on a training
objective. If X<sub>1</sub>, . . . , X<sub>n</sub> denote a collection of samples and y<sub>1</sub>, . . . , y<sub>n</sub>
be labels where y<sub>i</sub> = 1 denotes an anomaly and y<sub>i</sub> = 0 denotes a nominal sample,
then the objective function as described in the image below maps nominal samples
near the origin centered hypersphere and anomalies to be mapped away. Note from
the expression of the objective, that for an anomaly, the first term of the
summation would become 0 for each anomaly as y<sub>i</sub> = 1, and similarly for each
nominal sample, the second term would be 0 as y<sub>i</sub> = 0. Over the weights <em>W</em> of the
neural network <em>ɸ</em>, the objective is thus able to maximize the anomaly score from
the output heatmap for anomalies, and minimize it for nominal samples. This
allows it to perform the hypersphere mapping as described.</p>

<table>
  <tbody>
    <tr>
      <td>Formal definition of Objective Function</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/6-objective-function.png" alt="Objective-function" /></td>
    </tr>
  </tbody>
</table>

<p>For visualisation purposes only, consider this unit hypersphere centered at the
origin. The coloured patches on the surface of the sphere can be assumed to be
representations of concentrated data points (anomalies in our case) and we can
assume that all the nominal samples are present at the centre of the
hypersphere. This is what the objective function tries to achieve. Note that for
our case, the distribution of the anomalies and nominal samples may look
different than the exact representation shown in this figure, and this figure is
only intended to provide a visual aid for understanding the concept.</p>

<table>
  <tbody>
    <tr>
      <td>Example Hypersphere</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/7-hypersphere.png" alt="Hypersphere" /></td>
    </tr>
  </tbody>
</table>

<h3 id="gaussian-kernel-based-upsampling">Gaussian Kernel based upsampling</h3>

<p>Based on the formal description of the network, we can see that it maps an input
image of size <em>(h x w)</em> to an output heatmap of size <em>(u x v)</em> and the output is
smaller (lower resolution) than the input. While low-resolution heatmaps may be
useful for benchmarks and other tests of performance, for a human to understand
the output, there is a very pertinent need to have an upsampled heatmap. Usually
there is no access to ground-truth heatmaps for most datasets (MVTec-AD is an
exception), so we cannot learn in a supervised fashion the upsampling mapping.
So, instead a clever mathematical manoeuvre is used based on the property of
receptive fields for the FCN.</p>

<p>For every pixel in the output heatmap <em>A(X)</em>, there must be a unique input pixel
at the center of its receptive field. An empirical observation is known that the
effect of the receptive field for an output pixel decays in a Gaussian manner as
one moves away from the center of the receptive field. This fact is used in the
paper. <em>A(X)</em> is upsampled using a strided convolution with a fixed Gaussian
Kernel whose μ parameter (mean) comes from the input pixel at the center of the
receptive field for a given output pixel. The <em>𝝈</em> parameter (variance) is set
based on empirical testing to see which value generates an explainable heatmap.
As can be seen from the image below, which shows this empirical analysis for a
few inputs from the MVTec-AD dataset, a <em>𝝈</em> value that is neither too high nor
too low works well enough for most cases on comparing with the ground truth
heatmaps produced.</p>

<table>
  <tbody>
    <tr>
      <td>Sensitivity Analysis for <em>𝝈</em> value of Gaussian Kernel for MVTec-AD</td>
    </tr>
    <tr>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/8-gaussian-sigma-variations.png" alt="Gaussian-sigma-variation-sensitivity-analysis" /></td>
    </tr>
  </tbody>
</table>

<p>For visualisation purposes, this is what a Gaussian 2D distribution would look
like when plotted.</p>

<table>
  <tbody>
    <tr>
      <td>2D Gaussian Distribution</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/9-gauss.png" alt="2d-Gaussian-distribution" /></td>
    </tr>
  </tbody>
</table>

<p>This shows the working of the transposed convolution operation with a 2 x 2
kernel (not Gaussian, just a random kernel for illustration purposes).</p>

<table>
  <tbody>
    <tr>
      <td>Example of Transposed Convolution operation</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/10-transpose-conv.png" alt="Transpose-convolution-example" /></td>
    </tr>
  </tbody>
</table>

<p>And this figure from the paper shows the effect of both of these ideas combined.
It illustrates a 3 x 3 convolution followed by a 3 x 3 transposed convolution
with a gaussian kernel, both using a step size of 2.</p>

<table>
  <tbody>
    <tr>
      <td>Transposed convolution based upsampling for FCDD output</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/11-transconv.png" alt="Transpose-convolution-based-upsampling-for-FCDD" /></td>
    </tr>
  </tbody>
</table>

<h2 id="semi-supervised-fcdd-for-mvtec-ad">Semi-supervised FCDD for MVTec-AD</h2>

<p>The most exciting thing about this entire approach is that it is unsupervised
and does not require ground-truth heatmaps for providing output heatmaps. But if
ground-truth heatmaps are present, these can also be provided along with the
input to act as a semi-supervised setting. To do this, the model objective is
slightly modified during training. If X<sub>1</sub>, . . . , X<sub>n</sub> denote an input batch and
Y<sub>1</sub>, . . ., Y<sub>n</sub> denote corresponding ground-truth heatmaps, we can replace the
denominator of the objective function from <em>(u . v)</em> to <em>(h . w)</em> and in the
numerator we can replace (y<sub>i</sub>) by (Y<sub>i</sub>) and then add a summation for the Y<sub>i</sub> over j
from 1 to <em>(u . v)</em>. This allows us to train the model with a pixel-wise
objective. Using even a few of these ground-truth explanations improves
performance significantly, achieving up to 0.99 pixel-wise mean AUC for some of
the classes in the MVTec-AD and almost always outperforming the unsupervised
scores by a few points.</p>

<table>
  <tbody>
    <tr>
      <td>Modified objective function</td>
    </tr>
    <tr>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/12-modified-objective.png" alt="Modified-objective-function-for-semi-supervised-FCDD" /></td>
    </tr>
  </tbody>
</table>

<p>Another thing to note for datasets like MVTec-AD, where anomalies are subtle, is
that synthetic anomalies are also generated using confetti-like noise that
inserts coloured blobs into images to reflect the general nature of anomalies.
This helps in the overall training process.</p>

<table>
  <tbody>
    <tr>
      <td>Confetti Noise</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/13-confetti-noise.png" alt="Confetti-noise-example" /></td>
    </tr>
  </tbody>
</table>

<p>Overall FCDD achieves SOTA performance for MVTec-AD and is very comparable to
SOTA performance for the other datasets that the paper has experimented with.</p>

<h2 id="clever-hans">Clever Hans</h2>

<p>The FCDD approach where heatmaps as explanations are generated directly as
output, has also generated an interesting by-product observation. Images might
have watermarks sometimes, and it has been observed that deep one-class
classifiers fail to recognize true image features in the presence of watermarks.
For example, in the PASCAL VOC dataset, some of the images with horses have a
watermark in the lower left corner. A classifier trained on this dataset
identifies this watermark as the class identifying pattern. This effect is
called the “Clever Hans” effect in memory of the horse Hans, which could
correctly answer maths problems by reading its master.</p>

<p>In an attempt to interpret whether FCDD is vulnerable to the Clever Hans effect,
the authors swap the experimental setting by treating the “horse” class as
anomalous. This, of course, implies that the anomaly heatmaps produced by FCDD
should highlight the horses. Thus, any other highlighting in the heatmaps
produced would easily reveal that FCDD is characterizing based on other spurious
features.</p>

<p>The heatmaps produced by FCDD indeed reveal the vulnerabilities of the deep
one-classifier which learns features like the watermarks in the lower left
corner and also structures like bars and fences, instead of learning horse
features.</p>

<table>
  <tbody>
    <tr>
      <td>Clever Hans effect</td>
      <td><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/14-hans.png" alt="Clever-hans-effect" /></td>
    </tr>
  </tbody>
</table>

<p>This particular example underlines the robustness and interpretability of the
FCDD approach as it allows a trained practitioner to look at the inbuilt
explanations and understand / mitigate possible causes of failure. And this
makes it a favorable method for now, to answer the question of whether something
is an anomaly or not.</p>

<p><img src="https://iclr.iro.umontreal.ca/3eb756f1-8f25-4734-87b4-bcc07f583cf3_1642090226/public/images/2021-12-01-fcdd-explainable-anomaly-detection/15-maybe-maybe-not.jpeg" alt="Maybe-or-Maybe-Not" /></p>

<h2 id="references">References</h2>

<ul>
  <li>The image of the hypersphere is adopted from <a href="https://arxiv.org/abs/1706.03762">this
paper</a>. {Liu, Weiyang, et al. ‘SphereFace: Deep Hypersphere Embedding for Face Recognition’. 2017 IEEE Conference on Computer Vision and Pattern Recognition (CVPR), IEEE, 2017, pp. 6738–46. DOI.org (Crossref), https://doi.org/10.1109/CVPR.2017.713.}</li>
  <li>The image of the 2D gaussian distribution is adopted from <a href="https://towardsdatascience.com/prior-over-functions-gaussian-process-1c58e8c40272">this website</a></li>
  <li>The image of the transposed convolution examples is adopted from <a href="https://d2l.ai/chapter_computer-vision/transposed-conv.html">this website</a></li>
</ul>

</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/#anomaly-detection"> anomaly-detection </a>
  
    <a class="content-tag" href="/tags/#explainability"> explainability </a>
  
    <a class="content-tag" href="/tags/#one-class-classification"> one-class classification </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/#anomaly-detection"> anomaly-detection </a>
  
    <a class="content-tag" href="/tags/#explainability"> explainability </a>
  
    <a class="content-tag" href="/tags/#one-class-classification"> one-class classification </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>
