<!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>
    
      The token parser and manipulator, next-generation Deep Learning architecture &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/2021/12/01/contrastive-structured-world-model/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/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/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/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/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/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">The token parser and manipulator, next-generation Deep Learning architecture</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#representation"> representation </a>
  
    <a class="content-tag" href="/tags/#object"> object </a>
  
    <a class="content-tag" href="/tags/#symbolic"> symbolic </a>
  </span>

  <span id="iclr-post-authors" class="post-date"></span>
  <p>Deep Learning is an excellently scalable approach for processing unstructured, high-dimensional, raw sensory signal.
It is so good that these properties also becomes its most popular criticism.
At the moment, deep learning is <em>mostly</em> just a giant correlation machine, devouring enormous amount of data to recognise hidden pattern in data, but still lacking in human-like systematic generalisation required in many reasoning tasks.
Symbolic AI on the other hand possesses these abilities <em>by design</em>, but relied on handcrafted symbols that has already been abstracted away from the raw information.
Among many approach to combine the best of both worlds, I am most excited about the end-to-end trainable architecture with a perception module that structurised the raw input and a reasoning module operates on top of these symbol-like vectors.
While there are still a lot of work before such a system becomes practically relevant, in this blog post we will take a look at the paper <a href="https://arxiv.org/abs/1911.12247"><strong>Contrastive Learning of Structured World Model</strong></a>, an early paper that offer a glimpse into such architecture through a concrete implementation.</p>

<h1 id="replace-symbols-with-vectors-and-logic-with-algebra">Replace symbols with vectors and logic with algebra.</h1>

<p>The field of Neuro-symbolic AI naturally emerges with the goal of combining the complimentary advantages of both neural networks and symbolic methods.
These hybrid model are promised to offer the ability to learn representation from unstructured data at scale using DL, while also can perform logical reasoning from the wealth of symbolic AI’s literature.
Much research has since been done toward the interface between vectors representation outputs and symbolic inputs. However many of the same problems of symbolic approach still present when moving from human-designed symbols to machine-learned vectors.</p>

<p>Instead of this hybrid approach, many researchers envision about a conceptually simpler approach, in which the symbol-manipulation reasoning module (i.e system 2) is learnt jointly in an end-to-end fashion with the signal processing module of unstructured data (system 1).</p>

<p><img src="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/images/2021-12-01-contrastive-structured-world-model/binding.png" alt="Binding problem." />
Figure 1: A conceptual framework for dynamically learning and binding unstructured information into symbol-like tokens to facilitate reasoning in neural networks. Figure adopted from <a href="#binding">[Greff et al]</a> (permission pending for publication).</p>

<p>This vision is usually <a href="https://twitter.com/ylecun/status/1066080315599409152">succinctly put</a>:</p>
<blockquote>
  <p>“Replace symbols with vectors and logic with algebra”. – Yann Lecun</p>
</blockquote>

<hr />
<p><strong><em>Note:</em></strong>
Whether a system like this is still called “symbolic AI” or not is left as an semantic exercise for the celebrated researchers. In this blog, we will adopt the term “token” from the Transformer literature to refer to these symbol-like representation vectors.</p>

<hr />

<h1 id="contrastive-learning-of-structured-world-model">Contrastive Learning of Structured World Model</h1>
<p>While such archtecture might sound promising, it can be hard to really see what such an architecture is like.
The <a href="https://arxiv.org/abs/1911.12247"><strong>Contrastive Learning of Structured World Model</strong></a> (C-SWM) by <a href="#cswm">[Kipf et al.]</a> materialised such vision through very simple building blocks drawn from a wide range of Deep Learning subfield.
First let’s decompose the title of the paper to get a sense for its motivation and approach.</p>

<p>A <strong>world model</strong> refers to a compressed representation of the raw sensory signal that is assumed to come from a coherent and consistent environment with many independent and interacting agents, the world.
This is in contrast to the task-specific representation usually obtained with a standard supervised learning. 
Having learned a simulation of the world can enable a system to reason (counterfactually) and plan more efficiently, which is the goal of <em>Model-based</em> Reinforcement Learning.</p>

<p>A <strong>structured world model</strong> implies a world model that explicitly captures the structures of the world in its representation, as opposed to implicitly do it all in different subspaces of a single output vector.</p>

