<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html lang="en">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>Listening to Sounds of Silence for Speech Denoising</title>

    <!-- CSS  -->
    <!-- Materialize -> Collapsible - https://materializecss.com/collapsible.html
    Example: https://www.javatpoint.com/materialize-css-collapsible -->
    <link href="css/materialize.min.css" type="text/css" rel="stylesheet" media="screen,projection" />
    <link href="css/style.css" type="text/css" rel="stylesheet" media="screen,projection" />
    <link rel="stylesheet" href="css/normalize.css">
    <link rel="stylesheet" href="css/skeleton.css">
    <style type="text/css">
      body,
      input,
      select,
      td,
      li,
      div,
      textarea,
      p {
        font-size: 14px;
        line-height: 16px;
        /* font-family: verdana, arial, sans-serif; */
      }

      p.description {
        text-indent: 2em;
        text-align: justify;
      }

      body {
        margin: 5px;
        background-color: white;
      }

      h1 {
        font-size: 30px;
        font-weight: bold;
        letter-spacing: .2rem;
      }

      h2 {
        font-size: 18px;
        font-weight: bold;
        /* letter-spacing: .1rem; */
      }

      table thead tr{
       display:block;
      }

      table  tbody{
        display:block;
        /* height:200px; */
        overflow:auto;
      }

      table th,table td {
        width:100%;
        /* display:block; */
        /* overflow:auto; */
      }

      table td {
        padding-top: 15px;
        padding-bottom: 15px;
      }

      th:nth-child(1) {
        width: 150px;
        /* background: #ddd; */
        padding:10px;
      }

      th {
        text-transform: uppercase;
      }

      td:nth-child(1) {
        width: 150px;
        /* background: #ddd; */
      }

      /* the second */
      th:nth-child(2) {
        /* width: 100px; */
        /* background: #ccc; */
        padding-left: 50px;
      }

      .icon {
        width: 24px;
        height: 24px;
        margin-right:10px;
        vertical-align:middle;
      }

      .icon-large {
        width: 40px;
        height: 40px;
        margin-right:15px;
        /* -webkit-filter: invert(1); */
        vertical-align:middle;
      }

      .descriptionblock {
        width: 70%;
        margin: auto;
      }

      .docs-header {
        text-transform: uppercase;
        /* font-size: 1.4rem; */
        letter-spacing: .2rem;
        font-weight: 600;
        cursor: pointer;
        position: relative;
        text-decoration: none;
      }

      a.underline {
        color: #000;
        text-transform: uppercase;
        text-decoration: none;
        letter-spacing: 0.15em;
        
        display: inline-block;
        padding: 10px 0px;
        position: relative;
      }

      a.underline:after {    
        background: none repeat scroll 0 0 transparent;
        bottom: 0;
        content: "";
        display: block;
        height: 2px;
        left: 50%;
        position: absolute;
        background: #000;
        transition: width 0.3s ease 0s, left 0.3s ease 0s;
        width: 0;
      }

      a.underline:hover:after { 
        width: 100%; 
        left: 0; 
      }

      .second-title {
        letter-spacing: .2rem;
        font-weight: 600;
        text-align: center;
        margin-top: 0px;
      }

      li {
        margin: none;
        padding: none;
      }

      .collapsible {
        width: 100%;
        margin: 0px;
      }

      .collapsible-header {
        height: 100%;
      }

      .box {
        margin: auto;
        /* color: #FFF; */
        background-color: #eee;
        border-color: #eee;
        border-radius: 8px;
        padding: 10px;
        cursor: pointer;
        min-height: 30px;
        min-width: 30px;
        /* resize: both; */
        /* overflow: auto; */
        max-height: fit-content;
        max-width: fit-content;
      }

      .box:hover {
        background-color: #f2f2f2;
      }

      .mod {
        color: red;
      }

    </style>

    <!--  Scripts-->
    <script src="js/jquery-2.1.1.min.js"></script>
    <!-- <script src="https://code.jquery.com/jquery-2.1.1.min.js"></script> -->
    <script src="js/materialize.min.js"></script>
    <!-- <script src = "https://cdnjs.cloudflare.com/ajax/libs/materialize/0.97.3/js/materialize.min.js"></script> -->
    <!-- <script src="js/init.js"></script> -->
    <script src="js/wavesurfer.min.js"></script>

    <!-- js helper functions -->
    <script>
      console.log = function() {}    // To disable all console.log() functions
    </script>
    <script>
      function getUniqueID(path) {
        res_id = path.slice(path.lastIndexOf('/')+1, path.lastIndexOf('.')).replace("-", "_");
        parname = path.slice(0, path.lastIndexOf('/'));
        data_id = parname.slice(parname.lastIndexOf('/')+1).replace("-", "_");
        parname = parname.slice(0, parname.lastIndexOf('/'));
        type_id = parname.slice(parname.lastIndexOf('/')+1).replace("-", "_");
        entry_id = type_id + "_" + data_id + "_" + res_id;
        return entry_id;
      }

      function addAudio(title, path, width = 100) {
        // add an audio player in html
        entry_id = getUniqueID(path);
        console.log("addAudio:" + entry_id);
        document.write('<tr><td><div style="padding: 10px 0px 10px 0px; text-align: center;">' + title + '</div>\
          <div style="padding: 15px 0px 5px 0px;"><input class="button-primary" type="button" id="btn-play-' + entry_id + '" value="▶‖" disabled="disabled"/>\
          <input type="button" id="btn-stop-' + entry_id + '" value="&#x2b1b;" disabled="disabled" /></div>\
          </td>');
        document.write('<td><div id="audio-spectrum-' + entry_id + '">\
            <audio id="song_' + entry_id + '" style="display: none;" preload="false" src="' + path + '"></audio>\
            <script src="' + path.replace(".mp3", ".js") + '"><\/script>\
              </div>');
        document.write('</td></tr>');
      }

      function addComparisonRow(title, path, width = 100) {
        // add a comparison row of a given result folder
        dirname = path.slice(path.lastIndexOf('/')+1);
        // console.log('Filename:', dirname);

        snr = dirname.slice(0, dirname.indexOf('_')).split('snr')[1];
        // console.log('SNR:', snr);

        name = dirname.slice(dirname.indexOf('_')+1, dirname.lastIndexOf('_'));
        // console.log('Name:', name);

        // active = snr==="10" ? "active" : "";
        active = ""
        // console.log('active:', active);

        document.write(
          "<li>\
            <div class=\"collapsible-header " + active + "\"><img class='icon' src='icons/icons8-audio-wave-90.png'>\
              <span style='font-family:Courier'>SNR (dB): " + snr.padEnd(3, "*").split("*").join("&nbsp;") + "\t｜\t" + title + "</span></div>\
              <div class=\"collapsible-body\">" +
              "<table><thead><tr><th>Results</th><th>Audio waveform</th></tr></thead><tbody>"
        );

        var titles = [
          "Noisy Sample",
          "Clean Sample",
          "Ours-GTSI",
          "Ours",
          "Spectral Gating",
          "Adobe Audition",
          "DFL",
          "SEGAN",
          "Baseline-thres",
          "VSE",
        ];

        var filenames = [
          "noisy_input.mp3",
          "ground_truth_clean_input.mp3",
          "denoised_output_OURS_GT.mp3",
          "denoised_output_OURS.mp3",
          "denoised_output_SPECGATING.mp3",
          "denoised_output_AUDITION.mp3",
          "denoised_output_DFL.mp3",
          "denoised_output_SEGAN.mp3",
          "denoised_output_THRES.mp3",
          "denoised_output_VSE.mp3",
        ];

        var allpaths = [];

        for (var i = 0; i < filenames.length; i++) {
          filepath = path + "/" + filenames[i];
          addAudio(titles[i], filepath, width);
          allpaths.push(filepath);
        }

        document.write("</tbody></table></div></li>");
        return allpaths;
      }

      function addRealComparisonRow(title, path, vse = true, width = 100) {
        // add a comparison row of a given result folder

        example_name = path.slice(path.lastIndexOf('/')+1);
        // console.log('Filename:', dirname);

        name = example_name.slice(0, example_name.lastIndexOf('_'));
        // console.log('Name:', name);

        document.write(
          "<li>\
            <div class=\"collapsible-header\"><span style='font-family:Courier'>" + title + "</span></div>\
            <div class=\"collapsible-body\">" +
            "<table><thead><tr><th>Results</th><th>Audio waveform</th></tr></thead><tbody>"
        );

        var titles = [
          "Noisy Sample",
          "Ours",
          "Spectral Gating",
          "Adobe Audition",
          "DFL",
          "SEGAN",
          "Baseline-thres",
          "VSE",
        ];
        if (!vse) {
          titles.splice(-1,1);
          // console.log(titles);
        }

        var filenames = [
          "noisy_input.mp3",
          "denoised_output_ours.mp3",
          "denoised_output_specgating.mp3",
          "denoised_output_audition.mp3",
          "denoised_output_dfl.mp3",
          "denoised_output_segan.mp3",
          "denoised_output_thres.mp3",
          "denoised_output_vse.mp3",
        ];
        if (!vse) {
          filenames.splice(-1,1);
          // console.log(filenames);
        }

        var allpaths = [];

        for (var i = 0; i < filenames.length; i++) {
          filepath = path + "/" + filenames[i];
          addAudio(titles[i], filepath, width);
          allpaths.push(filepath);
        }

        document.write("</tbody></table></div></li>");
        return allpaths;
      }

      function addLanguageRow(title, path, width = 100) {
        dirname = path.slice(0, path.lastIndexOf('/'));
        pardirname = dirname.slice(0, dirname.lastIndexOf('/'));

        example_name = path.slice(path.lastIndexOf('/')+1);
        // console.log('Filename:', dirname);

        name = example_name.slice(0, example_name.lastIndexOf('_'));
        // console.log('Name:', name);

        title_split_list = title.split(">")
        htmltitle = title_split_list[0];
        texttitle = title_split_list[1];
        // texttitle_split_list = texttitle.split("｜")
        // texttitle_1 = texttitle_split_list[0]
        // texttitle_2 = texttitle_split_list[1]
        title_new = htmltitle + "><span style='font-family:Courier'>" + texttitle
        document.write(
          "<li>\
            <div class=\"collapsible-header\">" + title_new + "</div>\
            <div class=\"collapsible-body\">" +
            "<table><thead><tr><th>Results</th><th>Audio waveform</th></tr></thead><tbody>"
        );

        var titles = [
          "Noisy Sample",
          "Denoised Result",
          "Silent Intervals",
          // "Estimated Noise",
        ];

        var filenames = [
          "noisy_input.mp3",
          "denoised_output.mp3",
          "noise_intervals.mp3",
          // "predicted_full_noise.mp3",
        ];

        var allpaths = [];

        for (var i = 0; i < filenames.length; i++) {
          addAudio(titles[i], path + "/" + filenames[i], width);
          allpaths.push(path + "/" + filenames[i]);
        }

        document.write("</tbody></table></div></li>");
        return allpaths;
      }

      function addSOSRow(title, path, width = 100) {
        dirname = path.slice(0, path.lastIndexOf('/'));
        pardirname = dirname.slice(0, dirname.lastIndexOf('/'));

        example_name = path.slice(path.lastIndexOf('/')+1);
        // console.log('Filename:', dirname);

        name = example_name.slice(0, example_name.lastIndexOf('_'));
        // console.log('Name:', name);

        // texttitle_split_list = title.split("｜")
        // texttitle_1 = texttitle_split_list[0]
        // texttitle_2 = texttitle_split_list[1]
        // title_new = texttitle_1 + "</span>&nbsp;\t｜\t" + texttitle_2
        document.write(
          "<li>\
            <div class=\"collapsible-header\"><img class='icon' src='icons/icons8-guitar-90.png'><span style='font-family:Courier'>" + title + "</span></div>\
            <div class=\"collapsible-body\">" +
            "<table><thead><tr><th>Results</th><th>Audio waveform</th></tr></thead><tbody>"
        );

        var titles = [
          "Song Excerpt",
          "Denoised Result",
          "Silent Intervals",
          // "Estimated Noise",
        ];

        var filenames = [
          "noisy_input.mp3",
          "denoised_output.mp3",
          "noise_intervals.mp3",
          // "predicted_full_noise.mp3",
        ];

        var allpaths = [];

        for (var i = 0; i < filenames.length; i++) {
          addAudio(titles[i], path + "/" + filenames[i], width);
          allpaths.push(path + "/" + filenames[i]);
        }

        document.write("</tbody></table></div></li>");
        return allpaths;
      }

      function create_wavesurfer(path) {
        entry_id = getUniqueID(path);
        console.log("wavesurfer: " + entry_id);

        // Store the 3 buttons in some object
        var buttons = {
            play: document.getElementById("btn-play-" + entry_id),
            stop: document.getElementById("btn-stop-" + entry_id)
        };

        // Create an instance of wave surfer with its configuration
        var Spectrum = WaveSurfer.create({
            container: '#audio-spectrum-' + entry_id,
            // progressColor: "rgba(60, 145, 230, 1)",
            progressColor: "#1EAEDB",
            waveColor: "#ced4da",
            // waveColor: "#ddd",
            backend: "MediaElement",
            mediaType: "audio",
            // cursorColor: "#212529",
            // cursorColor: "#1EAEDB",
            // cursorColor: "#fff",
            cursorColor: "#ced4da",
            cursorWidth: 1,
            normalize: true,
            barWidth: 3,
            // minPxPerSec: 10
        });

        // Handle Play button
        buttons.play.addEventListener("click", function(){
            if (Spectrum.backend.isPaused()) {
              // Get the current progress according to the cursor position
              var currentProgress = Spectrum.getCurrentTime() / Spectrum.getDuration();

              // Reset graph
              Spectrum.empty();
              Spectrum.drawBuffer();
              // Set original position
              Spectrum.seekTo(currentProgress);

              Spectrum.play();

              // Enable/Disable respectively buttons
              buttons.stop.disabled = false;
              buttons.play.disabled = false;
              // buttons.play.value = "Pause";
            }
            else {
              Spectrum.pause();

              // Enable/Disable respectively buttons
              buttons.play.disabled = false;
              // buttons.play.value = "Play";
            }
        }, false);

        // Handle Stop button
        buttons.stop.addEventListener("click", function(){
            Spectrum.stop();

            // Enable/Disable respectively buttons
            buttons.play.disabled = false;
            buttons.stop.disabled = true;
            // buttons.play.value = "Play";
        }, false);


        // Add a listener to enable the play button once it's ready
        Spectrum.on('ready', function () {
            buttons.play.disabled = false;
            // Spectrum.empty();
            // Spectrum.drawBuffer();
            // Spectrum.seekTo(0);
            // console.log('ready');
        });

        $('.collapsible').click(function() {
            // alert('here?');
            // Spectrum.empty();
            Spectrum.drawBuffer();
        });
        
        // If you want a responsive mode (so when the user resizes the window)
        // the spectrum will be still playable
        window.addEventListener("resize", function(){
            // Get the current progress according to the cursor position
            var currentProgress = Spectrum.getCurrentTime() / Spectrum.getDuration();

            // Reset graph
            Spectrum.empty();
            Spectrum.drawBuffer();
            // Set original position
            Spectrum.seekTo(currentProgress);

            // Enable/Disable respectively buttons
            // buttons.pause.disabled = true;
            buttons.play.disabled = false;
            buttons.stop.disabled = false;
        }, false);

        // console.log(document.querySelector("#song"));
        // console.log(eval("data"));
        Spectrum.load(document.querySelector("#song_" + entry_id), eval("data_" + entry_id), preload="metadata");
      }
    </script>

  </head>
  <body>
    <h1 align="center">Listening to Sounds of Silence for Speech Denoising</h1>
    <h2 class="second-title"><i>Supplementary Material</i></h2>
    
    <!-- overview -->
    <div class="descriptionblock">
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Overview</a></h2>
      <p class="description">This offline webpage organizes our speech denoising results.
      We first show the
      comparison results on <tt>AudioSet</tt> dataset, <tt>DEMAND</tt> dataset and real-world
      audio recordings. 
      When demonstrating with real-world recordings, we also include
      scenarios in which audiovisual denoising would fail because of the lack of frontal faces
      in video footage as well as scenarios in which multiple speakers present.
      Both are common in daily life.
      We then present examples of our denoising results in other
      languages, which are all resulted from our model trained solely in English. 
      Lastly, we show two clips from the song "The Sound of
      Silence", as an echo of our title, to further demonstrate our model's ability to 
      reduce non-stationary noise like music.</p>
      <div class="box" style="width:600px; margin-top:40px;" onclick="$('html,body').animate({scrollTop: $('#audioset_header').offset().top-20}, 1000);">
        <!-- <img class='icon-large' src="icons/icons8-natural-user-interface-2-90.png" > -->
        <img class='icon-large' src="icons/icons8-natural-user-interface-2-100.png" >
        <span style="font-size: 16px;">Please click each item below to see and hear individual audio results.</span>
      </div>
    </div>

    <!-- audioset test results -->
    <div class="descriptionblock">
      <!-- <h2 class="docs-header">1. Comparison results on Audioset test data</h2> -->
      <h2 class="docs-header" id="audioset_header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Synthetic data:&nbsp;&nbsp;AVSPEECH + Audioset</a></h2>
      <p class="description">Here we show denoising results on 
      synthetic input signals.
      The input signals are generated using audio clips in
      <tt>AVSPEECH</tt> as foreground speech and 
      in <tt>AudioSet</tt> as background noise.
      With seven different input SNRs (from -10dB to 10dB),
      we compare the denoising results of our model with other methods. 
      </p>
      <p class="description">
      Please note that here the <tt>Ours-GTSI</tt> method uses ground-truth silent interval
      labels. It is by no means a practical approach. Rather, it is meant to 
      show the best possible (upper-bound) denoising quality when the silent intervals are perfectly 
      predicted.
      </p>
    </div>
    <div class="container" id="audioset">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Nadia Lopez",
                "asset/audioset-test/snr10_3bj-ba3P_cU_0000004"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Anand Varma",
                "asset/audioset-test/snr7_6-tqiaPoS2U_0000007"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: George Monbiot",
                "asset/audioset-test/snr3_8rZzHkpyPkc_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Jennifer Senior",
                "asset/audioset-test/snr0_DOgsYATbV-s_0000002"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Nancy Lublin",
                "asset/audioset-test/snr-3_KOtFDsC8JC0_0000003"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Shivani Siroya",
                "asset/audioset-test/snr-7_kSR8G8mfp84_0000009"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Nathalie Cabrol",
                // "asset/audioset-test/snr-10_sW9sr2_Z5kk_0000013"
                "asset/audioset-test/snr-10_wxCtIdI3xL0_0000003"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- DEMAND test results -->
    <div class="descriptionblock">
      <!-- <h2 align="center">2. Comparison results on DEMAND test data</h2> -->
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Synthetic data:&nbsp;&nbsp;AVSPEECH + DEMAND</a></h2>
      <p class="description">Here we provide comparison results 
      similar to the previous section.
      Instead of using <tt>AudioSet</tt> data as background noise,
      here we use <tt>DEMAND</tt>, another dataset used in previous denoising works, 
      as the source of background noise. All other setups are the same as in the previous section.
      </p>
    </div>
    <div class="container" id="demand">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Aomawa Shields",
                "asset/demand-test/snr10_yBdyFKqwKy0_0000020"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Nathalie Cabrol",
                "asset/demand-test/snr7_wxCtIdI3xL0_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Leah Buechley",
                "asset/demand-test/snr3_vTBp0Z5GPeI_0000006"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Abe Davis",
                "asset/demand-test/snr0_npNYP2vzaPo_0000011"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Del Harvey",
                "asset/demand-test/snr-3_mAvSoNUgMno_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Manuel Lima",
                // "asset/demand-test/snr-7_ltelQ3iKybU_0000012"
                "asset/demand-test/snr-7_BQZKs75RMqM_0000005"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addComparisonRow("Speaker: Oded Shoseyov",
                // "asset/demand-test/snr-10_CtvIX4s1bTU_0000010"
                "asset/demand-test/snr-10_lAzQWtkPzbI_0000002"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- Real-world results -->
    <div class="descriptionblock">
      <!-- <h2 align="center">3. Comparison results on real world data</h2> -->
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Real world data</a></h2>
      <p class="description">Here we provide denoising results on 
      real-world recordings, in comparison to other methods. 
      These examples are recorded in video with a single person
      from the front-facing view. 
      Only the (mono-channel) audio signals in the recordings 
      are provided to the denoising methods except for <tt>VSE</tt>,
      which requires audiovisual input (i.e., video footage is also provided as input).
      </p>
    </div>
    <div class="container" id="realworld">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <!-- <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Bill Freeman", 
                "asset/real-world/bill_freeman_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script> -->

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-voice-96.png'>\
              Speaker: Male Speaker", 
                "asset/real-world/henrique_cafe_less_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-voice-96.png'>\
              Speaker: Male Speaker", 
                "asset/real-world/henrique_campus_less_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-voice-96.png'>\
              Speaker: Male Speaker", 
                "asset/real-world/henrique_lab_less_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <!-- <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Female Interviewee", 
                "asset/real-world/face_mask_39_45_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Female Interviewee", 
                "asset/real-world/face_mask_56_104_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Female Interviewee", 
                "asset/real-world/face_mask_112_118_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Mickeyworkstv", 
                "asset/real-world/chinese_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Yusuke Furugen", 
                "asset/real-world/japanese_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Hera Jiwon", 
                "asset/real-world/korean_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script> -->

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-voice-96.png'>\
              Speaker: Dana Newman", 
                "asset/real-world/german_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <!-- <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Sliceofmatt", 
                "asset/real-world/french_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("Speaker: Veronica Montano", 
                "asset/real-world/spanish_1_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script> -->

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-voice-96.png'>\
              Speaker: Veronica Montano", 
                "asset/real-world/spanish_2_0000001"
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- VSE failed results -->
    <div class="descriptionblock">
      <!-- <h2 align="center">5. Comparison results on real world data ("Visual Speech Enhancement" method failure cases) </h2> -->
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Real world data:&nbsp;&nbsp;Audiovisual failed</a></h2>
      <p class="description">Here we present more denoising results on
      real-world recordings. Unlike those presented above,
      the examples here all have human faces either blocked (e.g., by facial masks during the COVID-19 pandemic)
      or excluded from the camera's field of view.
      As a result, the audiovisual method (i.e., <tt>VSE</tt>) becomes not applicable,
      and our experiments show that <tt>VSE</tt> fails in these cases. We therefore exclude it from 
      the compared methods.
      </p>
    </div>
    <div class="container" id="realworld">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Female Interviewee", 
                "asset/real-world/face_mask_39_45_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Female Interviewee", 
                "asset/real-world/face_mask_56_104_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Female Interviewee", 
                "asset/real-world/face_mask_112_118_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Mickeyworkstv", 
                "asset/real-world/chinese_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Yusuke Furugen", 
                "asset/real-world/japanese_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Hera Jiwon", 
                "asset/real-world/korean_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Sliceofmatt", 
                "asset/real-world/french_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-protection-mask-100.png'>\
              Speaker: Veronica Montano", 
                "asset/real-world/spanish_1_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- Multiple people results -->
    <div class="descriptionblock">
      <!-- <h2 align="center">4. Comparison results on real world data (multiple people)</h2> -->
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Real world data:&nbsp;&nbsp;multi-person</a></h2>
      <p class="description">Here we show denoising results on real-world recordings in which 
      multiple people speak. Our method is able to 
      suppress background noise while retaining the voices of all speakers.
      </p>
    </div>
    <div class="container" id="realworld">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-group-task-filled-100.png'>\
              Multiple speakers: Richard Hammond & wife", 
                "asset/real-world/richard_hammond_029_050_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-group-task-filled-100.png'>\
              Multiple speakers: Richard Hammond & wife", 
                "asset/real-world/richard_hammond_115_128_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-group-task-filled-100.png'>\
              Multiple speakers: Richard Hammond & wife", 
                "asset/real-world/richard_hammond_308_328_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addRealComparisonRow("<img class='icon' src='icons/icons8-group-task-filled-100.png'>\
              Multiple speakers: A street interview", 
                "asset/real-world/street_interview_0000001", false
              );
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- results on other languages -->
    <div class="descriptionblock">
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">Other languages</a></h2>
      <p class="description">Here we show our denoising results on speeches
      in other languages. 
      The silent interval detection results are also presented.
      In these examples, our model is trained with speeches <em>only in English</em>, the same as that used in previous examples.
      No additional training is conducted.
      </p>
    </div>
    <div class="container" id="languages">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-china-80.png'>\
              " + 'Chinese'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Mickeyworkstv", "asset/languages/chinese_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-japan-80.png'>\
              " + 'Japanese'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Yusuke Furugen", "asset/languages/japanese_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-south-korea-80.png'>\
              " + 'Korean'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Hera Jiwon", "asset/languages/korean_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-germany-80.png'>\
              " + 'German'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Dana Newman", "asset/languages/german_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-france-80.png'>\
              " + 'French'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Sliceofmatt", "asset/languages/french_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-spain-flag-80.png'>\
              " + 'Spanish'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Veronica Montano", "asset/languages/spanish_1_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addLanguageRow("<img class='icon' src='icons/icons8-spain-flag-80.png'>\
              " + 'Spanish'.padEnd(8, "*").split("*").join("&nbsp;") + " \t｜\t Speaker: Veronica Montano", "asset/languages/spanish_2_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

    <!-- sound of silence results -->
    <div class="descriptionblock">
      <!-- <h2 align="center">7. Song "The Sound of Silence"</h2> -->
      <h2 class="docs-header" onclick="$('html,body').animate({scrollTop: $(this).offset().top-20}, 1000);"><a class="underline">"The Sound of Silence"</a></h2>
      <p class="description">Lastly, listen to "The Sound of Silence" processed by our method that listens to the sounds of silence!</p>
    </div>
    <div class="container" id="sos">
      <!-- <div class="row">
        <div class="col s12 m12 l12"> -->
          <ul class="collapsible ">
            <!-- add each row here -->
            <script type="text/javascript">
              all_filepaths = addSOSRow("Excerpt 1 \t｜\t Singer: Simon & Garfunkel", "asset/sounds_of_silence/sos_1_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>

            <script type="text/javascript">
              all_filepaths = addSOSRow("Excerpt 2 \t｜\t Singer: Simon & Garfunkel", "asset/sounds_of_silence/sos_2_0000001");
            </script>
            <script type="text/javascript">
              for (i = 0; i < all_filepaths.length; i++){
                create_wavesurfer(all_filepaths[i]);
              }
            </script>
          </ul>
        <!-- </div>
      </div> -->
    </div>

  </body>
</html>