<p><strong>Contrastive Learning</strong> of this structured world model refers to a self-supervised approach that enable this model to be learned end to end from raw observation only, as all world models should.
After all, God does not give us the answer to the <em>ultimate question of life, universe and everything else</em> either. <sup id="fnref:1" role="doc-noteref"><a href="#fn:1" class="footnote" rel="footnote">1</a></sup></p>

<p>In this section, I will go through each individual modules and highlight how they fit in the overall architecture.
I won’t go into the detail implementation because they are quite simple, not particularly important for this blog and the authors have done an excellent job in explaining it in the original paper.</p>

<h2 id="the-overall-architecture">The overall architecture</h2>

<p>Similar to the blue print in Figure.1 above, the architecture of C-SWM is divided into 3 part:</p>
<ul>
  <li>The object-extractor <strong>segregates</strong> raw unstructured information into distinct object feature maps.</li>
  <li>The object-encoder <strong>transforms</strong> each feature map to a consistent set of object representations.</li>
  <li>The relational Graph neural network (GNN)  <strong>manipulates</strong> these symbols, and take on the role of composition module.</li>
</ul>

<p>All three components are tied together through a contrastive objective, and trained end-to-end in a self-supervised manner.</p>

<p><img src="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/images/2021-12-01-contrastive-structured-world-model/cswm.png" alt="C-SWM architecture" />
Figure 2: The architecture of C-SWM. The object extractor segregate information into object-level of abstraction. Object-encoder represents those segregated information to a common object representation format. The transition model process these tokens as the basic building block to model the dynamic of the world. Finally the entire framework is trained end-to-end via a self-supervised contrastive objective. Figure adopted from original paper, with annotations.</p>

<p>We can think of the first two module, the <em>object extractor</em> and the <em>object encoder</em> as the <em>token parser/learner</em>, which goal is to produce these <strong>set</strong> of compatible representation for each input data.
The GNN operates on this set of tokens can be treated as <em>token manipulator</em>, the counterpart for traditional symbolic AI methods, which takes on the role of reasoning computation.</p>

<h2 id="the-token-learnerparser">The token learner/parser</h2>

<p>The world has many different structures, so what kind of structure should we impose on our model?
In this paper, the level of abstraction designed for the token is the at the object level. <sup id="fnref:2" role="doc-noteref"><a href="#fn:2" class="footnote" rel="footnote">2</a></sup>
Object-centric representation learning is a subfield which chases this very objective <a href="#OOR1">[Workshop1]</a> <a href="#OOR2">[Workshop2]</a>.</p>

<h3 id="the-object-extractor">The object extractor</h3>

<p>The first step to find structure in unstructured data is to figure out which part of the input should be grouped into the same object.
This information segregation task is handled in this paper by the object extractor.</p>

<p>Since the input is a sequence of images, the authors opted for a standard Convolutional Neural Network.
This network processes the entire image at the same time, and output a sets of feature map with each feature map belong to a different entity, i.e “object”.</p>

<h3 id="the-object-encoder">The object encoder</h3>

<p>After the information segregation step, each feature map are further encoded to obtain the set of object representation.
In this case, the object encoder is simply an MLP that takes in the flatten feature map outputted by the object extractor.</p>

<p>Crucially, the MLP is reused across all feature maps.
This innocuous choice will enforce that the all object tokens lies in the same vector space, enhance the consistency and compatibility between object tokens for downstream manipulation.</p>

<h2 id="the-token-manipulator">The token manipulator</h2>
<p>This set of structured, high-level tokens will then be manipulated by a neural network counterpart of the logic module in symbolic AI.
In this paper, this token manipulator is implemented by simple graph neural network, with the assumption that the object tokens form a fully connected graph (i.e each object can potentially interact with all other objects).</p>

<p>This GNN share the same node and edge update function over all object tokens, similar to how the object encoder MLP is shared between them.
This choice will not only promote efficiency but also poses as a constraints on the interoperability between tokens during training.</p>

<p>This is, in my opinion, one of the most important advantages of this architecture over hybrid Neuro-symbolic approach, where many interface constraints are handled transparently through a simple choice of parameter sharing.</p>

<h2 id="the-object-factorised-contrastive-objective">The object-factorised contrastive objective</h2>

<p>Up until now, all the structure, “objectness”, we wish to impose on the representation are only vaguely expressed in the sense of a “set” of output token vectors, instead of a single (possibly larger) output vector.
There are evidence that given appropriate structure of the representation, this object abstraction will emerges as a byproduct of optimisation <a href="#monet">[Burgess, 2019]</a>.
I tend to believe that since it is easier to understand a scene in term of its constituent objects, the optimisation process will converges to that solution first, given appropriate architecture.</p>

<p>In C-SWM, to promote the disentanglement of features into object more explicitly, the authors further employed a object-factorised contrastive loss.
This is a simple modification to the original max-margin contrastive loss that takes into account the fact that the model outputs a set of tokens instead of a single one.</p>

<h1 id="butbut-its-just-evaluated-on-toy-dataset">But…but, it’s just evaluated on toy dataset!</h1>
<p>Since this paper doesn’t really fit into a well-defined task and benchmark, the authors had to come up with their own evaluation suite.</p>

<p><img src="https://iclr.iro.umontreal.ca/23436c38-ab42-454a-9799-a22610bbfd62_1642222669/public/images/2021-12-01-contrastive-structured-world-model/data.png" alt="C-SWM evaluation data" />
Figure 3: 5 different datasets C-SWM are evaluated on. Each dataset can aims to highlight an important component of the architecture.</p>

<p>The <em>2D shapes</em> and <em>3D Blocks</em> dataset demonstrated that a simple Convolutional Network can captures the object-centric representation in both simple and more challenging environment.
The <em>Pong</em>, <em>Space Invaders</em> game environment and <em>3-Body Physics</em> really highlight the important of the token manipulator module on top of the learned object-centric tokens.</p>

<p>Even though the authors has successfully convinced the ICLR reviewer of their vision through this carefully selected suite of environment, I can still heard the reviewer 2 among you raising your eyebrows about “mah toy datasets”.</p>

<p>Indeed we are still yet to see a fully incorporated architecture like this to “beat SoTA”, but there has been a lot of progress in each individual components.</p>

<h3 id="object-centric-representation">Object-centric representation</h3>
<p>A lot of progress in trying to learn unsupervised an object-centric representation of complex visual scene has taken place in the past few years. 
From the seminal work on image such as MONet <a href="#monet">[Burgess, 2018]</a>, Slot-Attention <a href="#slot">[Locatello et al., 2020]</a> toward more powerful model on video such as SIMONe <a href="#simone">[Kabra, 2021]</a> and SAVi <a href="#savi">[Kipf et al., 2021]</a>.</p>

<!-- ![SAVi](https://slot-attention-video.github.io/figures/teaser_video.mp4) -->
<!-- Figure 4. Slot Attention model for Video (SAVi) that can learn to segment and track object without labels. Figure adopted from [[Kipf et al]](#savi). -->

<h3 id="neural-reasoning">Neural Reasoning</h3>
<p>Alongside scaling pattern recognition side of neural network, there is also a lot of interest in extending neural network reasoning capability, mostly in the form of Graph Neural Network <a href="#relational">[Battaglia, 2018]</a>.
A notable effort in this space is term <em>Neural Algorithmic Reasoning</em> by <a href="#NAR">[Veličković, 2021]</a> in which traditional algorithms are being transformed into their differentiable counterparts.</p>

<h3 id="state-of-the-art-models-are-secretly-token-learners-and-manipulators">State of the Art models are secretly token learners and manipulators!?</h3>
<p>Even though I believe we won’t see this type of architecture be in the SOTA splotlight anytime soon, but if we squint our eyes enough, the current state of the art models are kind of already are?!</p>

<p>In 2022, we can not mention any SOTA without Transformers architecture <a href="#transformer">[Vaswani, 2017]</a>. Originally for text processing taking as input the language discrete tokens, we can see it as a purely token manipulator. Unsurprisingly, the transformers here also process a fully connected graph of its input tokens.</p>

<p>The Vision Transformer (VIT) <a href="#vit">[Dosovitsky, 2020]</a> which has challenged CNN on the image domain, its backyard, is the same transformer as token manipulator, but with a simple patch-based token parser.</p>

<p>Another example architecture that I liked the most are DETR <a href="#detr">[Carion, 2020]</a>, where the token parser is still a CNN to take advantage of locality structure of image, with a more complex token manipulator also based on Transformer to perform object detection.</p>

<h1 id="thoughts">Thoughts</h1>

<p>With all the astonishing result of scaling up deep learning model that still left a bitter taste in the mouth of many AI researchers <a href="#bitter">[Sutton, 2019]</a>, some can’t help but be repulsed when hear about adding more “structure” to the model.
While it might be possible that GPT-10 can internally represents and manipulates all the structures of the world in its massive vector space, I can’t help but wonder how much more inefficient it would take for not incorporating some sort of soft structures in the model itself.</p>

<p>From the perspective of a researcher whose job is to <em>inject inductive biases</em> into model, I believe the weak inductive bias presented in the architecture above will leave a sweet aftertaste, not just the bitterness.
After all, even if our GPT-10 overlord will need none of the “structureness”, I can only hope the token parser and manipulator above will help speeding up the research spiral between inductive biases and scaling, so that we can have a more advanced, and hopefully, benevolent AI faster.</p>

<p>Overall, given the simple components yet elegantly composed used in this paper, the C-SWM model really inspired and convinced me, and I hope now you too, that there are a lot more to come for the future of Deep Learning research.</p>

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

<p><a name="cswm"> Kipf, Thomas, Elise van der Pol, and Max Welling. “Contrastive Learning of Structured World Models.” International Conference on Learning Representations. 2019. </a></p>

<p><a name="binding"> Greff, Klaus, Sjoerd van Steenkiste, and Jürgen Schmidhuber. “On the binding problem in artificial neural networks.” arXiv preprint arXiv:2012.05208 (2020). </a></p>

<p><a name="OOR1"> Object-Oriented Learning (OOL): Perception, Representation, and Reasoning International Conference on Machine Learning (ICML) July 17, 2020, Virtual Workshop https://oolworkshop.github.io/ </a></p>

<p><a name="OOR2"> Object Representations for Learning and Reasoning Thirty-fourth Conference on Neural Information Processing Systems (NeurIPS) December 11, 2020, Virtual Workshop https://orlrworkshop.github.io </a></p>

<p><a name="monet"> Burgess, Christopher P., et al. “Monet: Unsupervised scene decomposition and representation.” arXiv preprint arXiv:1901.11390 (2019). </a></p>

<p><a name="simone"> Kabra, Rishabh, et al. “SIMONe: View-Invariant, Temporally-Abstracted Object Representations via Unsupervised Video Decomposition.” arXiv preprint arXiv:2106.03849 (2021). </a></p>

<p><a name="savi"> Kipf, Thomas, et al. “Conditional Object-Centric Learning from Video.” arXiv preprint arXiv:2111.12594 (2021). </a></p>

<p><a name="slot"> Locatello, Francesco, et al. “Object-centric learning with slot attention.” arXiv preprint arXiv:2006.15055 (2020). </a></p>

<p><a name="relational"> Battaglia, Peter W., et al. “Relational inductive biases, deep learning, and graph networks.” arXiv preprint arXiv:1806.01261 (2018). </a></p>

<p><a name="NAR"> Veličković, Petar, and Charles Blundell. “Neural Algorithmic Reasoning.” arXiv preprint arXiv:2105.02761 (2021). </a></p>

<p><a name="transformer"> Vaswani, Ashish, et al. “Attention is all you need.” Advances in neural information processing systems. 2017. </a></p>

<p><a name="vit"> Dosovitskiy, Alexey, et al. “An image is worth 16x16 words: Transformers for image recognition at scale.” arXiv preprint arXiv:2010.11929 (2020). </a></p>

<p><a name="detr"> Carion, Nicolas, et al. “End-to-end object detection with transformers.” European Conference on Computer Vision. Springer, Cham, 2020. </a></p>

<p><a name="bitter">Sutton, Rich. “The Bitter Lesson” March 13, 2019. http://incompleteideas.net/IncIdeas/BitterLesson.html</a></p>

<h2 id="footnotes">Footnotes</h2>
<div class="footnotes" role="doc-endnotes">
  <ol>
    <li id="fn:1" role="doc-endnote">
      <p>Spoiler alert, it’s 42! <a href="#fnref:1" class="reversefootnote" role="doc-backlink">&#8617;</a></p>
    </li>
    <li id="fn:2" role="doc-endnote">
      <p>“Object” in this paper (and the whole subfield of object-centric representation) is understand to be context-dependent, “you know it when you see it” kind of thing. Let’s not go down the philosophical rabbit hole of asking “What is an object?”. <a href="#fnref:2" class="reversefootnote" role="doc-backlink">&#8617;</a></p>
    </li>
  </ol>
</div>

</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/#representation"> representation </a>
  
    <a class="content-tag" href="/tags/#object"> object </a>
  
    <a class="content-tag" href="/tags/#symbolic"> symbolic </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/#representation"> representation </a>
  
    <a class="content-tag" href="/tags/#object"> object </a>
  
    <a class="content-tag" href="/tags/#symbolic"> symbolic </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>
