changeset 14:3f0dd362b755 draft

"planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/tools/meme commit 86a94f48321780dbe18ef5b099434c347ec2f4d0"
author iuc
date Wed, 11 Dec 2019 18:05:15 -0500
parents 57e5d9382f36
children 9dd5373f6a5a
files macros.xml meme.xml test-data/dreme_output_test1.html test-data/dreme_output_test1.txt test-data/dreme_output_test1.xml test-data/dreme_output_test2.html test-data/dreme_output_test2.txt test-data/dreme_output_test2.xml test-data/fimo_output_test1.gff test-data/fimo_output_test1.html test-data/fimo_output_test1.txt test-data/fimo_output_test1.xml test-data/fimo_output_test2.gff test-data/fimo_output_test2.html test-data/fimo_output_test2.txt test-data/fimo_output_test2.xml test-data/fimo_output_test3.html test-data/fimo_output_test3.txt test-data/fimo_output_test3.xml test-data/meme_output_test1.html test-data/meme_output_test1.txt test-data/meme_output_test1.xml test-data/meme_output_test2.html test-data/meme_output_test2.txt test-data/meme_output_test2.xml
diffstat 25 files changed, 143 insertions(+), 37468 deletions(-) [+]
line wrap: on
line diff
--- a/macros.xml	Thu May 17 14:10:48 2018 -0400
+++ b/macros.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,10 +1,9 @@
 <?xml version='1.0' encoding='UTF-8'?>
 <macros>
-    <token name="@WRAPPER_VERSION@">4.12.0</token>
+    <token name="@WRAPPER_VERSION@">5.0.5</token>
     <xml name="requirements">
         <requirements>
-            <requirement type="package" version="1.3.23">graphicsmagick</requirement>
-            <requirement type="package" version="4.12.0">meme</requirement>
+            <requirement type="package" version="5.0.5">meme</requirement>
             <yield/>
         </requirements>
     </xml>
--- a/meme.xml	Thu May 17 14:10:48 2018 -0400
+++ b/meme.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -280,18 +280,18 @@
             <param name="input1" value="meme_input_1.fasta" ftype="fasta" dbkey="hg19"/>
             <param name="options_type_selector" value="basic"/>
             <param name="non_commercial_use" value="True"/>
-            <output name="html_outfile" file="meme_output_test1.html" lines_diff="20"/>
-            <output name="txt_outfile" file="meme_output_test1.txt" lines_diff="12"/>
-            <output name="xml_outfile" file="meme_output_test1.xml" lines_diff="8"/>
+            <output name="html_outfile" file="meme_output_test1.html" compare="contains"/>
+            <output name="txt_outfile" file="meme_output_test1.txt" compare="contains"/>
+            <output name="xml_outfile" file="meme_output_test1.xml" compare="contains"/>
         </test>
         <test>
             <param name="input1" value="meme_input_1.fasta" ftype="fasta" dbkey="hg19"/>
             <param name="options_type_selector" value="advanced"/>
             <param name="plib" value="prior30.plib" ftype="txt"/>
             <param name="non_commercial_use" value="True"/>
-            <output name="html_outfile" file="meme_output_test2.html" lines_diff="20"/>
-            <output name="txt_outfile" file="meme_output_test2.txt" lines_diff="12"/>
-            <output name="xml_outfile" file="meme_output_test2.xml" lines_diff="8"/>
+            <output name="html_outfile" file="meme_output_test2.html" compare="contains"/>
+            <output name="txt_outfile" file="meme_output_test2.txt" compare="contains"/>
+            <output name="xml_outfile" file="meme_output_test2.xml" compare="contains"/>
         </test>
     </tests>
     <help>
--- a/test-data/dreme_output_test1.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test1.html	Wed Dec 11 18:05:15 2019 -0500
@@ -7,10 +7,9 @@
       // @JSON_VAR data
       var data = {
         "program": "dreme",
-        "version": "4.12.0",
-        "release": "Tue Jun 27 16:22:50 2017 -0700",
+        "version": "5.0.5",
         "cmd": [
-          "dreme", "-o", "./dreme_test1_out", "-p", "dreme_test_sites.fa",
+          "dreme", "-o", "./dreme_out", "-p",
           "-norc", "-rna", "-s", "1"
         ],
         "options": {
@@ -20,95 +19,19 @@
           "seed": 1,
           "stop": {
             "evalue": "0.05"
-          }
-        },
         "alphabet": {
           "name": "RNA",
           "like": "rna",
           "ncore": 4,
           "symbols": [
-            {
-              "symbol": "A",
-              "name": "Adenine",
-              "colour": "CC0000"
-            }, {
-              "symbol": "C",
-              "name": "Cytosine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "G",
-              "name": "Guanine",
-              "colour": "FFB300"
-            }, {
-              "symbol": "U",
-              "aliases": "T",
-              "name": "Uracil",
-              "colour": "008000"
-            }, {
-              "symbol": "N",
-              "aliases": "X.",
-              "name": "Any base",
-              "equals": "ACGU"
-            }, {
-              "symbol": "V",
-              "name": "Not U",
-              "equals": "ACG"
-            }, {
-              "symbol": "H",
-              "name": "Not G",
-              "equals": "ACU"
-            }, {
-              "symbol": "D",
-              "name": "Not C",
-              "equals": "AGU"
-            }, {
-              "symbol": "B",
-              "name": "Not A",
-              "equals": "CGU"
-            }, {
-              "symbol": "M",
-              "name": "Amino",
-              "equals": "AC"
-            }, {
-              "symbol": "R",
-              "name": "Purine",
-              "equals": "AG"
-            }, {
-              "symbol": "W",
-              "name": "Weak",
-              "equals": "AU"
-            }, {
-              "symbol": "S",
-              "name": "Strong",
-              "equals": "CG"
-            }, {
-              "symbol": "Y",
-              "name": "Pyrimidine",
-              "equals": "CU"
-            }, {
-              "symbol": "K",
-              "name": "Keto",
-              "equals": "GU"
-            }
-          ]
-        },
         "background": {
           "freqs": [0.221, 0.245, 0.221, 0.312]
-        },
-        "sequence_db": {
-          "name": "dreme test sites",
-          "file": "dreme_test_sites.fa",
-          "lmod": "Thu Apr 26 15:09:03 CEST 2018",
-          "count": 1000
-        },
         "control_db": {
           "name": "shuffled positive sequences",
           "from": "shuffled",
           "count": 1000,
           "freqs": [0.221, 0.245, 0.221, 0.312]
-        },
         "motifs": [
-          {
             "db": 0,
             "id": "UUYUCY",
             "alt": "DREME-1",
@@ -126,9 +49,7 @@
               [0.000000, 0.000000, 0.000000, 1.000000], 
               [0.000000, 1.000000, 0.000000, 0.000000], 
               [0.000000, 0.474946, 0.000000, 0.525054]
-            ],
             "matches": [
-              {
                 "seq": "UUUUCC",
                 "p": 147,
                 "n": 75,
@@ -140,6059 +61,53 @@
                 "n": 94,
                 "pvalue": "2.2e-005",
                 "evalue": "1.0e+000"
-              }, {
                 "seq": "UUCUCU",
                 "p": 94,
                 "n": 51,
                 "pvalue": "1.3e-004",
                 "evalue": "6.1e+000"
-              }, {
                 "seq": "UUCUCC",
                 "p": 75,
                 "n": 42,
                 "pvalue": "1.1e-003",
                 "evalue": "5.0e+001"
-              }
-            ]
-          }, {
-            "db": 0,
-            "id": "YAGG",
-            "alt": "DREME-2",
-            "len": 4,
-            "nsites": 793,
-            "evalue": "5.1e-012",
-            "p": 600,
-            "n": 416,
-            "pvalue": "1.1e-016",
-            "unerased_evalue": "2.4e-012",
-            "pwm": [
-              [0.000000, 0.692308, 0.000000, 0.307692], 
-              [1.000000, 0.000000, 0.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000]
-            ],
-            "matches": [
-              {
-                "seq": "CAGG",
-                "p": 441,
-                "n": 304,
-                "pvalue": "1.5e-010",
-                "evalue": "6.6e-006"
-              }, {
-                "seq": "UAGG",
-                "p": 232,
-                "n": 165,
-                "pvalue": "1.1e-004",
-                "evalue": "4.7e+000"
-              }
-            ]
-          }, {
-            "db": 0,
-            "id": "GAAGAW",
-            "alt": "DREME-3",
-            "len": 6,
-            "nsites": 89,
-            "evalue": "3.4e-005",
-            "p": 81,
-            "n": 22,
-            "pvalue": "8.2e-010",
-            "unerased_evalue": "3.5e-004",
-            "pwm": [
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [1.000000, 0.000000, 0.000000, 0.000000], 
-              [1.000000, 0.000000, 0.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [1.000000, 0.000000, 0.000000, 0.000000], 
-              [0.494382, 0.000000, 0.000000, 0.505618]
-            ],
-            "matches": [
-              {
-                "seq": "GAAGAU",
-                "p": 45,
-                "n": 7,
-                "pvalue": "2.4e-008",
-                "evalue": "9.9e-004"
-              }, {
-                "seq": "GAAGAA",
-                "p": 40,
-                "n": 16,
-                "pvalue": "7.9e-004",
-                "evalue": "3.3e+001"
-              }
-            ]
-          }, {
-            "db": 0,
-            "id": "SMUGGA",
-            "alt": "DREME-4",
-            "len": 6,
-            "nsites": 119,
-            "evalue": "3.7e-003",
-            "p": 110,
-            "n": 47,
-            "pvalue": "9.1e-008",
-            "unerased_evalue": "2.6e-005",
-            "pwm": [
-              [0.000000, 0.529412, 0.470588, 0.000000], 
-              [0.428571, 0.571429, 0.000000, 0.000000], 
-              [0.000000, 0.000000, 0.000000, 1.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [1.000000, 0.000000, 0.000000, 0.000000]
-            ],
-            "matches": [
-              {
-                "seq": "GAUGGA",
-                "p": 22,
-                "n": 6,
-                "pvalue": "1.7e-003",
-                "evalue": "7.1e+001"
-              }, {
-                "seq": "GCUGGA",
-                "p": 33,
-                "n": 14,
-                "pvalue": "3.6e-003",
-                "evalue": "1.5e+002"
-              }, {
-                "seq": "CCUGGA",
-                "p": 32,
-                "n": 15,
-                "pvalue": "8.6e-003",
-                "evalue": "3.5e+002"
-              }, {
-                "seq": "CAUGGA",
-                "p": 29,
-                "n": 13,
-                "pvalue": "9.1e-003",
-                "evalue": "3.7e+002"
-              }
-            ]
-          }
-        ],
-        "runtime": {
-          "host": "ThinkPad-T450s",
-          "when": "Thu May 03 13:22:29 CEST 2018",
-          "cpu": 13.95,
-          "real": 13.95,
-          "stop": "evalue"
-        }
-      };
-    </script>
     <script>
 var site_url = "http://meme-suite.org";
 </script>
-    <script>
-
-/*
- * $
- *
- * Shorthand function for getElementById
- */
-function $(el) {
-  return document.getElementById(el);
-}
-
-
-/*
- * See http://stackoverflow.com/a/5450113/66387
- * Does string multiplication like the perl x operator.
- */
-function string_mult(pattern, count) {
-    if (count < 1) return '';
-    var result = '';
-    while (count > 1) {
-        if (count & 1) result += pattern;
-        count >>= 1, pattern += pattern;
-    }
-    return result + pattern;
-}
-
-/*
- * See http://stackoverflow.com/questions/814613/how-to-read-get-data-from-a-url-using-javascript
- * Slightly modified with information from
- * https://developer.mozilla.org/en/DOM/window.location
- */
-function parse_params() {
-  "use strict";
-  var search, queryStart, queryEnd, query, params, nvPairs, i, nv, n, v;
-  search = window.location.search;
-  queryStart = search.indexOf("?") + 1;
-  queryEnd   = search.indexOf("#") + 1 || search.length + 1;
-  query      = search.slice(queryStart, queryEnd - 1);
-
-  if (query === search || query === "") return {};
-
-  params  = {};
-  nvPairs = query.replace(/\+/g, " ").split("&");
-
-  for (i = 0; i < nvPairs.length; i++) {
-    nv = nvPairs[i].split("=");
-    n  = decodeURIComponent(nv[0]);
-    v  = decodeURIComponent(nv[1]);
-    // allow a name to be used multiple times
-    // storing each value in the array
-    if (!(n in params)) {
-      params[n] = [];
-    }
-    params[n].push(nv.length === 2 ? v : null);
-  }
-  return params;
-}
-
-/*
- * coords
- *
- * Calculates the x and y offset of an element.
- * From http://www.quirksmode.org/js/findpos.html
- * with alterations to take into account scrolling regions
- */
-function coords(elem) {
-  var myX = myY = 0;
-  if (elem.getBoundingClientRect) {
-    var rect;
-    rect = elem.getBoundingClientRect();
-    myX = rect.left + ((typeof window.pageXOffset !== "undefined") ?
-        window.pageXOffset : document.body.scrollLeft);
-    myY = rect.top + ((typeof window.pageYOffset !== "undefined") ?
-        window.pageYOffset : document.body.scrollTop);
-  } else {
-    // this fall back doesn't properly handle absolutely positioned elements
-    // inside a scrollable box
-    var node;
-    if (elem.offsetParent) {
-      // subtract all scrolling
-      node = elem;
-      do {
-        myX -= node.scrollLeft ? node.scrollLeft : 0;
-        myY -= node.scrollTop ? node.scrollTop : 0;
-      } while (node = node.parentNode);
-      // this will include the page scrolling (which is unwanted) so add it back on
-      myX += (typeof window.pageXOffset !== "undefined") ? window.pageXOffset : document.body.scrollLeft;
-      myY += (typeof window.pageYOffset !== "undefined") ? window.pageYOffset : document.body.scrollTop;
-      // sum up offsets
-      node = elem;
-      do {
-        myX += node.offsetLeft;
-        myY += node.offsetTop;
-      } while (node = node.offsetParent);
-    }
-  }
-  return [myX, myY];
-}
-
-/*
- * position_popup
- *
- * Positions a popup relative to an anchor element.
- *
- * The avaliable positions are:
- * 0 - Centered below the anchor.
- */
-function position_popup(anchor, popup, position) {
-  "use strict";
-  var a_x, a_y, a_w, a_h, p_x, p_y, p_w, p_h;
-  var a_xy, spacer, margin, scrollbar, page_w;
-  // define constants
-  spacer = 5;
-  margin = 15;
-  scrollbar = 15;
-  // define the positions and widths
-  a_xy = coords(anchor);
-  a_x = a_xy[0];
-  a_y = a_xy[1];
-  a_w = anchor.offsetWidth;
-  a_h = anchor.offsetHeight;
-  p_w = popup.offsetWidth;
-  p_h = popup.offsetHeight;
-  page_w = null;
-  if (window.innerWidth) {
-    page_w = window.innerWidth;
-  } else if (document.body) {
-    page_w = document.body.clientWidth;
-  }
-  // check the position type is defined
-  if (typeof position !== "number") {
-    position = 0;
-  }
-  // calculate the popup position
-  switch (position) {
-    case 1:
-      p_x = a_x + a_w + spacer;
-      p_y = a_y + (a_h / 2) - (p_h / 2);
-      break;
-    case 0:
-    default:
-      p_x = a_x + (a_w / 2) - (p_w / 2);
-      p_y = a_y + a_h + spacer;
-      break;
-  }
-  // constrain the popup position
-  if (p_x < margin) {
-    p_x = margin;
-  } else if (page_w != null && (p_x + p_w) > (page_w - margin - scrollbar)) {
-    p_x = page_w - margin - scrollbar - p_w;
-  }
-  if (p_y < margin) {
-    p_y = margin;
-  }
-  // position the popup
-  popup.style.left = p_x + "px";
-  popup.style.top = p_y + "px";
-}
-
-function lookup_help_popup(popup_id) {
-  var _body, pop, info;
-  pop = document.getElementById(popup_id);
-  if (pop == null) {
-    _body = document.getElementsByTagName("body")[0];
-    pop = document.createElement("div");
-    pop.className = "pop_content";
-    pop.id = popup_id;
-    pop.style.backgroundColor = "#FFC";
-    pop.style.borderColor = "black";
-    info = document.createElement("p");
-    info.style.fontWeight = "bold";
-    info.appendChild(document.createTextNode("Error: No popup for topic \"" + popup_id + "\"."));
-    pop.appendChild(info);
-    // this might cause problems with the menu, but as this only happens
-    // when something is already wrong I don't think that's too much of a problem
-    _body.insertBefore(pop, _body.firstChild);
-  }
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-autobtns")) {
-    if (!/\bauto_buttons\b/.test(pop.className)) {
-      pop.className += " auto_buttons";
-      var back_btn_sec = document.createElement("div");
-      back_btn_sec.className = "nested_only pop_back_sec";
-      var back_btn = document.createElement("span");
-      back_btn.className = "pop_back";
-      back_btn.appendChild(document.createTextNode("<< back"));
-      back_btn.addEventListener("click", function(e) {
-        help_return();
-      }, false);
-      back_btn_sec.appendChild(back_btn);
-      pop.insertBefore(back_btn_sec, pop.firstChild);
-      var close_btn_sec = document.createElement("div");
-      close_btn_sec.className = "pop_close_sec";
-      var close_btn = document.createElement("span");
-      close_btn.className = "pop_close";
-      close_btn.appendChild(document.createTextNode("close"));
-      close_btn.addEventListener("click", function(e) {
-        help_popup();
-      }, false);
-      close_btn_sec.appendChild(close_btn);
-      pop.appendChild(close_btn_sec);
-    }
-  }
-  return pop;
-}
-
-/*
- * help_popup
- *
- * Moves around help pop-ups so they appear
- * below an activator.
- */
-function help_popup(activator, popup_id) {
-  "use strict";
-  var pop;
-  // set default values
-  if (typeof help_popup.popup === "undefined") {
-    help_popup.popup = [];
-  }
-  if (typeof help_popup.activator === "undefined") {
-    help_popup.activator = null;
-  }
-  var last_pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (typeof(activator) == "undefined") { // no activator so hide
-    if (last_pop != null) {
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-    }
-    return;
-  }
-  pop = lookup_help_popup(popup_id);
-  if (pop == last_pop) {
-    if (activator == help_popup.activator) {
-      //hide popup (as we've already shown it for the current help button)
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-      return; // toggling complete!
-    }
-  } else if (last_pop != null) {
-    //activating different popup so hide current one
-    last_pop.style.display = 'none';
-  }
-  help_popup.popup = [pop];
-  help_popup.activator = activator;
-  toggle_class(pop, "nested", false);
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = 'block';
-  position_popup(activator, pop);
-}
-
-/*
- * help_refine
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_refine(popup_id) {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not refine a help popup when one is not shown!");
-  }
-  var pop = lookup_help_popup(popup_id);
-  var last_pop = help_popup.popup[help_popup.popup.length - 1];
-  if (pop == last_pop) return; // slightly odd, but no real cause for alarm
-  help_popup.popup.push(pop);
-  toggle_class(pop, "nested", true);
-  last_pop.style.display = "none";
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = "block";
-  position_popup(help_popup.activator, pop);
-}
-
-/*
- * help_return
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_return() {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not return to a earlier help popup when one is not shown!");
-  }
-  var last_pop = help_popup.popup.pop();
-  last_pop.style.display = "none";
-  var pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (pop != null) {
-    toggle_class(pop, "nested", help_popup.popup.length > 1);
-    pop.style.display = "block";
-    position_popup(help_popup.activator, pop);
-  } else {
-    help_popup.activator = null;
-  }
-}
-
-/*
- * update_scroll_pad
- *
- * Creates padding at the bottom of the page to allow
- * scrolling of anything into view.
- */
-function update_scroll_pad() {
-  var page, pad;
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  pad = $("scrollpad");
-  if (pad === null) {
-    pad = document.createElement("div");
-    pad.id = 'scrollpad';
-    document.getElementsByTagName('body')[0].appendChild(pad);
-  }
-  pad.style.height = Math.abs(page.clientHeight - 100) + "px";
-}
-
-function substitute_classes(node, remove, add) {
-  "use strict";
-  var list, all, i, cls, classes;
-  list = node.className.split(/\s+/);
-  all = {};
-  for (i = 0; i < list.length; i++) {
-    if (list[i].length > 0) all[list[i]] = true;
-  }
-  for (i = 0; i < remove.length; i++) {
-    if (all.hasOwnProperty(remove[i])) {
-      delete all[remove[i]];
-    }
-  }
-  for (i = 0; i < add.length; i++) {
-    all[add[i]] = true;
-  }
-  classes = "";
-  for (cls in all) {
-    classes += cls + " ";
-  }
-  node.className = classes;
-}
-
-/*
- * toggle_class
- *
- * Adds or removes a class from the node. If the parameter 'enabled' is not 
- * passed then the existence of the class will be toggled, otherwise it will be
- * included if enabled is true.
- */
-function toggle_class(node, cls, enabled) {
-  var classes = node.className;
-  var list = classes.replace(/^\s+/, '').replace(/\s+$/, '').split(/\s+/);
-  var found = false;
-  for (var i = 0; i < list.length; i++) {
-    if (list[i] == cls) {
-      list.splice(i, 1);
-      i--;
-      found = true;
-    }
-  }
-  if (typeof enabled == "undefined") {
-    if (!found) list.push(cls);
-  } else {
-    if (enabled) list.push(cls);
-  }
-  node.className = list.join(" ");
-}
-
-/*
- * find_child
- *
- * Searches child nodes in depth first order and returns the first it finds
- * with the className specified.
- * TODO replace with querySelector
- */
-function find_child(node, className) {
-  var pattern;
-  if (node == null || typeof node !== "object") {
-    return null;
-  }
-  if (typeof className === "string") {
-    pattern = new RegExp("\\b" + className + "\\b");
-  } else {
-    pattern = className;
-  }
-  if (node.nodeType == Node.ELEMENT_NODE && 
-      pattern.test(node.className)) {
-    return node;
-  } else {
-    var result = null;
-    for (var i = 0; i < node.childNodes.length; i++) {
-      result = find_child(node.childNodes[i], pattern);
-      if (result != null) break;
-    }
-    return result;
-  }
-}
-
-/*
- * find_parent
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the className specified.
- */
-function find_parent(node, className) {
-  var pattern;
-  pattern = new RegExp("\\b" + className + "\\b");
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && 
-        pattern.test(node.className)) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * find_parent_tag
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the tag name specified. HTML tags should be specified in upper case.
- */
-function find_parent_tag(node, tag_name) {
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && node.tagName == tag_name) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * __toggle_help
- *
- * Uses the 'topic' property of the this object to
- * toggle display of a help topic.
- *
- * This function is not intended to be called directly.
- */
-function __toggle_help(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-
-  help_popup(this, this.getAttribute("data-topic"));
-}
-
-function setup_help_button(button) {
-  "use strict";
-  var topic;
-  if (button.hasAttribute("data-topic")) {
-    topic = button.getAttribute("data-topic");
-    if (document.getElementById(topic) != null) {
-      button.tabIndex = "0"; // make keyboard selectable
-      button.addEventListener("click", function() {
-        help_popup(button, topic);
-      }, false);
-      button.addEventListener("keydown", function(e) {
-        // toggle only on Enter or Spacebar, let other keys do their thing
-        if (e.keyCode !== 13 && e.keyCode !== 32) return;
-        // stop a submit or something like that
-        e.preventDefault();
-        help_popup(button, topic);
-      }, false);
-    } else {
-      button.style.visibility = "hidden";
-    }
-  }
-  button.className += " active";
-}
-
-/*
- * help_button
- *
- * Makes a help button for the passed topic.
- */
-function help_button(topic) {
-  var btn = document.createElement("div");
-  btn.className = "help";
-  btn.setAttribute("data-topic", topic);
-  setup_help_button(btn);
-  return btn;
-}
-
-/*
- * prepare_download
- *
- * Sets the attributes of a link to setup a file download using the given content.
- * If no link is provided then create one and click it.
- */
-function prepare_download(content, mimetype, filename, link) {
-  "use strict";
-  // if no link is provided then create one and click it
-  var click_link = false;
-  if (!link) {
-    link = document.createElement("a");
-    click_link = true;
-  }
-  try {
-    // Use a BLOB to convert the text into a data URL.
-    // We could do this manually with a base 64 conversion.
-    // This will only be supported on modern browsers,
-    // hence the try block.
-    var blob = new Blob([content], {type: mimetype});
-    var reader = new FileReader();
-    reader.onloadend = function() {
-      // If we're lucky the browser will also support the download
-      // attribute which will let us suggest a file name to save the link.
-      // Otherwise it is likely that the filename will be unintelligible. 
-      link.setAttribute("download", filename);
-      link.href = reader.result;
-      if (click_link) {
-        // must add the link to click it
-        document.body.appendChild(link);
-        link.click();
-        document.body.removeChild(link);
-      }
-    }
-    reader.readAsDataURL(blob);
-  } catch (error) {
-    if (console && console.log) console.log(error);
-    // probably an old browser
-    link.href = "";
-    link.visible = false;
-  }
-}
-
-/*
- * add_cell
- *
- * Add a cell to the table row.
- */
-function add_cell(row, node, cls, click_action) {
-  var cell = row.insertCell(row.cells.length);
-  if (node) cell.appendChild(node);
-  if (cls && cls !== "") cell.className = cls;
-  if (click_action) cell.addEventListener("click", click_action, false);
-}
-
-/*
- * add_header_cell
- *
- * Add a header cell to the table row.
- */
-function add_header_cell(row, node, help_topic, cls, colspan) {
-  var th = document.createElement("th");
-  if (node) th.appendChild(node);
-  if (help_topic && help_topic !== "") th.appendChild(help_button(help_topic));
-  if (cls && cls !== "") th.className = cls;
-  if (typeof colspan == "number" && colspan > 1) th.colSpan = colspan;
-  row.appendChild(th);
-}
-
-/*
- * add_text_cell
- *
- * Add a text cell to the table row.
- */
-function add_text_cell(row, text, cls, action) {
-  var node = null;
-  if (typeof(text) != 'undefined') node = document.createTextNode(text);
-  add_cell(row, node, cls, action);
-}
-
-/*
- * add_text_header_cell
- *
- * Add a text header cell to the table row.
- */
-function add_text_header_cell(row, text, help_topic, cls, action, colspan) {
-  var node = null;
-  if (typeof(text) != 'undefined') {
-    var nbsp = (help_topic ? "\u00A0" : "");
-    var str = "" + text;
-    var parts = str.split(/\n/);
-    if (parts.length === 1) {
-      if (action) {
-        node = document.createElement("span");
-        node.appendChild(document.createTextNode(str + nbsp));
-      } else {
-        node = document.createTextNode(str + nbsp);
-      }
-    } else {
-      node = document.createElement("span");
-      for (var i = 0; i < parts.length; i++) {
-        if (i !== 0) {
-          node.appendChild(document.createElement("br"));
-        }
-        node.appendChild(document.createTextNode(parts[i]));
-      }
-    }
-    if (action) {
-      node.addEventListener("click", action, false);
-      node.style.cursor = "pointer";
-    }
-  }
-  add_header_cell(row, node, help_topic, cls, colspan);
-}
-
-function setup_help() {
-  "use strict";
-  var help_buttons, i;
-  help_buttons = document.querySelectorAll(".help:not(.active)");
-  for (i = 0; i < help_buttons.length; i++) {
-    setup_help_button(help_buttons[i]);
-  }
-}
-
-function setup_scrollpad() {
-  "use strict";
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-scrollpad") && document.getElementById("scrollpad") == null) {
-    window.addEventListener("resize", update_scroll_pad, false);
-    update_scroll_pad();
-  }
-}
-
-// anon function to avoid polluting global scope
-(function() {
-  "use strict";
-  window.addEventListener("load", function load(evt) {
-    window.removeEventListener("load", load, false);
-    setup_help();
-    setup_scrollpad();
-  }, false);
-})();
-
-/*
- *  make_link
- *
- *  Creates a text node and if a URL is specified it surrounds it with a link.
- *  If the URL doesn't begin with "http://" it automatically adds it, as
- *  relative links don't make much sense in this context.
- */
-function make_link(text, url) {
-  var textNode = null;
-  var link = null;
-  if (typeof text !== "undefined" && text !== null) textNode = document.createTextNode(text);
-  if (typeof url === "string") {
-    if (url.indexOf("//") == -1) {
-      url = "http://" + url;
-    }
-    link = document.createElement('a');
-    link.href = url;
-    if (textNode) link.appendChild(textNode);
-    return link;
-  }
-  return textNode;
-}
-</script>
-    <script>
-function motif_logo_template(inputs) {
-  function _input(name) {
-    if (typeof inputs[name] === "undefined") {
-      throw new Error("Missing template variable: " + name);
-    }
-    return inputs[name];
-  }
-  return (
-"%!PS-Adobe-3.0 EPSF-3.0\n" +
-"%%Title: Sequence Logo : " + _input("TITLE") + "\n" +
-"%%Creator: " + _input("CREATOR") + "\n" +
-"%%CreationDate: " + _input("CREATIONDATE") + "\n" +
-"%%BoundingBox:   0  0  " + _input("BOUNDINGWIDTH") + " " + _input("BOUNDINGHEIGHT") + " \n" +
-"%%Pages: 0\n" +
-"%%DocumentFonts: \n" +
-"%%EndComments\n" +
-"\n" +
-"% ---- CONSTANTS ----\n" +
-"\/cmfactor 72 2.54 div def % defines points -> cm conversion\n" +
-"\/cm {cmfactor mul} bind def % defines centimeters\n" +
-"\n" +
-"% ---- VARIABLES ----\n" +
-"\n" +
-"% NA = Nucleic Acid, AA = Amino Acid\n" +
-"\/logoType (" + _input("LOGOTYPE") + ") def \n" +
-"\n" +
-"\/logoTitle (" + _input("TITLE") + ") def\n" +
-"\n" +
-"% Dimensions in cm\n" +
-"\/logoWidth " + _input("LOGOWIDTH") + " cm def\n" +
-"\/logoHeight " + _input("LOGOLINEHEIGHT") + " cm def\n" +
-"\/totalHeight " + _input("LOGOHEIGHT") + " cm def\n" +
-"\n" +
-"\/yaxis " + _input("YAXIS") + " def\n" +
-"\/yaxisLabel (" + _input("YAXISLABEL") + ") def\n" +
-"\/yaxisBits  " + _input("BARBITS") + " def % bits\n" +
-"\/yaxisTicBits " + _input("TICBITS") + " def\n" +
-"\n" +
-"\/xaxis " + _input("NUMBERING") + " def\n" +
-"\/xaxisLabel (" + _input("XAXISLABEL") + ") def\n" +
-"\/showEnds (" + _input("SHOWENDS") + ") def \n" +
-"\n" +
-"\/showFineprint true def\n" +
-"\/fineprint (" + _input("FINEPRINT") + ") def\n" +
-"\n" +
-"\/charsPerLine " + _input("CHARSPERLINE") + " def\n" +
-"\n" +
-"\/showingBox " + _input("SHOWINGBOX") + " def    \n" +
-"\/shrinking false def   % true falses\n" +
-"\/shrink  1.0 def\n" +
-"\/outline " + _input("OUTLINE") + " def\n" +
-"\n" +
-"\/IbeamFraction  " + _input("ERRORBARFRACTION") + " def\n" +
-"\/IbeamGray      0.50 def\n" +
-"\/IbeamLineWidth 0.5 def\n" +
-"\n" +
-"\/fontsize       " + _input("FONTSIZE") + " def\n" +
-"\/titleFontsize  " + _input("TITLEFONTSIZE") + " def\n" +
-"\/smallFontsize  " + _input("SMALLFONTSIZE") + " def\n" +
-"\n" +
-"\/topMargin      " + _input("TOPMARGIN") + " cm def\n" +
-"\/bottomMargin   " + _input("BOTTOMMARGIN") + " cm def\n" +
-"\n" +
-"\/defaultColor [0 0 0] def \n" +
-"\n" +
-_input("COLORDICT") + "\n" +
-"\n" +
-"\/colorDict fullColourDict def\n" +
-"\n" +
-"% ---- DERIVED PARAMETERS ----\n" +
-"\n" +
-"\/leftMargin\n" +
-"  fontsize 3.5 mul\n" +
-"\n" +
-"def \n" +
-"\n" +
-"\/rightMargin \n" +
-"  %Add extra room if showing ends\n" +
-"  showEnds (false) eq { fontsize}{fontsize 1.5 mul} ifelse\n" +
-"def\n" +
-"\n" +
-"\/yaxisHeight \n" +
-"  logoHeight \n" +
-"  bottomMargin sub  \n" +
-"  topMargin sub\n" +
-"def\n" +
-"\n" +
-"\/ticWidth fontsize 2 div def\n" +
-"\n" +
-"\/pointsPerBit yaxisHeight yaxisBits div  def\n" +
-"\n" +
-"\/stackMargin 1 def\n" +
-"\n" +
-"% Do not add space aroung characters if characters are boxed\n" +
-"\/charRightMargin \n" +
-"  showingBox { 0.0 } {stackMargin} ifelse\n" +
-"def\n" +
-"\n" +
-"\/charTopMargin \n" +
-"  showingBox { 0.0 } {stackMargin} ifelse\n" +
-"def\n" +
-"\n" +
-"\/charWidth\n" +
-"  logoWidth\n" +
-"  leftMargin sub\n" +
-"  rightMargin sub\n" +
-"  charsPerLine div\n" +
-"  charRightMargin sub\n" +
-"def\n" +
-"\n" +
-"\/charWidth4 charWidth 4 div def\n" +
-"\/charWidth2 charWidth 2 div def\n" +
-"\n" +
-"\/stackWidth \n" +
-"  charWidth charRightMargin add\n" +
-"def\n" +
-" \n" +
-"\/numberFontsize \n" +
-"  fontsize charWidth lt {fontsize}{charWidth} ifelse\n" +
-"def\n" +
-"\n" +
-"% movements to place 5'\/N and 3'\/C symbols\n" +
-"\/leftEndDeltaX  fontsize neg         def\n" +
-"\/leftEndDeltaY  fontsize 1.5 mul neg def\n" +
-"\/rightEndDeltaX fontsize 0.25 mul     def\n" +
-"\/rightEndDeltaY leftEndDeltaY        def\n" +
-"\n" +
-"% Outline width is proporional to charWidth, \n" +
-"% but no less that 1 point\n" +
-"\/outlinewidth \n" +
-"  charWidth 32 div dup 1 gt  {}{pop 1} ifelse\n" +
-"def\n" +
-"\n" +
-"\n" +
-"% ---- PROCEDURES ----\n" +
-"\n" +
-"\/StartLogo { \n" +
-"  % Save state\n" +
-"  save \n" +
-"  gsave \n" +
-"\n" +
-"  % Print Logo Title, top center \n" +
-"  gsave \n" +
-"    SetStringFont\n" +
-"\n" +
-"    logoWidth 2 div\n" +
-"    logoTitle\n" +
-"    stringwidth pop 2 div sub\n" +
-"    totalHeight\n" +
-"    titleFontsize sub\n" +
-"    moveto\n" +
-"\n" +
-"    logoTitle\n" +
-"    show\n" +
-"  grestore\n" +
-"\n" +
-"  % Print X-axis label, bottom center\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"\n" +
-"    logoWidth 2 div\n" +
-"    xaxisLabel\n" +
-"    stringwidth pop 2 div sub\n" +
-"    0\n" +
-"    titleFontsize 3 div\n" +
-"    add\n" +
-"    moveto\n" +
-"\n" +
-"    xaxisLabel\n" +
-"    show\n" +
-"  grestore\n" +
-"\n" +
-"  % Show Fine Print\n" +
-"  showFineprint {\n" +
-"    gsave\n" +
-"      SetSmallFont\n" +
-"      logoWidth\n" +
-"        fineprint stringwidth pop sub\n" +
-"        smallFontsize sub\n" +
-"          smallFontsize 3 div\n" +
-"      moveto\n" +
-"    \n" +
-"      fineprint show\n" +
-"    grestore\n" +
-"  } if\n" +
-"\n" +
-"  % Move to lower left corner of last line, first stack\n" +
-"  leftMargin bottomMargin translate\n" +
-"\n" +
-"  % Move above first line ready for StartLine \n" +
-"  0 totalHeight translate\n" +
-"\n" +
-"  SetLogoFont\n" +
-"} bind def\n" +
-"\n" +
-"\/EndLogo { \n" +
-"  grestore \n" +
-"  showpage \n" +
-"  restore \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/StartLine { \n" +
-"  % move down to the bottom of the line:\n" +
-"  0 logoHeight neg translate\n" +
-"  \n" +
-"  gsave \n" +
-"    yaxis { MakeYaxis } if\n" +
-"    xaxis { showEnds (true) eq {ShowLeftEnd} if } if\n" +
-"} bind def\n" +
-"\n" +
-"\/EndLine{ \n" +
-"    xaxis { showEnds (true) eq {ShowRightEnd} if } if\n" +
-"  grestore \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/MakeYaxis {\n" +
-"  gsave    \n" +
-"    stackMargin neg 0 translate\n" +
-"    ShowYaxisBar\n" +
-"    ShowYaxisLabel\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowYaxisBar { \n" +
-"  gsave  \n" +
-"    SetStringFont\n" +
-"\n" +
-"    \/str 10 string def % string to hold number  \n" +
-"    \/smallgap stackMargin 2 div def\n" +
-"\n" +
-"    % Draw first tic and bar\n" +
-"    gsave    \n" +
-"      ticWidth neg 0 moveto \n" +
-"      ticWidth 0 rlineto \n" +
-"      0 yaxisHeight rlineto\n" +
-"      stroke\n" +
-"    grestore\n" +
-"\n" +
-"   \n" +
-"    % Draw the tics\n" +
-"    % initial increment limit proc for\n" +
-"    0 yaxisTicBits yaxisBits abs %cvi\n" +
-"    {\/loopnumber exch def\n" +
-"\n" +
-"      % convert the number coming from the loop to a string\n" +
-"      % and find its width\n" +
-"      loopnumber 10 str cvrs\n" +
-"      \/stringnumber exch def % string representing the number\n" +
-"\n" +
-"      stringnumber stringwidth pop\n" +
-"      \/numberwidth exch def % width of number to show\n" +
-"\n" +
-"      \/halfnumberheight\n" +
-"         stringnumber CharBoxHeight 2 div\n" +
-"      def\n" +
-"\n" +
-"      numberwidth % move back width of number\n" +
-"      neg loopnumber pointsPerBit mul % shift on y axis\n" +
-"      halfnumberheight sub % down half the digit\n" +
-"\n" +
-"      moveto % move back the width of the string\n" +
-"\n" +
-"      ticWidth neg smallgap sub % Move back a bit more  \n" +
-"      0 rmoveto % move back the width of the tic  \n" +
-"\n" +
-"      stringnumber show\n" +
-"      smallgap 0 rmoveto % Make a small gap  \n" +
-"\n" +
-"      % now show the tic mark\n" +
-"      0 halfnumberheight rmoveto % shift up again\n" +
-"      ticWidth 0 rlineto\n" +
-"      stroke\n" +
-"    } for\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\/ShowYaxisLabel {\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"\n" +
-"    % How far we move left depends on the size of\n" +
-"    % the tic labels.\n" +
-"    \/str 10 string def % string to hold number  \n" +
-"    yaxisBits yaxisTicBits div cvi yaxisTicBits mul \n" +
-"    str cvs stringwidth pop\n" +
-"    ticWidth 1.5 mul  add neg  \n" +
-"\n" +
-"\n" +
-"    yaxisHeight\n" +
-"    yaxisLabel stringwidth pop\n" +
-"    sub 2 div\n" +
-"\n" +
-"    translate\n" +
-"    90 rotate\n" +
-"    0 0 moveto\n" +
-"    yaxisLabel show\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/StartStack {  % <stackNumber> startstack\n" +
-"  xaxis {MakeNumber}{pop} ifelse\n" +
-"  gsave\n" +
-"} bind def\n" +
-"\n" +
-"\/EndStack {\n" +
-"  grestore\n" +
-"  stackWidth 0 translate\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% Draw a character whose height is proportional to symbol bits\n" +
-"\/MakeSymbol{ % charbits character MakeSymbol\n" +
-"  gsave\n" +
-"    \/char exch def\n" +
-"    \/bits exch def\n" +
-"\n" +
-"    \/bitsHeight \n" +
-"       bits pointsPerBit mul \n" +
-"    def\n" +
-"\n" +
-"    \/charHeight \n" +
-"       bitsHeight charTopMargin sub\n" +
-"       dup \n" +
-"       0.0 gt {}{pop 0.0} ifelse % if neg replace with zero \n" +
-"    def \n" +
-" \n" +
-"    charHeight 0.0 gt {\n" +
-"      char SetColor\n" +
-"      charWidth charHeight char ShowChar\n" +
-"\n" +
-"      showingBox { % Unfilled box\n" +
-"        0 0 charWidth charHeight false ShowBox\n" +
-"      } if\n" +
-"\n" +
-"\n" +
-"    } if\n" +
-"\n" +
-"  grestore\n" +
-"\n" +
-"  0 bitsHeight translate \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowChar { % <width> <height> <char> ShowChar\n" +
-"  gsave\n" +
-"    \/tc exch def    % The character\n" +
-"    \/ysize exch def % the y size of the character\n" +
-"    \/xsize exch def % the x size of the character\n" +
-"\n" +
-"    \/xmulfactor 1 def \n" +
-"    \/ymulfactor 1 def\n" +
-"    \/limmulfactor 0.01 def\n" +
-"    \/drawable true def\n" +
-"\n" +
-"  \n" +
-"    % if ysize is negative, make everything upside down!\n" +
-"    ysize 0 lt {\n" +
-"      % put ysize normal in this orientation\n" +
-"      \/ysize ysize abs def\n" +
-"      xsize ysize translate\n" +
-"      180 rotate\n" +
-"    } if\n" +
-"\n" +
-"    shrinking {\n" +
-"      xsize 1 shrink sub 2 div mul\n" +
-"        ysize 1 shrink sub 2 div mul translate \n" +
-"\n" +
-"      shrink shrink scale\n" +
-"    } if\n" +
-"\n" +
-"    % Calculate the font scaling factors\n" +
-"    % Loop twice to catch small correction due to first scaling\n" +
-"    2 {\n" +
-"      gsave\n" +
-"        xmulfactor ymulfactor scale\n" +
-"      \n" +
-"        ysize % desired size of character in points\n" +
-"        tc CharBoxHeight \n" +
-"        dup 0.0 ne {\n" +
-"          div % factor by which to scale up the character\n" +
-"          \/ymulfactor exch def\n" +
-"        } % end if\n" +
-"        {pop pop}\n" +
-"        ifelse\n" +
-"\n" +
-"        xsize % desired size of character in points\n" +
-"        tc CharBoxWidth  \n" +
-"        dup 0.0 ne {\n" +
-"          div % factor by which to scale up the character\n" +
-"          \/xmulfactor exch def\n" +
-"        } % end if\n" +
-"        {pop pop}\n" +
-"        ifelse\n" +
-"      grestore\n" +
-"      % if the multiplication factors get too small we need to avoid a crash\n" +
-"      xmulfactor limmulfactor lt {\n" +
-"        \/xmulfactor 1 def\n" +
-"        \/drawable false def\n" +
-"      } if\n" +
-"      ymulfactor limmulfactor lt {\n" +
-"        \/ymulfactor 1 def\n" +
-"        \/drawable false def\n" +
-"      } if\n" +
-"    } repeat\n" +
-"\n" +
-"    % Adjust horizontal position if the symbol is an I\n" +
-"    tc (I) eq {\n" +
-"      charWidth 2 div % half of requested character width\n" +
-"      tc CharBoxWidth 2 div % half of the actual character\n" +
-"      sub 0 translate\n" +
-"      % Avoid x scaling for I \n" +
-"      \/xmulfactor 1 def \n" +
-"    } if\n" +
-"\n" +
-"\n" +
-"    % ---- Finally, draw the character\n" +
-"    drawable { \n" +
-"      newpath\n" +
-"      xmulfactor ymulfactor scale\n" +
-"\n" +
-"      % Move lower left corner of character to start point\n" +
-"      tc CharBox pop pop % llx lly : Lower left corner\n" +
-"      exch neg exch neg\n" +
-"      moveto\n" +
-"\n" +
-"      outline {  % outline characters:\n" +
-"        outlinewidth setlinewidth\n" +
-"        tc true charpath\n" +
-"        gsave 1 setgray fill grestore\n" +
-"        clip stroke\n" +
-"      } { % regular characters\n" +
-"        tc show\n" +
-"      } ifelse\n" +
-"    } if\n" +
-"\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowBox { % x1 y1 x2 y2 filled ShowBox\n" +
-"  gsave\n" +
-"    \/filled exch def \n" +
-"    \/y2 exch def\n" +
-"    \/x2 exch def\n" +
-"    \/y1 exch def\n" +
-"    \/x1 exch def\n" +
-"    newpath\n" +
-"    x1 y1 moveto\n" +
-"    x2 y1 lineto\n" +
-"    x2 y2 lineto\n" +
-"    x1 y2 lineto\n" +
-"    closepath\n" +
-"\n" +
-"    clip\n" +
-"    \n" +
-"    filled {\n" +
-"      fill\n" +
-"    }{ \n" +
-"      0 setgray stroke   \n" +
-"    } ifelse\n" +
-"\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/MakeNumber { % number MakeNumber\n" +
-"  gsave\n" +
-"    SetNumberFont\n" +
-"    stackWidth 0 translate\n" +
-"    90 rotate % rotate so the number fits\n" +
-"    dup stringwidth pop % find the length of the number\n" +
-"    neg % prepare for move\n" +
-"    stackMargin sub % Move back a bit\n" +
-"    charWidth (0) CharBoxHeight % height of numbers\n" +
-"    sub 2 div %\n" +
-"    moveto % move back to provide space\n" +
-"    show\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/Ibeam{ % heightInBits Ibeam\n" +
-"  gsave\n" +
-"    % Make an Ibeam of twice the given height in bits\n" +
-"    \/height exch  pointsPerBit mul def \n" +
-"    \/heightDRAW height IbeamFraction mul def\n" +
-"\n" +
-"    IbeamLineWidth setlinewidth\n" +
-"    IbeamGray setgray \n" +
-"\n" +
-"    charWidth2 height neg translate\n" +
-"    ShowIbar\n" +
-"    newpath\n" +
-"      0 0 moveto\n" +
-"      0 heightDRAW rlineto\n" +
-"    stroke\n" +
-"    newpath\n" +
-"      0 height moveto\n" +
-"      0 height rmoveto\n" +
-"      currentpoint translate\n" +
-"    ShowIbar\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    0 heightDRAW neg rlineto\n" +
-"    currentpoint translate\n" +
-"    stroke\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowIbar { % make a horizontal bar\n" +
-"  gsave\n" +
-"    newpath\n" +
-"      charWidth4 neg 0 moveto\n" +
-"      charWidth4 0 lineto\n" +
-"    stroke\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowLeftEnd {\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"    leftEndDeltaX leftEndDeltaY moveto\n" +
-"    logoType (NA) eq {(5) show ShowPrime} if\n" +
-"    logoType (AA) eq {(N) show} if\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowRightEnd { \n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"    rightEndDeltaX rightEndDeltaY moveto\n" +
-"    logoType (NA) eq {(3) show ShowPrime} if\n" +
-"    logoType (AA) eq {(C) show} if\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowPrime {\n" +
-"  gsave\n" +
-"    SetPrimeFont\n" +
-"    (\\242) show \n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-" \n" +
-"\/SetColor{ % <char> SetColor\n" +
-"  dup colorDict exch known {\n" +
-"    colorDict exch get aload pop setrgbcolor\n" +
-"  } {\n" +
-"    pop\n" +
-"    defaultColor aload pop setrgbcolor\n" +
-"  } ifelse \n" +
-"} bind def\n" +
-"\n" +
-"% define fonts\n" +
-"\/SetTitleFont {\/Times-Bold findfont titleFontsize scalefont setfont} bind def\n" +
-"\/SetLogoFont  {\/Helvetica-Bold findfont charWidth  scalefont setfont} bind def\n" +
-"\/SetStringFont{\/Helvetica-Bold findfont fontsize scalefont setfont} bind def\n" +
-"\/SetPrimeFont {\/Symbol findfont fontsize scalefont setfont} bind def\n" +
-"\/SetSmallFont {\/Helvetica findfont smallFontsize scalefont setfont} bind def\n" +
-"\n" +
-"\/SetNumberFont {\n" +
-"    \/Helvetica-Bold findfont \n" +
-"    numberFontsize\n" +
-"    scalefont\n" +
-"    setfont\n" +
-"} bind def\n" +
-"\n" +
-"%Take a single character and return the bounding box\n" +
-"\/CharBox { % <char> CharBox <lx> <ly> <ux> <uy>\n" +
-"  gsave\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    % take the character off the stack and use it here:\n" +
-"    true charpath \n" +
-"    flattenpath \n" +
-"    pathbbox % compute bounding box of 1 pt. char => lx ly ux uy\n" +
-"    % the path is here, but toss it away ...\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% The height of a characters bounding box\n" +
-"\/CharBoxHeight { % <char> CharBoxHeight <num>\n" +
-"  CharBox\n" +
-"  exch pop sub neg exch pop\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% The width of a characters bounding box\n" +
-"\/CharBoxWidth { % <char> CharBoxHeight <num>\n" +
-"  CharBox\n" +
-"  pop exch pop sub neg \n" +
-"} bind def\n" +
-"\n" +
-"% Set the colour scheme to be faded to indicate trimming\n" +
-"\/MuteColour {\n" +
-"  \/colorDict mutedColourDict def\n" +
-"} def\n" +
-"\n" +
-"% Restore the colour scheme to the normal colours\n" +
-"\/RestoreColour {\n" +
-"  \/colorDict fullColourDict def\n" +
-"} def\n" +
-"\n" +
-"% Draw the background for a trimmed section\n" +
-"% takes the number of columns as a parameter\n" +
-"\/DrawTrimBg { % <num> DrawTrimBox\n" +
-"  \/col exch def\n" +
-"  \n" +
-"  \/boxwidth \n" +
-"    col stackWidth mul \n" +
-"  def\n" +
-" \n" +
-"  gsave\n" +
-"    0.97 setgray\n" +
-"\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    boxwidth 0 rlineto\n" +
-"    0 yaxisHeight rlineto\n" +
-"    0 yaxisHeight lineto\n" +
-"    closepath\n" +
-"    \n" +
-"    fill\n" +
-"  grestore\n" +
-"} def\n" +
-"\n" +
-"\/DrawTrimEdge {\n" +
-"  gsave\n" +
-"    0.2 setgray\n" +
-"    [2] 0 setdash\n" +
-"\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    0 yaxisHeight lineto\n" +
-"    \n" +
-"    stroke\n" +
-"\n" +
-"} def\n" +
-"\n" +
-"\n" +
-"% Deprecated names\n" +
-"\/startstack {StartStack} bind  def\n" +
-"\/endstack {EndStack}     bind def\n" +
-"\/makenumber {MakeNumber} bind def\n" +
-"\/numchar { MakeSymbol }  bind def\n" +
-"\n" +
-"%%EndProlog\n" +
-"\n" +
-"%%Page: 1 1\n" +
-"StartLogo\n" +
-"\n" +
-_input("DATA") + "\n" +
-"\n" +
-"EndLogo\n" +
-"\n" +
-"%%EOF\n"
-  );
-}</script>
-    <script>
-//======================================================================
-// start Alphabet object
-//======================================================================
-var Alphabet = function(alphabet, background) {
-  "use strict";
-  var i, j, sym, aliases, complement, comp_e_sym, ambigs, generate_background;
-  generate_background = (background == null);
-  if (generate_background) {
-    background = [];
-    for (i = 0; i < alphabet.ncore; i++) background[i] = 1.0 / alphabet.ncore;
-  } else if (alphabet.ncore != background.length) {
-    throw new Error("The background length does not match the alphabet length.");
-  }
-  this.name = alphabet.name;
-  this.like = (alphabet.like != null ? alphabet.like.toUpperCase() : null);
-  this.ncore = alphabet.ncore;
-  this.symbols = alphabet.symbols;
-  this.background = background;
-  this.genbg = generate_background;
-  this.encode = {};
-  this.encode2core = {};
-  this.complement = {};
-  // check if all symbols are same case
-  var seen_uc = false;
-  var seen_lc = false;
-  var check_case = function (syms) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        if (sym >= 'a' && sym <= 'z') seen_lc = true;
-        else if (sym >= 'A' && sym <= 'Z') seen_uc = true;
-      }
-    }
-  };
-  for (i = 0; i < this.symbols.length; i++) {
-    check_case(this.symbols[i].symbol);
-    check_case(this.symbols[i].aliases);
-  }
-  // now map symbols to indexes
-  var update_array = function(array, syms, index) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        array[sym] = index;
-        // when only a single case is used, then encode as case insensitive
-        if (seen_uc != seen_lc) {
-          if (sym >= 'a' && sym <= 'z') {
-            array[sym.toUpperCase()] = index;
-          } else if (sym >= 'A' && sym <= 'Z') {
-            array[sym.toLowerCase()] = index;
-          }
-        }
-      }
-    }
-  }
-  // map core symbols to index
-  for (i = 0; i < this.ncore; i++) {
-    update_array(this.encode2core, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode2core, this.symbols[i].aliases, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-  }
-  // map ambigous symbols to index
-  ambigs = {};
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-    ambigs[this.symbols[i].equals] = i;
-  }
-  // determine complements
-  for (i = 0; i < this.ncore; i++) {
-    complement = this.symbols[i].complement;
-    if (typeof complement === "string") {
-      this.complement[i] = this.encode2core[complement];
-    }
-  }
-  next_symbol:
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    complement = "";
-    for (j = 0; j < this.symbols[i].equals.length; j++) {
-      comp_e_sym = this.complement[this.encode2core[this.symbols[i].equals.charAt(j)]];
-      if (typeof comp_e_sym !== "number") continue next_symbol;
-      complement += this.symbols[comp_e_sym].symbol;
-    }
-    complement = complement.split("").sort().join("");
-    if (typeof ambigs[complement] === "number") {
-      this.complement[i] = ambigs[complement];
-    }
-  }
-  // determine case insensitivity
-  this.case_insensitive = true;
-  if (seen_uc == seen_lc) {
-    // when there is a mixture of cases it probably won't
-    // be case insensitive but we still need to check
-    loop:
-    for (i = 0; i < this.symbols.length; i++) {
-      sym = this.symbols[i].symbol;
-      if (sym >= 'A' && sym <= 'Z') {
-        if (this.encode[sym.toLowerCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      } else if (sym >= 'a' && sym <= 'z') {
-        if (this.encode[sym.toUpperCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      }
-      aliases = this.symbols[i].aliases;
-      if (aliases != null) {
-        for (j = 0; j < aliases.length; j++) {
-          sym = aliases.charAt(j);
-          if (sym >= 'A' && sym <= 'Z') {
-            if (this.encode[sym.toLowerCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          } else if (sym >= 'a' && sym <= 'z') {
-            if (this.encode[sym.toUpperCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          }
-        }
-      }
-    }
-  }
-  // normalise aliases to remove the prime symbol and eliminate
-  // the alternate cases when the alphabet is case insensitive
-  var seen, out;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym = this.symbols[i].symbol;
-    aliases = this.symbols[i].aliases;
-    if (typeof aliases != "string") aliases = "";
-    seen = {};
-    out = [];
-    if (this.case_insensitive) {
-      sym = sym.toUpperCase();
-      aliases = aliases.toUpperCase();
-    }
-    seen[sym] = true;
-    for (j = 0; j < aliases.length; j++) {
-      if (!seen[aliases.charAt(j)]) {
-        seen[aliases.charAt(j)] = true;
-        out.push(aliases.charAt(j));
-      }
-    }
-    this.symbols[i].aliases = out.sort().join("");
-  }
-};
-// return the name of the alphabet
-Alphabet.prototype.get_alphabet_name = function() {
-  return this.name;
-};
-// return if the alphabet can be complemented
-Alphabet.prototype.has_complement = function() {
-  return (typeof this.symbols[0].complement === "string");
-};
-// return true if an uppercase letter has the same meaning as the lowercase form
-Alphabet.prototype.is_case_insensitive = function() {
-  return this.case_insensitive;
-};
-// return the information content of an alphabet letter
-Alphabet.prototype.get_ic = function() {
-  return Math.log(this.ncore) / Math.LN2;
-};
-// return the count of the core alphabet symbols
-Alphabet.prototype.get_size_core = function() {
-  return this.ncore;
-};
-// return the count of all alphabet symbols
-Alphabet.prototype.get_size_full = function() {
-  return this.symbols.length;
-};
-// return the symbol for the given alphabet index
-Alphabet.prototype.get_symbol = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  return this.symbols[alph_index].symbol;
-};
-// return the aliases for the given alphabet index
-Alphabet.prototype.get_aliases = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  var sym_obj = this.symbols[alph_index];
-  return (sym_obj.aliases != null ? sym_obj.aliases : "");
-};
-// return the name for the given alphabet index
-Alphabet.prototype.get_name = function(alph_index) {
-  "use strict";
-  var sym;
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  sym = this.symbols[alph_index];
-  return (typeof sym.name === "string" ? sym.name : sym.symbol);
-};
-// return the alphabet it is like or null
-Alphabet.prototype.get_like = function() {
-  "use strict";
-  return this.like;
-};
-// return the index of the complement for the given alphabet index
-Alphabet.prototype.get_complement = function(alph_index) {
-  var comp_e_sym = this.complement[alph_index];
-  if (typeof comp_e_sym === "number") {
-    return comp_e_sym;
-  } else {
-    return -1;
-  }
-};
-// return a string containing the core symbols
-Alphabet.prototype.get_symbols = function() {
-  "use strict";
-  var i, core_symbols;
-  core_symbols = "";
-  for (i = 0; i < this.ncore; i++) {
-    core_symbols += this.symbols[i].symbol;
-  }
-  return core_symbols;
-};
-// return if the background was not a uniform generated background
-Alphabet.prototype.has_bg = function() {
-  "use strict";
-  return !this.genbg;
-};
-// get the background frequency for the index
-Alphabet.prototype.get_bg_freq = function(alph_index) {
-  "use strict";
-  var freq, i, symbols;
-  if (alph_index >= 0) {
-    if (alph_index < this.ncore) {
-      return this.background[alph_index];
-    } else if (alph_index < this.symbols.length) {
-      freq = 0;
-      symbols = this.symbols[alph_index].equals;
-      for (i = 0; i < symbols.length; i++) {
-        freq += this.background[this.encode2core[symbols.charAt(i)]];
-      }
-      return freq;
-    } 
-  }
-  throw new Error("The alphabet index is out of range.");
-};
-// get the colour of the index
-Alphabet.prototype.get_colour = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return "black";
-  }
-  return "#" + this.symbols[alph_index].colour;
-};
-// get the rgb componets of the colour at the index
-Alphabet.prototype.get_rgb = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return {"red": 0, "green": 0, "blue": 0};
-  }
-  var colour = this.symbols[alph_index].colour;
-  var red = parseInt(colour.substr(0, 2), 16) / 255;
-  var green = parseInt(colour.substr(2, 2), 16) / 255;
-  var blue = parseInt(colour.substr(4, 2), 16) / 255;
-  return {"red": red, "green": green, "blue": blue};
-};
-// convert a symbol into the index
-Alphabet.prototype.get_index = function(letter) {
-  "use strict";
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    return -1;
-  }
-  return alph_index;
-};
-// convert a symbol into the list of core indexes that it equals
-Alphabet.prototype.get_indexes = function(letter) {
-  "use strict";
-  var alph_index, comprise_str, i, comprise_list;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    throw new Error("Unknown letter");
-  }
-  comprise_str = this.symbols[alph_index].equals;
-  comprise_list = [];
-  if (typeof comprise_str == "string") {
-    for (i = 0; i < comprise_str.length; i++) {
-      comprise_list.push(this.encode2core[comprise_str.charAt(i)]);
-    }
-  } else {
-    comprise_list.push(alph_index);
-  }
-  return comprise_list;
-};
-// check if a symbol is the primary way of representing the symbol in the alphabet
-Alphabet.prototype.is_prime_symbol = function(letter) {
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (alph_index == null) return false;
-  if (this.is_case_insensitive()) {
-    return (this.symbols[alph_index].symbol.toUpperCase() == letter.toUpperCase());
-  } else {
-    return (this.symbols[alph_index].symbol == letter);
-  }
-};
-// compare 2 alphabets
-Alphabet.prototype.equals = function(other) {
-  "use strict";
-  var i, sym1, sym2;
-  // first check that it's actually an alphabet object
-  if (!(typeof other === "object" && other != null && other instanceof Alphabet)) {
-    return false;
-  }
-  // second shortcircuit if it's the same object
-  if (this === other) return true;
-  // compare
-  if (this.name !== other.name) return false;
-  if (this.ncore !== other.ncore) return false;
-  if (this.symbols.length !== other.symbols.length) return false;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym1 = this.symbols[i];
-    sym2 = other.symbols[i];
-    if (sym1.symbol !== sym2.symbol) return false;
-    if (sym1.aliases !== sym2.aliases) return false;
-    if (sym1.name !== sym2.name) return false;
-    if (typeof sym1.colour !== typeof sym2.colour || 
-        (typeof sym1.colour === "string" && typeof sym2.colour === "string" &&
-         parseInt(sym1.colour, 16) != parseInt(sym2.colour, 16))) {
-      return false;
-    }
-    if (sym1.complement !== sym2.complement) return false;
-    if (sym1.equals !== sym2.equals) return false;
-  }
-  return true;
-};
-Alphabet.prototype.check_core_subset = function(super_alph) {
-  var complement_same = true;
-  var seen_set = {};
-  var sub_i, sub_symbol, super_i, super_symbol;
-  for (sub_i = 0; sub_i < this.ncore; sub_i++) {
-    sub_symbol = this.symbols[sub_i];
-    super_i = super_alph.encode[sub_symbol.symbol]; 
-    if (super_i == null) return 0;
-    super_symbol = super_alph.symbols[super_i];
-    if (seen_set[super_i]) return 0;
-    seen_set[super_i] = true;
-    // check complement
-    if (sub_symbol.complement != null && super_symbol.complement != null) {
-      if (super_alph.encode[sub_symbol.complement] != super_alph.encode[super_symbol.complement]) {
-        complement_same = false;
-      }
-    } else if (sub_symbol.complement != null || super_symbol.complement != null) {
-      complement_same = false;
-    }
-  }
-  return (complement_same ? 1 : -1);
-};
-// convert a sequence to its reverse complement
-Alphabet.prototype.invcomp_seq = function(seq) {
-  "use strict";
-  var syms, i, e_sym, comp_e_sym;
-  if (!this.has_complement()) throw new Error("Alphabet must be complementable");
-  syms = seq.split("");
-  for (i = 0; i < syms.length; i++) {
-    e_sym = this.encode[syms[i]];
-    if (typeof e_sym === "undefined") {
-      e_sym = this.ncore; // wildcard
-    }
-    comp_e_sym = this.complement[e_sym];
-    if (typeof comp_e_sym === "undefined") {
-      comp_e_sym = e_sym; // not complementable
-    }
-    syms[i] = this.symbols[comp_e_sym].symbol;
-  }
-  return syms.reverse().join("");
-};
-// convert the alphabet to the text version
-Alphabet.prototype.as_text = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  function symbol_as_text(sym) {
-    var out;
-    out = sym.symbol;
-    if (typeof sym.name === "string" && sym.name != sym.symbol) {
-      out += " " + name_as_text(sym.name);
-    }
-    if (typeof sym.colour === "string") {
-      out += " " + sym.colour;
-    }
-    return out;
-  }
-  var out, i, j, c, sym;
-  out = "";
-  // output core symbols with 2 way complements
-  for (i = 0; i < this.ncore; i++) {
-    c = this.complement[i];
-    if (typeof c === "number" && i < c && this.complement[c] === i) {
-      out += symbol_as_text(this.symbols[i]) + " ~ " + symbol_as_text(this.symbols[c]) + "\n";  
-    }
-  }
-  // output core symbols with no complement
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.complement[i] === "undefined") {
-      out += symbol_as_text(this.symbols[i]) + "\n";
-    }
-  }
-  // output ambiguous symbols that have comprising characters
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    if (this.symbols[i].equals.length == 0) break;
-    out += symbol_as_text(this.symbols[i]) + " = " + this.symbols[i].equals + "\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].equals + "\n";
-      }
-    }
-  }
-  // output aliases of core symbols
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].symbol + "\n";
-      }
-    }
-  }
-  // output gap symbols
-  i = this.symbols.length - 1;
-  if (this.symbols[i].equals.length == 0) {
-    out += symbol_as_text(this.symbols[i]) + " =\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " =\n";
-      }
-    }
-  }
-  return out;
-};
-// output the alphabet as it appears in minimal MEME format
-Alphabet.prototype.as_meme = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  if (this.equals(AlphStd.DNA)) {
-    return "ALPHABET= ACGT\n";
-  } else if (this.equals(AlphStd.PROTEIN)) {
-    return "ALPHABET= ACDEFGHIKLMNPQRSTVWY\n";
-  } else {
-    return "ALPHABET" + 
-      (this.name != null ? " " + name_as_text(this.name) : "") + 
-      (this.like != null ? " " + this.like + "-LIKE" : "") + "\n" +
-      this.as_text() + "END ALPHABET\n";
-  }
-};
-
-// Returns a table showing all the letters in the alphabet
-Alphabet.prototype.as_table = function() {
-  "use strict";
-  var i, j, row, th, td, aliases, equals, sym;
-  var table = document.createElement("table");
-  // create the core symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  if (this.has_complement()) {
-    th.appendChild(document.createTextNode("Complement"));
-  }
-  row.appendChild(th);
-  // list the core symbols
-  for (i = 0; i < this.ncore; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].complement != null) {
-      td.style.color = this.get_colour(this.get_index(this.symbols[i].complement));
-      td.appendChild(document.createTextNode(this.symbols[i].complement));
-    }
-    row.appendChild(td);
-  }
-  // create the ambiguous symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Matches"));
-  row.appendChild(th);
-  // list the ambiguous symbols
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    equals = this.symbols[i].equals.split('');
-    for (j = 0; j < equals.length; j++) {
-      if (j != 0) td.appendChild(document.createTextNode(' '));
-      sym = document.createElement("span");
-      sym.style.color = this.get_colour(this.get_index(equals[j]));
-      sym.appendChild(document.createTextNode(equals[j]));
-      td.appendChild(sym);
-    }
-    row.appendChild(td);
-  }
-  return table;
-};
-
-// returns a dictionary of the colours for EPS
-Alphabet.prototype._as_eps_dict = function() {
-  "use strict";
-  var i, sym, rgb;
-  var out = "/fullColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = this.get_rgb(i);
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  out += "/mutedColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = Alphabet.lighten_colour(this.get_rgb(i));
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  return out;
-};
-
-// return the alphabet name or a list of primary symbols
-Alphabet.prototype.toString = function() {
-  "use strict";
-  if (this.name != null) {
-    return this.name;
-  } else {
-    return this.get_symbols();
-  }
-};
-
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-// Helper functions
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-// Convert a colour specified in RGB colourspace values into LAB colourspace
-Alphabet.rgb2lab = function(rgb) {
-  "use strict";
-  var xyzHelper, labHelper;
-  // XYZ helper
-  xyzHelper = function(value) {
-    if (value > 0.0445) {
-      value = (value + 0.055) / 1.055;
-      value = Math.pow(value, 2.4);
-    } else {
-      value /= 12.92;
-    }
-    value *= 100;
-    return value;
-  };
-  // lab helper
-  labHelper = function(value) {
-    if (value > 0.008856) {
-      value = Math.pow(value, 1.0 / 3.0);
-    } else {
-      value = (7.787 * value) + (16.0 / 116.0);
-    }
-    return value;
-  };
-  // convert into XYZ colourspace
-  var c1, c2, c3;
-  if (typeof rgb == "number") {
-    c1 = xyzHelper(((rgb >> 16) & 0xFF) / 255.0);
-    c2 = xyzHelper(((rgb >> 8) & 0xFF) / 255.0);
-    c3 = xyzHelper((rgb & 0xFF) / 255.0);
-  } else {
-    c1 = xyzHelper(rgb.red);
-    c2 = xyzHelper(rgb.green);
-    c3 = xyzHelper(rgb.blue);
-  }
-  var x = (c1 * 0.4124) + (c2 * 0.3576) + (c3 * 0.1805);
-  var y = (c1 * 0.2126) + (c2 * 0.7152) + (c3 * 0.0722);
-  var z = (c1 * 0.0193) + (c2 * 0.1192) + (c3 * 0.9505);
-  // convert into Lab colourspace
-  c1 = labHelper(x / 95.047);
-  c2 = labHelper(y / 100.0);
-  c3 = labHelper(z / 108.883);
-  var l = (116.0 * c2) - 16;
-  var a = 500.0 * (c1 - c2);
-  var b = 200.0 * (c2 - c3);
-  return {"l": l, "a": a, "b": b};
-};
-
-// Convert a colour specified in HSV colourspace into RGB colourspace
-Alphabet.hsv2rgb = function(hue, sat, value, output_object) {
-  // achromatic (grey)
-  var r = value;
-  var g = value;
-  var b = value;
-  if (sat != 0) {
-    var h = hue / 60.0;
-    var i = Math.floor(h);
-    var f = h - i;
-    var p = value * (1.0 - sat);
-    var q = value * (1.0 - (sat * f));
-    var t = value * (1.0 - (sat * (1.0 - f)));
-    if (i == 0) {
-      r = value;
-      g = t;
-      b = p;
-    } else if (i == 1) {
-      r = q;
-      g = value;
-      b = p;
-    } else if (i == 2) {
-      r = p;
-      g = value;
-      b = t;
-    } else if (i == 3) {
-      r = p;
-      g = q;
-      b = value;
-    } else if (i == 4) {
-      r = t;
-      g = p;
-      b = value;
-    } else {
-      r = value;
-      g = p;
-      b = q;
-    }
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-// Calculate a distance score between two colours in LAB colourspace
-Alphabet.lab_dist = function(lab1, lab2) {
-  var c1 = Math.sqrt((lab1.l * lab1.l) + (lab1.a * lab1.a));
-  var c2 = Math.sqrt((lab2.l * lab2.l) + (lab2.a * lab2.a));
-  var dc = c1 - c2;
-  var dl = lab1.l - lab2.l;
-  var da = lab1.a - lab2.a;
-  var db = lab1.b - lab2.b;
-  // we don't want NaN due to rounding errors so fudge things a bit...
-  var dh = 0;
-  var dh_squared = (da * da) + (db * db) - (dc * dc);
-  if (dh_squared > 0) {
-    dh = Math.sqrt(dh_squared);
-  }
-  var first = dl;
-  var second = dc / (1.0 + (0.045 * c1));
-  var third = dh / (1.0 + (0.015 * c1));
-  return Math.sqrt((first * first) + (second * second) + (third * third));
-};
-
-// convert an RGB value into a HSL value
-Alphabet.rgb2hsl = function(rgb) {
-  "use strict";
-  var min, max, delta, h, s, l, r, g, b;
-  if (typeof rgb == "number") {
-    r = ((rgb >> 16) & 0xFF) / 255.0;
-    g = ((rgb >> 8) & 0xFF) / 255.0;
-    b = (rgb & 0xFF) / 255.0;
-  } else {
-    r = rgb.red;
-    g = rgb.green;
-    b = rgb.blue;
-  }
-  min = Math.min(r, g, b);
-  max = Math.max(r, g, b);
-  delta = max - min;
-  l = min + (delta / 2);
-  if (max == min) {
-    h = 0; // achromatic (grayscale)
-    s = 0;
-  } else {
-    if (l > 0.5) {
-      s = delta / (2 - max - min);
-    } else {
-      s = delta / (max + min);
-    }
-    if (max == r) {
-      h = (g - b) / delta;
-      if (g < b) h += 6;
-    } else if (max == g) {
-      h = ((b - r) / delta) + 2;
-    } else {
-      h = ((r - g) / delta) + 4;
-    }
-    h /= 6;
-  }
-  return {"h": h, "s": s, "l": l};
-};
-
-// convert a HSL value into an RGB value
-Alphabet.hsl2rgb = function(hsl, output_object) {
-  "use strict";
-  function _hue(p, q, t) {
-    "use strict";
-    if (t < 0) t += 1;
-    else if (t > 1) t -= 1;
-    if (t < (1.0 / 6.0)) {
-      return p + ((q - p) * 6.0 * t);
-    } else if (t < 0.5) {
-      return q;
-    } else if (t < (2.0 / 3.0)) {
-      return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-    } else {
-      return p;
-    }
-  }
-  var r, g, b, p, q;
-  if (hsl.s == 0) {
-    // achromatic (grayscale)
-    r = hsl.l;
-    g = hsl.l;
-    b = hsl.l;
-  } else {
-    if (hsl.l < 0.5) {
-      q = hsl.l * (1 + hsl.s);
-    } else {
-      q = hsl.l + hsl.s - (hsl.l * hsl.s);
-    }
-    p = (2 * hsl.l) - q;
-    r = _hue(p, q, hsl.h + (1.0 / 3.0));
-    g = _hue(p, q, hsl.h);
-    b = _hue(p, q, hsl.h - (1.0 / 3.0));
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-Alphabet.lighten_colour = function(rgb) {
-  "use strict";
-  var hsl = Alphabet.rgb2hsl(rgb);
-  hsl.l += (1.0 - hsl.l) * 2 / 3;
-  return Alphabet.hsl2rgb(hsl, typeof rgb != "number");
-};
-
-//======================================================================
-// end Alphabet object
-//======================================================================
-
-//======================================================================
-// start StandardAlphabet object
-//======================================================================
-
-// an extension of the alphabet object to support some additional fields 
-// only present in standard alphabets.
-var StandardAlphabet = function(enum_code, enum_name, alphabet_data) {
-  Alphabet.apply(this, [alphabet_data]);
-  this.enum_code = enum_code;
-  this.enum_name = enum_name;
-};
-StandardAlphabet.prototype = Alphabet.prototype;
-StandardAlphabet.prototype.constructor = StandardAlphabet;
-
-// A unique code for this standard alphabet.
-// This code will be a power of 2 to enable creation of bitsets for
-// a selection of standard alphabets.
-StandardAlphabet.prototype.get_code = function() {
-  return this.enum_code;
-};
-
-// A unique name for this standard alphabet.
-// this name will be all upper case and the same as the property that
-// refers to this alphabet in the AlphStd collection.
-StandardAlphabet.prototype.get_enum = function() {
-  return this.enum_name;
-};
-
-//======================================================================
-// end StandardAlphabet object
-//======================================================================
-
-// A collection of standard alphabets.
-var AlphStd = {
-  RNA: new StandardAlphabet(1, "RNA", {
-    "name": "RNA",
-    "like": "RNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300"},
-      {"symbol": "U", "name": "Uracil", "colour": "008000",
-        "aliases": "T"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGU", "aliases": "X."},
-      {"symbol": "V", "name": "Not U", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACU"},
-      {"symbol": "D", "name": "Not C", "equals": "AGU"},
-      {"symbol": "B", "name": "Not A", "equals": "CGU"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AU"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CU"},
-      {"symbol": "K", "name": "Keto", "equals": "GU"}
-    ]
-  }), 
-  DNA: new StandardAlphabet(2, "DNA", {
-    "name": "DNA",
-    "like": "DNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000", "complement": "T"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC", "complement": "G"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300", "complement": "C"},
-      {"symbol": "T", "name": "Thymine", "colour": "008000", "complement": "A",
-        "aliases": "U"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGT", "aliases": "X."},
-      {"symbol": "V", "name": "Not T", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACT"},
-      {"symbol": "D", "name": "Not C", "equals": "AGT"},
-      {"symbol": "B", "name": "Not A", "equals": "CGT"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AT"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CT"},
-      {"symbol": "K", "name": "Keto", "equals": "GT"}
-    ]
-  }), 
-  PROTEIN: new StandardAlphabet(4, "PROTEIN", {
-    "name": "Protein",
-    "like": "PROTEIN",
-    "ncore": 20,
-    "symbols": [
-      {"symbol": "A", "name": "Alanine", "colour": "0000CC"},
-      {"symbol": "C", "name": "Cysteine", "colour": "0000CC"},
-      {"symbol": "D", "name": "Aspartic acid", "colour": "FF00FF"},
-      {"symbol": "E", "name": "Glutamic acid", "colour": "FF00FF"},
-      {"symbol": "F", "name": "Phenylalanine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Glycine", "colour": "FFB300"},
-      {"symbol": "H", "name": "Histidine", "colour": "FFCCCC"},
-      {"symbol": "I", "name": "Isoleucine", "colour": "0000CC"},
-      {"symbol": "K", "name": "Lysine", "colour": "CC0000"},
-      {"symbol": "L", "name": "Leucine", "colour": "0000CC"},
-      {"symbol": "M", "name": "Methionine", "colour": "0000CC"},
-      {"symbol": "N", "name": "Asparagine", "colour": "008000"},
-      {"symbol": "P", "name": "Proline", "colour": "FFFF00"},
-      {"symbol": "Q", "name": "Glutamine", "colour": "008000"},
-      {"symbol": "R", "name": "Arginine", "colour": "CC0000"},
-      {"symbol": "S", "name": "Serine", "colour": "008000"},
-      {"symbol": "T", "name": "Threonine", "colour": "008000"},
-      {"symbol": "V", "name": "Valine", "colour": "0000CC"},
-      {"symbol": "W", "name": "Tryptophan", "colour": "0000CC"},
-      {"symbol": "Y", "name": "Tyrosine", "colour": "33E6CC"},
-      {"symbol": "X", "name": "Any amino acid", "equals": "ACDEFGHIKLMNPQRSTVWY", "aliases": "*."},
-      {"symbol": "B", "name": "Asparagine or Aspartic acid", "equals": "DN"}, 
-      {"symbol": "Z", "name": "Glutamine or Glutamic acid", "equals": "EQ"}, 
-      {"symbol": "J", "name": "Leucine or Isoleucine", "equals": "IL"}
-    ]
-  })
-};
-
-//======================================================================
-// start Symbol object
-//======================================================================
-var Symbol = function(alph_index, scale, alphabet) {
-  "use strict";
-  //variable prototype
-  this.symbol = alphabet.get_symbol(alph_index);
-  this.scale = scale;
-  this.colour = alphabet.get_colour(alph_index);
-};
-
-Symbol.prototype.get_symbol = function() {
-  "use strict";
-  return this.symbol;
-};
-
-Symbol.prototype.get_scale = function() {
-  "use strict";
-  return this.scale;
-};
-
-Symbol.prototype.get_colour = function() {
-  "use strict";
-  return this.colour;
-};
-
-Symbol.prototype.toString = function() {
-  "use strict";
-  return this.symbol + " " + (Math.round(this.scale*1000)/10) + "%";
-};
-
-function compare_symbol(sym1, sym2) {
-  "use strict";
-  if (sym1.get_scale() < sym2.get_scale()) {
-    return -1;
-  } else if (sym1.get_scale() > sym2.get_scale()) {
-    return 1;
-  } else {
-    return 0;
-  }
-}
-//======================================================================
-// end Symbol object
-//======================================================================
-
-//======================================================================
-// start Pspm object
-//======================================================================
-var Pspm = function(matrix, name, ltrim, rtrim, nsites, evalue, pssm, alt) {
-  "use strict";
-  var row, col, data, row_sum, delta, evalue_re;
-  if (typeof name !== "string") {
-    name = "";
-  }
-  this.name = name;
-  //construct
-  if (matrix instanceof Pspm) {
-    // copy constructor
-    this.alph_length = matrix.alph_length;
-    this.motif_length = matrix.motif_length;
-    this.name = matrix.name;
-    this.alt = matrix.alt;
-    this.nsites = matrix.nsites;
-    this.evalue = matrix.evalue;
-    this.ltrim = matrix.ltrim;
-    this.rtrim = matrix.rtrim;
-    this.pspm = [];
-    for (row = 0; row < matrix.motif_length; row++) {
-      this.pspm[row] = [];
-      for (col = 0; col < matrix.alph_length; col++) {
-        this.pspm[row][col] = matrix.pspm[row][col];
-      }
-    }
-    if (matrix.pssm != null) {
-      this.pssm = [];
-      for (row = 0; row < matrix.motif_length; row++) {
-        this.pspm[row] = [];
-        for (col = 0; col < matrix.alph_length; col++) {
-          this.pssm[row][col] = matrix.pssm[row][col];
-        }
-      }
-    }
-  } else {
-    // check parameters
-    if (ltrim == null) {
-      ltrim = 0;
-    } else if (typeof ltrim !== "number" || ltrim % 1 !== 0 || ltrim < 0) {
-      throw new Error("ltrim must be a non-negative integer, got: " + ltrim);
-    }
-    if (rtrim == null) {
-      rtrim = 0;
-    } else if (typeof rtrim !== "number" || rtrim % 1 !== 0 || rtrim < 0) {
-      throw new Error("rtrim must be a non-negative integer, got: " + rtrim);
-    }
-    if (nsites != null) {
-      if (typeof nsites !== "number" || nsites < 0) {
-        throw new Error("nsites must be a positive number, got: " + nsites);
-      } else if (nsites == 0) {
-        nsites = null;
-      }
-    }
-    if (evalue != null) {
-      if (typeof evalue === "number") {
-        if (evalue < 0) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else if (typeof evalue === "string") {
-        evalue_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-        if (!evalue_re.test(evalue)) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else {
-        throw new Error("evalue must be a non-negative number, got: " + evalue);
-      }
-    }
-    // set properties
-    this.name = name;
-    this.alt = alt;
-    this.nsites = nsites;
-    this.evalue = evalue;
-    this.ltrim = ltrim;
-    this.rtrim = rtrim;
-    if (typeof matrix === "string") {
-      // string constructor
-      data = parse_pspm_string(matrix);
-      this.alph_length = data["alph_length"];
-      this.motif_length = data["motif_length"];
-      this.pspm = data["pspm"];
-      if (this.evalue == null) {
-        if (data["evalue"] != null) {
-          this.evalue = data["evalue"];
-        } else {
-          this.evalue = 0;
-        }
-      }
-      if (this.nsites == null) {
-        if (typeof data["nsites"] === "number") {
-          this.nsites = data["nsites"];
-        } else {
-          this.nsites = 20;
-        }
-      }
-    } else {
-      // assume pspm is a nested array
-      this.motif_length = matrix.length;
-      this.alph_length = (matrix.length > 0 ? matrix[0].length : 0);
-      if (this.nsites == null) {
-        this.nsites = 20;
-      }
-      if (this.evalue == null) {
-        this.evalue = 0;
-      }
-      this.pspm = [];
-      // copy pspm and check
-      for (row = 0; row < this.motif_length; row++) {
-        if (this.alph_length != matrix[row].length) {
-          throw new Error("COLUMN_MISMATCH");
-        }
-        this.pspm[row] = [];
-        row_sum = 0;
-        for (col = 0; col < this.alph_length; col++) {
-          this.pspm[row][col] = matrix[row][col];
-          row_sum += this.pspm[row][col];
-        }
-        delta = 0.1;
-        if (isNaN(row_sum) || (row_sum > 1 && (row_sum - 1) > delta) || 
-            (row_sum < 1 && (1 - row_sum) > delta)) {
-          throw new Error("INVALID_SUM");
-        }
-      }
-      // copy pssm
-      if (pssm != null) {
-        this.pssm = [];
-        for (row = 0; row < this.motif_length; row++) {
-          this.pssm[row] = [];
-          for (col = 0; col < this.alph_length; col++) {
-            this.pssm[row][col] = pssm[row][col];
-          }
-        }
-      }
-    }
-  }
-};
-
-Pspm.prototype.copy = function() {
-  "use strict";
-  return new Pspm(this);
-};
-
-Pspm.prototype.reverse = function() {
-  "use strict";
-  var x, y, temp, temp_trim;
-  //reverse
-  x = 0;
-  y = this.motif_length-1;
-  while (x < y) {
-    temp = this.pspm[x];
-    this.pspm[x] = this.pspm[y];
-    this.pspm[y] = temp;
-    x++;
-    y--;
-  }
-  // reverse pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //reverse
-    x = 0;
-    y = this.motif_length-1;
-    while (x < y) {
-      temp = this.pssm[x];
-      this.pspm[x] = this.pssm[y];
-      this.pssm[y] = temp;
-      x++;
-      y--;
-    }
-  }
-  //swap triming
-  temp_trim = this.ltrim;
-  this.ltrim = this.rtrim;
-  this.rtrim = temp_trim;
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.reverse_complement = function(alphabet) {
-  "use strict";
-  var x, y, temp, i, row, c, temp_trim;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  if (!alphabet.has_complement()) {
-    throw new Error("The specified alphabet can not be complemented.");
-  }
-  // reverse motif
-  this.reverse();
-  //complement
-  for (x = 0; x < this.motif_length; x++) {
-    row = this.pspm[x];
-    for (i = 0; i < row.length; i++) {
-      c = alphabet.get_complement(i);
-      if (c < i) continue;
-      temp = row[i];
-      row[i] = row[c];
-      row[c] = temp;
-    }
-  }
-  // complement pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //complement
-    for (x = 0; x < this.motif_length; x++) {
-      row = this.pssm[x];
-      for (i = 0; i < row.length; i++) {
-        c = alphabet.get_complement(i);
-        if (c < i) continue;
-        temp = row[i];
-        row[i] = row[c];
-        row[c] = temp;
-      }
-    }
-  }
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.get_stack = function(position, alphabet, ssc) {
-  "use strict";
-  var row, stack_ic, alphabet_ic, stack, i, sym;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  row = this.pspm[position];
-  stack_ic = this.get_stack_ic(position, alphabet);
-  if (ssc) stack_ic -= this.get_error(alphabet);
-  alphabet_ic = alphabet.get_ic();
-  stack = [];
-  for (i = 0; i < this.alph_length; i++) {
-    sym = new Symbol(i, row[i]*stack_ic/alphabet_ic, alphabet);
-    if (sym.get_scale() <= 0) {
-      continue;
-    }
-    stack.push(sym);
-  }
-  stack.sort(compare_symbol);
-  return stack;
-};
-
-Pspm.prototype.get_stack_ic = function(position, alphabet) {
-  "use strict";
-  var row, H, i;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size fo the pspm.");
-  }
-  row = this.pspm[position];
-  H = 0;
-  for (i = 0; i < this.alph_length; i++) {
-    if (row[i] === 0) {
-      continue;
-    }
-    H -= (row[i] * (Math.log(row[i]) / Math.LN2));
-  }
-  return alphabet.get_ic() - H;
-};
-
-Pspm.prototype.get_error = function(alphabet) {
-  "use strict";
-  if (this.nsites === 0) {
-    return 0;
-  }
-  return (alphabet.get_size_core()-1) / (2 * Math.LN2 * this.nsites);
-};
-
-Pspm.prototype.get_motif_length = function() {
-  "use strict";
-  return this.motif_length;
-};
-
-Pspm.prototype.get_alph_length = function() {
-  "use strict";
-  return this.alph_length;
-};
-
-Pspm.prototype.get_left_trim = function() {
-  "use strict";
-  return this.ltrim;
-};
-
-Pspm.prototype.get_right_trim = function() {
-  "use strict";
-  return this.rtrim;
-};
-
-Pspm.prototype.as_best_match = function(alphabet) {
-  "use strict";
-  var match, odds, best_odds, best_index;
-  var i, j;
-  match = "";
-  for (i = 0; i < this.motif_length; i++) {
-    best_index = 0;
-    best_odds = this.pspm[i][0] / alphabet.get_bg_freq(0);
-    for (j = 1; j < this.alph_length; j++) {
-      odds = this.pspm[i][j] / alphabet.get_bg_freq(j);
-      if (odds > best_odds) {
-        best_odds = odds;
-        best_index = j;
-      }
-    }
-    match += alphabet.get_symbol(best_index);
-  }
-  return match;
-};
-
-Pspm.prototype.as_count_matrix = function() {
-  "use strict";
-  var count, count_text, text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      count = Math.round(this.nsites * this.pspm[i][j]);
-      count_text = "" + count;
-      // pad up to length of 4
-      if (count_text.length < 4) {
-        text += (new Array(5 - count_text.length)).join(" ") + count_text;
-      } else {
-        text += count_text;
-      }
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_probability_matrix = function() {
-  "use strict";
-  var text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      text += this.pspm[i][j].toFixed(6);
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_score_matrix = function(alphabet, pseudo) {
-  "use strict";
-  var me, score, out, row, col, score_text;
-  me = this;
-  if (typeof this.pssm === "undefined") {
-    if (!(typeof alphabet === "object" && alphabet != null && alphabet instanceof Alphabet)) {
-      throw new Error("The alphabet is required to generate the pssm.");
-    }
-    if (typeof pseudo === "undefined") {
-      pseudo = 0.01;
-    } else if (typeof pseudo !== "number" || pseudo < 0) {
-      throw new Error("Expected positive number for pseudocount");
-    }
-    score = function(row, col) {
-      "use strict";
-      var p, bg, p2;
-      p = me.pspm[row][col];
-      bg = alphabet.get_bg_freq(col);
-      p2 = (p * me.nsites + bg * pseudo) / (me.nsites + pseudo);
-      return (p2 > 0 ? Math.round((Math.log(p2 / bg) / Math.LN2) * 100) : -10000);
-    };
-  } else {
-    score = function(row, col) {
-      "use strict";
-      return me.pssm[row][col];
-    };
-  }
-  out = "";
-  for (row = 0; row < this.motif_length; row++) {
-    for (col = 0; col < this.alph_length; col++) {
-      if (col !== 0) {
-        out += " ";
-      }
-      score_text = "" + score(row, col);
-      // pad out to 6 characters
-      if (score_text.length < 6) {
-        out += (new Array(7 - score_text.length)).join(" ") + score_text;
-      } else {
-        out += score_text;
-      }
-    }
-    out += "\n";
-  }
-  return out;
-}
-
-Pspm.prototype.as_pspm = function() {
-  "use strict";
-  return "letter-probability matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + " nsites= " + this.nsites + 
-      " E= " + (typeof this.evalue === "number" ? 
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_probability_matrix();
-};
-
-Pspm.prototype.as_pssm = function(alphabet, pseudo) {
-  "use strict";
-  return "log-odds matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + 
-      " E= " + (typeof this.evalue == "number" ?
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_score_matrix(alphabet, pseudo);
-};
-
-Pspm.prototype.as_meme = function(options) {
-  var with_header, with_pspm, with_pssm, version, alphabet, bg_source, pseudocount, strands;
-  var out, alen, i;
-  // get the options
-  if (typeof options !== "object" || options === null) {
-    options = {};
-  }
-  with_header = (typeof options["with_header"] === "boolean" ? options["with_header"] : false);
-  with_pspm = (typeof options["with_pspm"] === "boolean" ? options["with_pspm"] : false);
-  with_pssm = (typeof options["with_pssm"] === "boolean" ? options["with_pssm"] : false);
-  if (!with_pspm && !with_pssm) with_pspm = true;
-  if (with_header) {
-    if (typeof options["version"] === "string" && /^\d+(?:\.\d+){0,2}$/.test(options["version"])) {
-      version = options["version"];
-    } else if (typeof options["version"] === "number") {
-      version = options["version"].toFixed(0);
-    } else {
-      version = "4";
-    }
-    if (typeof options["strands"] === "number" && options["strands"] === 1) {
-      strands = 1;
-    } else {
-      strands = 2;
-    }
-    if (typeof options["bg_source"] === "string") {
-      bg_source = options["bg_source"];
-    } else {
-      bg_source = "unknown source";
-    }
-    if (typeof options["alphabet"] === "object" && options["alphabet"] != null
-        && options["alphabet"] instanceof Alphabet) {
-      alphabet = options["alphabet"];
-    } else {
-      throw new Error("The alphabet is required to generate the header.");
-    }
-  }
-  // now create the output
-  out = "";
-  if (with_header) {
-    out = "MEME version " + version + "\n\n";
-    out += alphabet.as_meme() + "\n";
-    if (alphabet.has_complement()) { // assume DNA has both strands unless otherwise specified
-      out += "strands: " + (strands === 1 ? "+" : "+ -") + "\n\n";
-    }
-    out += "Background letter frequencies (from " + bg_source + "):\n";
-    alen = alphabet.get_size_core();
-    for (i = 0; i < alen; i++) {
-      if (i !== 0) {
-        if (i % 9 === 0) { // maximum of nine entries per line
-          out += "\n";
-        } else {
-          out += " ";
-        }
-      }
-      out += alphabet.get_symbol(i) + " " + alphabet.get_bg_freq(i).toFixed(3);
-    }
-  }
-  out += "\n\n";
-  out += "MOTIF " + this.name + (this.alt == null ? "" : " " + this.alt);
-  if (with_pssm) {
-    out += "\n\n";
-    out += this.as_pssm(options["alphabet"], options["pseudocount"]);
-  }
-  if (with_pspm) {
-    out += "\n\n";
-    out += this.as_pspm();
-  }
-  return out;
-}
-
-Pspm.prototype.toString = function() {
-  "use strict";
-  var str, i, row;
-  str = "";
-  for (i = 0; i < this.pspm.length; i++) {
-    row = this.pspm[i];
-    str += row.join("\t") + "\n";
-  }
-  return str;
-};
-
-function parse_pspm_properties(str) {
-  "use strict";
-  var parts, i, eqpos, before, after, properties, prop, num, num_re;
-  num_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-  parts = trim(str).split(/\s+/);
-  // split up words containing =
-  for (i = 0; i < parts.length;) {
-    eqpos = parts[i].indexOf("=");
-    if (eqpos != -1) {
-      before = parts[i].substr(0, eqpos);
-      after = parts[i].substr(eqpos+1);
-      if (before.length > 0 && after.length > 0) {
-        parts.splice(i, 1, before, "=", after);
-        i += 3;
-      } else if (before.length > 0) {
-        parts.splice(i, 1, before, "=");
-        i += 2;
-      } else if (after.length > 0) {
-        parts.splice(i, 1, "=", after);
-        i += 2;
-      } else {
-        parts.splice(i, 1, "=");
-        i++;
-      }
-    } else {
-      i++;
-    }
-  }
-  properties = {};
-  for (i = 0; i < parts.length; i += 3) {
-    if (parts.length - i < 3) {
-      throw new Error("Expected PSPM property was incomplete. "+
-          "Remaing parts are: " + parts.slice(i).join(" "));
-    }
-    if (parts[i+1] !== "=") {
-      throw new Error("Expected '=' in PSPM property between key and " +
-          "value but got " + parts[i+1]); 
-    }
-    prop = parts[i].toLowerCase();
-    num = parts[i+2];
-    if (!num_re.test(num)) {
-      throw new Error("Expected numeric value for PSPM property '" + 
-          prop + "' but got '" + num + "'");
-    }
-    properties[prop] = num;
-  }
-  return properties;
-}
-
-function parse_pspm_string(pspm_string) {
-  "use strict";
-  var header_re, lines, first_line, line_num, col_num, alph_length, 
-      motif_length, nsites, evalue, pspm, i, line, match, props, parts,
-      j, prob;
-  header_re = /^letter-probability\s+matrix:(.*)$/i;
-  lines = pspm_string.split(/\n/);
-  first_line = true;
-  line_num = 0;
-  col_num = 0;
-  alph_length;
-  motif_length;
-  nsites;
-  evalue;
-  pspm = [];
-  for (i = 0; i < lines.length; i++) {
-    line = trim(lines[i]);
-    if (line.length === 0) { 
-      continue;
-    }
-    // check the first line for a header though allow matrices without it
-    if (first_line) {
-      first_line = false;
-      match = header_re.exec(line);
-      if (match !== null) {
-        props = parse_pspm_properties(match[1]);
-        if (props.hasOwnProperty("alength")) {
-          alph_length = parseFloat(props["alength"]);
-          if (alph_length != 4 && alph_length != 20) {
-            throw new Error("PSPM property alength should be 4 or 20" +
-                " but got " + alph_length);
-          }
-        }
-        if (props.hasOwnProperty("w")) {
-          motif_length = parseFloat(props["w"]);
-          if (motif_length % 1 !== 0 || motif_length < 1) {
-            throw new Error("PSPM property w should be an integer larger " +
-                "than zero but got " + motif_length);
-          }
-        }
-        if (props.hasOwnProperty("nsites")) {
-          nsites = parseFloat(props["nsites"]);
-          if (nsites <= 0) {
-            throw new Error("PSPM property nsites should be larger than " +
-                "zero but got " + nsites);
-          }
-        }
-        if (props.hasOwnProperty("e")) {
-          evalue = props["e"];
-          if (evalue < 0) {
-            throw new Error("PSPM property evalue should be " +
-                "non-negative but got " + evalue);
-          }
-        }
-        continue;
-      }
-    }
-    pspm[line_num] = [];
-    col_num = 0;
-    parts = line.split(/\s+/);
-    for (j = 0; j < parts.length; j++) {
-      prob = parseFloat(parts[j]);
-      if (prob != parts[j] || prob < 0 || prob > 1) {
-        throw new Error("Expected probability but got '" + parts[j] + "'"); 
-      }
-      pspm[line_num][col_num] = prob;
-      col_num++;
-    }
-    line_num++;
-  }
-  if (typeof motif_length === "number") {
-    if (pspm.length != motif_length) {
-      throw new Error("Expected PSPM to have a motif length of " + 
-          motif_length + " but it was actually " + pspm.length);
-    }
-  } else {
-    motif_length = pspm.length;
-  }
-  if (typeof alph_length !== "number") {
-    alph_length = pspm[0].length;
-    if (alph_length != 4 && alph_length != 20) {
-      throw new Error("Expected length of first row in the PSPM to be " +
-          "either 4 or 20 but got " + alph_length);
-    }
-  }
-  for (i = 0; i < pspm.length; i++) {
-    if (pspm[i].length != alph_length) {
-      throw new Error("Expected PSPM row " + i + " to have a length of " + 
-          alph_length + " but the length was " + pspm[i].length);
-    }
-  }
-  return {"pspm": pspm, "motif_length": motif_length, 
-    "alph_length": alph_length, "nsites": nsites, "evalue": evalue};
-}
-//======================================================================
-// end Pspm object
-//======================================================================
-
-//======================================================================
-// start Logo object
-//======================================================================
-
-var Logo = function(alphabet, options) {
-  "use strict";
-  this.alphabet = alphabet;
-  this.fine_text = "";
-  this.x_axis = 1;
-  this.y_axis = true;
-  this.xlate_nsyms = 1;
-  this.xlate_start = null;
-  this.xlate_end = null;
-  this.pspm_list = [];
-  this.pspm_column = [];
-  this.rows = 0;
-  this.columns = 0;
-  if (typeof options === "string") {
-    // the old method signature had fine_text here so we support that
-    this.fine_text = options;
-  } else if (typeof options === "object" && options != null) {
-    this.fine_text = (typeof options.fine_text === "string" ? options.fine_text : "");
-    this.x_axis = (typeof options.x_axis === "boolean" ? (options.x_axis ? 1 : 0) : 1);
-    if (options.x_axis_hidden != null && options.x_axis_hidden) this.x_axis = -1;
-    this.y_axis = (typeof options.y_axis === "boolean" ? options.y_axis : true);
-    this.xlate_nsyms = (typeof options.xlate_nsyms === "number" ? options.xlate_nsyms : this.xlate_nsyms);
-    this.xlate_start = (typeof options.xlate_start === "number" ? options.xlate_start : this.xlate_start);
-    this.xlate_end = (typeof options.xlate_end === "number" ? options.xlate_end : this.xlate_end);
-  }
-};
-
-Logo.prototype.add_pspm = function(pspm, column) {
-  "use strict";
-  var col;
-  if (typeof column === "undefined") {
-    column = 0;
-  } else if (column < 0) {
-    throw new Error("Column index out of bounds.");
-  }
-  this.pspm_list[this.rows] = pspm;
-  this.pspm_column[this.rows] = column;
-  this.rows++;
-  col = column + pspm.get_motif_length();
-  if (col > this.columns) {
-    this.columns = col;
-  }
-};
-
-Logo.prototype.get_columns = function() {
-  "use strict";
-  return this.columns;
-};
-
-Logo.prototype.get_xlate_nsyms = function() {
-  "use strict";
-  return this.xlate_nsyms;
-};
-
-Logo.prototype.get_xlate_start = function() {
-  "use strict";
-  return (this.xlate_start != null ? this.xlate_start : 0);
-};
-
-Logo.prototype.get_xlate_end = function() {
-  "use strict";
-  return (this.xlate_end != null ? this.xlate_end : this.columns * this.xlate_nsyms);
-};
-
-Logo.prototype.get_xlate_columns = function() {
-  "use strict";
-  return this.get_xlate_end() - this.get_xlate_start();
-};
-
-Logo.prototype.get_rows = function() {
-  "use strict";
-  return this.rows;
-};
-
-Logo.prototype.get_pspm = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_list[row_index];
-};
-
-Logo.prototype.get_offset = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_column[row_index];
-};
-
-Logo.prototype._as_eps_data = function(ssc, errbars) {
-  var i, j, pos, stack_pos, pspm, stack, sym, out;
-  out = "";
-  for (i = 0; i < this.rows; i++) {
-    out += "\nStartLine\n";
-    // Indent
-    for (j = 0; j < this.pspm_column[i]; j++) {
-      out += "() startstack\nendstack\n\n";
-    }
-    pspm = this.pspm_list[i];
-    if (pspm.get_left_trim() > 0) {
-      out += "MuteColour\nDrawTrimEdge\n" + pspm.get_left_trim() + " DrawTrimBg\n";
-    }
-    for (pos = 0; pos < pspm.get_motif_length(); pos++) {
-      if (pos != 0 && pos == pspm.get_left_trim()) { // enable full colour
-        out += "DrawTrimEdge\nRestoreColour\n";
-      } else if (pos == (pspm.get_motif_length() - pspm.get_right_trim())) {
-        out += "MuteColour\n" + pspm.get_right_trim() + " DrawTrimBg\n";
-      }
-      out += "(" + (pos + 1) + ") startstack\n";
-      stack = pspm.get_stack(pos, this.alphabet, ssc);
-      for (stack_pos = 0; stack_pos < stack.length; stack_pos++) {
-        sym = stack[stack_pos];
-        out += " " + (sym.get_scale() * this.alphabet.get_ic()) + " (" + sym.get_symbol() + ") numchar\n";
-      }
-      if (errbars) {
-        out += " " + pspm.get_error(this.alphabet) + " Ibeam\n";
-      }
-      out += "endstack\n\n";
-    }
-    if (pspm.get_right_trim() > 0 || pspm.get_left_trim() == pspm.get_motif_length()) {
-      out += "RestoreColour\n";
-    }
-    out += "EndLine\n";
-  }
-  return out;
-};
-
-Logo.prototype.as_eps = function(options) {
-  "use strict";
-  if (this.xlate_nsyms != 1) throw new Error("Unsupported setting xlate_nsyms for EPS");
-  if (this.xlate_start != null) throw new Error("Unsupported setting xlate_start for EPS");
-  if (this.xlate_end != null) throw new Error("Unsupported setting xlate_end for EPS");
-
-  var LOGOHEIGHT = 7.5; // default height of line in cm
-  var cm2pts, height, width, now, ssc, errbars;
-  if (typeof options === "undefined") {
-    options = {};
-  }
-  cm2pts = 72 / 2.54;
-  if (typeof options.logo_height == "number") {
-    height = options.logo_height;
-  } else {
-    height = LOGOHEIGHT * this.rows;
-  }
-  if (typeof options.logo_width == "number") {
-    width = options.logo_width;
-  } else {
-    width = this.columns + 2;
-  }
-  now = new Date();
-  ssc = (typeof options.ssc == "boolean" ? options.ssc : false);
-  errbars = (typeof options.show_error_bar == "boolean" ? options.show_error_bar : ssc);
-  var values = {
-    "LOGOHEIGHT": height,
-    "LOGOWIDTH": width,
-    "BOUNDINGHEIGHT": Math.round(height * cm2pts),
-    "BOUNDINGWIDTH": Math.round(width * cm2pts),
-    "LOGOLINEHEIGHT": (height / this.rows),
-    "CHARSPERLINE": this.columns,
-    "BARBITS": this.alphabet.get_ic(),
-    "LOGOTYPE": (this.alphabet.has_complement() ? "NA" : "AA"),
-    "CREATIONDATE": now.getDate() + "." + (now.getMonth() + 1) + "." + now.getFullYear() + " " + now.getHours() + ":" + now.getMinutes() + ":" + now.getSeconds(),
-    "ERRORBARFRACTION": (typeof options.error_bar_fraction == "number" ? options.error_bar_fraction : 1.0),
-    "TICBITS": (typeof options.ticbits == "number" ? options.ticbits : 1.0),
-    "TITLE": (typeof options.title == "string" ? options.title : ""),
-    "FINEPRINT": (typeof options.fineprint == "string" ? options.fineprint : this.fine_text),
-    "XAXISLABEL": (typeof options.xaxislabel == "string" ? options.xaxislabel : ""),
-    "YAXISLABEL": (typeof options.yaxislabel == "string" ? options.yaxislabel : "bits"),
-    "SSC": ssc,
-    "YAXIS": (typeof options.show_y_axis == "boolean" ? options.show_y_axis : this.y_axis),
-    "SHOWENDS": (typeof options.show_ends == "boolean" ? options.show_ends : false),
-    "ERRBAR": errbars,
-    "OUTLINE": (typeof options.show_outline == "boolean" ? options.show_outline : false),
-    "NUMBERING": (typeof options.show_numbering == "boolean" ? options.show_numbering : this.x_axis != 0),
-    "SHOWINGBOX": (typeof options.show_box == "boolean" ? options.show_box : false),
-    "CREATOR": (typeof options.creator == "string" ? options.creator : "motif_logo.js"),
-    "FONTSIZE": (typeof options.label_font_size == "number" ? options.label_font_size : 12),
-    "TITLEFONTSIZE": (typeof options.title_font_size == "number" ? options.title_font_size : 12),
-    "SMALLFONTSIZE": (typeof options.small_font_size == "number" ? options.small_font_size : 6),
-    "TOPMARGIN" : (typeof options.top_margin == "number" ? options.top_margin : 0.9),
-    "BOTTOMMARGIN": (typeof options.bottom_margin == "number" ? options.bottom_margin : 0.9),
-    "COLORDICT": this.alphabet._as_eps_dict(),
-    "DATA": this._as_eps_data(ssc, errbars)
-  };
-  // now this requires that the script containing the template has been imported!
-  return motif_logo_template(values);
-};
-
-//======================================================================
-// end Logo object
-//======================================================================
-
-// calculate the exact size (in pixels) of an object drawn on the
-// canvas assuming that the background of the canvas is transparent.
-function canvas_bounds(ctx, cwidth, cheight) {
-  "use strict";
-  var data, r, c, top_line, bottom_line, left_line, right_line, 
-      txt_width, txt_height;
-
-  // extract the image data
-  data = ctx.getImageData(0, 0, cwidth, cheight).data;
-
-  // set initial values
-  top_line = -1; bottom_line = -1; left_line = -1; right_line = -1;
-  txt_width = 0; txt_height = 0;
-
-  // Find the top-most line with a non-transparent pixel
-  for (r = 0; r < cheight; r++) {
-    for (c = 0; c < cwidth; c++) {
-      if (data[r * cwidth * 4 + c * 4 + 3]) {
-        top_line = r;
-        break;
-      }
-    }
-    if (top_line != -1) {
-      break;
-    }
-  }
-  
-  // Only bother looking if we found at least one set pixel... 
-  if (top_line != -1) {
-
-    //find the last line with a non-transparent pixel
-    for (r = cheight-1; r >= top_line; r--) {
-      for(c = 0; c < cwidth; c++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          bottom_line = r;
-          break;
-        }
-      }
-      if (bottom_line != -1) {
-        break;
-      }
-    }
-    // calculate height
-    txt_height = bottom_line - top_line + 1;
-
-    // Find the left-most line with a non-transparent pixel
-    for (c = 0; c < cwidth; c++) {
-      for (r = top_line; r <= bottom_line; r++) {
-        if (data[r * cwidth * 4 + c * 4 + 3]) {
-          left_line = c;
-          break;
-        }
-      }
-      if (left_line != -1) {
-        break;
-      }
-    }
-
-    //find the right most line with a non-transparent pixel
-    for (c = cwidth-1; c >= left_line; c--) {
-      for(r = top_line; r <= bottom_line; r++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          right_line = c;
-          break;
-        }
-      }
-      if (right_line != -1) {
-        break;
-      }
-    }
-    txt_width = right_line - left_line + 1;
-  }
-
-  //return the bounds
-  return {bound_top: top_line, bound_bottom: bottom_line, 
-    bound_left: left_line, bound_right: right_line, width: txt_width, 
-    height: txt_height};
-}
-
-//======================================================================
-// start RasterizedAlphabet
-//======================================================================
-
-// Rasterize Alphabet
-// 1) Measure width of text at default font for all symbols in alphabet
-// 2) sort in width ascending
-// 3) Drop the top and bottom 10% (designed to ignore outliers like 'W' and 'I')
-// 4) Calculate the average as the maximum scaling factor (designed to stop I becoming a rectangular blob).
-// 5) Assume scale of zero would result in width of zero, interpolate scale required to make perfect width font
-// 6) Draw text onto temp canvas at calculated scale
-// 7) Find bounds of drawn text
-// 8) Paint on to another canvas at the desired height (but only scaling width to fit if larger).
-var RasterizedAlphabet = function(alphabet, logo_scale, font, width) {
-  "use strict";
-  var default_size, safety_pad, canvas, ctx, middle, baseline, widths, sizes,
-      i, sym, size, tenpercent, avg_width, scale, 
-      target_width, target_height;
-  //variable prototypes
-  this.alphabet = alphabet;
-  this.scale = logo_scale;
-  this.sym_cache = {};
-  this.stack_num_cache = [];
-  this.scale_num_cache = [];
-  // size of canvas
-  default_size = 60; // size of measuring canvas
-  safety_pad = 20; // pixels to pad around so we don't miss the edges
-  // create a canvas to do our measuring
-  canvas = document.createElement("canvas");
-  if (!canvas.getContext) throw new Error("No canvas support");
-  canvas.width = default_size + 2 * safety_pad;
-  canvas.height = default_size + 2 * safety_pad;
-  middle = Math.round(canvas.width / 2);
-  baseline = Math.round(canvas.height - safety_pad);
-  ctx = canvas.getContext('2d');
-  if (!supports_text(ctx)) throw new Error("Canvas does not support text");
-  ctx.font = font;
-  ctx.textAlign = "center";
-  ctx.translate(middle, baseline);
-  // list of widths
-  widths = [];
-  sizes = [];
-  //now measure each letter in the alphabet
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    // reset the canvas
-    ctx.clearRect(0, 0, canvas.width, canvas.height);
-    ctx.fillStyle = alphabet.get_colour(i);
-    // draw the test text
-    ctx.fillText(alphabet.get_symbol(i), 0, 0);
-    //measure
-    size = canvas_bounds(ctx, canvas.width, canvas.height);
-    if (size.width === 0) throw new Error("Invisible symbol!");
-    widths.push(size.width);
-    sizes[i] = size;
-  }
-  //sort the widths
-  widths.sort(function(a,b) {return a - b;});
-  //drop 10% of the items off each end
-  tenpercent = Math.floor(widths.length / 10);
-  for (i = 0; i < tenpercent; ++i) {
-    widths.pop();
-    widths.shift();
-  }
-  //calculate average width
-  avg_width = 0;
-  for (i = 0; i < widths.length; ++i) {
-    avg_width += widths[i];
-  }
-  avg_width /= widths.length;
-  // calculate the target width
-  target_width = width * this.scale * 2;
-  // calculate scales
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    sym = alphabet.get_symbol(i);
-    size = sizes[i];
-    // calculate scale
-    scale = target_width / Math.max(avg_width, size.width);
-    // estimate scaled height
-    target_height = size.height * scale;
-    // create an appropriately sized canvas
-    canvas = document.createElement("canvas");
-    canvas.width = target_width;
-    canvas.height = target_height + safety_pad * 2;
-    // calculate the middle
-    middle = Math.round(canvas.width / 2);
-    // calculate the baseline
-    baseline = Math.round(canvas.height - safety_pad);
-    // get the context and prepare to draw the rasterized text
-    ctx = canvas.getContext('2d');
-    ctx.font = font;
-    ctx.fillStyle = alphabet.get_colour(i);
-    ctx.textAlign = "center";
-    ctx.translate(middle, baseline);
-    ctx.save();
-    ctx.scale(scale, scale);
-    // draw the text
-    ctx.fillText(sym, 0, 0);
-    ctx.restore();
-    this.sym_cache[sym] = {"image": canvas, "size": canvas_bounds(ctx, canvas.width, canvas.height)};
-  }
-};
-
-RasterizedAlphabet.prototype.get_alphabet = function() {
-  return this.alphabet;
-};
-
-RasterizedAlphabet.prototype.get_scale = function() {
-  return this.scale;
-};
-
-RasterizedAlphabet.prototype.draw_stack_sym = function(ctx, letter, dx, dy, dWidth, dHeight) {
-  "use strict";
-  var entry, image, size;
-  entry = this.sym_cache[letter];
-  image = entry.image;
-  size = entry.size;
-  ctx.drawImage(image, 0, size.bound_top -1, image.width, size.height+1, dx, dy, dWidth, dHeight);
-};
-
-RasterizedAlphabet.prototype.draw_stack_num = function(ctx, font, stack_width, index) {
-  var image, image_ctx, text_length;
-  if (index >= this.stack_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.save();
-    image_ctx.font = font;
-    text_length = image_ctx.measureText("" + (index + 1)).width;
-    image_ctx.restore();
-    // resize the canvas to fit
-    image.width = Math.ceil(stack_width);
-    image.height = Math.ceil(text_length);
-    // draw the text
-    image_ctx = image.getContext('2d');
-    image_ctx.translate(Math.round(stack_width / 2), 0);
-    image_ctx.font = font;
-    image_ctx.textBaseline = "middle";
-    image_ctx.textAlign = "right";
-    image_ctx.rotate(-(Math.PI / 2));
-    image_ctx.fillText("" + (index + 1), 0, 0);
-    this.stack_num_cache[index] = image;
-  } else {
-    image = this.stack_num_cache[index];
-  }
-  ctx.drawImage(image, 0, 0);
-}
-
-RasterizedAlphabet.prototype.draw_scale_num = function(ctx, font, num) {
-  var image, image_ctx, text_size, m_length;
-  if (num >= this.scale_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.font = font;
-    text_size = image_ctx.measureText("" + num);
-    if (text_size.actualBoundingBoxAscent && text_size.actualBoundingBoxDesent) {
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(text_size.actualBoundingBoxAscent + text_size.actualBoundingBoxDesent);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.fillText("" + num, image.width, text_size.actualBoundingBoxAscent);
-    } else {
-      // measure width of 'm' to approximate height, we double it later anyway
-      m_length = image_ctx.measureText("m").width;
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(2 * m_length);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.textBaseline = "middle";
-      image_ctx.fillText("" + num, image.width, m_length);
-    }
-    this.scale_num_cache[num] = image;
-  } else {
-    image = this.scale_num_cache[num];
-  }
-  ctx.drawImage(image, -image.width, -Math.round(image.height / 2))
-}
-
-//======================================================================
-// end RasterizedAlphabet
-//======================================================================
-
-//======================================================================
-// start LogoMetrics object
-//======================================================================
-
-var LogoMetrics = function(ctx, logo_columns, logo_rows, has_names, has_finetext, x_axis, y_axis) {
-  "use strict";
-  var i, row_height;
-  //variable prototypes
-  this.pad_top = (has_names ? 5 : 0);
-  this.pad_left = (y_axis ? 10 : 0);
-  this.pad_right = (has_finetext ? 15 : 0);
-  this.pad_bottom = 0;
-  this.pad_middle = 20;
-  this.name_height = 14;
-  this.name_font = "bold " + this.name_height + "px Times, sans-serif";
-  this.name_spacer = 0;
-  this.y_axis = y_axis;
-  this.y_label = "bits";
-  this.y_label_height = 12;
-  this.y_label_font = "bold " + this.y_label_height + "px Helvetica, sans-serif";
-  this.y_label_spacer = 3;
-  this.y_num_height = 12;
-  this.y_num_width = 0;
-  this.y_num_font = "bold " + this.y_num_height + "px Helvetica, sans-serif";
-  this.y_tic_width = 5;
-  this.stack_pad_left = 0;
-  this.stack_font = "bold 25px Helvetica, sans-serif";
-  this.stack_height = 90;
-  this.stack_width = 26;
-  this.stacks_pad_right = 5;
-  this.x_axis = x_axis;
-  this.x_num_above = 2;
-  this.x_num_height = 12;
-  this.x_num_width = 0;
-  this.x_num_font = "bold " + this.x_num_height + "px Helvetica, sans-serif";
-  this.fine_txt_height = 6;
-  this.fine_txt_above = 2;
-  this.fine_txt_font = "normal " + this.fine_txt_height + "px Helvetica, sans-serif";
-  this.letter_metrics = new Array();
-  this.summed_width = 0;
-  this.summed_height = 0;
-  //calculate the width of the y axis numbers
-  ctx.font = this.y_num_font;
-  for (i = 0; i <= 2; i++) {
-    this.y_num_width = Math.max(this.y_num_width, ctx.measureText("" + i).width);
-  }
-  //calculate the width of the x axis numbers (but they are rotated so it becomes height)
-  if (x_axis == 1) {
-    ctx.font = this.x_num_font;
-    for (i = 1; i <= logo_columns; i++) {
-      this.x_num_width = Math.max(this.x_num_width, ctx.measureText("" + i).width);
-    }
-  } else if (x_axis == 0) {
-    this.x_num_height = 4;
-    this.x_num_width = 4;
-  } else {
-    this.x_num_height = 0;
-    this.x_num_width = 0;
-  }
-  
-  //calculate how much vertical space we want to draw this
-  //first we add the padding at the top and bottom since that's always there
-  this.summed_height += this.pad_top + this.pad_bottom;
-  //all except the last row have the same amount of space allocated to them
-  if (logo_rows > 1) {
-    row_height = this.stack_height + this.pad_middle;
-    if (has_names) {
-      row_height += this.name_height;
-      //the label is allowed to overlap into the spacer
-      row_height += Math.max(this.y_num_height/2, this.name_spacer); 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    } else {
-      row_height += this.y_num_height/2; 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    }
-    this.summed_height += row_height * (logo_rows - 1);
-  }
-  //the last row has the name and fine text below it but no padding
-  this.summed_height += this.stack_height + (this.y_axis ? this.y_num_height/2 : 0);
-
-  var fine_txt_total = (has_finetext ? this.fine_txt_height + this.fine_txt_above : 0);
-  if (has_names) {
-    this.summed_height += fine_txt_total + this.name_height;
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + this.name_spacer);
-  } else {
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + fine_txt_total);
-  }
-
-  //calculate how much horizontal space we want to draw this
-  //first add the padding at the left and right since that's always there
-  this.summed_width += this.pad_left + this.pad_right;
-  if (this.y_axis) {
-    //add on the space for the y-axis label
-    this.summed_width += this.y_label_height + this.y_label_spacer;
-    //add on the space for the y-axis
-    this.summed_width += this.y_num_width + this.y_tic_width;
-  }
-  //add on the space for the stacks
-  this.summed_width += (this.stack_pad_left + this.stack_width) * logo_columns;
-  //add on the padding after the stacks (an offset from the fine text)
-  this.summed_width += this.stacks_pad_right;
-
-};
-
-//======================================================================
-// end LogoMetrics object
-//======================================================================
-
-//found this trick at http://talideon.com/weblog/2005/02/detecting-broken-images-js.cfm
-function image_ok(img) {
-  "use strict";
-  // During the onload event, IE correctly identifies any images that
-  // weren't downloaded as not complete. Others should too. Gecko-based
-  // browsers act like NS4 in that they report this incorrectly.
-  if (!img.complete) {
-    return false;
-  }
-  // However, they do have two very useful properties: naturalWidth and
-  // naturalHeight. These give the true size of the image. If it failed
-  // to load, either of these should be zero.
-  if (typeof img.naturalWidth !== "undefined" && img.naturalWidth === 0) {
-    return false;
-  }
-  // No other way of checking: assume it's ok.
-  return true;
-}
-  
-function supports_text(ctx) {
-  "use strict";
-  if (!ctx.fillText) {
-    return false;
-  }
-  if (!ctx.measureText) {
-    return false;
-  }
-  return true;
-}
-
-//draws the scale, returns the width
-function draw_scale(ctx, metrics, alphabet_ic, raster) {
-  "use strict";
-  var tic_height, i;
-  tic_height = metrics.stack_height / alphabet_ic;
-  ctx.save();
-  ctx.translate(metrics.y_label_height, metrics.y_num_height/2);
-  //draw the axis label
-  ctx.save();
-  ctx.font = metrics.y_label_font;
-  ctx.translate(0, metrics.stack_height/2);
-  ctx.rotate(-(Math.PI / 2));
-  ctx.textAlign = "center";
-  ctx.fillText("bits", 0, 0);
-  ctx.restore();
-
-  ctx.translate(metrics.y_label_spacer + metrics.y_num_width, 0);
-
-  //draw the axis tics
-  ctx.save();
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i <= alphabet_ic; i++) {
-    //draw the number
-    ctx.save();
-    ctx.translate(-1, 0);
-    raster.draw_scale_num(ctx, metrics.y_num_font, i);
-    ctx.restore();
-    //draw the tic
-    ctx.fillRect(0, -1, metrics.y_tic_width, 2);
-    //prepare for next tic
-    ctx.translate(0, -tic_height);
-  }
-  ctx.restore();
-
-  ctx.fillRect(metrics.y_tic_width - 2, 0, 2, metrics.stack_height)
-
-  ctx.restore();
-}
-
-function draw_stack_num(ctx, metrics, row_index, raster) {
-  "use strict";
-  ctx.save();
-  ctx.translate(0, Math.round(metrics.stack_height + metrics.x_num_above));
-  if (metrics.x_axis == 1) {
-    raster.draw_stack_num(ctx, metrics.x_num_font, metrics.stack_width, row_index);
-  } else if (metrics.x_axis == 0) {
-    // draw dots instead of the numbers (good for small logos)
-    ctx.beginPath();
-    var radius = Math.round(metrics.x_num_height / 2);
-    ctx.arc(Math.round(metrics.stack_width / 2), radius, radius, 0, 2 * Math.PI, false);
-    ctx.fill();
-  }
-  ctx.restore();
-}
-
-function draw_stack(ctx, metrics, symbols, raster) {
-  "use strict";
-  var preferred_pad, sym_min, i, sym, sym_height, pad;
-  preferred_pad = 0;
-  sym_min = 5;
-
-  ctx.save();//1
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i < symbols.length; i++) {
-    sym = symbols[i];
-    sym_height = metrics.stack_height * sym.get_scale();
-    
-    pad = preferred_pad;
-    if (sym_height - pad < sym_min) {
-      pad = Math.min(pad, Math.max(0, sym_height - sym_min));
-    }
-    sym_height -= pad;
-
-    //translate to the correct position
-    ctx.translate(0, -(pad/2 + sym_height));
-
-    //draw
-    raster.draw_stack_sym(ctx, sym.get_symbol(), 0, 0, metrics.stack_width, sym_height);
-    //translate past the padding
-    ctx.translate(0, -(pad/2));
-  }
-  ctx.restore();//1
-}
-
-function draw_dashed_line(ctx, pattern, start, x1, y1, x2, y2) {
-  "use strict";
-  var x, y, len, i, dx, dy, tlen, theta, mulx, muly, lx, ly;
-  dx = x2 - x1;
-  dy = y2 - y1;
-  tlen = Math.pow(dx*dx + dy*dy, 0.5);
-  theta = Math.atan2(dy,dx);
-  mulx = Math.cos(theta);
-  muly = Math.sin(theta);
-  lx = [];
-  ly = [];
-  for (i = 0; i < pattern; ++i) {
-    lx.push(pattern[i] * mulx);
-    ly.push(pattern[i] * muly);
-  }
-  i = start;
-  x = x1;
-  y = y1;
-  len = 0;
-  ctx.beginPath();
-  while (len + pattern[i] < tlen) {
-    ctx.moveTo(x, y);
-    x += lx[i];
-    y += ly[i];
-    ctx.lineTo(x, y);
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-    x += lx[i];
-    y += ly[i];
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-  }
-  if (len < tlen) {
-    ctx.moveTo(x, y);
-    x += mulx * (tlen - len);
-    y += muly * (tlen - len);
-    ctx.lineTo(x, y);
-  }
-  ctx.stroke();
-}
-
-function draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider) {
-  "use strict";
-  var left_size = left_end - left_start;
-  var right_size = right_end - right_start;
-  var line_x;
-
-  ctx.save();//s8
-  ctx.fillStyle = "rgb(240, 240, 240)";
-  if (left_size > 0) {
-    ctx.fillRect(left_start * metrics.stack_width, 0, left_size * metrics.stack_width, metrics.stack_height);
-  }
-  if (right_size > 0) {
-    ctx.fillRect(right_start * metrics.stack_width, 0, right_size * metrics.stack_width, metrics.stack_height);
-  }
-  ctx.fillStyle = "rgb(51, 51, 51)";
-  if (left_size > 0 && left_divider) {
-    line_x = (left_end * metrics.stack_width) - 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  if (right_size > 0 && right_divider) {
-    line_x = (right_start * metrics.stack_width) + 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  ctx.restore();//s8
-}
-
-function size_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var draw_name, draw_finetext, metrics;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  if (canvas.width !== 0 && canvas.height !== 0) {
-    return;
-  }
-  metrics = new LogoMetrics(canvas.getContext('2d'), 
-      logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      canvas.width = metrics.summed_width * (canvas.height / metrics.summed_height);
-    } else if (canvas.height === 0) {
-      canvas.height = metrics.summed_height * (canvas.width / metrics.summed_width);
-    }
-  }
-}
-
-function draw_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var i, draw_name, draw_finetext, ctx, metrics, raster, pspm_i, pspm, 
-      offset, col_index, motif_position, ssc;
-  ssc = false;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  ctx = canvas.getContext('2d');
-  //assume that the user wants the canvas scaled equally so calculate what the best width for this image should be
-  metrics = new LogoMetrics(ctx, logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      scale = 1;
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      scale = canvas.height / metrics.summed_height;
-      canvas.width = metrics.summed_width * scale;
-    } else if (canvas.height === 0) {
-      scale = canvas.width / metrics.summed_width;
-      canvas.height = metrics.summed_height * scale;
-    } else {
-      scale = Math.min(canvas.width / metrics.summed_width, canvas.height / metrics.summed_height);
-    }
-  }
-  // cache the raster based on the assumption that we will be drawing a lot
-  // of logos the same size and alphabet
-  if (typeof draw_logo_on_canvas.raster_cache === "undefined") {
-    draw_logo_on_canvas.raster_cache = [];
-  }
-  for (i = 0; i < draw_logo_on_canvas.raster_cache.length; i++) {
-    raster = draw_logo_on_canvas.raster_cache[i];
-    if (raster.get_alphabet().equals(logo.alphabet) &&
-        Math.abs(raster.get_scale() - scale) < 0.1) break;
-    raster = null;
-  }
-  if (raster == null) {
-    raster = new RasterizedAlphabet(logo.alphabet, scale, metrics.stack_font, metrics.stack_width);
-    draw_logo_on_canvas.raster_cache.push(raster);
-  }
-  ctx = canvas.getContext('2d');
-  ctx.save();//s1
-  ctx.scale(scale, scale);
-  ctx.save();//s2
-  ctx.save();//s7
-  //create margin
-  ctx.translate(Math.round(metrics.pad_left), Math.round(metrics.pad_top));
-  for (pspm_i = 0; pspm_i < logo.get_rows(); ++pspm_i) {
-    pspm = logo.get_pspm(pspm_i);
-    offset = logo.get_offset(pspm_i);
-    //optionally draw name if this isn't the last row or is the only row 
-    if (draw_name && (logo.get_rows() == 1 || pspm_i != (logo.get_rows()-1))) {
-      ctx.save();//s4
-      ctx.translate(Math.round(metrics.summed_width/2), Math.round(metrics.name_height));
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s4
-      ctx.translate(0, Math.round(metrics.name_height + 
-          Math.min(0, metrics.name_spacer - metrics.y_num_height/2)));
-    }
-    //draw scale
-    if (logo.y_axis) draw_scale(ctx, metrics, logo.alphabet.get_ic(), raster);
-    ctx.save();//s5
-    //translate across past the scale
-    if (logo.y_axis) {
-      ctx.translate(Math.round(metrics.y_label_height + metrics.y_label_spacer + 
-        metrics.y_num_width + metrics.y_tic_width), Math.round(metrics.y_num_height / 2));
-    }
-    //draw the trimming background
-    if (pspm.get_left_trim() > 0 || pspm.get_right_trim() > 0) {
-      var left_start = offset * logo.get_xlate_nsyms();
-      var left_end = (offset + pspm.get_left_trim()) * logo.get_xlate_nsyms();
-      var left_divider = true;
-      if (left_end < logo.get_xlate_start() || left_start > logo.get_xlate_end()) {
-        // no overlap
-        left_start = 0;
-        left_end = 0;
-        left_divider = false;
-      } else {
-        if (left_start < logo.get_xlate_start()) {
-          left_start = logo.get_xlate_start();
-        }
-        if (left_end > logo.get_xlate_end()) {
-          left_end = logo.get_xlate_end();
-          left_divider = false;
-        }
-        left_start -= logo.get_xlate_start();
-        left_end -= logo.get_xlate_start();
-        if (left_end < left_start) {
-          left_start = 0;
-          left_end = 0;
-          left_divider = false;
-        }
-      }
-      var right_end = (offset + pspm.get_motif_length()) * logo.get_xlate_nsyms();
-      //var right_start = right_end - (pspm.get_left_trim() * logo.get_xlate_nsyms());
-      var right_start = right_end - (pspm.get_right_trim() * logo.get_xlate_nsyms());
-      var right_divider = true;
-      if (right_end < logo.get_xlate_start() || right_start > logo.get_xlate_end()) {
-        // no overlap
-        right_start = 0;
-        right_end = 0;
-        right_divider = false;
-      } else {
-        if (right_start < logo.get_xlate_start()) {
-          right_start = logo.get_xlate_start();
-          right_divider = false;
-        }
-        if (right_end > logo.get_xlate_end()) {
-          right_end = logo.get_xlate_end();
-        }
-        right_start -= logo.get_xlate_start();
-        right_end -= logo.get_xlate_start();
-        if (right_end < right_start) {
-          right_start = 0;
-          right_end = 0;
-          right_divider = false;
-        }
-      }
-      draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider);
-    }
-    //draw letters
-    var xlate_col;
-    for (xlate_col = logo.get_xlate_start(); xlate_col < logo.get_xlate_end(); xlate_col++) {
-      ctx.translate(metrics.stack_pad_left,0);
-      col_index = Math.floor(xlate_col / logo.get_xlate_nsyms());
-      if (xlate_col % logo.get_xlate_nsyms() == 0) {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          motif_position = col_index - offset;
-          draw_stack_num(ctx, metrics, motif_position, raster);
-          draw_stack(ctx, metrics, pspm.get_stack(motif_position, logo.alphabet, ssc), raster);
-        }
-      } else {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          ctx.save();// s5.1
-          ctx.translate(0, Math.round(metrics.stack_height));
-          // TODO draw a dot or dash or something to indicate continuity of the motif
-          ctx.restore(); //s5.1
-        }
-      }
-      ctx.translate(Math.round(metrics.stack_width), 0);
-    }
-    ctx.restore();//s5
-    ////optionally draw name if this is the last row but isn't the only row 
-    if (draw_name && (logo.get_rows() != 1 && pspm_i == (logo.get_rows()-1))) {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width + metrics.name_spacer));
-
-      ctx.save();//s6
-      ctx.translate(metrics.summed_width/2, metrics.name_height);
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s6
-      ctx.translate(0, metrics.name_height);
-    } else {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width));
-    }
-    //if not the last row then add middle padding
-    if (pspm_i != (logo.get_rows() -1)) {
-      ctx.translate(0, metrics.pad_middle);
-    }
-  }
-  ctx.restore();//s7
-  if (logo.fine_text.length > 0) {
-    ctx.translate(metrics.summed_width - metrics.pad_right, metrics.summed_height - metrics.pad_bottom);
-    ctx.font = metrics.fine_txt_font;
-    ctx.textAlign = "right";
-    ctx.fillText(logo.fine_text, 0,0);
-  }
-  ctx.restore();//s2
-  ctx.restore();//s1
-}
-
-function create_canvas(c_width, c_height, c_id, c_title, c_display) {
-  "use strict";
-  var canvas = document.createElement("canvas");
-  //check for canvas support before attempting anything
-  if (!canvas.getContext) {
-    return null;
-  }
-  var ctx = canvas.getContext('2d');
-  //check for html5 text drawing support
-  if (!supports_text(ctx)) {
-    return null;
-  }
-  //size the canvas
-  canvas.width = c_width;
-  canvas.height = c_height;
-  canvas.id = c_id;
-  canvas.title = c_title;
-  canvas.style.display = c_display;
-  return canvas;
-}
-
-function logo_1(alphabet, fine_text, pspm) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  logo.add_pspm(pspm);
-  return logo;
-}
-
-function logo_2(alphabet, fine_text, target, query, query_offset) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  if (query_offset < 0) {
-    logo.add_pspm(target, -query_offset);
-    logo.add_pspm(query);
-  } else {
-    logo.add_pspm(target);
-    logo.add_pspm(query, query_offset);
-  }      
-  return logo;
-}
-
-/*
- * Specifies an alternate source for an image.
- * If the image with the image_id specified has
- * not loaded then a generated logo will be used 
- * to replace it.
- *
- * Note that the image must either have dimensions
- * or a scale must be set.
- */
-function alternate_logo(logo, image_id, scale) {
-  "use strict";
-  var image = document.getElementById(image_id);
-  if (!image) {
-    alert("Can't find specified image id (" +  image_id + ")");
-    return;
-  }
-  //if the image has loaded then there is no reason to use the canvas
-  if (image_ok(image)) {
-    return;
-  }
-  //the image has failed to load so replace it with a canvas if we can.
-  var canvas = create_canvas(image.width, image.height, image_id, image.title, image.style.display);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the image with the canvas
-  image.parentNode.replaceChild(canvas, image);
-}
-
-/*
- * Specifes that the element with the specified id
- * should be replaced with a generated logo.
- */
-function replace_logo(logo, replace_id, scale, title_txt, display_style) {
-  "use strict";
-  var element = document.getElementById(replace_id);
-  if (!replace_id) {
-    alert("Can't find specified id (" + replace_id + ")");
-    return;
-  }
-  //found the element!
-  var canvas = create_canvas(50, 120, replace_id, title_txt, display_style);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the element with the canvas
-  element.parentNode.replaceChild(canvas, element);
-}
-
-/*
- * Fast string trimming implementation found at
- * http://blog.stevenlevithan.com/archives/faster-trim-javascript
- *
- * Note that regex is good at removing leading space but
- * bad at removing trailing space as it has to first go through
- * the whole string.
- */
-function trim (str) {
-  "use strict";
-  var ws, i;
-  str = str.replace(/^\s\s*/, '');
-  ws = /\s/; i = str.length;
-  while (ws.test(str.charAt(--i)));
-  return str.slice(0, i + 1);
-}
-</script>
-    <script>
-var current_motif = 0;
-var dreme_alphabet = new Alphabet(data.alphabet, data.control_db.freqs);
-
-/*
- * Create a pspm for the given motif data
- */
-function motif_pspm(m) {
-  return new Pspm(m.pwm, m.id, 0, 0, m.nsites, m.evalue);
-}
-
-/*
- * Create a count matrix from the given motif data
- */
-function motif_count_matrix(motif) {
-  return motif_pspm(motif).as_count_matrix();
-}
-
-/*
- * Create a probablity matrix from the given motif data
- */
-function motif_prob_matrix(motif) {
-  return motif_pspm(motif).as_probability_matrix();
-}
-
-/*
- * Create a minimal meme format motif from the given motif data
- */
-function motif_minimal_meme(motif) {
-  return motif_pspm(motif).as_meme({
-    "with_header": true, 
-    "with_pspm": true,
-    "with_pssm": false,
-    "version": data["version"],
-    "alphabet": dreme_alphabet,
-    "strands": (data.options.revcomp ? 2 : 1)
-  });
-}
-
-/*
- * Fill in a template variable
- */
-function set_tvar(template, tvar, value) {
-  var node;
-  node = find_child(template, tvar);
-  if (node === null) {
-    throw new Error("Template does not contain variable " + tvar);
-  }
-  node.innerHTML = "";
-  if (typeof value !== "object") {
-    node.appendChild(document.createTextNode(value));
-  } else {
-    node.appendChild(value);
-  }
-}
-
-/*
- * Make a canvas with the motif logo drawn on it. 
- */
-function make_logo(motif, height, rc) {
-  var pspm = new Pspm(motif["pwm"]);
-  if (rc) pspm = pspm.copy().reverse_complement(dreme_alphabet);
-  var logo = new Logo(dreme_alphabet);
-  logo.add_pspm(pspm, 0);
-  var canvas = document.createElement('canvas');
-  canvas.height = height;
-  canvas.width = 0;
-  draw_logo_on_canvas(logo, canvas, false);
-  return canvas;
-}
-
-/*
- * Create a button designed to contain a single symbol
- */
-function make_sym_btn(symbol, title, action) {
-  var box, sbox;
-  box = document.createElement("div");
-  box.tabIndex = 0;
-  box.className = "sym_btn";
-  sbox = document.createElement("span");
-  if (typeof symbol == "string") {
-    sbox.appendChild(document.createTextNode(symbol));
-  } else {
-    sbox.appendChild(symbol);
-  }
-  box.appendChild(sbox);
-  box.title = title;
-  box.addEventListener('click', action, false);
-  box.addEventListener('keydown', action, false);
-  return box;
-}
-
-/*
- * Create a pair of text spans with different classes.
- * This is useful when using CSS to only display one of them.
- */
-function text_pair(txt1, cls1, txt2, cls2) {
-  var container, part1, part2;
-  container = document.createElement("span");
-  part1 = document.createElement("span");
-  part1.appendChild(document.createTextNode(txt1));
-  part1.className = cls1;
-  container.appendChild(part1);
-  part2 = document.createElement("span");
-  part2.appendChild(document.createTextNode(txt2));
-  part2.className = cls2;
-  container.appendChild(part2);
-  return container;
-}
-
-/*
- * Make a colourised sequence.
- */
-function make_seq(seq) {
-  var i, j, letter, lbox, sbox;
-  sbox = document.createElement("span");
-  for (i = 0; i < seq.length; i = j) {
-    letter = seq.charAt(i);
-    for (j = i+1; j < seq.length; j++) {
-      if (seq.charAt(j) !== letter) {
-        break;
-      }
-    }
-    lbox = document.createElement("span");
-    lbox.style.color = dreme_alphabet.get_colour(dreme_alphabet.get_index(letter));
-    lbox.appendChild(document.createTextNode(seq.substring(i, j)));
-    sbox.appendChild(lbox);
-  }
-  return sbox;
-}
-
-/*
- * Create a description element taking into account the newlines in the source text.
- */
-function make_description(text) {
-  var i, j, lines, p;
-  var container = document.createElement("div");
-  var paragraphs = text.split(/\n\n+/);
-  for (i = 0; i < paragraphs.length; i++) {
-    lines = paragraphs[i].split(/\n/);
-    p = document.createElement("p");
-    p.appendChild(document.createTextNode(lines[0]));
-    for (j = 1; j < lines.length; j++) {
-      p.appendChild(document.createElement("br"));
-      p.appendChild(document.createTextNode(lines[j]));
-    }
-    container.appendChild(p);
-  }
-  return container;
-}
-
-/*
- * Make the table header for the discovered motifs.
- */
-function make_motif_header() {
-  var row = document.createElement("tr");
-  add_text_header_cell(row, "", "", "motif_ordinal");
-  add_text_header_cell(row, "Motif", "pop_motifs_word", "motif_word");
-  add_text_header_cell(row, "Logo", "pop_motifs_logo", "motif_logo");
-  if (data.options.revcomp) {
-    add_text_header_cell(row, "RC Logo", "pop_motifs_rc_logo", "motif_logo");
-  }
-  add_text_header_cell(row, "E-value", "pop_motifs_evalue", "motif_evalue");
-  add_text_header_cell(row, "Unerased E-value", "pop_motifs_uevalue", "motif_evalue");
-  add_text_header_cell(row, "More", "pop_more", "motif_more");
-  add_text_header_cell(row, "Submit/Download", "pop_submit_dl", "motif_submit");
-  row.className = "more";
-  return row;
-}
-
-/*
- * Make a compact motif summary row for the discovered motifs.
- */
-function make_motif_row(tbody, ordinal, motif) {
-  var row = document.createElement("tr");
-  add_text_cell(row, "" + ordinal + ".", "motif_ordinal");
-  add_text_cell(row, motif["id"], "motif_word");
-  add_cell(row, make_logo(motif, 50, false), "motif_logo");
-  if (data.options.revcomp) {
-    add_cell(row, make_logo(motif, 50, true), "motif_logo");
-  }
-  add_text_cell(row, motif["evalue"], "motif_evalue");
-  add_text_cell(row, motif["unerased_evalue"], "motif_evalue");
-  add_cell(row, make_sym_btn(text_pair("\u21A7", "less", "\u21A5", "more"), "Show more information.", function(e) { toggle_class(tbody, "collapsed"); }, "\u21A5", ""), "motif_more");
-  add_cell(row, make_sym_btn("\u21E2", "Submit the motif to another MEME Suite program or download it.", function(e) { action_show_outpop(e, ordinal); }), "motif_submit");
-  return row;
-}
-
-/*
- * Make a sortable table of enriched matching rows.
- */
-function make_motif_words(motif) {
-  var row, i, match;
-  var table = document.createElement("table");
-  var thead = document.createElement("thead");
-  row = document.createElement("tr");
-  add_text_header_cell(row, "Word", "pop_match_word", "match_word", function(e) {sort_table(this, compare_words);});
-  add_text_header_cell(row, "Positives", "pop_match_pos", "match_count", function(e) {sort_table(this, compare_counts);});
-  add_text_header_cell(row, "Negatives", "pop_match_neg", "match_count", function(e) {sort_table(this, compare_counts);});
-  add_text_header_cell(row, "P-value", "pop_match_pval", "match_evalue", function(e) {sort_table(this, compare_evalues);});
-  add_text_header_cell(row, "E-value", "pop_match_eval", "match_evalue", function(e) {sort_table(this, compare_evalues);});
-  thead.appendChild(row);
-  table.appendChild(thead);
-  var tbody = document.createElement("tbody");
-  for (i = 0; i < motif.matches.length; i++) {
-    match = motif.matches[i];
-    row = document.createElement("tr");
-    add_cell(row, make_seq(match.seq), "match_word");
-    add_text_cell(row, match.p + " / " + data.sequence_db.count, "match_count");
-    add_text_cell(row, match.n + " / " + data.control_db.count, "match_count");
-    add_text_cell(row, match.pvalue, "match_evalue");
-    add_text_cell(row, match.evalue, "match_evalue");
-    tbody.appendChild(row);
-  }
-  table.appendChild(tbody);
-  return table;
-}
-
-/*
- * Make an expanded view of a discovered motif.
- */
-function make_motif_exp(tbody, ordinal, motif) {
-  "use strict";
-  var box, pspm, logo_box;
-  box = $("tmpl_motif_expanded").cloneNode(true);
-  toggle_class(box, "template", false);
-  box.id = "";
-  find_child(box, "tvar_logo").appendChild(make_logo(motif, 150, false));
-  if (data.options.revcomp) {
-    find_child(box, "tvar_rclogo").appendChild(make_logo(motif, 150, true));
-  }
-  set_tvar(box, "tvar_p", motif["p"]);
-  set_tvar(box, "tvar_p_total", data.sequence_db.count);
-  set_tvar(box, "tvar_n", motif["n"]);
-  set_tvar(box, "tvar_n_total", data.control_db.count);
-  set_tvar(box, "tvar_pvalue", motif["pvalue"]);
-  set_tvar(box, "tvar_evalue", motif["evalue"]);
-  set_tvar(box, "tvar_uevalue", motif["unerased_evalue"]);
-  set_tvar(box, "tvar_words", make_motif_words(motif));
-  var cell = document.createElement("td");
-  cell.colSpan = 8;
-  cell.appendChild(box);
-  var row = document.createElement("tr");
-  row.className = "more";
-  row.appendChild(cell);
-  return row;
-}
-
-/*
- * Convert a string containing a scientific number into the log of that number
- * without having an intermediate representation of the number.
- * This is intended to avoid underflow problems with the tiny evalues that
- * MEME and DREME can create.
- */
-function sci2log(scinum) {
-  "use strict";
-  var ev_re, match, sig, exp;
-  ev_re = /^(.*)e(.*)$/;
-  if (match = ev_re.exec(scinum)) {
-    sig = parseFloat(match[1]);
-    exp = parseInt(match[2]);
-    return Math.log(sig) + (exp * Math.log(10));
-  }
-  return 0;
-}
-
-/*
- * Create a table of discovered motifs. A fresh table body is used for each
- * motif to make hiding/showing rows with css easier.
- */
-function make_motifs() {
-  "use strict";
-  var i, row, tbody, motif, ordinal;
-  // make the motifs table
-  var container = $("motifs");
-  container.innerHTML = ""; // clear content
-  var table = document.createElement("table");
-  // add a header that is always shown
-  var thead = document.createElement("thead");
-  thead.appendChild(make_motif_header());
-  table.appendChild(thead);
-  for (i = 0; i < data.motifs.length; i++) {
-    ordinal = i + 1;
-    motif = data.motifs[i];
-    tbody = document.createElement("tbody");
-    tbody.className = "collapsed";
-    tbody.appendChild(make_motif_row(tbody, ordinal, motif));
-    tbody.appendChild(make_motif_exp(tbody, ordinal, motif));
-    // create a following header for every row except the last one
-    if ((i + 1) < data.motifs.length) tbody.appendChild(make_motif_header());
-    table.appendChild(tbody);
-  }
-  container.appendChild(table);
-}
-
-/*
- * Create a table showing all the alphabet symbols, their names and frequencies.
- */
-function make_alpha_bg(alph, freqs) {
-  function colour_symbol(index) {
-    var span = document.createElement("span");
-    span.appendChild(document.createTextNode(alph.get_symbol(index)));
-    span.style.color = alph.get_colour(index);
-    span.className = "alpha_symbol";
-    return span;
-  }
-  var table, thead, tbody, row, th, span, i;
-  // create table
-  table = document.createElement("table");
-  table.className = "inputs";
-  // create header
-  thead = document.createElement("thead");
-  table.appendChild(thead);
-  row = thead.insertRow(thead.rows.length);
-  if (alph.has_complement()) {
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-  } else {
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-  }
-  // add alphabet entries
-  tbody = document.createElement("tbody");
-  table.appendChild(tbody);
-  if (alph.has_complement()) {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      var c = alph.get_complement(i);
-      if (i > c) continue;
-      row = tbody.insertRow(tbody.rows.length);
-      add_text_cell(row, alph.get_name(i));
-      add_text_cell(row, "" + freqs[i].toFixed(3));
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, "~");
-      add_cell(row, colour_symbol(c)); 
-      add_text_cell(row, "" + freqs[c].toFixed(3));
-      add_text_cell(row, alph.get_name(c));
-    }
-  } else {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      row = tbody.insertRow(tbody.rows.length);
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, alph.get_name(i));
-      add_text_cell(row, "" + freqs[i].toFixed(3));
-    }
-  }
-  return table;
-}
-
-/*
- * Updates the format download text in the popup.
- * This is called when either the format or current motif changes.
- */
-function update_outpop_format(index) {
-  var motif = data.motifs[index];
-  var fn = [motif_count_matrix, motif_prob_matrix, motif_minimal_meme];
-  var suffix = ["_counts.txt", "_freqs.txt", ".meme"];
-  var format = parseInt($("text_format").value);
-  var text = fn[format](motif);
-  prepare_download(text, "text/plain", motif.id + suffix[format], $("outpop_text_dl"));
-  $("outpop_text").value = text;
-}
-
-/*
- * Updates the motif logos and format download text in the popup.
- * This is called whenever the current motif changes.
- */
-function update_outpop_motif(index) {
-  "use strict";
-  var motifs, motif, pspm, logo, canvas, num;
-  motifs = data["motifs"];
-  if (index < 0 || index >= motifs.length) {return;}
-  current_motif = index;
-  motif = motifs[index];
-  pspm = new Pspm(motif["pwm"]);
-  logo = new Logo(dreme_alphabet, "");
-  logo.add_pspm(pspm, 0);
-  canvas = $("outpop_logo");
-  canvas.width = canvas.width; // clear canvas
-  draw_logo_on_canvas(logo, canvas, false);
-  canvas = $("outpop_logo_rc");
-  canvas.width = canvas.width; // clear rc canvas
-  if (data.options.revcomp) {
-    pspm.reverse_complement(dreme_alphabet);
-    logo = new Logo(dreme_alphabet, "");
-    logo.add_pspm(pspm, 0);
-    draw_logo_on_canvas(logo, canvas, false);
-  }
-  num = $("outpop_num");
-  num.innerHTML = "";
-  num.appendChild(document.createTextNode("" + (index + 1)));
-  update_outpop_format(index);
-}
-
-
-/*
- * Initialise and display the download popup.
- */
-function action_show_outpop(e, ordinal) {
-  "use strict";
-  function init() {
-    "use strict";
-    var close_btn, next_btn, prev_btn, cancel_btn, do_btn;
-    var tab1, tab2, tab3;
-    var pnl1, pnl2, pnl3;
-    var format_list;
-    var tbl_submit, inputs, i, default_prog;
-    close_btn = $("outpop_close");
-    close_btn.addEventListener("click", action_hide_outpop, false);
-    close_btn.addEventListener("keydown", action_hide_outpop, false);
-    next_btn = $("outpop_next");
-    next_btn.addEventListener("click", action_outpop_next, false);
-    next_btn.addEventListener("keydown", action_outpop_next, false);
-    prev_btn = $("outpop_prev");
-    prev_btn.addEventListener("click", action_outpop_prev, false);
-    prev_btn.addEventListener("keydown", action_outpop_prev, false);
-    cancel_btn = $("outpop_cancel");
-    cancel_btn.addEventListener("click", action_hide_outpop, false);
-    do_btn = $("outpop_do");
-    do_btn.addEventListener("click", action_outpop_submit, false);
-    tab1 = $("outpop_tab_1");
-    tab1.tabIndex = 0;
-    tab1.addEventListener("click", action_outpop_tab, false);
-    tab1.addEventListener("keydown", action_outpop_tab, false);
-    tab2 = $("outpop_tab_2");
-    tab2.tabIndex = 0;
-    tab2.addEventListener("click", action_outpop_tab, false);
-    tab2.addEventListener("keydown", action_outpop_tab, false);
-    tab3 = $("outpop_tab_3");
-    tab3.tabIndex = 0;
-    tab3.addEventListener("click", action_outpop_tab, false);
-    tab3.addEventListener("keydown", action_outpop_tab, false);
-    pnl1 = $("outpop_pnl_1");
-    pnl2 = $("outpop_pnl_2");
-    pnl3 = $("outpop_pnl_3");
-    toggle_class(tab1, "activeTab", true);
-    toggle_class(tab2, "activeTab", false);
-    toggle_class(tab3, "activeTab", false);
-    pnl1.style.display = "block";
-    pnl2.style.display = "none";
-    pnl3.style.display = "none";
-    format_list = $("text_format");
-    format_list.addEventListener("change", action_outpop_format, false);
-    // setup program selection
-    tbl_submit = $("programs");
-    // when not dna, hide the inputs for programs that require dna motifs
-    toggle_class(tbl_submit, "alphabet_dna", dreme_alphabet.has_complement());//TODO FIXME alphabet_dna is a bad name for a field when allowing custom alphabets
-    // add a click listener for the radio buttons
-    inputs = tbl_submit.querySelectorAll("input[type='radio']");
-    for (i = 0; i < inputs.length; i++) {
-      inputs[i].addEventListener("click", action_outpop_program, false);
-    }
-    // ensure that a default program option is selected for DNA and Protein
-    default_prog = document.getElementById(dreme_alphabet.has_complement() ? "submit_tomtom" : "submit_fimo");
-    default_prog.checked = true;
-    action_outpop_program.call(default_prog);
-    // disable reverse-complement when not DNA
-    $("logo_rc_option").disabled = !dreme_alphabet.has_complement(); 
-    // set errorbars on when ssc is on
-    $("logo_ssc").addEventListener("change", action_outpop_ssc, false);
-  }
-  // store the focused element
-  action_hide_outpop.last_active = document.activeElement;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // hide the help popup
-  help_popup();
-  // on first load initilize the popup
-  if (!action_show_outpop.ready) {
-    init();
-    action_show_outpop.ready = true;
-  }
-  update_outpop_motif(ordinal - 1);
-  // display the download popup
-  $("grey_out_page").style.display = "block";
-  $("download").style.display = "block";
-  $("outpop_close").focus();
-}
-
-/*
- * Hide the download popup.
- */
-function action_hide_outpop(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  $("download").style.display = "none";
-  $("grey_out_page").style.display = "none";
-  if (typeof action_hide_outpop.last_active !== "undefined") {
-    action_hide_outpop.last_active.focus();
-  }
-}
-
-/*
- * Show the next motif in the download popup.
- */
-function action_outpop_next(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif + 1);
-}
-
-/*
- * Show the previous motif in the download popup.
- */
-function action_outpop_prev(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif - 1);
-}
-
-/*
- * Highlight the selected row in the program list.
- */
-function action_outpop_program() {
-  "use strict";
-  var table, tr, rows, i;
-  tr = find_parent_tag(this, "TR");
-  table = find_parent_tag(tr, "TABLE");
-  rows = table.querySelectorAll("tr");
-  for (i = 0; i < rows.length; i++) {
-    toggle_class(rows[i], "selected", rows[i] === tr);
-  }
-}
-
-/*
- * Enable error bars when small sample correction is enabled.
- */
-function action_outpop_ssc() {
-  "use strict";
-  $("logo_err").value = $("logo_ssc").value;
-}
-
-/*
- * Submit the motif to the selected program.
- */
-function action_outpop_submit(e) {
-  "use strict";
-  var form, input, program, motifs;
-  // find out which program is selected
-  var radios, i;
-  radios = document.getElementsByName("program");
-  program = "fimo"; // default to fimo, since it works with all alphabet types
-  for (i = 0; i < radios.length; i++) {
-    if (radios[i].checked) program = radios[i].value;
-  }
-
-  motifs = motif_minimal_meme(data.motifs[current_motif]);
-  form = document.createElement("form");
-  form.setAttribute("method", "post");
-  form.setAttribute("action", site_url + "/tools/" + program);
-  
-  input = document.createElement("input");
-  input.setAttribute("type", "hidden");
-  input.setAttribute("name", "motifs_embed");
-  input.setAttribute("value", motifs);
-  form.appendChild(input);
-
-  document.body.appendChild(form);
-  form.submit();
-  document.body.removeChild(form);
-}
-
-/*
- * Download the format text.
- * Wire the link containing the data URI text to a download button so it looks
- * the same as the server submit stuff.
- */
-function action_outpop_download_motif(e) {
-  $("outpop_text_dl").click();
-}
-
-/*
- * Download the motif logo.
- * The EPS format can be calculated locally in Javascript
- */
-function action_outpop_download_logo(e) {
-  "use strict";
-  var pspm, logo, eps;
-  var logo_rc, logo_ssc, logo_width, logo_height;
-  var motif = data.motifs[current_motif];
-  if ($("logo_format").value == "0") { // EPS
-    logo_rc = ($("logo_rc").value == "1");
-    logo_ssc = ($("logo_ssc").value == "1");
-    logo_width = parseFloat($("logo_width").value);
-    if (isNaN(logo_width) || !isFinite(logo_width) || logo_width <= 0) logo_width = null;
-    logo_height = parseFloat($("logo_height").value);
-    if (isNaN(logo_height) || !isFinite(logo_height) || logo_height <= 0) logo_height = null;
-    // create a PSPM from the motif
-    pspm = motif_pspm(motif);
-    if (logo_rc) pspm.reverse_complement(dreme_alphabet);
-    logo = new Logo(dreme_alphabet);
-    logo.add_pspm(pspm, 0);
-    eps = logo.as_eps({"ssc": logo_ssc, "logo_width": logo_width, "logo_height": logo_height});
-    prepare_download(eps, "application/postscript", motif.id + ".eps");
-  } else {
-    $("logo_motifs").value = motif_minimal_meme(motif);
-    $("logo_form").submit();
-  }
-}
-
-/*
- * Change the selected tab in the download popup.
- */
-function action_outpop_tab(e) {
-  "use strict";
-  var tab1, tab2, tab3, pnl1, pnl2, pnl3, do_btn;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  tab1 = $("outpop_tab_1");
-  tab2 = $("outpop_tab_2");
-  tab3 = $("outpop_tab_3");
-  pnl1 = $("outpop_pnl_1");
-  pnl2 = $("outpop_pnl_2");
-  pnl3 = $("outpop_pnl_3");
-  do_btn = $("outpop_do");
-
-  toggle_class(tab1, "activeTab", (this === tab1));
-  toggle_class(tab2, "activeTab", (this === tab2));
-  toggle_class(tab3, "activeTab", (this === tab3));
-  pnl1.style.display = ((this === tab1) ? "block" : "none");
-  pnl2.style.display = ((this === tab2) ? "block" : "none");
-  pnl3.style.display = ((this === tab3) ? "block" : "none");
-  do_btn.value = ((this === tab1) ? "Submit" : "Download");
-  do_btn.removeEventListener("click", action_outpop_submit, false);
-  do_btn.removeEventListener("click", action_outpop_download_logo, false);
-  do_btn.removeEventListener("click", action_outpop_download_motif, false);
-  if (this === tab1) {
-    do_btn.addEventListener("click", action_outpop_submit, false);
-  } else if (this === tab2) {
-    do_btn.addEventListener("click", action_outpop_download_motif, false);
-  } else {
-    do_btn.addEventListener("click", action_outpop_download_logo, false);
-  }
-}
-
-/*
- * Update the text in the download format popup.
- */
-function action_outpop_format() {
-  update_outpop_format(current_motif);
-}
-
-/*
- * Find all text nodes in the given container.
- */
-function text_nodes(container) {
-  var textNodes = [];
-  var stack = [container];
-  // depth first search to maintain ordering when flattened 
-  while (stack.length > 0) {
-    var node = stack.pop();
-    if (node.nodeType == Node.TEXT_NODE) {
-      textNodes.push(node);
-    } else {
-      for (var i = node.childNodes.length-1; i >= 0; i--) {
-        stack.push(node.childNodes[i]);
-      }
-    }
-  }
-  return textNodes;
-}
-
-/*
- * Get the text out of a specific text node.
- */
-function node_text(node) {
-  if (node === undefined) {
-    return '';
-  } else if (node.textContent) {
-    return node.textContent;
-  } else if (node.innerText) {
-    return node.innerText;
-  } else {
-    return '';
-  }
-}
-
-/*
- * Get the text contained within the element.
- */
-function elem_text(elem, separator) {
-  if (separator === undefined) separator = '';
-  return text_nodes(elem).map(node_text).join(separator);
-}
-
-/*
- * Sort all rows in the first table body based on the column of the given element and the comparison function.
- * The sort is not very fast and is intended for small tables only.
- */
-function sort_table(colEle, compare_function) {
-  //find the parent of colEle that is either a td or th
-  var i, j;
-  var cell = colEle;
-  while (true) {
-    if (cell == null) return;
-    if (cell.nodeType == Node.ELEMENT_NODE && 
-        (cell.tagName.toLowerCase() == "td" || cell.tagName.toLowerCase() == "th")) {
-      break;
-    }
-    cell = cell.parentNode;
-  }
-  //find the parent of cell that is a tr
-  var row = cell;
-  while (true) {
-    if (row == null) return;
-    if (row.nodeType == Node.ELEMENT_NODE && row.tagName.toLowerCase() == "tr") {
-      break;
-    }
-    row = row.parentNode;
-  }
-  //find the parent of row that is a table
-  var table = row;
-  while (true) {
-    if (table == null) return;
-    if (table.nodeType == Node.ELEMENT_NODE && table.tagName.toLowerCase() == "table") {
-      break;
-    }
-    table = table.parentNode;
-  }
-  var column_index = cell.cellIndex;
-  // do a bubble sort, because the tables are so small it doesn't matter
-  var change;
-  var trs = table.tBodies[0].getElementsByTagName('tr');
-  var already_sorted = true;
-  var reverse = false;
-  while (true) {
-    do {
-      change = false;
-      for (i = 0; i < trs.length -1; i++) {
-        var v1 = elem_text(trs[i].cells[column_index]);
-        var v2 = elem_text(trs[i+1].cells[column_index]);
-        if (reverse) {
-          var tmp = v1;
-          v1 = v2;
-          v2 = tmp;
-        }
-        if (compare_function(v1, v2) > 0) {
-          exchange(trs[i], trs[i+1], table);
-          change = true;
-          already_sorted = false;
-          trs = table.tBodies[0].getElementsByTagName('tr');
-        }
-      }
-    } while (change);
-    if (reverse) break;// we've sorted twice so exit
-    if (!already_sorted) break;// sort did something so exit
-    // when it's sorted one way already then sort the opposite way
-    reverse = true;
-  }
-  // put arrows on the headers
-  var headers = table.tHead.getElementsByTagName('tr');
-  for (i = 0; i < headers.length; i++) {
-    for (j = 0; j < headers[i].cells.length; j++) {
-      var cell = headers[i].cells[j];
-      var arrows = cell.getElementsByClassName("sort_arrow");
-      var arrow;
-      if (arrows.length == 0) {
-        arrow = document.createElement("span");
-        arrow.className = "sort_arrow";
-        cell.insertBefore(arrow, cell.firstChild);
-      } else {
-        arrow = arrows[0];
-      }
-      arrow.innerHTML = "";
-      if (j == column_index) {
-        arrow.appendChild(document.createTextNode(reverse ? "\u25B2" : "\u25BC"));
-      }
-    }
-  }
-}
-
-/*
- * Swap two rows in a table.
- */
-function exchange(oRowI, oRowJ, oTable) {
-  var i = oRowI.rowIndex;
-  var j = oRowJ.rowIndex;
-   if (i == j+1) {
-    oTable.tBodies[0].insertBefore(oRowI, oRowJ);
-  } if (j == i+1) {
-    oTable.tBodies[0].insertBefore(oRowJ, oRowI);
-  } else {
-    var tmpNode = oTable.tBodies[0].replaceChild(oRowI, oRowJ);
-    if(typeof(oRowI) != "undefined") {
-      oTable.tBodies[0].insertBefore(tmpNode, oRowI);
-    } else {
-      oTable.appendChild(tmpNode);
-    }
-  }
-}
-
-/*
- * Compare two E-values which may be very small.
- */
-function compare_evalues(v1, v2) {
-  var e1 = sci2log(v1);
-  var e2 = sci2log(v2);
-  if (e1 < e2) return -1;
-  else if (e1 > e2) return 1;
-  return 0;
-}
-
-/*
- * Compare two counts.
- */
-function compare_counts(v1, v2) {
-  var re = /(\d+)\s*\/\s*\d+/;
-  var m1 = re.exec(v1);
-  var m2 = re.exec(v2);
-  if (m1 == null && m2 == null) return 0;
-  if (m1 == null) return -1;
-  if (m2 == null) return 1;
-  return parseInt(m2[1]) - parseInt(m1[1]);
-}
-
-/*
- * Compare two sequence words.
- */
-function compare_words(v1, v2) {
-  return v1.localeCompare(v2);
-}
-
-
-</script>
-    <style>
-/* The following is the content of meme.css */
-body { background-color:white; font-size: 12px; font-family: Verdana, Arial, Helvetica, sans-serif;}
-
-div.help {
-  display: inline-block;
-  margin: 0px;
-  padding: 0px;
-  width: 12px;
-  height: 13px;
-  cursor: pointer;
-  background-image: url();
-}
-
-div.help:hover {
-  background-image: url();
-}
-
-p.spaced { line-height: 1.8em;}
-
-span.citation { font-family: "Book Antiqua", "Palatino Linotype", serif; color: #004a4d;}
-
-p.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-td.jump { font-size: 13px; color: #ffffff; background-color: #00666a;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-a.jump { margin: 15px 0 0; font-style: normal; font-variant: small-caps;
-  font-weight: bolder; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.mainh {font-size: 1.5em; font-style: normal; margin: 15px 0 0;
-  font-variant: small-caps; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.line {border-bottom: 1px solid #CCCCCC; font-size: 1.5em; font-style: normal;
-  margin: 15px 0 0; padding-bottom: 3px; font-variant: small-caps;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-h4 {border-bottom: 1px solid #CCCCCC; font-size: 1.2em; font-style: normal;
-  margin: 10px 0 0; padding-bottom: 3px; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h5 {margin: 0px}
-
-a.help { font-size: 9px; font-style: normal; text-transform: uppercase;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-div.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-div.pad1 { margin: 10px 5px;}
-
-div.pad2 { margin: 25px 5px 5px;}
-h2.pad2 { padding: 25px 5px 5px;}
-
-div.pad3 { padding: 5px 0px 10px 30px;}
-
-div.box { border: 2px solid #CCCCCC; padding:10px; overflow: hidden;}
-
-div.bar { border-left: 7px solid #00666a; padding:5px; margin-top:25px; }
-
-div.subsection {margin:25px 0px;}
-
-img {border:0px none;}
-
-th.majorth {text-align:left;}
-th.minorth {font-weight:normal; text-align:left; width:8em; padding: 3px 0px;}
-th.actionth {font-weight:normal; text-align:left;}
-
-.explain h5 {font-size:1em; margin-left: 1em;}
-
-div.doc {margin-left: 2em; margin-bottom: 3em;}
-
-th.trainingset {
-  border-bottom: thin dashed black; 
-  font-weight:normal; 
-  padding:0px 10px;
-}
-div.pop_content {
-  position:absolute;
-  z-index:50;
-  width:300px;
-  padding: 5px;
-  background: #E4ECEC;
-  font-size: 12px;
-  font-family: Arial;
-  border-style: double;
-  border-width: 3px;
-  border-color: #AA2244;
-  display:none;
-}
-
-div.pop_content > *:first-child {
-  margin-top: 0px;
-}
-
-div.pop_content h1, div.pop_content h2, div.pop_content h3, div.pop_content h4, 
-div.pop_content h5, div.pop_content h6, div.pop_content p {
-  margin: 0px;
-}
-
-div.pop_content p + h1, div.pop_content p + h2, div.pop_content p + h3, 
-div.pop_content p + h4, div.pop_content p + h5, div.pop_content p + h6 {
-  margin-top: 5px;
-}
-
-div.pop_content p + p {
-  margin-top: 5px;
-}
-
-div.pop_content > *:last-child {
-  margin-bottom: 0px;
-}
-
-div.pop_content div.pop_close {
-  /* old definition */
-  float:right;
-  bottom: 0;
-}
-
-div.pop_content span.pop_close, div.pop_content span.pop_back {
-  display: inline-block;
-  border: 2px outset #661429;
-  background-color: #CCC;
-  padding-left: 1px;
-  padding-right: 1px;
-  padding-top: 0px;
-  padding-bottom: 0px;
-  cursor: pointer;
-  color: #AA2244; /*#661429;*/
-  font-weight: bold;
-}
-
-div.pop_content span.pop_close:active, div.pop_content span.pop_back:active {
-  border-style: inset;
-}
-
-div.pop_content span.pop_close {
-  float:right;
-  /*border: 2px outset #AA002B;*/
-  /*color: #AA2244;*/
-}
-
-div.pop_content:not(.nested) .nested_only {
-  display: none;
-}
-
-div.pop_back_sec {
-  margin-bottom: 5px;
-}
-
-div.pop_close_sec {
-  margin-top: 5px;
-}
-
-table.hide_advanced tr.advanced {
-  display: none;
-}
-span.show_more {
-  display: none;
-}
-table.hide_advanced span.show_more {
-  display: inline;
-}
-table.hide_advanced span.show_less {
-  display: none;
-}
-
-
-/*****************************************************************************
- * Program logo styling
- ****************************************************************************/
-div.prog_logo {
-  border-bottom: 0.25em solid #0f5f60;
-  height: 4.5em;
-  width: 24em;
-  display:inline-block;
-}
-div.prog_logo img {
-  float:left;
-  width: 4em;
-  border-style: none;
-  margin-right: 0.2em;
-}
-div.prog_logo h1, div.prog_logo h1:hover, div.prog_logo h1:active, div.prog_logo h1:visited {
-  margin:0;
-  padding:0;
-  font-family: Arial, Helvetica,  sans-serif;
-  font-size: 3.2em;
-  line-height: 1em;
-  vertical-align: top;
-  display: block;
-  color: #026666;
-  letter-spacing: -0.06em;
-  text-shadow: 0.04em 0.06em 0.05em #666;
-}
-div.prog_logo h2, div.prog_logo h2:hover, div.prog_logo h2:active, div.prog_logo h2:visited {
-  display: block;
-  margin:0;
-  padding:0;
-  font-family: Helvetica, sans-serif;
-  font-size: 0.9em;
-  line-height: 1em;
-  letter-spacing: -0.06em;
-  color: black;
-}
-
-div.big.prog_logo {
-  font-size: 18px;
-}
-
-</style>
-    <style>
 /* dreme output specific css */
-div.header {
-  position: relative;
-  overflow: hidden;
-  margin-top: 15px;
-  margin-bottom: 5px;
-  margin-right: 3px;
-  margin-left: 3px;
-}
-div.header > h2 {
-  font-size: 1.5em;
-  font-style: normal;
-  margin: 0;
-  font-variant: small-caps; 
-  font-family: Georgia, "Times New Roman", Times, serif;
-}
-div.header > span {
-  position: absolute;
-  right: 0;
-  bottom: 0;
-}
-
-div.template {
-  position: absolute;
-  z-index: 1;
-  left: 0;
-  top: 0;
-  visibility: hidden;
-}
-
-div.sym_btn {
-  display:inline-block;
-  text-decoration: underline;
-  cursor: pointer;
-  font-size: 20px;
-  line-height:20px; 
-  text-align: center;
-  width: 20px;
-  height: 20px;
-  color: blue;
-}
-div.sym_btn:hover {
-  color: white;
-  background-color: blue;
-}
-
-div.sym_btn.positioned {
-  position: absolute;
-  top: 0px;
-}
-
-div.box + div.box {
-  margin-top: 5px;
-}
-
-th.motif_ordinal {
-
-}
-td.motif_ordinal {
-  text-align: right;
-  padding-right: 10px;
-  font-weight: bold;
-  font-size: large;
-}
-th.motif_word {
-  padding-right: 10px;
-}
-td.motif_word {
-  font-size:15px; 
-  font-family: 'Courier New', Courier, monospace;
-  padding-right: 10px;
-}
-th.motif_logo {
-  padding-right: 10px;
-}
-td.motif_logo {
-  padding-right: 10px;
-}
-th.motif_evalue {
-  text-align:right;
-  padding-right: 10px;
-}
-td.motif_evalue {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-th.motif_more {
-  padding: 0 5px;
-}
-td.motif_more {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_submit {
-  padding: 0 5px;
-}
-td.motif_submit {
-  text-align: center;
-  padding: 0 5px;
-}
-th.match_word {
-  padding-right: 10px;
-}
-td.match_word {
-  padding-right: 10px;
-  font-weight: bold;
-  font-size: large; 
-  font-family: 'Courier New', Courier, monospace;
-}
-th.match_evalue, th.match_count {
-  text-align: right;
-  padding-right: 10px;
-}
-td.match_evalue, td.match_count {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-
-div.tabArea {
-  font-size: 80%;
-  font-weight: bold;
-}
-
-.norc div.tabArea {
-  display: none;
-}
-
-span.tab, span.tab:visited {
-  cursor: pointer;
-  color: #888;
-  background-color: #ddd;
-  border: 2px solid #ccc;
-  padding: 2px 1em;
-  text-decoration: none;
-}
-span.tab.middle {
-  border-left-width: 0px;
-}
-div.tabArea.base span.tab {
-  border-top-width: 0px;
-}
-div.tabArea.top span.tab {
-  border-bottom-width: 0px;
-}
-
-span.tab:hover {
-  background-color: #bbb;
-  border-color: #bbb;
-  color: #666;
-}
-span.tab.activeTab, span.tab.activeTab:hover, span.tab.activeTab:visited {
-  background-color: white;
-  color: black;
-  cursor: default;
-}
-div.tabMain {
-  border: 2px solid #ccc;
-  background-color: white;
-  padding: 10px;
-}
-div.tabMain.base {
-  margin-top: 5px;
-  display: inline-block;
-  max-width: 98%;
-}
-
-div.tabMain.top {
-  margin-bottom: 5px;
-}
-
-div.grey_background {
-  position:fixed; 
-  z-index: 8;
-  background-color: #000;
-  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
-  opacity: 0.5;
-  left: 0;
-  top: 0;
-  width: 100%;
-  height: 100%;
-}
-
-div.popup_wrapper {
-  position:fixed; 
-  z-index:9;
-  width:100%; 
-  height:0; 
-  top:50%; 
-  left:0;
-}
-
-div.popup {
-  width: 600px; 
-  z-index:9;
-  margin-left: auto;
-  margin-right: auto;
-  padding: 5px;
-  background-color: #FFF;
-  border-style: double;
-  border-width: 5px;
-  border-color: #00666a;
-  position:relative; 
-}
-div.close {
-  cursor: pointer;
-  border: 1px solid black; 
-  width:15px; 
-  height:15px; 
-  line-height:15px; /* this causes vertical centering */
-  text-align:center; 
-  background-color:#FFF; 
-  color:#000; 
-  font-size:15px;
-  font-family:monospace;
-}
-
-div.close:hover {
-  color:#FFF;
-  background-color:#000; 
-}
-
-div.navnum {
-  width:100%; 
-  height:20px; 
-  line-height:20px; 
-  text-align:center; 
-  font-size:medium;
-}
-
-div.navarrow {
-  font-size: 30px;
-  text-decoration:none;
-  cursor: pointer;
-  -moz-user-select: none;  
-  -webkit-user-select: none;  
-  -ms-user-select: none;
-}
-
-div.navarrow > span.inactive {
-  display: inline;
-}
-div.navarrow > span.active {
-  display: none;
-}
-
-div.navarrow:hover > span.active {
-  display: inline;
-}
-div.navarrow:hover > span.inactive {
-  display: none;
-}
-
-table.programs {
-  width: 100%;
-}
-
-table.programs tr {
-  background-color: #EFE;
-}
-
-table.programs tr.selected {
-  background-color: #262;
-  color: #FFF;
-}
-
-table.programs tr.dna_only {
-  display: none;
-}
-
-table.programs.alphabet_dna tr.dna_only {
-  display: table-row;
-}
-
-table.inputs {
-  margin-top: 20px;
-  border-collapse:collapse;
-}
-table.inputs * td, table.inputs * th {
-  padding-left: 15px;
-  padding-right: 15px;
-  padding-top: 1px;
-  padding-bottom: 1px;
-}
-
 /* program settings */
-span.strand_none, span.strand_given, span.strand_both {
-  display: none;
-}
-td.none span.strand_none, td.given span.strand_given, td.both span.strand_both {
-  display: inline;
-}
-
-/* show the expanded motif only when the collapsed one is hidden */
-tbody *.less, tbody.collapsed *.more {
-  display: none;
-}
-
-tbody.collapsed *.less {
-  display: inline;
-}
-
 </style>
   </head>
   <body data-scrollpad="true">
-    <!--  -->
-    <div id="grey_out_page" class="grey_background" style="display:none;">
-    </div>
-
-    <!-- Help popups -->
-    <div class="pop_content" id="pop_">
-      <p>Help poup.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_motifs_word">
-      <p>
         The name of the motif uses the IUPAC codes for nucleotides which has 
         a different letter to represent each of the 15 possible combinations.
-      </p>
-      <p>
         The name is itself a representation of the motif though the position
-        weight matrix is not directly equalivant as it is generated from the
+        weight matrix is not directly equivalent as it is generated from the
         sites found that matched the letters given in the name.
-      </p>
-      <p>
-        <a id="doc_alphabets_url" href="#">
-        Read more about the MEME suite's use of the IUPAC alphabets.
-        </a>
-        <script>$("doc_alphabets_url").href = site_url + "/doc/alphabets.html";</script>
-      </p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_logo">
-      <p>The logo of the motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_rc_logo">
-      <p>The logo of the reverse complement motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_evalue">
       <p>The E-value is the enrichment p-value times the number of candidate 
         motifs tested.</p>
       <p>The enrichment p-value is calculated using Fisher's Exact Test for 
         enrichment of the motif in the positive sequences.</p>
       <p>Note that the counts used in Fisher's Exact Test are made after 
         erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_uevalue">
       <p>The E-value of the motif calculated without erasing the sites of 
         previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_more">
       <p>Show more information on the motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_submit_dl">
       <p>Submit your motif to another MEME Suite program or download your motif.</p>
       <h5>Supported Programs</h5>
-      <dl>
         <dt>Tomtom</dt>
         <dd>Tomtom is a tool for searching for similar known motifs. 
-          </dd>
         <dt>MAST</dt>
         <dd>MAST is a tool for searching biological sequence databases for 
           sequences that contain one or more of a group of known motifs.
-          </dd>
         <dt>FIMO</dt>
         <dd>FIMO is a tool for searching biological sequence databases for 
           sequences that contain one or more known motifs.
-          </dd>
-        <dt>GOMO</dt>
-        <dd>GOMO is a tool for identifying possible roles (Gene Ontology 
+        <dt>GOMo</dt>
+        <dd>GOMo is a tool for identifying possible roles (Gene Ontology 
           terms) for DNA binding motifs.
-          </dd>
         <dt>SpaMo</dt>
         <dd>SpaMo is a tool for inferring possible transcription factor
           complexes by finding motifs with enriched spacings.
-          </dd>
-      </dl>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_positives">
-      <p># positive sequences matching the motif / # positive sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_negatives">
-      <p># negative sequences matching the motif / # negative sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_pvalue">
-      <p>The p-value of Fisher's Exact Test for enrichment of the motif in 
-        the positive sequences.</p>
-      <p>Note that the counts used in Fisher's Exact Test are made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_evalue">
-      <p>The E-value is the motif p-value times the number of candidate motifs 
-        tested.</p>
-      <p>Note that the p-value was calculated with counts made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_uevalue">
-      <p>The E-value of the motif calculated without erasing the sites of 
-        previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_word">
-      <p>All words matching the motif whose uncorrected p-value is less than
-      <span id="help_add_pv_thresh"></span>.</p>
-      <script>$("help_add_pv_thresh").innerHTML = data.options.add_pv_thresh;</script>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_pos">
-      <p># positive sequences with matches to the word / # positive sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_neg">
-      <p># negative sequences with matches to the word / # negative sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_pval">
-      <p>The p-value of Fisher's Exact Test for enrichment of the word in 
-        the positive sequences.</p>
-      <p>Note that the counts used in Fisher's Exact Test are made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_eval">
-      <p>The word p-value times the number of candidates tested.</p>
-      <p>Note that the p-value was calculated with counts made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_source">
-      <p>The sequence file used by DREME to find the motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_alph">
-      <p>The alphabet of the sequences.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_count">
-      <p>The count of the sequences.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_name">
-      <p>The name of the alphabet symbol.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_control">
-      <p>The frequency of the alphabet symbol in the control dataset.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <!-- templates -->
-
-    <div class="template box expanded_motif" id="tmpl_motif_expanded">
-      <div>
-        <span class="tvar_logo"></span>
-        <span class="tvar_rclogo"></span>
-      </div>
-      <h4>Details</h4>
-      <table class="details">
-        <thead>
-          <tr>
-            <th class="match_count">Positives <div class="help" data-topic="pop_motif_positives"></div></th>
-            <th class="match_count">Negatives <div class="help" data-topic="pop_motif_negatives"></div></th>
-            <th class="match_evalue">P-value <div class="help" data-topic="pop_motif_pvalue"></div></th>
-            <th class="match_evalue">E-value <div class="help" data-topic="pop_motif_evalue"></div></th>
-            <th class="match_evalue">Unerased E-value <div class="help" data-topic="pop_motif_uevalue"></div></th>
-          </tr>
-        </thead>
-        <tbody>
-          <tr>
-            <td class="match_count">
-              <span class="tvar_p"></span> / <span class="tvar_p_total"></span>
-            </td>
-            <td class="match_count">
-              <span class="tvar_n"></span> / <span class="tvar_n_total"></span>
-            </td>
-            <td class="tvar_pvalue match_evalue"></td>
-            <td class="tvar_evalue match_evalue"></td>
-            <td class="tvar_uevalue match_evalue"></td>
-          </tr>
-        </tbody>
-      </table>
-      <h4>Enriched Matching Words</h4>
-      <div class="tvar_words"></div>
-    </div>
-
-
-    <div class="popup_wrapper">
-      <div class="popup" style="display:none; top: -150px;" id="download">
-        <div>
-          <div style="float:right; ">
-            <div id="outpop_close" class="close" tabindex="0">x</div>
-          </div>
-          <h2 class="mainh" style="margin:0; padding:0;">Submit or Download</h2>
-          <div style="clear:both"></div>
-        </div>
-          <div style="height:100px">
-            <div style="float:right; width: 30px;">
-              <div id="outpop_prev" class="navarrow" tabindex="0">
-                <span class="inactive">&#8679;</span><span class="active">&#11014;</span>
-              </div>
-              <div id="outpop_num" class="navnum"></div>
-              <div id="outpop_next" class="navarrow" tabindex="0">
-                <span class="inactive">&#8681;</span><span class="active">&#11015;</span>
-              </div>
-            </div>
-            <div id="logo_box" style="height: 100px; margin-right: 40px;">
-              <canvas id="outpop_logo" height="100" width="250"></canvas>
-              <canvas id="outpop_logo_rc" height="100" width="250"></canvas>
-            </div>
-          </div>
-          <div>
-            <!-- tabs start -->
-            <div class="tabArea top">
-              <span id="outpop_tab_1" class="tab">Submit Motif</span><span
-                id="outpop_tab_2" class="tab middle">Download Motif</span><span 
-                id="outpop_tab_3" class="tab middle">Download Logo</span>
-            </div>
-            <div class="tabMain top">
-              <!-- Submit to another program -->
-              <div id="outpop_pnl_1">
-                <h4 class="compact">Submit to program</h4>
-                <table id="programs" class="programs">
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="tomtom" id="submit_tomtom"></td>
-                    <td><label for="submit_tomtom">Tomtom</label></td>
-                    <td><label for="submit_tomtom">Find similar motifs in
-                        published libraries or a library you supply.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="fimo" id="submit_fimo"></td>
-                    <td><label for="submit_fimo">FIMO</label></td>
-                    <td><label for="submit_fimo">Find motif occurrences in
-                        sequence data.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="mast" id="submit_mast"></td>
-                    <td><label for="submit_mast">MAST</label></td>
-                    <td><label for="submit_mast">Rank sequences by affinity to
-                        groups of motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="gomo" id="submit_gomo"></td>
-                    <td><label for="submit_gomo">GOMo</label></td>
-                    <td><label for="submit_gomo">Identify possible roles (Gene
-                        Ontology terms) for motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="spamo" id="submit_spamo"></td>
-                    <td><label for="submit_spamo">SpaMo</label></td>
-                    <td><label for="submit_spamo">Find other motifs that are
-                        enriched at specific close spacings which might imply the existance of a complex.</label></td>
-                  </tr>
-                </table>
-              </div>
-              <!-- download text format  -->
-              <div id="outpop_pnl_2">
-                <div>
-                  <label for="text_format">Format:</label>
-                  <select id="text_format">
-                    <option value="0">Count Matrix</option>
-                    <option value="1">Probability Matrix</option>
-                    <option value="2">Minimal MEME</option>
-                  </select>
-                </div>
-                <textarea id="outpop_text" name="content"
-                  style="width:99%; white-space: pre; word-wrap: normal; overflow-x: scroll;" 
-                  rows="8" readonly="readonly" wrap="off"></textarea>
-                <a id="outpop_text_dl" download="meme.txt" href=""></a>
-              </div>
-              <!-- download logo format -->
-              <div id="outpop_pnl_3">
-                <form id="logo_form" method="post" action="">
-                  <script>$("logo_form").action = site_url + "/utilities/generate_logo";</script>
-                  <input type="hidden" name="program" value="DREME"/>
-                  <input type="hidden" id="logo_motifs" name="motifs" value=""/>
-                  <table>
-                    <tr>
-                      <td><label for="logo_format">Format:</label></td>
-                      <td>
-                        <select id="logo_format" name="png">
-                          <option value="1">PNG (for web)</option>
-                          <option value="0">EPS (for publication)</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_rc">Orientation:</label></td>
-                      <td>
-                        <select id="logo_rc" name="rc1">
-                          <option value="0">Normal</option>
-                          <option value="1" id="logo_rc_option">Reverse Complement</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_ssc">Small Sample Correction:</label></td>
-                      <td>
-                        <input type="hidden" id="logo_err" name="errbars" value="0"/>
-                        <select id="logo_ssc" name="ssc">
-                          <option value="0">Off</option>
-                          <option value="1">On</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_width">Width:</label></td>
-                      <td>
-                        <input type="text" id="logo_width" size="4" placeholder="default" name="width"/>&nbsp;cm
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_height">Height:</label></td>
-                      <td>
-                        <input type="text" id="logo_height" size="4" placeholder="default" name="height"/>&nbsp;cm
-                      </td>
-                    </tr>
-                  </table>
-                </form>
-              </div>
-              <!-- Buttons -->
-              <div>
-                <div style="float:left;">
-                  <input type="button" id="outpop_do" value="Submit" />
-                </div>
-                <div style="float:right;">
-                  <input id="outpop_cancel" type="button" value="Cancel" />
-                </div>
-                <div style="clear:both;"></div>
-              </div>
-            </div>
-        </div>
-      </div>
-    </div>
-
-
-
-    <!-- Page starts here -->
-    <div id="top" class="pad1">
-      <div class="prog_logo big">
-        <img src="" alt="DREME Logo"/>
-        <h1>DREME</h1>
-        <h2>Discriminative Regular Expression Motif Elicitation</h2>
-      </div>
-      <p class="spaced">
-        For further information on how to interpret these results or to get a 
-        copy of the MEME software please access 
-        <a href="http://meme.nbcr.net/">http://meme.nbcr.net</a>. 
-      </p>
-      <p>
-        If you use DREME in your research please cite the following paper:<br />
-        <span class="citation">
-          Timothy L. Bailey, "DREME: Motif discovery in transcription factor ChIP-seq data", <i>Bioinformatics</i>, <b>27</b>(12):1653-1659, 2011.
-          <a href="http://bioinformatics.oxfordjournals.org/content/27/12/1653">[full text]</a>
-        </span>
-      </p>
-    </div>
-    <!-- navigation -->
-    <div class="pad2">
-      <a class="jump" href="#motifs_sec">Discovered Motifs</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#inputs_sec">Inputs &amp; Settings</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#info_sec">Program information</a>
-    </div>
-    <!-- alert the user when their browser is not up to the task -->
-    <noscript><h1 style="color:red">Javascript is required to view these results!</h1></noscript>
-    <h1 id="html5_warning" style="color:red; display:none;">Your browser does not support canvas!</h1>
-    <script>
-      if (!window.HTMLCanvasElement) $("html5_warning").style.display = "block";
-    </script>
-    <!-- description -->
-    <div id="description_section" style="display:none">
-      <div id="description" class="header">
-        <h2>Description</h2>
-      </div>
-      <div id="description_text" class="box">
-      </div>
-    </div>
-    <script>
-      if (data.description) {
-        $("description_text").innerHTML = "";
-        $("description_text").appendChild(make_description(data.description));
-        $("description_section").style.display = "block";
-      }
-    </script>
-    <!-- motifs -->
-    <div id="motifs_sec" class="header">
-      <h2>Discovered Motifs</h2>
-      <span><a href="#inputs_sec">Next</a>&nbsp;<a href="#">Top</a></span>
-    </div>
-    <div id="motifs" class="box">
-      <p>No motifs were discovered!</p>
-    </div>
-    <script>make_motifs();</script>
-    <!-- inputs and settings -->
-    <div id="inputs_sec" class="header">
-      <h2>Inputs &amp; Settings</h2>
-      <span><a href="#motifs_sec">Previous</a>&nbsp;<a href="#info_sec">Next</a>&nbsp;<a href="#">Top</a></span>
-    </div>
-    <div class="box">
-      <h4>Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th>Alphabet <div class="help" data-topic="pop_seq_alph"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_seq_source"></td>
-          <td id="ins_seq_alphabet"></td>
-          <td id="ins_seq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.sequence_db;
-        $("ins_seq_source").innerHTML = db.file;
-        $("ins_seq_alphabet").innerHTML = dreme_alphabet.get_alphabet_name();
-        $("ins_seq_count").innerHTML = db.count;
-      }
-      </script>
-      <h4>Control Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_cseq_source"></td>
-          <td id="ins_cseq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.control_db;
-        if (db.from == "shuffled") {
-          $("ins_cseq_source").innerHTML = "Shuffled Sequences";
-        } else {
-          $("ins_cseq_source").innerHTML = db.file;
-        }
-        $("ins_cseq_count").innerHTML = db.count;
-      }
-      </script>
-      <h4>Background</h4>
-      <span id="alpha_bg"></span>
-      <script>
-      {
-        $("alpha_bg").appendChild(make_alpha_bg(dreme_alphabet, data.control_db.freqs));
-      }
-      </script>
-      <h4>Other Settings</h4>
-      <table id="tbl_settings" class="inputs hide_advanced">
-        <tr>
-          <th>Strand Handling</th>
-          <td id="opt_strand">
-            <span class="strand_none">This alphabet only has one strand</span>
-            <span class="strand_given">Only the given strand is processed</span>
-            <span class="strand_both">Both the given and reverse complement strands are processed</span>
-          </td>
-        </tr>
-        <tr><th># REs to Generalize</th><td id="opt_ngen"></td></tr>
-        <tr><th>Shuffle Seed</th><td id="opt_seed"></td></tr>
-        <tr><th>E-value Threshold</th><td id="opt_stop_evalue"></td></tr>
-        <tr><th>Max Motif Count</th><td id="opt_stop_count"></td></tr>
-        <tr><th>Max Run Time</th><td id="opt_stop_time"></td></tr>
-      </table>
-      <script>
-      {
-        $("opt_strand").className = (dreme_alphabet.has_complement() ? (data.options.revcomp ? "both" : "given") : "none");
-        $("opt_ngen").innerHTML = data.options.ngen;
-        $("opt_seed").innerHTML = data.options.seed;
-        $("opt_stop_evalue").innerHTML = data.options.stop.evalue;
-        $("opt_stop_count").innerHTML = (typeof data.options.stop.count == "number" ? data.options.stop.count : "No maximum motif count.");
-        $("opt_stop_time").innerHTML = (typeof data.options.stop.time == "number" ? data.options.stop.time + " seconds." : "No maximum running time.");
-      }
-      </script>
-    </div>
-    <!-- list information on this program -->
-    <div id="info_sec" class="bar" style="position:relative">
-      <div style="position: absolute; right: 0;"><a href="#inputs_sec">Previous</a> <a href="#">Top</a></div>
-      <div class="subsection">
-        <h5 id="version">DREME version</h5>
-        <span id="ins_version"></span> 
-        (Release date: <span id="ins_release"></span>)<br>
-      </div>
-      <script>
-        $("ins_version").innerHTML = data["version"];
-        $("ins_release").innerHTML = data["release"];
-      </script>
-      <div class="subsection">
-        <h5 id="reference">Reference</h5>
-        <span class="citation">
-          Timothy L. Bailey, "DREME: Motif discovery in transcription factor ChIP-seq data", <i>Bioinformatics</i>, <b>27</b>(12):1653-1659, 2011.
-          <a href="http://bioinformatics.oxfordjournals.org/content/27/12/1653">[full text]</a>
-        </span>
-      </div>
-      <div class="subsection">
-        <h5 id="command">Command line</h5>
-        <textarea id="cmd" rows="3" style="width:100%;" readonly="readonly">
-        </textarea>
-        <script>$("cmd").value = data["cmd"].join(" ");</script>
-      </div>
-    </div>
-    
   </body>
 </html>
--- a/test-data/dreme_output_test1.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test1.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,12 +1,7 @@
-# DREME 4.12.0
-#     command: dreme -o ./dreme_test1_out -p dreme_test_sites.fa -norc -rna -s 1
-#   positives: 1000 from dreme_test_sites.fa (Thu Apr 26 15:09:03 CEST 2018)
+# DREME 5.0.5
 #   negatives: 1000 from shuffled positives
-#        host: ThinkPad-T450s
-#        when: Thu May 03 13:22:29 CEST 2018
 
-MEME version 4.12.0
-
+MEME version 5.0.5
 ALPHABET "RNA" RNA-LIKE
 A "Adenine" CC0000
 C "Cytosine" 0000CC
@@ -27,20 +22,15 @@
 K "Keto" = GU
 T = U
 END ALPHABET
-
 Background letter frequencies (from dataset):
 A 0.221 C 0.245 G 0.221 U 0.312
-
-
 MOTIF UUYUCY DREME-1
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST      UUYUCY        387        210   2.6e-018   1.2e-013
 #           UUUUCC        147         75   1.8e-007   8.1e-003
 #           UUUUCU        155         94   2.2e-005   1.0e+000
 #           UUCUCU         94         51   1.3e-004   6.1e+000
 #           UUCUCC         75         42   1.1e-003   5.0e+001
-
 letter-probability matrix: alength= 4 w= 6 nsites= 459 E= 1.2e-013
 0.000000 0.000000 0.000000 1.000000
 0.000000 0.000000 0.000000 1.000000
@@ -48,29 +38,21 @@
 0.000000 0.000000 0.000000 1.000000
 0.000000 1.000000 0.000000 0.000000
 0.000000 0.474946 0.000000 0.525054
-
-
 MOTIF YAGG DREME-2
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST        YAGG        600        416   1.1e-016   5.1e-012
 #             CAGG        441        304   1.5e-010   6.6e-006
 #             UAGG        232        165   1.1e-004   4.7e+000
-
 letter-probability matrix: alength= 4 w= 4 nsites= 793 E= 5.1e-012
 0.000000 0.692308 0.000000 0.307692
 1.000000 0.000000 0.000000 0.000000
 0.000000 0.000000 1.000000 0.000000
 0.000000 0.000000 1.000000 0.000000
-
-
 MOTIF GAAGAW DREME-3
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST      GAAGAW         81         22   8.2e-010   3.4e-005
 #           GAAGAU         45          7   2.4e-008   9.9e-004
 #           GAAGAA         40         16   7.9e-004   3.3e+001
-
 letter-probability matrix: alength= 4 w= 6 nsites= 89 E= 3.4e-005
 0.000000 0.000000 1.000000 0.000000
 1.000000 0.000000 0.000000 0.000000
@@ -78,17 +60,13 @@
 0.000000 0.000000 1.000000 0.000000
 1.000000 0.000000 0.000000 0.000000
 0.494382 0.000000 0.000000 0.505618
-
-
 MOTIF SMUGGA DREME-4
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST      SMUGGA        110         47   9.1e-008   3.7e-003
 #           GAUGGA         22          6   1.7e-003   7.1e+001
 #           GCUGGA         33         14   3.6e-003   1.5e+002
 #           CCUGGA         32         15   8.6e-003   3.5e+002
 #           CAUGGA         29         13   9.1e-003   3.7e+002
-
 letter-probability matrix: alength= 4 w= 6 nsites= 119 E= 3.7e-003
 0.000000 0.529412 0.470588 0.000000
 0.428571 0.571429 0.000000 0.000000
@@ -96,7 +74,4 @@
 0.000000 0.000000 1.000000 0.000000
 0.000000 0.000000 1.000000 0.000000
 1.000000 0.000000 0.000000 0.000000
-
-
 # Stopping reason: E-value threshold exceeded
-#    Running time: 13.95 seconds
--- a/test-data/dreme_output_test1.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test1.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,7 +1,5 @@
-<dreme version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
+<dreme version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
   <model>
-    <command_line>dreme -o ./dreme_test1_out -p dreme_test_sites.fa -norc -rna -s 1</command_line>
-    <positives name="dreme test sites" count="1000" file="dreme_test_sites.fa" last_mod_date="Thu Apr 26 15:09:03 CEST 2018" />
     <negatives name="shuffled positive sequences" count="1000" from="shuffled"/>
     <alphabet name="RNA" like="rna">
       <letter id="A" symbol="A" name="Adenine" colour="CC0000"/>
@@ -26,8 +24,6 @@
     <ngen>100</ngen>
     <add_pv_thresh>0.01</add_pv_thresh>
     <seed>1</seed>
-    <host>ThinkPad-T450s</host>
-    <when>Thu May 03 13:22:29 CEST 2018</when>
   </model>
   <motifs>
     <motif id="m01" alt="DREME-1" seq="UUYUCY" length="6" nsites="459" p="387" n="210" pvalue="2.6e-018" evalue="1.2e-013" unerased_evalue="1.2e-013">
@@ -73,5 +69,4 @@
       <match seq="CAUGGA" p="29" n="13" pvalue="9.1e-003" evalue="3.7e+002"/>
     </motif>
   </motifs>
-  <run_time cpu="13.95" real="13.95" stop="evalue"/>
 </dreme>
--- a/test-data/dreme_output_test2.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test2.html	Wed Dec 11 18:05:15 2019 -0500
@@ -7,10 +7,10 @@
       // @JSON_VAR data
       var data = {
         "program": "dreme",
-        "version": "4.12.0",
-        "release": "Tue Jun 27 16:22:50 2017 -0700",
+        "version": "5.0.5",
+        "release": "Mon Mar 18 20:12:19 2019 -0700",
         "cmd": [
-          "dreme", "-o", "./dreme_test2_out", "-p", "dreme_test_sites.fa",
+          "dreme", "-o", "./dreme_out", "-p",
           "-norc", "-rna", "-s", "1", "-e", "1e-05", "-g", "100", "-mink",
           "4", "-maxk", "10"
         ],
@@ -36,80 +36,57 @@
               "symbol": "C",
               "name": "Cytosine",
               "colour": "0000CC"
-            }, {
               "symbol": "G",
               "name": "Guanine",
               "colour": "FFB300"
-            }, {
               "symbol": "U",
               "aliases": "T",
               "name": "Uracil",
               "colour": "008000"
-            }, {
               "symbol": "N",
               "aliases": "X.",
               "name": "Any base",
               "equals": "ACGU"
-            }, {
               "symbol": "V",
               "name": "Not U",
               "equals": "ACG"
-            }, {
               "symbol": "H",
               "name": "Not G",
               "equals": "ACU"
-            }, {
               "symbol": "D",
               "name": "Not C",
               "equals": "AGU"
-            }, {
               "symbol": "B",
               "name": "Not A",
               "equals": "CGU"
-            }, {
               "symbol": "M",
               "name": "Amino",
               "equals": "AC"
-            }, {
               "symbol": "R",
               "name": "Purine",
               "equals": "AG"
-            }, {
               "symbol": "W",
               "name": "Weak",
               "equals": "AU"
-            }, {
               "symbol": "S",
               "name": "Strong",
               "equals": "CG"
-            }, {
               "symbol": "Y",
               "name": "Pyrimidine",
               "equals": "CU"
-            }, {
               "symbol": "K",
               "name": "Keto",
               "equals": "GU"
-            }
-          ]
-        },
         "background": {
           "freqs": [0.221, 0.245, 0.221, 0.312]
-        },
         "sequence_db": {
-          "name": "dreme test sites",
-          "file": "dreme_test_sites.fa",
-          "lmod": "Thu Apr 26 15:09:03 CEST 2018",
           "count": 1000
-        },
         "control_db": {
           "name": "shuffled positive sequences",
           "from": "shuffled",
           "count": 1000,
           "freqs": [0.221, 0.245, 0.221, 0.312]
-        },
         "motifs": [
-          {
             "db": 0,
             "id": "UUYUCY",
             "alt": "DREME-1",
@@ -127,5993 +104,64 @@
               [0.000000, 0.000000, 0.000000, 1.000000], 
               [0.000000, 1.000000, 0.000000, 0.000000], 
               [0.000000, 0.474946, 0.000000, 0.525054]
-            ],
             "matches": [
-              {
                 "seq": "UUUUCC",
                 "p": 147,
                 "n": 75,
                 "pvalue": "1.8e-007",
                 "evalue": "2.2e-002"
-              }, {
-                "seq": "UUUUCU",
-                "p": 155,
-                "n": 94,
-                "pvalue": "2.2e-005",
-                "evalue": "2.8e+000"
-              }, {
-                "seq": "UUCUCU",
-                "p": 94,
-                "n": 51,
-                "pvalue": "1.3e-004",
-                "evalue": "1.7e+001"
-              }, {
-                "seq": "UUCUCC",
-                "p": 75,
-                "n": 42,
-                "pvalue": "1.1e-003",
-                "evalue": "1.4e+002"
-              }
-            ]
-          }, {
-            "db": 0,
-            "id": "YAGG",
-            "alt": "DREME-2",
-            "len": 4,
-            "nsites": 793,
-            "evalue": "1.4e-011",
-            "p": 600,
-            "n": 416,
-            "pvalue": "1.1e-016",
-            "unerased_evalue": "6.3e-012",
-            "pwm": [
-              [0.000000, 0.692308, 0.000000, 0.307692], 
-              [1.000000, 0.000000, 0.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000], 
-              [0.000000, 0.000000, 1.000000, 0.000000]
-            ],
-            "matches": [
-              {
-                "seq": "CAGG",
-                "p": 441,
-                "n": 304,
-                "pvalue": "1.5e-010",
-                "evalue": "1.8e-005"
-              }, {
-                "seq": "UAGG",
-                "p": 232,
-                "n": 165,
-                "pvalue": "1.1e-004",
-                "evalue": "1.3e+001"
-              }
-            ]
-          }
-        ],
-        "runtime": {
-          "host": "ThinkPad-T450s",
-          "when": "Thu May 03 13:22:11 CEST 2018",
-          "cpu": 15.97,
-          "real": 15.97,
-          "stop": "evalue"
-        }
-      };
     </script>
-    <script>
 var site_url = "http://meme-suite.org";
-</script>
-    <script>
-
-/*
- * $
- *
- * Shorthand function for getElementById
- */
-function $(el) {
-  return document.getElementById(el);
-}
-
-
-/*
- * See http://stackoverflow.com/a/5450113/66387
- * Does string multiplication like the perl x operator.
- */
-function string_mult(pattern, count) {
-    if (count < 1) return '';
-    var result = '';
-    while (count > 1) {
-        if (count & 1) result += pattern;
-        count >>= 1, pattern += pattern;
-    }
-    return result + pattern;
-}
-
-/*
- * See http://stackoverflow.com/questions/814613/how-to-read-get-data-from-a-url-using-javascript
- * Slightly modified with information from
- * https://developer.mozilla.org/en/DOM/window.location
- */
-function parse_params() {
-  "use strict";
-  var search, queryStart, queryEnd, query, params, nvPairs, i, nv, n, v;
-  search = window.location.search;
-  queryStart = search.indexOf("?") + 1;
-  queryEnd   = search.indexOf("#") + 1 || search.length + 1;
-  query      = search.slice(queryStart, queryEnd - 1);
-
-  if (query === search || query === "") return {};
-
-  params  = {};
-  nvPairs = query.replace(/\+/g, " ").split("&");
-
-  for (i = 0; i < nvPairs.length; i++) {
-    nv = nvPairs[i].split("=");
-    n  = decodeURIComponent(nv[0]);
-    v  = decodeURIComponent(nv[1]);
-    // allow a name to be used multiple times
-    // storing each value in the array
-    if (!(n in params)) {
-      params[n] = [];
-    }
-    params[n].push(nv.length === 2 ? v : null);
-  }
-  return params;
-}
-
-/*
- * coords
- *
- * Calculates the x and y offset of an element.
- * From http://www.quirksmode.org/js/findpos.html
- * with alterations to take into account scrolling regions
- */
-function coords(elem) {
-  var myX = myY = 0;
-  if (elem.getBoundingClientRect) {
-    var rect;
-    rect = elem.getBoundingClientRect();
-    myX = rect.left + ((typeof window.pageXOffset !== "undefined") ?
-        window.pageXOffset : document.body.scrollLeft);
-    myY = rect.top + ((typeof window.pageYOffset !== "undefined") ?
-        window.pageYOffset : document.body.scrollTop);
-  } else {
-    // this fall back doesn't properly handle absolutely positioned elements
-    // inside a scrollable box
-    var node;
-    if (elem.offsetParent) {
-      // subtract all scrolling
-      node = elem;
-      do {
-        myX -= node.scrollLeft ? node.scrollLeft : 0;
-        myY -= node.scrollTop ? node.scrollTop : 0;
-      } while (node = node.parentNode);
-      // this will include the page scrolling (which is unwanted) so add it back on
-      myX += (typeof window.pageXOffset !== "undefined") ? window.pageXOffset : document.body.scrollLeft;
-      myY += (typeof window.pageYOffset !== "undefined") ? window.pageYOffset : document.body.scrollTop;
-      // sum up offsets
-      node = elem;
-      do {
-        myX += node.offsetLeft;
-        myY += node.offsetTop;
-      } while (node = node.offsetParent);
-    }
-  }
-  return [myX, myY];
-}
-
-/*
- * position_popup
- *
- * Positions a popup relative to an anchor element.
- *
- * The avaliable positions are:
- * 0 - Centered below the anchor.
- */
-function position_popup(anchor, popup, position) {
-  "use strict";
-  var a_x, a_y, a_w, a_h, p_x, p_y, p_w, p_h;
-  var a_xy, spacer, margin, scrollbar, page_w;
-  // define constants
-  spacer = 5;
-  margin = 15;
-  scrollbar = 15;
-  // define the positions and widths
-  a_xy = coords(anchor);
-  a_x = a_xy[0];
-  a_y = a_xy[1];
-  a_w = anchor.offsetWidth;
-  a_h = anchor.offsetHeight;
-  p_w = popup.offsetWidth;
-  p_h = popup.offsetHeight;
-  page_w = null;
-  if (window.innerWidth) {
-    page_w = window.innerWidth;
-  } else if (document.body) {
-    page_w = document.body.clientWidth;
-  }
-  // check the position type is defined
-  if (typeof position !== "number") {
-    position = 0;
-  }
-  // calculate the popup position
-  switch (position) {
-    case 1:
-      p_x = a_x + a_w + spacer;
-      p_y = a_y + (a_h / 2) - (p_h / 2);
-      break;
-    case 0:
-    default:
-      p_x = a_x + (a_w / 2) - (p_w / 2);
-      p_y = a_y + a_h + spacer;
-      break;
-  }
-  // constrain the popup position
-  if (p_x < margin) {
-    p_x = margin;
-  } else if (page_w != null && (p_x + p_w) > (page_w - margin - scrollbar)) {
-    p_x = page_w - margin - scrollbar - p_w;
-  }
-  if (p_y < margin) {
-    p_y = margin;
-  }
-  // position the popup
-  popup.style.left = p_x + "px";
-  popup.style.top = p_y + "px";
-}
-
-function lookup_help_popup(popup_id) {
-  var _body, pop, info;
-  pop = document.getElementById(popup_id);
-  if (pop == null) {
-    _body = document.getElementsByTagName("body")[0];
-    pop = document.createElement("div");
-    pop.className = "pop_content";
-    pop.id = popup_id;
-    pop.style.backgroundColor = "#FFC";
-    pop.style.borderColor = "black";
-    info = document.createElement("p");
-    info.style.fontWeight = "bold";
-    info.appendChild(document.createTextNode("Error: No popup for topic \"" + popup_id + "\"."));
-    pop.appendChild(info);
-    // this might cause problems with the menu, but as this only happens
-    // when something is already wrong I don't think that's too much of a problem
-    _body.insertBefore(pop, _body.firstChild);
-  }
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-autobtns")) {
-    if (!/\bauto_buttons\b/.test(pop.className)) {
-      pop.className += " auto_buttons";
-      var back_btn_sec = document.createElement("div");
-      back_btn_sec.className = "nested_only pop_back_sec";
-      var back_btn = document.createElement("span");
-      back_btn.className = "pop_back";
-      back_btn.appendChild(document.createTextNode("<< back"));
-      back_btn.addEventListener("click", function(e) {
-        help_return();
-      }, false);
-      back_btn_sec.appendChild(back_btn);
-      pop.insertBefore(back_btn_sec, pop.firstChild);
-      var close_btn_sec = document.createElement("div");
-      close_btn_sec.className = "pop_close_sec";
-      var close_btn = document.createElement("span");
-      close_btn.className = "pop_close";
-      close_btn.appendChild(document.createTextNode("close"));
-      close_btn.addEventListener("click", function(e) {
-        help_popup();
-      }, false);
-      close_btn_sec.appendChild(close_btn);
-      pop.appendChild(close_btn_sec);
-    }
-  }
-  return pop;
-}
-
-/*
- * help_popup
- *
- * Moves around help pop-ups so they appear
- * below an activator.
- */
-function help_popup(activator, popup_id) {
-  "use strict";
-  var pop;
-  // set default values
-  if (typeof help_popup.popup === "undefined") {
-    help_popup.popup = [];
-  }
-  if (typeof help_popup.activator === "undefined") {
-    help_popup.activator = null;
-  }
-  var last_pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (typeof(activator) == "undefined") { // no activator so hide
-    if (last_pop != null) {
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-    }
-    return;
-  }
-  pop = lookup_help_popup(popup_id);
-  if (pop == last_pop) {
-    if (activator == help_popup.activator) {
-      //hide popup (as we've already shown it for the current help button)
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-      return; // toggling complete!
-    }
-  } else if (last_pop != null) {
-    //activating different popup so hide current one
-    last_pop.style.display = 'none';
-  }
-  help_popup.popup = [pop];
-  help_popup.activator = activator;
-  toggle_class(pop, "nested", false);
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = 'block';
-  position_popup(activator, pop);
-}
-
-/*
- * help_refine
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_refine(popup_id) {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not refine a help popup when one is not shown!");
-  }
-  var pop = lookup_help_popup(popup_id);
-  var last_pop = help_popup.popup[help_popup.popup.length - 1];
-  if (pop == last_pop) return; // slightly odd, but no real cause for alarm
-  help_popup.popup.push(pop);
-  toggle_class(pop, "nested", true);
-  last_pop.style.display = "none";
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = "block";
-  position_popup(help_popup.activator, pop);
-}
-
-/*
- * help_return
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_return() {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not return to a earlier help popup when one is not shown!");
-  }
-  var last_pop = help_popup.popup.pop();
-  last_pop.style.display = "none";
-  var pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (pop != null) {
-    toggle_class(pop, "nested", help_popup.popup.length > 1);
-    pop.style.display = "block";
-    position_popup(help_popup.activator, pop);
-  } else {
-    help_popup.activator = null;
-  }
-}
-
-/*
- * update_scroll_pad
- *
- * Creates padding at the bottom of the page to allow
- * scrolling of anything into view.
- */
-function update_scroll_pad() {
-  var page, pad;
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  pad = $("scrollpad");
-  if (pad === null) {
-    pad = document.createElement("div");
-    pad.id = 'scrollpad';
-    document.getElementsByTagName('body')[0].appendChild(pad);
-  }
-  pad.style.height = Math.abs(page.clientHeight - 100) + "px";
-}
-
-function substitute_classes(node, remove, add) {
-  "use strict";
-  var list, all, i, cls, classes;
-  list = node.className.split(/\s+/);
-  all = {};
-  for (i = 0; i < list.length; i++) {
-    if (list[i].length > 0) all[list[i]] = true;
-  }
-  for (i = 0; i < remove.length; i++) {
-    if (all.hasOwnProperty(remove[i])) {
-      delete all[remove[i]];
-    }
-  }
-  for (i = 0; i < add.length; i++) {
-    all[add[i]] = true;
-  }
-  classes = "";
-  for (cls in all) {
-    classes += cls + " ";
-  }
-  node.className = classes;
-}
-
-/*
- * toggle_class
- *
- * Adds or removes a class from the node. If the parameter 'enabled' is not 
- * passed then the existence of the class will be toggled, otherwise it will be
- * included if enabled is true.
- */
-function toggle_class(node, cls, enabled) {
-  var classes = node.className;
-  var list = classes.replace(/^\s+/, '').replace(/\s+$/, '').split(/\s+/);
-  var found = false;
-  for (var i = 0; i < list.length; i++) {
-    if (list[i] == cls) {
-      list.splice(i, 1);
-      i--;
-      found = true;
-    }
-  }
-  if (typeof enabled == "undefined") {
-    if (!found) list.push(cls);
-  } else {
-    if (enabled) list.push(cls);
-  }
-  node.className = list.join(" ");
-}
-
-/*
- * find_child
- *
- * Searches child nodes in depth first order and returns the first it finds
- * with the className specified.
- * TODO replace with querySelector
- */
-function find_child(node, className) {
-  var pattern;
-  if (node == null || typeof node !== "object") {
-    return null;
-  }
-  if (typeof className === "string") {
-    pattern = new RegExp("\\b" + className + "\\b");
-  } else {
-    pattern = className;
-  }
-  if (node.nodeType == Node.ELEMENT_NODE && 
-      pattern.test(node.className)) {
-    return node;
-  } else {
-    var result = null;
-    for (var i = 0; i < node.childNodes.length; i++) {
-      result = find_child(node.childNodes[i], pattern);
-      if (result != null) break;
-    }
-    return result;
-  }
-}
-
-/*
- * find_parent
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the className specified.
- */
-function find_parent(node, className) {
-  var pattern;
-  pattern = new RegExp("\\b" + className + "\\b");
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && 
-        pattern.test(node.className)) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * find_parent_tag
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the tag name specified. HTML tags should be specified in upper case.
- */
-function find_parent_tag(node, tag_name) {
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && node.tagName == tag_name) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * __toggle_help
- *
- * Uses the 'topic' property of the this object to
- * toggle display of a help topic.
- *
- * This function is not intended to be called directly.
- */
-function __toggle_help(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-
-  help_popup(this, this.getAttribute("data-topic"));
-}
-
-function setup_help_button(button) {
-  "use strict";
-  var topic;
-  if (button.hasAttribute("data-topic")) {
-    topic = button.getAttribute("data-topic");
-    if (document.getElementById(topic) != null) {
-      button.tabIndex = "0"; // make keyboard selectable
-      button.addEventListener("click", function() {
-        help_popup(button, topic);
-      }, false);
-      button.addEventListener("keydown", function(e) {
-        // toggle only on Enter or Spacebar, let other keys do their thing
-        if (e.keyCode !== 13 && e.keyCode !== 32) return;
-        // stop a submit or something like that
-        e.preventDefault();
-        help_popup(button, topic);
-      }, false);
-    } else {
-      button.style.visibility = "hidden";
-    }
-  }
-  button.className += " active";
-}
-
-/*
- * help_button
- *
- * Makes a help button for the passed topic.
- */
-function help_button(topic) {
-  var btn = document.createElement("div");
-  btn.className = "help";
-  btn.setAttribute("data-topic", topic);
-  setup_help_button(btn);
-  return btn;
-}
-
-/*
- * prepare_download
- *
- * Sets the attributes of a link to setup a file download using the given content.
- * If no link is provided then create one and click it.
- */
-function prepare_download(content, mimetype, filename, link) {
-  "use strict";
-  // if no link is provided then create one and click it
-  var click_link = false;
-  if (!link) {
-    link = document.createElement("a");
-    click_link = true;
-  }
-  try {
-    // Use a BLOB to convert the text into a data URL.
-    // We could do this manually with a base 64 conversion.
-    // This will only be supported on modern browsers,
-    // hence the try block.
-    var blob = new Blob([content], {type: mimetype});
-    var reader = new FileReader();
-    reader.onloadend = function() {
-      // If we're lucky the browser will also support the download
-      // attribute which will let us suggest a file name to save the link.
-      // Otherwise it is likely that the filename will be unintelligible. 
-      link.setAttribute("download", filename);
-      link.href = reader.result;
-      if (click_link) {
-        // must add the link to click it
-        document.body.appendChild(link);
-        link.click();
-        document.body.removeChild(link);
-      }
-    }
-    reader.readAsDataURL(blob);
-  } catch (error) {
-    if (console && console.log) console.log(error);
-    // probably an old browser
-    link.href = "";
-    link.visible = false;
-  }
-}
-
-/*
- * add_cell
- *
- * Add a cell to the table row.
- */
-function add_cell(row, node, cls, click_action) {
-  var cell = row.insertCell(row.cells.length);
-  if (node) cell.appendChild(node);
-  if (cls && cls !== "") cell.className = cls;
-  if (click_action) cell.addEventListener("click", click_action, false);
-}
-
-/*
- * add_header_cell
- *
- * Add a header cell to the table row.
- */
-function add_header_cell(row, node, help_topic, cls, colspan) {
-  var th = document.createElement("th");
-  if (node) th.appendChild(node);
-  if (help_topic && help_topic !== "") th.appendChild(help_button(help_topic));
-  if (cls && cls !== "") th.className = cls;
-  if (typeof colspan == "number" && colspan > 1) th.colSpan = colspan;
-  row.appendChild(th);
-}
-
-/*
- * add_text_cell
- *
- * Add a text cell to the table row.
- */
-function add_text_cell(row, text, cls, action) {
-  var node = null;
-  if (typeof(text) != 'undefined') node = document.createTextNode(text);
-  add_cell(row, node, cls, action);
-}
-
-/*
- * add_text_header_cell
- *
- * Add a text header cell to the table row.
- */
-function add_text_header_cell(row, text, help_topic, cls, action, colspan) {
-  var node = null;
-  if (typeof(text) != 'undefined') {
-    var nbsp = (help_topic ? "\u00A0" : "");
-    var str = "" + text;
-    var parts = str.split(/\n/);
-    if (parts.length === 1) {
-      if (action) {
-        node = document.createElement("span");
-        node.appendChild(document.createTextNode(str + nbsp));
-      } else {
-        node = document.createTextNode(str + nbsp);
-      }
-    } else {
-      node = document.createElement("span");
-      for (var i = 0; i < parts.length; i++) {
-        if (i !== 0) {
-          node.appendChild(document.createElement("br"));
-        }
-        node.appendChild(document.createTextNode(parts[i]));
-      }
-    }
-    if (action) {
-      node.addEventListener("click", action, false);
-      node.style.cursor = "pointer";
-    }
-  }
-  add_header_cell(row, node, help_topic, cls, colspan);
-}
-
-function setup_help() {
-  "use strict";
-  var help_buttons, i;
-  help_buttons = document.querySelectorAll(".help:not(.active)");
-  for (i = 0; i < help_buttons.length; i++) {
-    setup_help_button(help_buttons[i]);
-  }
-}
-
-function setup_scrollpad() {
-  "use strict";
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-scrollpad") && document.getElementById("scrollpad") == null) {
-    window.addEventListener("resize", update_scroll_pad, false);
-    update_scroll_pad();
-  }
-}
-
-// anon function to avoid polluting global scope
-(function() {
-  "use strict";
-  window.addEventListener("load", function load(evt) {
-    window.removeEventListener("load", load, false);
-    setup_help();
-    setup_scrollpad();
-  }, false);
-})();
-
-/*
- *  make_link
- *
- *  Creates a text node and if a URL is specified it surrounds it with a link.
- *  If the URL doesn't begin with "http://" it automatically adds it, as
- *  relative links don't make much sense in this context.
- */
-function make_link(text, url) {
-  var textNode = null;
-  var link = null;
-  if (typeof text !== "undefined" && text !== null) textNode = document.createTextNode(text);
-  if (typeof url === "string") {
-    if (url.indexOf("//") == -1) {
-      url = "http://" + url;
-    }
-    link = document.createElement('a');
-    link.href = url;
-    if (textNode) link.appendChild(textNode);
-    return link;
-  }
-  return textNode;
-}
-</script>
-    <script>
-function motif_logo_template(inputs) {
-  function _input(name) {
-    if (typeof inputs[name] === "undefined") {
-      throw new Error("Missing template variable: " + name);
-    }
-    return inputs[name];
-  }
-  return (
-"%!PS-Adobe-3.0 EPSF-3.0\n" +
-"%%Title: Sequence Logo : " + _input("TITLE") + "\n" +
-"%%Creator: " + _input("CREATOR") + "\n" +
-"%%CreationDate: " + _input("CREATIONDATE") + "\n" +
-"%%BoundingBox:   0  0  " + _input("BOUNDINGWIDTH") + " " + _input("BOUNDINGHEIGHT") + " \n" +
-"%%Pages: 0\n" +
-"%%DocumentFonts: \n" +
-"%%EndComments\n" +
-"\n" +
-"% ---- CONSTANTS ----\n" +
-"\/cmfactor 72 2.54 div def % defines points -> cm conversion\n" +
-"\/cm {cmfactor mul} bind def % defines centimeters\n" +
-"\n" +
-"% ---- VARIABLES ----\n" +
-"\n" +
-"% NA = Nucleic Acid, AA = Amino Acid\n" +
-"\/logoType (" + _input("LOGOTYPE") + ") def \n" +
-"\n" +
-"\/logoTitle (" + _input("TITLE") + ") def\n" +
-"\n" +
-"% Dimensions in cm\n" +
-"\/logoWidth " + _input("LOGOWIDTH") + " cm def\n" +
-"\/logoHeight " + _input("LOGOLINEHEIGHT") + " cm def\n" +
-"\/totalHeight " + _input("LOGOHEIGHT") + " cm def\n" +
-"\n" +
-"\/yaxis " + _input("YAXIS") + " def\n" +
-"\/yaxisLabel (" + _input("YAXISLABEL") + ") def\n" +
-"\/yaxisBits  " + _input("BARBITS") + " def % bits\n" +
-"\/yaxisTicBits " + _input("TICBITS") + " def\n" +
-"\n" +
-"\/xaxis " + _input("NUMBERING") + " def\n" +
-"\/xaxisLabel (" + _input("XAXISLABEL") + ") def\n" +
-"\/showEnds (" + _input("SHOWENDS") + ") def \n" +
-"\n" +
-"\/showFineprint true def\n" +
-"\/fineprint (" + _input("FINEPRINT") + ") def\n" +
-"\n" +
-"\/charsPerLine " + _input("CHARSPERLINE") + " def\n" +
-"\n" +
-"\/showingBox " + _input("SHOWINGBOX") + " def    \n" +
-"\/shrinking false def   % true falses\n" +
-"\/shrink  1.0 def\n" +
-"\/outline " + _input("OUTLINE") + " def\n" +
-"\n" +
-"\/IbeamFraction  " + _input("ERRORBARFRACTION") + " def\n" +
-"\/IbeamGray      0.50 def\n" +
-"\/IbeamLineWidth 0.5 def\n" +
-"\n" +
-"\/fontsize       " + _input("FONTSIZE") + " def\n" +
-"\/titleFontsize  " + _input("TITLEFONTSIZE") + " def\n" +
-"\/smallFontsize  " + _input("SMALLFONTSIZE") + " def\n" +
-"\n" +
-"\/topMargin      " + _input("TOPMARGIN") + " cm def\n" +
-"\/bottomMargin   " + _input("BOTTOMMARGIN") + " cm def\n" +
-"\n" +
-"\/defaultColor [0 0 0] def \n" +
-"\n" +
-_input("COLORDICT") + "\n" +
-"\n" +
-"\/colorDict fullColourDict def\n" +
-"\n" +
-"% ---- DERIVED PARAMETERS ----\n" +
-"\n" +
-"\/leftMargin\n" +
-"  fontsize 3.5 mul\n" +
-"\n" +
-"def \n" +
-"\n" +
-"\/rightMargin \n" +
-"  %Add extra room if showing ends\n" +
-"  showEnds (false) eq { fontsize}{fontsize 1.5 mul} ifelse\n" +
-"def\n" +
-"\n" +
-"\/yaxisHeight \n" +
-"  logoHeight \n" +
-"  bottomMargin sub  \n" +
-"  topMargin sub\n" +
-"def\n" +
-"\n" +
-"\/ticWidth fontsize 2 div def\n" +
-"\n" +
-"\/pointsPerBit yaxisHeight yaxisBits div  def\n" +
-"\n" +
-"\/stackMargin 1 def\n" +
-"\n" +
-"% Do not add space aroung characters if characters are boxed\n" +
-"\/charRightMargin \n" +
-"  showingBox { 0.0 } {stackMargin} ifelse\n" +
-"def\n" +
-"\n" +
-"\/charTopMargin \n" +
-"  showingBox { 0.0 } {stackMargin} ifelse\n" +
-"def\n" +
-"\n" +
-"\/charWidth\n" +
-"  logoWidth\n" +
-"  leftMargin sub\n" +
-"  rightMargin sub\n" +
-"  charsPerLine div\n" +
-"  charRightMargin sub\n" +
-"def\n" +
-"\n" +
-"\/charWidth4 charWidth 4 div def\n" +
-"\/charWidth2 charWidth 2 div def\n" +
-"\n" +
-"\/stackWidth \n" +
-"  charWidth charRightMargin add\n" +
-"def\n" +
-" \n" +
-"\/numberFontsize \n" +
-"  fontsize charWidth lt {fontsize}{charWidth} ifelse\n" +
-"def\n" +
-"\n" +
-"% movements to place 5'\/N and 3'\/C symbols\n" +
-"\/leftEndDeltaX  fontsize neg         def\n" +
-"\/leftEndDeltaY  fontsize 1.5 mul neg def\n" +
-"\/rightEndDeltaX fontsize 0.25 mul     def\n" +
-"\/rightEndDeltaY leftEndDeltaY        def\n" +
-"\n" +
-"% Outline width is proporional to charWidth, \n" +
-"% but no less that 1 point\n" +
-"\/outlinewidth \n" +
-"  charWidth 32 div dup 1 gt  {}{pop 1} ifelse\n" +
-"def\n" +
-"\n" +
-"\n" +
-"% ---- PROCEDURES ----\n" +
-"\n" +
-"\/StartLogo { \n" +
-"  % Save state\n" +
-"  save \n" +
-"  gsave \n" +
-"\n" +
-"  % Print Logo Title, top center \n" +
-"  gsave \n" +
-"    SetStringFont\n" +
-"\n" +
-"    logoWidth 2 div\n" +
-"    logoTitle\n" +
-"    stringwidth pop 2 div sub\n" +
-"    totalHeight\n" +
-"    titleFontsize sub\n" +
-"    moveto\n" +
-"\n" +
-"    logoTitle\n" +
-"    show\n" +
-"  grestore\n" +
-"\n" +
-"  % Print X-axis label, bottom center\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"\n" +
-"    logoWidth 2 div\n" +
-"    xaxisLabel\n" +
-"    stringwidth pop 2 div sub\n" +
-"    0\n" +
-"    titleFontsize 3 div\n" +
-"    add\n" +
-"    moveto\n" +
-"\n" +
-"    xaxisLabel\n" +
-"    show\n" +
-"  grestore\n" +
-"\n" +
-"  % Show Fine Print\n" +
-"  showFineprint {\n" +
-"    gsave\n" +
-"      SetSmallFont\n" +
-"      logoWidth\n" +
-"        fineprint stringwidth pop sub\n" +
-"        smallFontsize sub\n" +
-"          smallFontsize 3 div\n" +
-"      moveto\n" +
-"    \n" +
-"      fineprint show\n" +
-"    grestore\n" +
-"  } if\n" +
-"\n" +
-"  % Move to lower left corner of last line, first stack\n" +
-"  leftMargin bottomMargin translate\n" +
-"\n" +
-"  % Move above first line ready for StartLine \n" +
-"  0 totalHeight translate\n" +
-"\n" +
-"  SetLogoFont\n" +
-"} bind def\n" +
-"\n" +
-"\/EndLogo { \n" +
-"  grestore \n" +
-"  showpage \n" +
-"  restore \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/StartLine { \n" +
-"  % move down to the bottom of the line:\n" +
-"  0 logoHeight neg translate\n" +
-"  \n" +
-"  gsave \n" +
-"    yaxis { MakeYaxis } if\n" +
-"    xaxis { showEnds (true) eq {ShowLeftEnd} if } if\n" +
-"} bind def\n" +
-"\n" +
-"\/EndLine{ \n" +
-"    xaxis { showEnds (true) eq {ShowRightEnd} if } if\n" +
-"  grestore \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/MakeYaxis {\n" +
-"  gsave    \n" +
-"    stackMargin neg 0 translate\n" +
-"    ShowYaxisBar\n" +
-"    ShowYaxisLabel\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowYaxisBar { \n" +
-"  gsave  \n" +
-"    SetStringFont\n" +
-"\n" +
-"    \/str 10 string def % string to hold number  \n" +
-"    \/smallgap stackMargin 2 div def\n" +
-"\n" +
-"    % Draw first tic and bar\n" +
-"    gsave    \n" +
-"      ticWidth neg 0 moveto \n" +
-"      ticWidth 0 rlineto \n" +
-"      0 yaxisHeight rlineto\n" +
-"      stroke\n" +
-"    grestore\n" +
-"\n" +
-"   \n" +
-"    % Draw the tics\n" +
-"    % initial increment limit proc for\n" +
-"    0 yaxisTicBits yaxisBits abs %cvi\n" +
-"    {\/loopnumber exch def\n" +
-"\n" +
-"      % convert the number coming from the loop to a string\n" +
-"      % and find its width\n" +
-"      loopnumber 10 str cvrs\n" +
-"      \/stringnumber exch def % string representing the number\n" +
-"\n" +
-"      stringnumber stringwidth pop\n" +
-"      \/numberwidth exch def % width of number to show\n" +
-"\n" +
-"      \/halfnumberheight\n" +
-"         stringnumber CharBoxHeight 2 div\n" +
-"      def\n" +
-"\n" +
-"      numberwidth % move back width of number\n" +
-"      neg loopnumber pointsPerBit mul % shift on y axis\n" +
-"      halfnumberheight sub % down half the digit\n" +
-"\n" +
-"      moveto % move back the width of the string\n" +
-"\n" +
-"      ticWidth neg smallgap sub % Move back a bit more  \n" +
-"      0 rmoveto % move back the width of the tic  \n" +
-"\n" +
-"      stringnumber show\n" +
-"      smallgap 0 rmoveto % Make a small gap  \n" +
-"\n" +
-"      % now show the tic mark\n" +
-"      0 halfnumberheight rmoveto % shift up again\n" +
-"      ticWidth 0 rlineto\n" +
-"      stroke\n" +
-"    } for\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\/ShowYaxisLabel {\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"\n" +
-"    % How far we move left depends on the size of\n" +
-"    % the tic labels.\n" +
-"    \/str 10 string def % string to hold number  \n" +
-"    yaxisBits yaxisTicBits div cvi yaxisTicBits mul \n" +
-"    str cvs stringwidth pop\n" +
-"    ticWidth 1.5 mul  add neg  \n" +
-"\n" +
-"\n" +
-"    yaxisHeight\n" +
-"    yaxisLabel stringwidth pop\n" +
-"    sub 2 div\n" +
-"\n" +
-"    translate\n" +
-"    90 rotate\n" +
-"    0 0 moveto\n" +
-"    yaxisLabel show\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/StartStack {  % <stackNumber> startstack\n" +
-"  xaxis {MakeNumber}{pop} ifelse\n" +
-"  gsave\n" +
-"} bind def\n" +
-"\n" +
-"\/EndStack {\n" +
-"  grestore\n" +
-"  stackWidth 0 translate\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% Draw a character whose height is proportional to symbol bits\n" +
-"\/MakeSymbol{ % charbits character MakeSymbol\n" +
-"  gsave\n" +
-"    \/char exch def\n" +
-"    \/bits exch def\n" +
-"\n" +
-"    \/bitsHeight \n" +
-"       bits pointsPerBit mul \n" +
-"    def\n" +
-"\n" +
-"    \/charHeight \n" +
-"       bitsHeight charTopMargin sub\n" +
-"       dup \n" +
-"       0.0 gt {}{pop 0.0} ifelse % if neg replace with zero \n" +
-"    def \n" +
-" \n" +
-"    charHeight 0.0 gt {\n" +
-"      char SetColor\n" +
-"      charWidth charHeight char ShowChar\n" +
-"\n" +
-"      showingBox { % Unfilled box\n" +
-"        0 0 charWidth charHeight false ShowBox\n" +
-"      } if\n" +
-"\n" +
-"\n" +
-"    } if\n" +
-"\n" +
-"  grestore\n" +
-"\n" +
-"  0 bitsHeight translate \n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowChar { % <width> <height> <char> ShowChar\n" +
-"  gsave\n" +
-"    \/tc exch def    % The character\n" +
-"    \/ysize exch def % the y size of the character\n" +
-"    \/xsize exch def % the x size of the character\n" +
-"\n" +
-"    \/xmulfactor 1 def \n" +
-"    \/ymulfactor 1 def\n" +
-"    \/limmulfactor 0.01 def\n" +
-"    \/drawable true def\n" +
-"\n" +
-"  \n" +
-"    % if ysize is negative, make everything upside down!\n" +
-"    ysize 0 lt {\n" +
-"      % put ysize normal in this orientation\n" +
-"      \/ysize ysize abs def\n" +
-"      xsize ysize translate\n" +
-"      180 rotate\n" +
-"    } if\n" +
-"\n" +
-"    shrinking {\n" +
-"      xsize 1 shrink sub 2 div mul\n" +
-"        ysize 1 shrink sub 2 div mul translate \n" +
-"\n" +
-"      shrink shrink scale\n" +
-"    } if\n" +
-"\n" +
-"    % Calculate the font scaling factors\n" +
-"    % Loop twice to catch small correction due to first scaling\n" +
-"    2 {\n" +
-"      gsave\n" +
-"        xmulfactor ymulfactor scale\n" +
-"      \n" +
-"        ysize % desired size of character in points\n" +
-"        tc CharBoxHeight \n" +
-"        dup 0.0 ne {\n" +
-"          div % factor by which to scale up the character\n" +
-"          \/ymulfactor exch def\n" +
-"        } % end if\n" +
-"        {pop pop}\n" +
-"        ifelse\n" +
-"\n" +
-"        xsize % desired size of character in points\n" +
-"        tc CharBoxWidth  \n" +
-"        dup 0.0 ne {\n" +
-"          div % factor by which to scale up the character\n" +
-"          \/xmulfactor exch def\n" +
-"        } % end if\n" +
-"        {pop pop}\n" +
-"        ifelse\n" +
-"      grestore\n" +
-"      % if the multiplication factors get too small we need to avoid a crash\n" +
-"      xmulfactor limmulfactor lt {\n" +
-"        \/xmulfactor 1 def\n" +
-"        \/drawable false def\n" +
-"      } if\n" +
-"      ymulfactor limmulfactor lt {\n" +
-"        \/ymulfactor 1 def\n" +
-"        \/drawable false def\n" +
-"      } if\n" +
-"    } repeat\n" +
-"\n" +
-"    % Adjust horizontal position if the symbol is an I\n" +
-"    tc (I) eq {\n" +
-"      charWidth 2 div % half of requested character width\n" +
-"      tc CharBoxWidth 2 div % half of the actual character\n" +
-"      sub 0 translate\n" +
-"      % Avoid x scaling for I \n" +
-"      \/xmulfactor 1 def \n" +
-"    } if\n" +
-"\n" +
-"\n" +
-"    % ---- Finally, draw the character\n" +
-"    drawable { \n" +
-"      newpath\n" +
-"      xmulfactor ymulfactor scale\n" +
-"\n" +
-"      % Move lower left corner of character to start point\n" +
-"      tc CharBox pop pop % llx lly : Lower left corner\n" +
-"      exch neg exch neg\n" +
-"      moveto\n" +
-"\n" +
-"      outline {  % outline characters:\n" +
-"        outlinewidth setlinewidth\n" +
-"        tc true charpath\n" +
-"        gsave 1 setgray fill grestore\n" +
-"        clip stroke\n" +
-"      } { % regular characters\n" +
-"        tc show\n" +
-"      } ifelse\n" +
-"    } if\n" +
-"\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowBox { % x1 y1 x2 y2 filled ShowBox\n" +
-"  gsave\n" +
-"    \/filled exch def \n" +
-"    \/y2 exch def\n" +
-"    \/x2 exch def\n" +
-"    \/y1 exch def\n" +
-"    \/x1 exch def\n" +
-"    newpath\n" +
-"    x1 y1 moveto\n" +
-"    x2 y1 lineto\n" +
-"    x2 y2 lineto\n" +
-"    x1 y2 lineto\n" +
-"    closepath\n" +
-"\n" +
-"    clip\n" +
-"    \n" +
-"    filled {\n" +
-"      fill\n" +
-"    }{ \n" +
-"      0 setgray stroke   \n" +
-"    } ifelse\n" +
-"\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/MakeNumber { % number MakeNumber\n" +
-"  gsave\n" +
-"    SetNumberFont\n" +
-"    stackWidth 0 translate\n" +
-"    90 rotate % rotate so the number fits\n" +
-"    dup stringwidth pop % find the length of the number\n" +
-"    neg % prepare for move\n" +
-"    stackMargin sub % Move back a bit\n" +
-"    charWidth (0) CharBoxHeight % height of numbers\n" +
-"    sub 2 div %\n" +
-"    moveto % move back to provide space\n" +
-"    show\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/Ibeam{ % heightInBits Ibeam\n" +
-"  gsave\n" +
-"    % Make an Ibeam of twice the given height in bits\n" +
-"    \/height exch  pointsPerBit mul def \n" +
-"    \/heightDRAW height IbeamFraction mul def\n" +
-"\n" +
-"    IbeamLineWidth setlinewidth\n" +
-"    IbeamGray setgray \n" +
-"\n" +
-"    charWidth2 height neg translate\n" +
-"    ShowIbar\n" +
-"    newpath\n" +
-"      0 0 moveto\n" +
-"      0 heightDRAW rlineto\n" +
-"    stroke\n" +
-"    newpath\n" +
-"      0 height moveto\n" +
-"      0 height rmoveto\n" +
-"      currentpoint translate\n" +
-"    ShowIbar\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    0 heightDRAW neg rlineto\n" +
-"    currentpoint translate\n" +
-"    stroke\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowIbar { % make a horizontal bar\n" +
-"  gsave\n" +
-"    newpath\n" +
-"      charWidth4 neg 0 moveto\n" +
-"      charWidth4 0 lineto\n" +
-"    stroke\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowLeftEnd {\n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"    leftEndDeltaX leftEndDeltaY moveto\n" +
-"    logoType (NA) eq {(5) show ShowPrime} if\n" +
-"    logoType (AA) eq {(N) show} if\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowRightEnd { \n" +
-"  gsave\n" +
-"    SetStringFont\n" +
-"    rightEndDeltaX rightEndDeltaY moveto\n" +
-"    logoType (NA) eq {(3) show ShowPrime} if\n" +
-"    logoType (AA) eq {(C) show} if\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"\/ShowPrime {\n" +
-"  gsave\n" +
-"    SetPrimeFont\n" +
-"    (\\242) show \n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-" \n" +
-"\/SetColor{ % <char> SetColor\n" +
-"  dup colorDict exch known {\n" +
-"    colorDict exch get aload pop setrgbcolor\n" +
-"  } {\n" +
-"    pop\n" +
-"    defaultColor aload pop setrgbcolor\n" +
-"  } ifelse \n" +
-"} bind def\n" +
-"\n" +
-"% define fonts\n" +
-"\/SetTitleFont {\/Times-Bold findfont titleFontsize scalefont setfont} bind def\n" +
-"\/SetLogoFont  {\/Helvetica-Bold findfont charWidth  scalefont setfont} bind def\n" +
-"\/SetStringFont{\/Helvetica-Bold findfont fontsize scalefont setfont} bind def\n" +
-"\/SetPrimeFont {\/Symbol findfont fontsize scalefont setfont} bind def\n" +
-"\/SetSmallFont {\/Helvetica findfont smallFontsize scalefont setfont} bind def\n" +
-"\n" +
-"\/SetNumberFont {\n" +
-"    \/Helvetica-Bold findfont \n" +
-"    numberFontsize\n" +
-"    scalefont\n" +
-"    setfont\n" +
-"} bind def\n" +
-"\n" +
-"%Take a single character and return the bounding box\n" +
-"\/CharBox { % <char> CharBox <lx> <ly> <ux> <uy>\n" +
-"  gsave\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    % take the character off the stack and use it here:\n" +
-"    true charpath \n" +
-"    flattenpath \n" +
-"    pathbbox % compute bounding box of 1 pt. char => lx ly ux uy\n" +
-"    % the path is here, but toss it away ...\n" +
-"  grestore\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% The height of a characters bounding box\n" +
-"\/CharBoxHeight { % <char> CharBoxHeight <num>\n" +
-"  CharBox\n" +
-"  exch pop sub neg exch pop\n" +
-"} bind def\n" +
-"\n" +
-"\n" +
-"% The width of a characters bounding box\n" +
-"\/CharBoxWidth { % <char> CharBoxHeight <num>\n" +
-"  CharBox\n" +
-"  pop exch pop sub neg \n" +
-"} bind def\n" +
-"\n" +
-"% Set the colour scheme to be faded to indicate trimming\n" +
-"\/MuteColour {\n" +
-"  \/colorDict mutedColourDict def\n" +
-"} def\n" +
-"\n" +
-"% Restore the colour scheme to the normal colours\n" +
-"\/RestoreColour {\n" +
-"  \/colorDict fullColourDict def\n" +
-"} def\n" +
-"\n" +
-"% Draw the background for a trimmed section\n" +
-"% takes the number of columns as a parameter\n" +
-"\/DrawTrimBg { % <num> DrawTrimBox\n" +
-"  \/col exch def\n" +
-"  \n" +
-"  \/boxwidth \n" +
-"    col stackWidth mul \n" +
-"  def\n" +
-" \n" +
-"  gsave\n" +
-"    0.97 setgray\n" +
-"\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    boxwidth 0 rlineto\n" +
-"    0 yaxisHeight rlineto\n" +
-"    0 yaxisHeight lineto\n" +
-"    closepath\n" +
-"    \n" +
-"    fill\n" +
-"  grestore\n" +
-"} def\n" +
-"\n" +
-"\/DrawTrimEdge {\n" +
-"  gsave\n" +
-"    0.2 setgray\n" +
-"    [2] 0 setdash\n" +
-"\n" +
-"    newpath\n" +
-"    0 0 moveto\n" +
-"    0 yaxisHeight lineto\n" +
-"    \n" +
-"    stroke\n" +
-"\n" +
-"} def\n" +
-"\n" +
-"\n" +
-"% Deprecated names\n" +
-"\/startstack {StartStack} bind  def\n" +
-"\/endstack {EndStack}     bind def\n" +
-"\/makenumber {MakeNumber} bind def\n" +
-"\/numchar { MakeSymbol }  bind def\n" +
-"\n" +
-"%%EndProlog\n" +
-"\n" +
-"%%Page: 1 1\n" +
-"StartLogo\n" +
-"\n" +
-_input("DATA") + "\n" +
-"\n" +
-"EndLogo\n" +
-"\n" +
-"%%EOF\n"
-  );
-}</script>
-    <script>
-//======================================================================
-// start Alphabet object
-//======================================================================
-var Alphabet = function(alphabet, background) {
-  "use strict";
-  var i, j, sym, aliases, complement, comp_e_sym, ambigs, generate_background;
-  generate_background = (background == null);
-  if (generate_background) {
-    background = [];
-    for (i = 0; i < alphabet.ncore; i++) background[i] = 1.0 / alphabet.ncore;
-  } else if (alphabet.ncore != background.length) {
-    throw new Error("The background length does not match the alphabet length.");
-  }
-  this.name = alphabet.name;
-  this.like = (alphabet.like != null ? alphabet.like.toUpperCase() : null);
-  this.ncore = alphabet.ncore;
-  this.symbols = alphabet.symbols;
-  this.background = background;
-  this.genbg = generate_background;
-  this.encode = {};
-  this.encode2core = {};
-  this.complement = {};
-  // check if all symbols are same case
-  var seen_uc = false;
-  var seen_lc = false;
-  var check_case = function (syms) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        if (sym >= 'a' && sym <= 'z') seen_lc = true;
-        else if (sym >= 'A' && sym <= 'Z') seen_uc = true;
-      }
-    }
-  };
-  for (i = 0; i < this.symbols.length; i++) {
-    check_case(this.symbols[i].symbol);
-    check_case(this.symbols[i].aliases);
-  }
-  // now map symbols to indexes
-  var update_array = function(array, syms, index) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        array[sym] = index;
-        // when only a single case is used, then encode as case insensitive
-        if (seen_uc != seen_lc) {
-          if (sym >= 'a' && sym <= 'z') {
-            array[sym.toUpperCase()] = index;
-          } else if (sym >= 'A' && sym <= 'Z') {
-            array[sym.toLowerCase()] = index;
-          }
-        }
-      }
-    }
-  }
-  // map core symbols to index
-  for (i = 0; i < this.ncore; i++) {
-    update_array(this.encode2core, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode2core, this.symbols[i].aliases, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-  }
-  // map ambigous symbols to index
-  ambigs = {};
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-    ambigs[this.symbols[i].equals] = i;
-  }
-  // determine complements
-  for (i = 0; i < this.ncore; i++) {
-    complement = this.symbols[i].complement;
-    if (typeof complement === "string") {
-      this.complement[i] = this.encode2core[complement];
-    }
-  }
-  next_symbol:
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    complement = "";
-    for (j = 0; j < this.symbols[i].equals.length; j++) {
-      comp_e_sym = this.complement[this.encode2core[this.symbols[i].equals.charAt(j)]];
-      if (typeof comp_e_sym !== "number") continue next_symbol;
-      complement += this.symbols[comp_e_sym].symbol;
-    }
-    complement = complement.split("").sort().join("");
-    if (typeof ambigs[complement] === "number") {
-      this.complement[i] = ambigs[complement];
-    }
-  }
-  // determine case insensitivity
-  this.case_insensitive = true;
-  if (seen_uc == seen_lc) {
-    // when there is a mixture of cases it probably won't
-    // be case insensitive but we still need to check
-    loop:
-    for (i = 0; i < this.symbols.length; i++) {
-      sym = this.symbols[i].symbol;
-      if (sym >= 'A' && sym <= 'Z') {
-        if (this.encode[sym.toLowerCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      } else if (sym >= 'a' && sym <= 'z') {
-        if (this.encode[sym.toUpperCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      }
-      aliases = this.symbols[i].aliases;
-      if (aliases != null) {
-        for (j = 0; j < aliases.length; j++) {
-          sym = aliases.charAt(j);
-          if (sym >= 'A' && sym <= 'Z') {
-            if (this.encode[sym.toLowerCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          } else if (sym >= 'a' && sym <= 'z') {
-            if (this.encode[sym.toUpperCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          }
-        }
-      }
-    }
-  }
-  // normalise aliases to remove the prime symbol and eliminate
-  // the alternate cases when the alphabet is case insensitive
-  var seen, out;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym = this.symbols[i].symbol;
-    aliases = this.symbols[i].aliases;
-    if (typeof aliases != "string") aliases = "";
-    seen = {};
-    out = [];
-    if (this.case_insensitive) {
-      sym = sym.toUpperCase();
-      aliases = aliases.toUpperCase();
-    }
-    seen[sym] = true;
-    for (j = 0; j < aliases.length; j++) {
-      if (!seen[aliases.charAt(j)]) {
-        seen[aliases.charAt(j)] = true;
-        out.push(aliases.charAt(j));
-      }
-    }
-    this.symbols[i].aliases = out.sort().join("");
-  }
-};
-// return the name of the alphabet
-Alphabet.prototype.get_alphabet_name = function() {
-  return this.name;
-};
-// return if the alphabet can be complemented
-Alphabet.prototype.has_complement = function() {
-  return (typeof this.symbols[0].complement === "string");
-};
-// return true if an uppercase letter has the same meaning as the lowercase form
-Alphabet.prototype.is_case_insensitive = function() {
-  return this.case_insensitive;
-};
-// return the information content of an alphabet letter
-Alphabet.prototype.get_ic = function() {
-  return Math.log(this.ncore) / Math.LN2;
-};
-// return the count of the core alphabet symbols
-Alphabet.prototype.get_size_core = function() {
-  return this.ncore;
-};
-// return the count of all alphabet symbols
-Alphabet.prototype.get_size_full = function() {
-  return this.symbols.length;
-};
-// return the symbol for the given alphabet index
-Alphabet.prototype.get_symbol = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  return this.symbols[alph_index].symbol;
-};
-// return the aliases for the given alphabet index
-Alphabet.prototype.get_aliases = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  var sym_obj = this.symbols[alph_index];
-  return (sym_obj.aliases != null ? sym_obj.aliases : "");
-};
-// return the name for the given alphabet index
-Alphabet.prototype.get_name = function(alph_index) {
-  "use strict";
-  var sym;
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  sym = this.symbols[alph_index];
-  return (typeof sym.name === "string" ? sym.name : sym.symbol);
-};
-// return the alphabet it is like or null
-Alphabet.prototype.get_like = function() {
-  "use strict";
-  return this.like;
-};
-// return the index of the complement for the given alphabet index
-Alphabet.prototype.get_complement = function(alph_index) {
-  var comp_e_sym = this.complement[alph_index];
-  if (typeof comp_e_sym === "number") {
-    return comp_e_sym;
-  } else {
-    return -1;
-  }
-};
-// return a string containing the core symbols
-Alphabet.prototype.get_symbols = function() {
-  "use strict";
-  var i, core_symbols;
-  core_symbols = "";
-  for (i = 0; i < this.ncore; i++) {
-    core_symbols += this.symbols[i].symbol;
-  }
-  return core_symbols;
-};
-// return if the background was not a uniform generated background
-Alphabet.prototype.has_bg = function() {
-  "use strict";
-  return !this.genbg;
-};
-// get the background frequency for the index
-Alphabet.prototype.get_bg_freq = function(alph_index) {
-  "use strict";
-  var freq, i, symbols;
-  if (alph_index >= 0) {
-    if (alph_index < this.ncore) {
-      return this.background[alph_index];
-    } else if (alph_index < this.symbols.length) {
-      freq = 0;
-      symbols = this.symbols[alph_index].equals;
-      for (i = 0; i < symbols.length; i++) {
-        freq += this.background[this.encode2core[symbols.charAt(i)]];
-      }
-      return freq;
-    } 
-  }
-  throw new Error("The alphabet index is out of range.");
-};
-// get the colour of the index
-Alphabet.prototype.get_colour = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return "black";
-  }
-  return "#" + this.symbols[alph_index].colour;
-};
-// get the rgb componets of the colour at the index
-Alphabet.prototype.get_rgb = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return {"red": 0, "green": 0, "blue": 0};
-  }
-  var colour = this.symbols[alph_index].colour;
-  var red = parseInt(colour.substr(0, 2), 16) / 255;
-  var green = parseInt(colour.substr(2, 2), 16) / 255;
-  var blue = parseInt(colour.substr(4, 2), 16) / 255;
-  return {"red": red, "green": green, "blue": blue};
-};
-// convert a symbol into the index
-Alphabet.prototype.get_index = function(letter) {
-  "use strict";
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    return -1;
-  }
-  return alph_index;
-};
-// convert a symbol into the list of core indexes that it equals
-Alphabet.prototype.get_indexes = function(letter) {
-  "use strict";
-  var alph_index, comprise_str, i, comprise_list;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    throw new Error("Unknown letter");
-  }
-  comprise_str = this.symbols[alph_index].equals;
-  comprise_list = [];
-  if (typeof comprise_str == "string") {
-    for (i = 0; i < comprise_str.length; i++) {
-      comprise_list.push(this.encode2core[comprise_str.charAt(i)]);
-    }
-  } else {
-    comprise_list.push(alph_index);
-  }
-  return comprise_list;
-};
-// check if a symbol is the primary way of representing the symbol in the alphabet
-Alphabet.prototype.is_prime_symbol = function(letter) {
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (alph_index == null) return false;
-  if (this.is_case_insensitive()) {
-    return (this.symbols[alph_index].symbol.toUpperCase() == letter.toUpperCase());
-  } else {
-    return (this.symbols[alph_index].symbol == letter);
-  }
-};
-// compare 2 alphabets
-Alphabet.prototype.equals = function(other) {
-  "use strict";
-  var i, sym1, sym2;
-  // first check that it's actually an alphabet object
-  if (!(typeof other === "object" && other != null && other instanceof Alphabet)) {
-    return false;
-  }
-  // second shortcircuit if it's the same object
-  if (this === other) return true;
-  // compare
-  if (this.name !== other.name) return false;
-  if (this.ncore !== other.ncore) return false;
-  if (this.symbols.length !== other.symbols.length) return false;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym1 = this.symbols[i];
-    sym2 = other.symbols[i];
-    if (sym1.symbol !== sym2.symbol) return false;
-    if (sym1.aliases !== sym2.aliases) return false;
-    if (sym1.name !== sym2.name) return false;
-    if (typeof sym1.colour !== typeof sym2.colour || 
-        (typeof sym1.colour === "string" && typeof sym2.colour === "string" &&
-         parseInt(sym1.colour, 16) != parseInt(sym2.colour, 16))) {
-      return false;
-    }
-    if (sym1.complement !== sym2.complement) return false;
-    if (sym1.equals !== sym2.equals) return false;
-  }
-  return true;
-};
-Alphabet.prototype.check_core_subset = function(super_alph) {
-  var complement_same = true;
-  var seen_set = {};
-  var sub_i, sub_symbol, super_i, super_symbol;
-  for (sub_i = 0; sub_i < this.ncore; sub_i++) {
-    sub_symbol = this.symbols[sub_i];
-    super_i = super_alph.encode[sub_symbol.symbol]; 
-    if (super_i == null) return 0;
-    super_symbol = super_alph.symbols[super_i];
-    if (seen_set[super_i]) return 0;
-    seen_set[super_i] = true;
-    // check complement
-    if (sub_symbol.complement != null && super_symbol.complement != null) {
-      if (super_alph.encode[sub_symbol.complement] != super_alph.encode[super_symbol.complement]) {
-        complement_same = false;
-      }
-    } else if (sub_symbol.complement != null || super_symbol.complement != null) {
-      complement_same = false;
-    }
-  }
-  return (complement_same ? 1 : -1);
-};
-// convert a sequence to its reverse complement
-Alphabet.prototype.invcomp_seq = function(seq) {
-  "use strict";
-  var syms, i, e_sym, comp_e_sym;
-  if (!this.has_complement()) throw new Error("Alphabet must be complementable");
-  syms = seq.split("");
-  for (i = 0; i < syms.length; i++) {
-    e_sym = this.encode[syms[i]];
-    if (typeof e_sym === "undefined") {
-      e_sym = this.ncore; // wildcard
-    }
-    comp_e_sym = this.complement[e_sym];
-    if (typeof comp_e_sym === "undefined") {
-      comp_e_sym = e_sym; // not complementable
-    }
-    syms[i] = this.symbols[comp_e_sym].symbol;
-  }
-  return syms.reverse().join("");
-};
-// convert the alphabet to the text version
-Alphabet.prototype.as_text = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  function symbol_as_text(sym) {
-    var out;
-    out = sym.symbol;
-    if (typeof sym.name === "string" && sym.name != sym.symbol) {
-      out += " " + name_as_text(sym.name);
-    }
-    if (typeof sym.colour === "string") {
-      out += " " + sym.colour;
-    }
-    return out;
-  }
-  var out, i, j, c, sym;
-  out = "";
-  // output core symbols with 2 way complements
-  for (i = 0; i < this.ncore; i++) {
-    c = this.complement[i];
-    if (typeof c === "number" && i < c && this.complement[c] === i) {
-      out += symbol_as_text(this.symbols[i]) + " ~ " + symbol_as_text(this.symbols[c]) + "\n";  
-    }
-  }
-  // output core symbols with no complement
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.complement[i] === "undefined") {
-      out += symbol_as_text(this.symbols[i]) + "\n";
-    }
-  }
-  // output ambiguous symbols that have comprising characters
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    if (this.symbols[i].equals.length == 0) break;
-    out += symbol_as_text(this.symbols[i]) + " = " + this.symbols[i].equals + "\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].equals + "\n";
-      }
-    }
-  }
-  // output aliases of core symbols
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].symbol + "\n";
-      }
-    }
-  }
-  // output gap symbols
-  i = this.symbols.length - 1;
-  if (this.symbols[i].equals.length == 0) {
-    out += symbol_as_text(this.symbols[i]) + " =\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " =\n";
-      }
-    }
-  }
-  return out;
-};
-// output the alphabet as it appears in minimal MEME format
-Alphabet.prototype.as_meme = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  if (this.equals(AlphStd.DNA)) {
-    return "ALPHABET= ACGT\n";
-  } else if (this.equals(AlphStd.PROTEIN)) {
-    return "ALPHABET= ACDEFGHIKLMNPQRSTVWY\n";
-  } else {
-    return "ALPHABET" + 
-      (this.name != null ? " " + name_as_text(this.name) : "") + 
-      (this.like != null ? " " + this.like + "-LIKE" : "") + "\n" +
-      this.as_text() + "END ALPHABET\n";
-  }
-};
-
-// Returns a table showing all the letters in the alphabet
-Alphabet.prototype.as_table = function() {
-  "use strict";
-  var i, j, row, th, td, aliases, equals, sym;
-  var table = document.createElement("table");
-  // create the core symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  if (this.has_complement()) {
-    th.appendChild(document.createTextNode("Complement"));
-  }
-  row.appendChild(th);
-  // list the core symbols
-  for (i = 0; i < this.ncore; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].complement != null) {
-      td.style.color = this.get_colour(this.get_index(this.symbols[i].complement));
-      td.appendChild(document.createTextNode(this.symbols[i].complement));
-    }
-    row.appendChild(td);
-  }
-  // create the ambiguous symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Matches"));
-  row.appendChild(th);
-  // list the ambiguous symbols
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    equals = this.symbols[i].equals.split('');
-    for (j = 0; j < equals.length; j++) {
-      if (j != 0) td.appendChild(document.createTextNode(' '));
-      sym = document.createElement("span");
-      sym.style.color = this.get_colour(this.get_index(equals[j]));
-      sym.appendChild(document.createTextNode(equals[j]));
-      td.appendChild(sym);
-    }
-    row.appendChild(td);
-  }
-  return table;
-};
-
-// returns a dictionary of the colours for EPS
-Alphabet.prototype._as_eps_dict = function() {
-  "use strict";
-  var i, sym, rgb;
-  var out = "/fullColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = this.get_rgb(i);
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  out += "/mutedColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = Alphabet.lighten_colour(this.get_rgb(i));
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  return out;
-};
-
-// return the alphabet name or a list of primary symbols
-Alphabet.prototype.toString = function() {
-  "use strict";
-  if (this.name != null) {
-    return this.name;
-  } else {
-    return this.get_symbols();
-  }
-};
-
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-// Helper functions
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-// Convert a colour specified in RGB colourspace values into LAB colourspace
-Alphabet.rgb2lab = function(rgb) {
-  "use strict";
-  var xyzHelper, labHelper;
-  // XYZ helper
-  xyzHelper = function(value) {
-    if (value > 0.0445) {
-      value = (value + 0.055) / 1.055;
-      value = Math.pow(value, 2.4);
-    } else {
-      value /= 12.92;
-    }
-    value *= 100;
-    return value;
-  };
-  // lab helper
-  labHelper = function(value) {
-    if (value > 0.008856) {
-      value = Math.pow(value, 1.0 / 3.0);
-    } else {
-      value = (7.787 * value) + (16.0 / 116.0);
-    }
-    return value;
-  };
-  // convert into XYZ colourspace
-  var c1, c2, c3;
-  if (typeof rgb == "number") {
-    c1 = xyzHelper(((rgb >> 16) & 0xFF) / 255.0);
-    c2 = xyzHelper(((rgb >> 8) & 0xFF) / 255.0);
-    c3 = xyzHelper((rgb & 0xFF) / 255.0);
-  } else {
-    c1 = xyzHelper(rgb.red);
-    c2 = xyzHelper(rgb.green);
-    c3 = xyzHelper(rgb.blue);
-  }
-  var x = (c1 * 0.4124) + (c2 * 0.3576) + (c3 * 0.1805);
-  var y = (c1 * 0.2126) + (c2 * 0.7152) + (c3 * 0.0722);
-  var z = (c1 * 0.0193) + (c2 * 0.1192) + (c3 * 0.9505);
-  // convert into Lab colourspace
-  c1 = labHelper(x / 95.047);
-  c2 = labHelper(y / 100.0);
-  c3 = labHelper(z / 108.883);
-  var l = (116.0 * c2) - 16;
-  var a = 500.0 * (c1 - c2);
-  var b = 200.0 * (c2 - c3);
-  return {"l": l, "a": a, "b": b};
-};
-
-// Convert a colour specified in HSV colourspace into RGB colourspace
-Alphabet.hsv2rgb = function(hue, sat, value, output_object) {
-  // achromatic (grey)
-  var r = value;
-  var g = value;
-  var b = value;
-  if (sat != 0) {
-    var h = hue / 60.0;
-    var i = Math.floor(h);
-    var f = h - i;
-    var p = value * (1.0 - sat);
-    var q = value * (1.0 - (sat * f));
-    var t = value * (1.0 - (sat * (1.0 - f)));
-    if (i == 0) {
-      r = value;
-      g = t;
-      b = p;
-    } else if (i == 1) {
-      r = q;
-      g = value;
-      b = p;
-    } else if (i == 2) {
-      r = p;
-      g = value;
-      b = t;
-    } else if (i == 3) {
-      r = p;
-      g = q;
-      b = value;
-    } else if (i == 4) {
-      r = t;
-      g = p;
-      b = value;
-    } else {
-      r = value;
-      g = p;
-      b = q;
-    }
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-// Calculate a distance score between two colours in LAB colourspace
-Alphabet.lab_dist = function(lab1, lab2) {
-  var c1 = Math.sqrt((lab1.l * lab1.l) + (lab1.a * lab1.a));
-  var c2 = Math.sqrt((lab2.l * lab2.l) + (lab2.a * lab2.a));
-  var dc = c1 - c2;
-  var dl = lab1.l - lab2.l;
-  var da = lab1.a - lab2.a;
-  var db = lab1.b - lab2.b;
-  // we don't want NaN due to rounding errors so fudge things a bit...
-  var dh = 0;
-  var dh_squared = (da * da) + (db * db) - (dc * dc);
-  if (dh_squared > 0) {
-    dh = Math.sqrt(dh_squared);
-  }
-  var first = dl;
-  var second = dc / (1.0 + (0.045 * c1));
-  var third = dh / (1.0 + (0.015 * c1));
-  return Math.sqrt((first * first) + (second * second) + (third * third));
-};
-
-// convert an RGB value into a HSL value
-Alphabet.rgb2hsl = function(rgb) {
-  "use strict";
-  var min, max, delta, h, s, l, r, g, b;
-  if (typeof rgb == "number") {
-    r = ((rgb >> 16) & 0xFF) / 255.0;
-    g = ((rgb >> 8) & 0xFF) / 255.0;
-    b = (rgb & 0xFF) / 255.0;
-  } else {
-    r = rgb.red;
-    g = rgb.green;
-    b = rgb.blue;
-  }
-  min = Math.min(r, g, b);
-  max = Math.max(r, g, b);
-  delta = max - min;
-  l = min + (delta / 2);
-  if (max == min) {
-    h = 0; // achromatic (grayscale)
-    s = 0;
-  } else {
-    if (l > 0.5) {
-      s = delta / (2 - max - min);
-    } else {
-      s = delta / (max + min);
-    }
-    if (max == r) {
-      h = (g - b) / delta;
-      if (g < b) h += 6;
-    } else if (max == g) {
-      h = ((b - r) / delta) + 2;
-    } else {
-      h = ((r - g) / delta) + 4;
-    }
-    h /= 6;
-  }
-  return {"h": h, "s": s, "l": l};
-};
-
-// convert a HSL value into an RGB value
-Alphabet.hsl2rgb = function(hsl, output_object) {
-  "use strict";
-  function _hue(p, q, t) {
-    "use strict";
-    if (t < 0) t += 1;
-    else if (t > 1) t -= 1;
-    if (t < (1.0 / 6.0)) {
-      return p + ((q - p) * 6.0 * t);
-    } else if (t < 0.5) {
-      return q;
-    } else if (t < (2.0 / 3.0)) {
-      return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-    } else {
-      return p;
-    }
-  }
-  var r, g, b, p, q;
-  if (hsl.s == 0) {
-    // achromatic (grayscale)
-    r = hsl.l;
-    g = hsl.l;
-    b = hsl.l;
-  } else {
-    if (hsl.l < 0.5) {
-      q = hsl.l * (1 + hsl.s);
-    } else {
-      q = hsl.l + hsl.s - (hsl.l * hsl.s);
-    }
-    p = (2 * hsl.l) - q;
-    r = _hue(p, q, hsl.h + (1.0 / 3.0));
-    g = _hue(p, q, hsl.h);
-    b = _hue(p, q, hsl.h - (1.0 / 3.0));
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-Alphabet.lighten_colour = function(rgb) {
-  "use strict";
-  var hsl = Alphabet.rgb2hsl(rgb);
-  hsl.l += (1.0 - hsl.l) * 2 / 3;
-  return Alphabet.hsl2rgb(hsl, typeof rgb != "number");
-};
-
-//======================================================================
-// end Alphabet object
-//======================================================================
-
-//======================================================================
-// start StandardAlphabet object
-//======================================================================
-
-// an extension of the alphabet object to support some additional fields 
-// only present in standard alphabets.
-var StandardAlphabet = function(enum_code, enum_name, alphabet_data) {
-  Alphabet.apply(this, [alphabet_data]);
-  this.enum_code = enum_code;
-  this.enum_name = enum_name;
-};
-StandardAlphabet.prototype = Alphabet.prototype;
-StandardAlphabet.prototype.constructor = StandardAlphabet;
-
-// A unique code for this standard alphabet.
-// This code will be a power of 2 to enable creation of bitsets for
-// a selection of standard alphabets.
-StandardAlphabet.prototype.get_code = function() {
-  return this.enum_code;
-};
-
-// A unique name for this standard alphabet.
-// this name will be all upper case and the same as the property that
-// refers to this alphabet in the AlphStd collection.
-StandardAlphabet.prototype.get_enum = function() {
-  return this.enum_name;
-};
-
-//======================================================================
-// end StandardAlphabet object
-//======================================================================
-
-// A collection of standard alphabets.
-var AlphStd = {
-  RNA: new StandardAlphabet(1, "RNA", {
-    "name": "RNA",
-    "like": "RNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300"},
-      {"symbol": "U", "name": "Uracil", "colour": "008000",
-        "aliases": "T"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGU", "aliases": "X."},
-      {"symbol": "V", "name": "Not U", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACU"},
-      {"symbol": "D", "name": "Not C", "equals": "AGU"},
-      {"symbol": "B", "name": "Not A", "equals": "CGU"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AU"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CU"},
-      {"symbol": "K", "name": "Keto", "equals": "GU"}
-    ]
-  }), 
-  DNA: new StandardAlphabet(2, "DNA", {
-    "name": "DNA",
-    "like": "DNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000", "complement": "T"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC", "complement": "G"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300", "complement": "C"},
-      {"symbol": "T", "name": "Thymine", "colour": "008000", "complement": "A",
-        "aliases": "U"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGT", "aliases": "X."},
-      {"symbol": "V", "name": "Not T", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACT"},
-      {"symbol": "D", "name": "Not C", "equals": "AGT"},
-      {"symbol": "B", "name": "Not A", "equals": "CGT"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AT"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CT"},
-      {"symbol": "K", "name": "Keto", "equals": "GT"}
-    ]
-  }), 
-  PROTEIN: new StandardAlphabet(4, "PROTEIN", {
-    "name": "Protein",
-    "like": "PROTEIN",
-    "ncore": 20,
-    "symbols": [
-      {"symbol": "A", "name": "Alanine", "colour": "0000CC"},
-      {"symbol": "C", "name": "Cysteine", "colour": "0000CC"},
-      {"symbol": "D", "name": "Aspartic acid", "colour": "FF00FF"},
-      {"symbol": "E", "name": "Glutamic acid", "colour": "FF00FF"},
-      {"symbol": "F", "name": "Phenylalanine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Glycine", "colour": "FFB300"},
-      {"symbol": "H", "name": "Histidine", "colour": "FFCCCC"},
-      {"symbol": "I", "name": "Isoleucine", "colour": "0000CC"},
-      {"symbol": "K", "name": "Lysine", "colour": "CC0000"},
-      {"symbol": "L", "name": "Leucine", "colour": "0000CC"},
-      {"symbol": "M", "name": "Methionine", "colour": "0000CC"},
-      {"symbol": "N", "name": "Asparagine", "colour": "008000"},
-      {"symbol": "P", "name": "Proline", "colour": "FFFF00"},
-      {"symbol": "Q", "name": "Glutamine", "colour": "008000"},
-      {"symbol": "R", "name": "Arginine", "colour": "CC0000"},
-      {"symbol": "S", "name": "Serine", "colour": "008000"},
-      {"symbol": "T", "name": "Threonine", "colour": "008000"},
-      {"symbol": "V", "name": "Valine", "colour": "0000CC"},
-      {"symbol": "W", "name": "Tryptophan", "colour": "0000CC"},
-      {"symbol": "Y", "name": "Tyrosine", "colour": "33E6CC"},
-      {"symbol": "X", "name": "Any amino acid", "equals": "ACDEFGHIKLMNPQRSTVWY", "aliases": "*."},
-      {"symbol": "B", "name": "Asparagine or Aspartic acid", "equals": "DN"}, 
-      {"symbol": "Z", "name": "Glutamine or Glutamic acid", "equals": "EQ"}, 
-      {"symbol": "J", "name": "Leucine or Isoleucine", "equals": "IL"}
-    ]
-  })
-};
-
-//======================================================================
-// start Symbol object
-//======================================================================
-var Symbol = function(alph_index, scale, alphabet) {
-  "use strict";
-  //variable prototype
-  this.symbol = alphabet.get_symbol(alph_index);
-  this.scale = scale;
-  this.colour = alphabet.get_colour(alph_index);
-};
-
-Symbol.prototype.get_symbol = function() {
-  "use strict";
-  return this.symbol;
-};
-
-Symbol.prototype.get_scale = function() {
-  "use strict";
-  return this.scale;
-};
-
-Symbol.prototype.get_colour = function() {
-  "use strict";
-  return this.colour;
-};
-
-Symbol.prototype.toString = function() {
-  "use strict";
-  return this.symbol + " " + (Math.round(this.scale*1000)/10) + "%";
-};
-
-function compare_symbol(sym1, sym2) {
-  "use strict";
-  if (sym1.get_scale() < sym2.get_scale()) {
-    return -1;
-  } else if (sym1.get_scale() > sym2.get_scale()) {
-    return 1;
-  } else {
-    return 0;
-  }
-}
-//======================================================================
-// end Symbol object
-//======================================================================
-
-//======================================================================
-// start Pspm object
-//======================================================================
-var Pspm = function(matrix, name, ltrim, rtrim, nsites, evalue, pssm, alt) {
-  "use strict";
-  var row, col, data, row_sum, delta, evalue_re;
-  if (typeof name !== "string") {
-    name = "";
-  }
-  this.name = name;
-  //construct
-  if (matrix instanceof Pspm) {
-    // copy constructor
-    this.alph_length = matrix.alph_length;
-    this.motif_length = matrix.motif_length;
-    this.name = matrix.name;
-    this.alt = matrix.alt;
-    this.nsites = matrix.nsites;
-    this.evalue = matrix.evalue;
-    this.ltrim = matrix.ltrim;
-    this.rtrim = matrix.rtrim;
-    this.pspm = [];
-    for (row = 0; row < matrix.motif_length; row++) {
-      this.pspm[row] = [];
-      for (col = 0; col < matrix.alph_length; col++) {
-        this.pspm[row][col] = matrix.pspm[row][col];
-      }
-    }
-    if (matrix.pssm != null) {
-      this.pssm = [];
-      for (row = 0; row < matrix.motif_length; row++) {
-        this.pspm[row] = [];
-        for (col = 0; col < matrix.alph_length; col++) {
-          this.pssm[row][col] = matrix.pssm[row][col];
-        }
-      }
-    }
-  } else {
-    // check parameters
-    if (ltrim == null) {
-      ltrim = 0;
-    } else if (typeof ltrim !== "number" || ltrim % 1 !== 0 || ltrim < 0) {
-      throw new Error("ltrim must be a non-negative integer, got: " + ltrim);
-    }
-    if (rtrim == null) {
-      rtrim = 0;
-    } else if (typeof rtrim !== "number" || rtrim % 1 !== 0 || rtrim < 0) {
-      throw new Error("rtrim must be a non-negative integer, got: " + rtrim);
-    }
-    if (nsites != null) {
-      if (typeof nsites !== "number" || nsites < 0) {
-        throw new Error("nsites must be a positive number, got: " + nsites);
-      } else if (nsites == 0) {
-        nsites = null;
-      }
-    }
-    if (evalue != null) {
-      if (typeof evalue === "number") {
-        if (evalue < 0) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else if (typeof evalue === "string") {
-        evalue_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-        if (!evalue_re.test(evalue)) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else {
-        throw new Error("evalue must be a non-negative number, got: " + evalue);
-      }
-    }
-    // set properties
-    this.name = name;
-    this.alt = alt;
-    this.nsites = nsites;
-    this.evalue = evalue;
-    this.ltrim = ltrim;
-    this.rtrim = rtrim;
-    if (typeof matrix === "string") {
-      // string constructor
-      data = parse_pspm_string(matrix);
-      this.alph_length = data["alph_length"];
-      this.motif_length = data["motif_length"];
-      this.pspm = data["pspm"];
-      if (this.evalue == null) {
-        if (data["evalue"] != null) {
-          this.evalue = data["evalue"];
-        } else {
-          this.evalue = 0;
-        }
-      }
-      if (this.nsites == null) {
-        if (typeof data["nsites"] === "number") {
-          this.nsites = data["nsites"];
-        } else {
-          this.nsites = 20;
-        }
-      }
-    } else {
-      // assume pspm is a nested array
-      this.motif_length = matrix.length;
-      this.alph_length = (matrix.length > 0 ? matrix[0].length : 0);
-      if (this.nsites == null) {
-        this.nsites = 20;
-      }
-      if (this.evalue == null) {
-        this.evalue = 0;
-      }
-      this.pspm = [];
-      // copy pspm and check
-      for (row = 0; row < this.motif_length; row++) {
-        if (this.alph_length != matrix[row].length) {
-          throw new Error("COLUMN_MISMATCH");
-        }
-        this.pspm[row] = [];
-        row_sum = 0;
-        for (col = 0; col < this.alph_length; col++) {
-          this.pspm[row][col] = matrix[row][col];
-          row_sum += this.pspm[row][col];
-        }
-        delta = 0.1;
-        if (isNaN(row_sum) || (row_sum > 1 && (row_sum - 1) > delta) || 
-            (row_sum < 1 && (1 - row_sum) > delta)) {
-          throw new Error("INVALID_SUM");
-        }
-      }
-      // copy pssm
-      if (pssm != null) {
-        this.pssm = [];
-        for (row = 0; row < this.motif_length; row++) {
-          this.pssm[row] = [];
-          for (col = 0; col < this.alph_length; col++) {
-            this.pssm[row][col] = pssm[row][col];
-          }
-        }
-      }
-    }
-  }
-};
-
-Pspm.prototype.copy = function() {
-  "use strict";
-  return new Pspm(this);
-};
-
-Pspm.prototype.reverse = function() {
-  "use strict";
-  var x, y, temp, temp_trim;
-  //reverse
-  x = 0;
-  y = this.motif_length-1;
-  while (x < y) {
-    temp = this.pspm[x];
-    this.pspm[x] = this.pspm[y];
-    this.pspm[y] = temp;
-    x++;
-    y--;
-  }
-  // reverse pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //reverse
-    x = 0;
-    y = this.motif_length-1;
-    while (x < y) {
-      temp = this.pssm[x];
-      this.pspm[x] = this.pssm[y];
-      this.pssm[y] = temp;
-      x++;
-      y--;
-    }
-  }
-  //swap triming
-  temp_trim = this.ltrim;
-  this.ltrim = this.rtrim;
-  this.rtrim = temp_trim;
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.reverse_complement = function(alphabet) {
-  "use strict";
-  var x, y, temp, i, row, c, temp_trim;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  if (!alphabet.has_complement()) {
-    throw new Error("The specified alphabet can not be complemented.");
-  }
-  // reverse motif
-  this.reverse();
-  //complement
-  for (x = 0; x < this.motif_length; x++) {
-    row = this.pspm[x];
-    for (i = 0; i < row.length; i++) {
-      c = alphabet.get_complement(i);
-      if (c < i) continue;
-      temp = row[i];
-      row[i] = row[c];
-      row[c] = temp;
-    }
-  }
-  // complement pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //complement
-    for (x = 0; x < this.motif_length; x++) {
-      row = this.pssm[x];
-      for (i = 0; i < row.length; i++) {
-        c = alphabet.get_complement(i);
-        if (c < i) continue;
-        temp = row[i];
-        row[i] = row[c];
-        row[c] = temp;
-      }
-    }
-  }
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.get_stack = function(position, alphabet, ssc) {
-  "use strict";
-  var row, stack_ic, alphabet_ic, stack, i, sym;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  row = this.pspm[position];
-  stack_ic = this.get_stack_ic(position, alphabet);
-  if (ssc) stack_ic -= this.get_error(alphabet);
-  alphabet_ic = alphabet.get_ic();
-  stack = [];
-  for (i = 0; i < this.alph_length; i++) {
-    sym = new Symbol(i, row[i]*stack_ic/alphabet_ic, alphabet);
-    if (sym.get_scale() <= 0) {
-      continue;
-    }
-    stack.push(sym);
-  }
-  stack.sort(compare_symbol);
-  return stack;
-};
-
-Pspm.prototype.get_stack_ic = function(position, alphabet) {
-  "use strict";
-  var row, H, i;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size fo the pspm.");
-  }
-  row = this.pspm[position];
-  H = 0;
-  for (i = 0; i < this.alph_length; i++) {
-    if (row[i] === 0) {
-      continue;
-    }
-    H -= (row[i] * (Math.log(row[i]) / Math.LN2));
-  }
-  return alphabet.get_ic() - H;
-};
-
-Pspm.prototype.get_error = function(alphabet) {
-  "use strict";
-  if (this.nsites === 0) {
-    return 0;
-  }
-  return (alphabet.get_size_core()-1) / (2 * Math.LN2 * this.nsites);
-};
-
-Pspm.prototype.get_motif_length = function() {
-  "use strict";
-  return this.motif_length;
-};
-
-Pspm.prototype.get_alph_length = function() {
-  "use strict";
-  return this.alph_length;
-};
-
-Pspm.prototype.get_left_trim = function() {
-  "use strict";
-  return this.ltrim;
-};
-
-Pspm.prototype.get_right_trim = function() {
-  "use strict";
-  return this.rtrim;
-};
-
-Pspm.prototype.as_best_match = function(alphabet) {
-  "use strict";
-  var match, odds, best_odds, best_index;
-  var i, j;
-  match = "";
-  for (i = 0; i < this.motif_length; i++) {
-    best_index = 0;
-    best_odds = this.pspm[i][0] / alphabet.get_bg_freq(0);
-    for (j = 1; j < this.alph_length; j++) {
-      odds = this.pspm[i][j] / alphabet.get_bg_freq(j);
-      if (odds > best_odds) {
-        best_odds = odds;
-        best_index = j;
-      }
-    }
-    match += alphabet.get_symbol(best_index);
-  }
-  return match;
-};
-
-Pspm.prototype.as_count_matrix = function() {
-  "use strict";
-  var count, count_text, text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      count = Math.round(this.nsites * this.pspm[i][j]);
-      count_text = "" + count;
-      // pad up to length of 4
-      if (count_text.length < 4) {
-        text += (new Array(5 - count_text.length)).join(" ") + count_text;
-      } else {
-        text += count_text;
-      }
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_probability_matrix = function() {
-  "use strict";
-  var text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      text += this.pspm[i][j].toFixed(6);
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_score_matrix = function(alphabet, pseudo) {
-  "use strict";
-  var me, score, out, row, col, score_text;
-  me = this;
-  if (typeof this.pssm === "undefined") {
-    if (!(typeof alphabet === "object" && alphabet != null && alphabet instanceof Alphabet)) {
-      throw new Error("The alphabet is required to generate the pssm.");
-    }
-    if (typeof pseudo === "undefined") {
-      pseudo = 0.01;
-    } else if (typeof pseudo !== "number" || pseudo < 0) {
-      throw new Error("Expected positive number for pseudocount");
-    }
-    score = function(row, col) {
-      "use strict";
-      var p, bg, p2;
-      p = me.pspm[row][col];
-      bg = alphabet.get_bg_freq(col);
-      p2 = (p * me.nsites + bg * pseudo) / (me.nsites + pseudo);
-      return (p2 > 0 ? Math.round((Math.log(p2 / bg) / Math.LN2) * 100) : -10000);
-    };
-  } else {
-    score = function(row, col) {
-      "use strict";
-      return me.pssm[row][col];
-    };
-  }
-  out = "";
-  for (row = 0; row < this.motif_length; row++) {
-    for (col = 0; col < this.alph_length; col++) {
-      if (col !== 0) {
-        out += " ";
-      }
-      score_text = "" + score(row, col);
-      // pad out to 6 characters
-      if (score_text.length < 6) {
-        out += (new Array(7 - score_text.length)).join(" ") + score_text;
-      } else {
-        out += score_text;
-      }
-    }
-    out += "\n";
-  }
-  return out;
-}
-
-Pspm.prototype.as_pspm = function() {
-  "use strict";
-  return "letter-probability matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + " nsites= " + this.nsites + 
-      " E= " + (typeof this.evalue === "number" ? 
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_probability_matrix();
-};
-
-Pspm.prototype.as_pssm = function(alphabet, pseudo) {
-  "use strict";
-  return "log-odds matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + 
-      " E= " + (typeof this.evalue == "number" ?
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_score_matrix(alphabet, pseudo);
-};
-
-Pspm.prototype.as_meme = function(options) {
-  var with_header, with_pspm, with_pssm, version, alphabet, bg_source, pseudocount, strands;
-  var out, alen, i;
-  // get the options
-  if (typeof options !== "object" || options === null) {
-    options = {};
-  }
-  with_header = (typeof options["with_header"] === "boolean" ? options["with_header"] : false);
-  with_pspm = (typeof options["with_pspm"] === "boolean" ? options["with_pspm"] : false);
-  with_pssm = (typeof options["with_pssm"] === "boolean" ? options["with_pssm"] : false);
-  if (!with_pspm && !with_pssm) with_pspm = true;
-  if (with_header) {
-    if (typeof options["version"] === "string" && /^\d+(?:\.\d+){0,2}$/.test(options["version"])) {
-      version = options["version"];
-    } else if (typeof options["version"] === "number") {
-      version = options["version"].toFixed(0);
-    } else {
-      version = "4";
-    }
-    if (typeof options["strands"] === "number" && options["strands"] === 1) {
-      strands = 1;
-    } else {
-      strands = 2;
-    }
-    if (typeof options["bg_source"] === "string") {
-      bg_source = options["bg_source"];
-    } else {
-      bg_source = "unknown source";
-    }
-    if (typeof options["alphabet"] === "object" && options["alphabet"] != null
-        && options["alphabet"] instanceof Alphabet) {
-      alphabet = options["alphabet"];
-    } else {
-      throw new Error("The alphabet is required to generate the header.");
-    }
-  }
-  // now create the output
-  out = "";
-  if (with_header) {
-    out = "MEME version " + version + "\n\n";
-    out += alphabet.as_meme() + "\n";
-    if (alphabet.has_complement()) { // assume DNA has both strands unless otherwise specified
-      out += "strands: " + (strands === 1 ? "+" : "+ -") + "\n\n";
-    }
-    out += "Background letter frequencies (from " + bg_source + "):\n";
-    alen = alphabet.get_size_core();
-    for (i = 0; i < alen; i++) {
-      if (i !== 0) {
-        if (i % 9 === 0) { // maximum of nine entries per line
-          out += "\n";
-        } else {
-          out += " ";
-        }
-      }
-      out += alphabet.get_symbol(i) + " " + alphabet.get_bg_freq(i).toFixed(3);
-    }
-  }
-  out += "\n\n";
-  out += "MOTIF " + this.name + (this.alt == null ? "" : " " + this.alt);
-  if (with_pssm) {
-    out += "\n\n";
-    out += this.as_pssm(options["alphabet"], options["pseudocount"]);
-  }
-  if (with_pspm) {
-    out += "\n\n";
-    out += this.as_pspm();
-  }
-  return out;
-}
-
-Pspm.prototype.toString = function() {
-  "use strict";
-  var str, i, row;
-  str = "";
-  for (i = 0; i < this.pspm.length; i++) {
-    row = this.pspm[i];
-    str += row.join("\t") + "\n";
-  }
-  return str;
-};
-
-function parse_pspm_properties(str) {
-  "use strict";
-  var parts, i, eqpos, before, after, properties, prop, num, num_re;
-  num_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-  parts = trim(str).split(/\s+/);
-  // split up words containing =
-  for (i = 0; i < parts.length;) {
-    eqpos = parts[i].indexOf("=");
-    if (eqpos != -1) {
-      before = parts[i].substr(0, eqpos);
-      after = parts[i].substr(eqpos+1);
-      if (before.length > 0 && after.length > 0) {
-        parts.splice(i, 1, before, "=", after);
-        i += 3;
-      } else if (before.length > 0) {
-        parts.splice(i, 1, before, "=");
-        i += 2;
-      } else if (after.length > 0) {
-        parts.splice(i, 1, "=", after);
-        i += 2;
-      } else {
-        parts.splice(i, 1, "=");
-        i++;
-      }
-    } else {
-      i++;
-    }
-  }
-  properties = {};
-  for (i = 0; i < parts.length; i += 3) {
-    if (parts.length - i < 3) {
-      throw new Error("Expected PSPM property was incomplete. "+
-          "Remaing parts are: " + parts.slice(i).join(" "));
-    }
-    if (parts[i+1] !== "=") {
-      throw new Error("Expected '=' in PSPM property between key and " +
-          "value but got " + parts[i+1]); 
-    }
-    prop = parts[i].toLowerCase();
-    num = parts[i+2];
-    if (!num_re.test(num)) {
-      throw new Error("Expected numeric value for PSPM property '" + 
-          prop + "' but got '" + num + "'");
-    }
-    properties[prop] = num;
-  }
-  return properties;
-}
-
-function parse_pspm_string(pspm_string) {
-  "use strict";
-  var header_re, lines, first_line, line_num, col_num, alph_length, 
-      motif_length, nsites, evalue, pspm, i, line, match, props, parts,
-      j, prob;
-  header_re = /^letter-probability\s+matrix:(.*)$/i;
-  lines = pspm_string.split(/\n/);
-  first_line = true;
-  line_num = 0;
-  col_num = 0;
-  alph_length;
-  motif_length;
-  nsites;
-  evalue;
-  pspm = [];
-  for (i = 0; i < lines.length; i++) {
-    line = trim(lines[i]);
-    if (line.length === 0) { 
-      continue;
-    }
-    // check the first line for a header though allow matrices without it
-    if (first_line) {
-      first_line = false;
-      match = header_re.exec(line);
-      if (match !== null) {
-        props = parse_pspm_properties(match[1]);
-        if (props.hasOwnProperty("alength")) {
-          alph_length = parseFloat(props["alength"]);
-          if (alph_length != 4 && alph_length != 20) {
-            throw new Error("PSPM property alength should be 4 or 20" +
-                " but got " + alph_length);
-          }
-        }
-        if (props.hasOwnProperty("w")) {
-          motif_length = parseFloat(props["w"]);
-          if (motif_length % 1 !== 0 || motif_length < 1) {
-            throw new Error("PSPM property w should be an integer larger " +
-                "than zero but got " + motif_length);
-          }
-        }
-        if (props.hasOwnProperty("nsites")) {
-          nsites = parseFloat(props["nsites"]);
-          if (nsites <= 0) {
-            throw new Error("PSPM property nsites should be larger than " +
-                "zero but got " + nsites);
-          }
-        }
-        if (props.hasOwnProperty("e")) {
-          evalue = props["e"];
-          if (evalue < 0) {
-            throw new Error("PSPM property evalue should be " +
-                "non-negative but got " + evalue);
-          }
-        }
-        continue;
-      }
-    }
-    pspm[line_num] = [];
-    col_num = 0;
-    parts = line.split(/\s+/);
-    for (j = 0; j < parts.length; j++) {
-      prob = parseFloat(parts[j]);
-      if (prob != parts[j] || prob < 0 || prob > 1) {
-        throw new Error("Expected probability but got '" + parts[j] + "'"); 
-      }
-      pspm[line_num][col_num] = prob;
-      col_num++;
-    }
-    line_num++;
-  }
-  if (typeof motif_length === "number") {
-    if (pspm.length != motif_length) {
-      throw new Error("Expected PSPM to have a motif length of " + 
-          motif_length + " but it was actually " + pspm.length);
-    }
-  } else {
-    motif_length = pspm.length;
-  }
-  if (typeof alph_length !== "number") {
-    alph_length = pspm[0].length;
-    if (alph_length != 4 && alph_length != 20) {
-      throw new Error("Expected length of first row in the PSPM to be " +
-          "either 4 or 20 but got " + alph_length);
-    }
-  }
-  for (i = 0; i < pspm.length; i++) {
-    if (pspm[i].length != alph_length) {
-      throw new Error("Expected PSPM row " + i + " to have a length of " + 
-          alph_length + " but the length was " + pspm[i].length);
-    }
-  }
-  return {"pspm": pspm, "motif_length": motif_length, 
-    "alph_length": alph_length, "nsites": nsites, "evalue": evalue};
-}
-//======================================================================
-// end Pspm object
-//======================================================================
-
-//======================================================================
-// start Logo object
-//======================================================================
-
-var Logo = function(alphabet, options) {
-  "use strict";
-  this.alphabet = alphabet;
-  this.fine_text = "";
-  this.x_axis = 1;
-  this.y_axis = true;
-  this.xlate_nsyms = 1;
-  this.xlate_start = null;
-  this.xlate_end = null;
-  this.pspm_list = [];
-  this.pspm_column = [];
-  this.rows = 0;
-  this.columns = 0;
-  if (typeof options === "string") {
-    // the old method signature had fine_text here so we support that
-    this.fine_text = options;
-  } else if (typeof options === "object" && options != null) {
-    this.fine_text = (typeof options.fine_text === "string" ? options.fine_text : "");
-    this.x_axis = (typeof options.x_axis === "boolean" ? (options.x_axis ? 1 : 0) : 1);
-    if (options.x_axis_hidden != null && options.x_axis_hidden) this.x_axis = -1;
-    this.y_axis = (typeof options.y_axis === "boolean" ? options.y_axis : true);
-    this.xlate_nsyms = (typeof options.xlate_nsyms === "number" ? options.xlate_nsyms : this.xlate_nsyms);
-    this.xlate_start = (typeof options.xlate_start === "number" ? options.xlate_start : this.xlate_start);
-    this.xlate_end = (typeof options.xlate_end === "number" ? options.xlate_end : this.xlate_end);
-  }
-};
-
-Logo.prototype.add_pspm = function(pspm, column) {
-  "use strict";
-  var col;
-  if (typeof column === "undefined") {
-    column = 0;
-  } else if (column < 0) {
-    throw new Error("Column index out of bounds.");
-  }
-  this.pspm_list[this.rows] = pspm;
-  this.pspm_column[this.rows] = column;
-  this.rows++;
-  col = column + pspm.get_motif_length();
-  if (col > this.columns) {
-    this.columns = col;
-  }
-};
-
-Logo.prototype.get_columns = function() {
-  "use strict";
-  return this.columns;
-};
-
-Logo.prototype.get_xlate_nsyms = function() {
-  "use strict";
-  return this.xlate_nsyms;
-};
-
-Logo.prototype.get_xlate_start = function() {
-  "use strict";
-  return (this.xlate_start != null ? this.xlate_start : 0);
-};
-
-Logo.prototype.get_xlate_end = function() {
-  "use strict";
-  return (this.xlate_end != null ? this.xlate_end : this.columns * this.xlate_nsyms);
-};
-
-Logo.prototype.get_xlate_columns = function() {
-  "use strict";
-  return this.get_xlate_end() - this.get_xlate_start();
-};
-
-Logo.prototype.get_rows = function() {
-  "use strict";
-  return this.rows;
-};
-
-Logo.prototype.get_pspm = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_list[row_index];
-};
-
-Logo.prototype.get_offset = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_column[row_index];
-};
-
-Logo.prototype._as_eps_data = function(ssc, errbars) {
-  var i, j, pos, stack_pos, pspm, stack, sym, out;
-  out = "";
-  for (i = 0; i < this.rows; i++) {
-    out += "\nStartLine\n";
-    // Indent
-    for (j = 0; j < this.pspm_column[i]; j++) {
-      out += "() startstack\nendstack\n\n";
-    }
-    pspm = this.pspm_list[i];
-    if (pspm.get_left_trim() > 0) {
-      out += "MuteColour\nDrawTrimEdge\n" + pspm.get_left_trim() + " DrawTrimBg\n";
-    }
-    for (pos = 0; pos < pspm.get_motif_length(); pos++) {
-      if (pos != 0 && pos == pspm.get_left_trim()) { // enable full colour
-        out += "DrawTrimEdge\nRestoreColour\n";
-      } else if (pos == (pspm.get_motif_length() - pspm.get_right_trim())) {
-        out += "MuteColour\n" + pspm.get_right_trim() + " DrawTrimBg\n";
-      }
-      out += "(" + (pos + 1) + ") startstack\n";
-      stack = pspm.get_stack(pos, this.alphabet, ssc);
-      for (stack_pos = 0; stack_pos < stack.length; stack_pos++) {
-        sym = stack[stack_pos];
-        out += " " + (sym.get_scale() * this.alphabet.get_ic()) + " (" + sym.get_symbol() + ") numchar\n";
-      }
-      if (errbars) {
-        out += " " + pspm.get_error(this.alphabet) + " Ibeam\n";
-      }
-      out += "endstack\n\n";
-    }
-    if (pspm.get_right_trim() > 0 || pspm.get_left_trim() == pspm.get_motif_length()) {
-      out += "RestoreColour\n";
-    }
-    out += "EndLine\n";
-  }
-  return out;
-};
-
-Logo.prototype.as_eps = function(options) {
-  "use strict";
-  if (this.xlate_nsyms != 1) throw new Error("Unsupported setting xlate_nsyms for EPS");
-  if (this.xlate_start != null) throw new Error("Unsupported setting xlate_start for EPS");
-  if (this.xlate_end != null) throw new Error("Unsupported setting xlate_end for EPS");
-
-  var LOGOHEIGHT = 7.5; // default height of line in cm
-  var cm2pts, height, width, now, ssc, errbars;
-  if (typeof options === "undefined") {
-    options = {};
-  }
-  cm2pts = 72 / 2.54;
-  if (typeof options.logo_height == "number") {
-    height = options.logo_height;
-  } else {
-    height = LOGOHEIGHT * this.rows;
-  }
-  if (typeof options.logo_width == "number") {
-    width = options.logo_width;
-  } else {
-    width = this.columns + 2;
-  }
-  now = new Date();
-  ssc = (typeof options.ssc == "boolean" ? options.ssc : false);
-  errbars = (typeof options.show_error_bar == "boolean" ? options.show_error_bar : ssc);
-  var values = {
-    "LOGOHEIGHT": height,
-    "LOGOWIDTH": width,
-    "BOUNDINGHEIGHT": Math.round(height * cm2pts),
-    "BOUNDINGWIDTH": Math.round(width * cm2pts),
-    "LOGOLINEHEIGHT": (height / this.rows),
-    "CHARSPERLINE": this.columns,
-    "BARBITS": this.alphabet.get_ic(),
-    "LOGOTYPE": (this.alphabet.has_complement() ? "NA" : "AA"),
-    "CREATIONDATE": now.getDate() + "." + (now.getMonth() + 1) + "." + now.getFullYear() + " " + now.getHours() + ":" + now.getMinutes() + ":" + now.getSeconds(),
-    "ERRORBARFRACTION": (typeof options.error_bar_fraction == "number" ? options.error_bar_fraction : 1.0),
-    "TICBITS": (typeof options.ticbits == "number" ? options.ticbits : 1.0),
-    "TITLE": (typeof options.title == "string" ? options.title : ""),
-    "FINEPRINT": (typeof options.fineprint == "string" ? options.fineprint : this.fine_text),
-    "XAXISLABEL": (typeof options.xaxislabel == "string" ? options.xaxislabel : ""),
-    "YAXISLABEL": (typeof options.yaxislabel == "string" ? options.yaxislabel : "bits"),
-    "SSC": ssc,
-    "YAXIS": (typeof options.show_y_axis == "boolean" ? options.show_y_axis : this.y_axis),
-    "SHOWENDS": (typeof options.show_ends == "boolean" ? options.show_ends : false),
-    "ERRBAR": errbars,
-    "OUTLINE": (typeof options.show_outline == "boolean" ? options.show_outline : false),
-    "NUMBERING": (typeof options.show_numbering == "boolean" ? options.show_numbering : this.x_axis != 0),
-    "SHOWINGBOX": (typeof options.show_box == "boolean" ? options.show_box : false),
-    "CREATOR": (typeof options.creator == "string" ? options.creator : "motif_logo.js"),
-    "FONTSIZE": (typeof options.label_font_size == "number" ? options.label_font_size : 12),
-    "TITLEFONTSIZE": (typeof options.title_font_size == "number" ? options.title_font_size : 12),
-    "SMALLFONTSIZE": (typeof options.small_font_size == "number" ? options.small_font_size : 6),
-    "TOPMARGIN" : (typeof options.top_margin == "number" ? options.top_margin : 0.9),
-    "BOTTOMMARGIN": (typeof options.bottom_margin == "number" ? options.bottom_margin : 0.9),
-    "COLORDICT": this.alphabet._as_eps_dict(),
-    "DATA": this._as_eps_data(ssc, errbars)
-  };
-  // now this requires that the script containing the template has been imported!
-  return motif_logo_template(values);
-};
-
-//======================================================================
-// end Logo object
-//======================================================================
-
-// calculate the exact size (in pixels) of an object drawn on the
-// canvas assuming that the background of the canvas is transparent.
-function canvas_bounds(ctx, cwidth, cheight) {
-  "use strict";
-  var data, r, c, top_line, bottom_line, left_line, right_line, 
-      txt_width, txt_height;
-
-  // extract the image data
-  data = ctx.getImageData(0, 0, cwidth, cheight).data;
-
-  // set initial values
-  top_line = -1; bottom_line = -1; left_line = -1; right_line = -1;
-  txt_width = 0; txt_height = 0;
-
-  // Find the top-most line with a non-transparent pixel
-  for (r = 0; r < cheight; r++) {
-    for (c = 0; c < cwidth; c++) {
-      if (data[r * cwidth * 4 + c * 4 + 3]) {
-        top_line = r;
-        break;
-      }
-    }
-    if (top_line != -1) {
-      break;
-    }
-  }
-  
-  // Only bother looking if we found at least one set pixel... 
-  if (top_line != -1) {
-
-    //find the last line with a non-transparent pixel
-    for (r = cheight-1; r >= top_line; r--) {
-      for(c = 0; c < cwidth; c++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          bottom_line = r;
-          break;
-        }
-      }
-      if (bottom_line != -1) {
-        break;
-      }
-    }
-    // calculate height
-    txt_height = bottom_line - top_line + 1;
-
-    // Find the left-most line with a non-transparent pixel
-    for (c = 0; c < cwidth; c++) {
-      for (r = top_line; r <= bottom_line; r++) {
-        if (data[r * cwidth * 4 + c * 4 + 3]) {
-          left_line = c;
-          break;
-        }
-      }
-      if (left_line != -1) {
-        break;
-      }
-    }
-
-    //find the right most line with a non-transparent pixel
-    for (c = cwidth-1; c >= left_line; c--) {
-      for(r = top_line; r <= bottom_line; r++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          right_line = c;
-          break;
-        }
-      }
-      if (right_line != -1) {
-        break;
-      }
-    }
-    txt_width = right_line - left_line + 1;
-  }
-
-  //return the bounds
-  return {bound_top: top_line, bound_bottom: bottom_line, 
-    bound_left: left_line, bound_right: right_line, width: txt_width, 
-    height: txt_height};
-}
-
-//======================================================================
-// start RasterizedAlphabet
-//======================================================================
-
-// Rasterize Alphabet
-// 1) Measure width of text at default font for all symbols in alphabet
-// 2) sort in width ascending
-// 3) Drop the top and bottom 10% (designed to ignore outliers like 'W' and 'I')
-// 4) Calculate the average as the maximum scaling factor (designed to stop I becoming a rectangular blob).
-// 5) Assume scale of zero would result in width of zero, interpolate scale required to make perfect width font
-// 6) Draw text onto temp canvas at calculated scale
-// 7) Find bounds of drawn text
-// 8) Paint on to another canvas at the desired height (but only scaling width to fit if larger).
-var RasterizedAlphabet = function(alphabet, logo_scale, font, width) {
-  "use strict";
-  var default_size, safety_pad, canvas, ctx, middle, baseline, widths, sizes,
-      i, sym, size, tenpercent, avg_width, scale, 
-      target_width, target_height;
-  //variable prototypes
-  this.alphabet = alphabet;
-  this.scale = logo_scale;
-  this.sym_cache = {};
-  this.stack_num_cache = [];
-  this.scale_num_cache = [];
-  // size of canvas
-  default_size = 60; // size of measuring canvas
-  safety_pad = 20; // pixels to pad around so we don't miss the edges
-  // create a canvas to do our measuring
-  canvas = document.createElement("canvas");
-  if (!canvas.getContext) throw new Error("No canvas support");
-  canvas.width = default_size + 2 * safety_pad;
-  canvas.height = default_size + 2 * safety_pad;
-  middle = Math.round(canvas.width / 2);
-  baseline = Math.round(canvas.height - safety_pad);
-  ctx = canvas.getContext('2d');
-  if (!supports_text(ctx)) throw new Error("Canvas does not support text");
-  ctx.font = font;
-  ctx.textAlign = "center";
-  ctx.translate(middle, baseline);
-  // list of widths
-  widths = [];
-  sizes = [];
-  //now measure each letter in the alphabet
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    // reset the canvas
-    ctx.clearRect(0, 0, canvas.width, canvas.height);
-    ctx.fillStyle = alphabet.get_colour(i);
-    // draw the test text
-    ctx.fillText(alphabet.get_symbol(i), 0, 0);
-    //measure
-    size = canvas_bounds(ctx, canvas.width, canvas.height);
-    if (size.width === 0) throw new Error("Invisible symbol!");
-    widths.push(size.width);
-    sizes[i] = size;
-  }
-  //sort the widths
-  widths.sort(function(a,b) {return a - b;});
-  //drop 10% of the items off each end
-  tenpercent = Math.floor(widths.length / 10);
-  for (i = 0; i < tenpercent; ++i) {
-    widths.pop();
-    widths.shift();
-  }
-  //calculate average width
-  avg_width = 0;
-  for (i = 0; i < widths.length; ++i) {
-    avg_width += widths[i];
-  }
-  avg_width /= widths.length;
-  // calculate the target width
-  target_width = width * this.scale * 2;
-  // calculate scales
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    sym = alphabet.get_symbol(i);
-    size = sizes[i];
-    // calculate scale
-    scale = target_width / Math.max(avg_width, size.width);
-    // estimate scaled height
-    target_height = size.height * scale;
-    // create an appropriately sized canvas
-    canvas = document.createElement("canvas");
-    canvas.width = target_width;
-    canvas.height = target_height + safety_pad * 2;
-    // calculate the middle
-    middle = Math.round(canvas.width / 2);
-    // calculate the baseline
-    baseline = Math.round(canvas.height - safety_pad);
-    // get the context and prepare to draw the rasterized text
-    ctx = canvas.getContext('2d');
-    ctx.font = font;
-    ctx.fillStyle = alphabet.get_colour(i);
-    ctx.textAlign = "center";
-    ctx.translate(middle, baseline);
-    ctx.save();
-    ctx.scale(scale, scale);
-    // draw the text
-    ctx.fillText(sym, 0, 0);
-    ctx.restore();
-    this.sym_cache[sym] = {"image": canvas, "size": canvas_bounds(ctx, canvas.width, canvas.height)};
-  }
-};
-
-RasterizedAlphabet.prototype.get_alphabet = function() {
-  return this.alphabet;
-};
-
-RasterizedAlphabet.prototype.get_scale = function() {
-  return this.scale;
-};
-
-RasterizedAlphabet.prototype.draw_stack_sym = function(ctx, letter, dx, dy, dWidth, dHeight) {
-  "use strict";
-  var entry, image, size;
-  entry = this.sym_cache[letter];
-  image = entry.image;
-  size = entry.size;
-  ctx.drawImage(image, 0, size.bound_top -1, image.width, size.height+1, dx, dy, dWidth, dHeight);
-};
-
-RasterizedAlphabet.prototype.draw_stack_num = function(ctx, font, stack_width, index) {
-  var image, image_ctx, text_length;
-  if (index >= this.stack_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.save();
-    image_ctx.font = font;
-    text_length = image_ctx.measureText("" + (index + 1)).width;
-    image_ctx.restore();
-    // resize the canvas to fit
-    image.width = Math.ceil(stack_width);
-    image.height = Math.ceil(text_length);
-    // draw the text
-    image_ctx = image.getContext('2d');
-    image_ctx.translate(Math.round(stack_width / 2), 0);
-    image_ctx.font = font;
-    image_ctx.textBaseline = "middle";
-    image_ctx.textAlign = "right";
-    image_ctx.rotate(-(Math.PI / 2));
-    image_ctx.fillText("" + (index + 1), 0, 0);
-    this.stack_num_cache[index] = image;
-  } else {
-    image = this.stack_num_cache[index];
-  }
-  ctx.drawImage(image, 0, 0);
-}
-
-RasterizedAlphabet.prototype.draw_scale_num = function(ctx, font, num) {
-  var image, image_ctx, text_size, m_length;
-  if (num >= this.scale_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.font = font;
-    text_size = image_ctx.measureText("" + num);
-    if (text_size.actualBoundingBoxAscent && text_size.actualBoundingBoxDesent) {
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(text_size.actualBoundingBoxAscent + text_size.actualBoundingBoxDesent);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.fillText("" + num, image.width, text_size.actualBoundingBoxAscent);
-    } else {
-      // measure width of 'm' to approximate height, we double it later anyway
-      m_length = image_ctx.measureText("m").width;
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(2 * m_length);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.textBaseline = "middle";
-      image_ctx.fillText("" + num, image.width, m_length);
-    }
-    this.scale_num_cache[num] = image;
-  } else {
-    image = this.scale_num_cache[num];
-  }
-  ctx.drawImage(image, -image.width, -Math.round(image.height / 2))
-}
-
 //======================================================================
 // end RasterizedAlphabet
 //======================================================================
-
 //======================================================================
 // start LogoMetrics object
 //======================================================================
-
-var LogoMetrics = function(ctx, logo_columns, logo_rows, has_names, has_finetext, x_axis, y_axis) {
-  "use strict";
-  var i, row_height;
-  //variable prototypes
-  this.pad_top = (has_names ? 5 : 0);
-  this.pad_left = (y_axis ? 10 : 0);
-  this.pad_right = (has_finetext ? 15 : 0);
-  this.pad_bottom = 0;
-  this.pad_middle = 20;
-  this.name_height = 14;
-  this.name_font = "bold " + this.name_height + "px Times, sans-serif";
-  this.name_spacer = 0;
-  this.y_axis = y_axis;
-  this.y_label = "bits";
-  this.y_label_height = 12;
-  this.y_label_font = "bold " + this.y_label_height + "px Helvetica, sans-serif";
-  this.y_label_spacer = 3;
-  this.y_num_height = 12;
-  this.y_num_width = 0;
-  this.y_num_font = "bold " + this.y_num_height + "px Helvetica, sans-serif";
-  this.y_tic_width = 5;
-  this.stack_pad_left = 0;
-  this.stack_font = "bold 25px Helvetica, sans-serif";
-  this.stack_height = 90;
-  this.stack_width = 26;
-  this.stacks_pad_right = 5;
-  this.x_axis = x_axis;
-  this.x_num_above = 2;
-  this.x_num_height = 12;
-  this.x_num_width = 0;
-  this.x_num_font = "bold " + this.x_num_height + "px Helvetica, sans-serif";
-  this.fine_txt_height = 6;
-  this.fine_txt_above = 2;
-  this.fine_txt_font = "normal " + this.fine_txt_height + "px Helvetica, sans-serif";
-  this.letter_metrics = new Array();
-  this.summed_width = 0;
-  this.summed_height = 0;
-  //calculate the width of the y axis numbers
-  ctx.font = this.y_num_font;
-  for (i = 0; i <= 2; i++) {
-    this.y_num_width = Math.max(this.y_num_width, ctx.measureText("" + i).width);
-  }
-  //calculate the width of the x axis numbers (but they are rotated so it becomes height)
-  if (x_axis == 1) {
-    ctx.font = this.x_num_font;
-    for (i = 1; i <= logo_columns; i++) {
-      this.x_num_width = Math.max(this.x_num_width, ctx.measureText("" + i).width);
-    }
-  } else if (x_axis == 0) {
-    this.x_num_height = 4;
-    this.x_num_width = 4;
-  } else {
-    this.x_num_height = 0;
-    this.x_num_width = 0;
-  }
-  
-  //calculate how much vertical space we want to draw this
-  //first we add the padding at the top and bottom since that's always there
-  this.summed_height += this.pad_top + this.pad_bottom;
-  //all except the last row have the same amount of space allocated to them
-  if (logo_rows > 1) {
-    row_height = this.stack_height + this.pad_middle;
-    if (has_names) {
-      row_height += this.name_height;
-      //the label is allowed to overlap into the spacer
-      row_height += Math.max(this.y_num_height/2, this.name_spacer); 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    } else {
-      row_height += this.y_num_height/2; 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    }
-    this.summed_height += row_height * (logo_rows - 1);
-  }
-  //the last row has the name and fine text below it but no padding
-  this.summed_height += this.stack_height + (this.y_axis ? this.y_num_height/2 : 0);
-
-  var fine_txt_total = (has_finetext ? this.fine_txt_height + this.fine_txt_above : 0);
-  if (has_names) {
-    this.summed_height += fine_txt_total + this.name_height;
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + this.name_spacer);
-  } else {
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + fine_txt_total);
-  }
-
-  //calculate how much horizontal space we want to draw this
-  //first add the padding at the left and right since that's always there
-  this.summed_width += this.pad_left + this.pad_right;
-  if (this.y_axis) {
-    //add on the space for the y-axis label
-    this.summed_width += this.y_label_height + this.y_label_spacer;
-    //add on the space for the y-axis
-    this.summed_width += this.y_num_width + this.y_tic_width;
-  }
-  //add on the space for the stacks
-  this.summed_width += (this.stack_pad_left + this.stack_width) * logo_columns;
-  //add on the padding after the stacks (an offset from the fine text)
-  this.summed_width += this.stacks_pad_right;
-
-};
-
-//======================================================================
-// end LogoMetrics object
-//======================================================================
-
-//found this trick at http://talideon.com/weblog/2005/02/detecting-broken-images-js.cfm
-function image_ok(img) {
-  "use strict";
-  // During the onload event, IE correctly identifies any images that
-  // weren't downloaded as not complete. Others should too. Gecko-based
-  // browsers act like NS4 in that they report this incorrectly.
-  if (!img.complete) {
-    return false;
-  }
-  // However, they do have two very useful properties: naturalWidth and
-  // naturalHeight. These give the true size of the image. If it failed
-  // to load, either of these should be zero.
-  if (typeof img.naturalWidth !== "undefined" && img.naturalWidth === 0) {
-    return false;
-  }
-  // No other way of checking: assume it's ok.
-  return true;
-}
-  
-function supports_text(ctx) {
-  "use strict";
-  if (!ctx.fillText) {
-    return false;
-  }
-  if (!ctx.measureText) {
-    return false;
-  }
-  return true;
-}
-
-//draws the scale, returns the width
-function draw_scale(ctx, metrics, alphabet_ic, raster) {
-  "use strict";
-  var tic_height, i;
-  tic_height = metrics.stack_height / alphabet_ic;
-  ctx.save();
-  ctx.translate(metrics.y_label_height, metrics.y_num_height/2);
-  //draw the axis label
-  ctx.save();
-  ctx.font = metrics.y_label_font;
-  ctx.translate(0, metrics.stack_height/2);
-  ctx.rotate(-(Math.PI / 2));
-  ctx.textAlign = "center";
-  ctx.fillText("bits", 0, 0);
-  ctx.restore();
-
-  ctx.translate(metrics.y_label_spacer + metrics.y_num_width, 0);
-
-  //draw the axis tics
-  ctx.save();
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i <= alphabet_ic; i++) {
-    //draw the number
-    ctx.save();
-    ctx.translate(-1, 0);
-    raster.draw_scale_num(ctx, metrics.y_num_font, i);
-    ctx.restore();
-    //draw the tic
-    ctx.fillRect(0, -1, metrics.y_tic_width, 2);
-    //prepare for next tic
-    ctx.translate(0, -tic_height);
-  }
-  ctx.restore();
-
-  ctx.fillRect(metrics.y_tic_width - 2, 0, 2, metrics.stack_height)
-
-  ctx.restore();
-}
-
-function draw_stack_num(ctx, metrics, row_index, raster) {
-  "use strict";
-  ctx.save();
-  ctx.translate(0, Math.round(metrics.stack_height + metrics.x_num_above));
-  if (metrics.x_axis == 1) {
-    raster.draw_stack_num(ctx, metrics.x_num_font, metrics.stack_width, row_index);
-  } else if (metrics.x_axis == 0) {
-    // draw dots instead of the numbers (good for small logos)
-    ctx.beginPath();
-    var radius = Math.round(metrics.x_num_height / 2);
-    ctx.arc(Math.round(metrics.stack_width / 2), radius, radius, 0, 2 * Math.PI, false);
-    ctx.fill();
-  }
-  ctx.restore();
-}
-
-function draw_stack(ctx, metrics, symbols, raster) {
-  "use strict";
-  var preferred_pad, sym_min, i, sym, sym_height, pad;
-  preferred_pad = 0;
-  sym_min = 5;
-
-  ctx.save();//1
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i < symbols.length; i++) {
-    sym = symbols[i];
-    sym_height = metrics.stack_height * sym.get_scale();
-    
-    pad = preferred_pad;
-    if (sym_height - pad < sym_min) {
-      pad = Math.min(pad, Math.max(0, sym_height - sym_min));
-    }
-    sym_height -= pad;
-
-    //translate to the correct position
-    ctx.translate(0, -(pad/2 + sym_height));
-
-    //draw
-    raster.draw_stack_sym(ctx, sym.get_symbol(), 0, 0, metrics.stack_width, sym_height);
-    //translate past the padding
-    ctx.translate(0, -(pad/2));
-  }
-  ctx.restore();//1
-}
-
-function draw_dashed_line(ctx, pattern, start, x1, y1, x2, y2) {
-  "use strict";
-  var x, y, len, i, dx, dy, tlen, theta, mulx, muly, lx, ly;
-  dx = x2 - x1;
-  dy = y2 - y1;
-  tlen = Math.pow(dx*dx + dy*dy, 0.5);
-  theta = Math.atan2(dy,dx);
-  mulx = Math.cos(theta);
-  muly = Math.sin(theta);
-  lx = [];
-  ly = [];
-  for (i = 0; i < pattern; ++i) {
-    lx.push(pattern[i] * mulx);
-    ly.push(pattern[i] * muly);
-  }
-  i = start;
-  x = x1;
-  y = y1;
-  len = 0;
-  ctx.beginPath();
-  while (len + pattern[i] < tlen) {
-    ctx.moveTo(x, y);
-    x += lx[i];
-    y += ly[i];
-    ctx.lineTo(x, y);
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-    x += lx[i];
-    y += ly[i];
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-  }
-  if (len < tlen) {
-    ctx.moveTo(x, y);
-    x += mulx * (tlen - len);
-    y += muly * (tlen - len);
-    ctx.lineTo(x, y);
-  }
-  ctx.stroke();
-}
-
-function draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider) {
-  "use strict";
-  var left_size = left_end - left_start;
-  var right_size = right_end - right_start;
-  var line_x;
-
-  ctx.save();//s8
-  ctx.fillStyle = "rgb(240, 240, 240)";
-  if (left_size > 0) {
-    ctx.fillRect(left_start * metrics.stack_width, 0, left_size * metrics.stack_width, metrics.stack_height);
-  }
-  if (right_size > 0) {
-    ctx.fillRect(right_start * metrics.stack_width, 0, right_size * metrics.stack_width, metrics.stack_height);
-  }
-  ctx.fillStyle = "rgb(51, 51, 51)";
-  if (left_size > 0 && left_divider) {
-    line_x = (left_end * metrics.stack_width) - 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  if (right_size > 0 && right_divider) {
-    line_x = (right_start * metrics.stack_width) + 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  ctx.restore();//s8
-}
-
-function size_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var draw_name, draw_finetext, metrics;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  if (canvas.width !== 0 && canvas.height !== 0) {
-    return;
-  }
-  metrics = new LogoMetrics(canvas.getContext('2d'), 
-      logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      canvas.width = metrics.summed_width * (canvas.height / metrics.summed_height);
-    } else if (canvas.height === 0) {
-      canvas.height = metrics.summed_height * (canvas.width / metrics.summed_width);
-    }
-  }
-}
-
-function draw_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var i, draw_name, draw_finetext, ctx, metrics, raster, pspm_i, pspm, 
-      offset, col_index, motif_position, ssc;
-  ssc = false;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  ctx = canvas.getContext('2d');
-  //assume that the user wants the canvas scaled equally so calculate what the best width for this image should be
-  metrics = new LogoMetrics(ctx, logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      scale = 1;
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      scale = canvas.height / metrics.summed_height;
-      canvas.width = metrics.summed_width * scale;
-    } else if (canvas.height === 0) {
-      scale = canvas.width / metrics.summed_width;
-      canvas.height = metrics.summed_height * scale;
-    } else {
-      scale = Math.min(canvas.width / metrics.summed_width, canvas.height / metrics.summed_height);
-    }
-  }
-  // cache the raster based on the assumption that we will be drawing a lot
-  // of logos the same size and alphabet
-  if (typeof draw_logo_on_canvas.raster_cache === "undefined") {
-    draw_logo_on_canvas.raster_cache = [];
-  }
-  for (i = 0; i < draw_logo_on_canvas.raster_cache.length; i++) {
-    raster = draw_logo_on_canvas.raster_cache[i];
-    if (raster.get_alphabet().equals(logo.alphabet) &&
-        Math.abs(raster.get_scale() - scale) < 0.1) break;
-    raster = null;
-  }
-  if (raster == null) {
-    raster = new RasterizedAlphabet(logo.alphabet, scale, metrics.stack_font, metrics.stack_width);
-    draw_logo_on_canvas.raster_cache.push(raster);
-  }
-  ctx = canvas.getContext('2d');
-  ctx.save();//s1
-  ctx.scale(scale, scale);
-  ctx.save();//s2
-  ctx.save();//s7
-  //create margin
-  ctx.translate(Math.round(metrics.pad_left), Math.round(metrics.pad_top));
-  for (pspm_i = 0; pspm_i < logo.get_rows(); ++pspm_i) {
-    pspm = logo.get_pspm(pspm_i);
-    offset = logo.get_offset(pspm_i);
-    //optionally draw name if this isn't the last row or is the only row 
-    if (draw_name && (logo.get_rows() == 1 || pspm_i != (logo.get_rows()-1))) {
-      ctx.save();//s4
-      ctx.translate(Math.round(metrics.summed_width/2), Math.round(metrics.name_height));
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s4
-      ctx.translate(0, Math.round(metrics.name_height + 
-          Math.min(0, metrics.name_spacer - metrics.y_num_height/2)));
-    }
-    //draw scale
-    if (logo.y_axis) draw_scale(ctx, metrics, logo.alphabet.get_ic(), raster);
-    ctx.save();//s5
-    //translate across past the scale
-    if (logo.y_axis) {
-      ctx.translate(Math.round(metrics.y_label_height + metrics.y_label_spacer + 
-        metrics.y_num_width + metrics.y_tic_width), Math.round(metrics.y_num_height / 2));
-    }
-    //draw the trimming background
-    if (pspm.get_left_trim() > 0 || pspm.get_right_trim() > 0) {
-      var left_start = offset * logo.get_xlate_nsyms();
-      var left_end = (offset + pspm.get_left_trim()) * logo.get_xlate_nsyms();
-      var left_divider = true;
-      if (left_end < logo.get_xlate_start() || left_start > logo.get_xlate_end()) {
-        // no overlap
-        left_start = 0;
-        left_end = 0;
-        left_divider = false;
-      } else {
-        if (left_start < logo.get_xlate_start()) {
-          left_start = logo.get_xlate_start();
-        }
-        if (left_end > logo.get_xlate_end()) {
-          left_end = logo.get_xlate_end();
-          left_divider = false;
-        }
-        left_start -= logo.get_xlate_start();
-        left_end -= logo.get_xlate_start();
-        if (left_end < left_start) {
-          left_start = 0;
-          left_end = 0;
-          left_divider = false;
-        }
-      }
-      var right_end = (offset + pspm.get_motif_length()) * logo.get_xlate_nsyms();
-      //var right_start = right_end - (pspm.get_left_trim() * logo.get_xlate_nsyms());
-      var right_start = right_end - (pspm.get_right_trim() * logo.get_xlate_nsyms());
-      var right_divider = true;
-      if (right_end < logo.get_xlate_start() || right_start > logo.get_xlate_end()) {
-        // no overlap
-        right_start = 0;
-        right_end = 0;
-        right_divider = false;
-      } else {
-        if (right_start < logo.get_xlate_start()) {
-          right_start = logo.get_xlate_start();
-          right_divider = false;
-        }
-        if (right_end > logo.get_xlate_end()) {
-          right_end = logo.get_xlate_end();
-        }
-        right_start -= logo.get_xlate_start();
-        right_end -= logo.get_xlate_start();
-        if (right_end < right_start) {
-          right_start = 0;
-          right_end = 0;
-          right_divider = false;
-        }
-      }
-      draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider);
-    }
-    //draw letters
-    var xlate_col;
-    for (xlate_col = logo.get_xlate_start(); xlate_col < logo.get_xlate_end(); xlate_col++) {
-      ctx.translate(metrics.stack_pad_left,0);
-      col_index = Math.floor(xlate_col / logo.get_xlate_nsyms());
-      if (xlate_col % logo.get_xlate_nsyms() == 0) {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          motif_position = col_index - offset;
-          draw_stack_num(ctx, metrics, motif_position, raster);
-          draw_stack(ctx, metrics, pspm.get_stack(motif_position, logo.alphabet, ssc), raster);
-        }
-      } else {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          ctx.save();// s5.1
-          ctx.translate(0, Math.round(metrics.stack_height));
-          // TODO draw a dot or dash or something to indicate continuity of the motif
-          ctx.restore(); //s5.1
-        }
-      }
-      ctx.translate(Math.round(metrics.stack_width), 0);
-    }
-    ctx.restore();//s5
-    ////optionally draw name if this is the last row but isn't the only row 
-    if (draw_name && (logo.get_rows() != 1 && pspm_i == (logo.get_rows()-1))) {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width + metrics.name_spacer));
-
-      ctx.save();//s6
-      ctx.translate(metrics.summed_width/2, metrics.name_height);
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s6
-      ctx.translate(0, metrics.name_height);
-    } else {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width));
-    }
-    //if not the last row then add middle padding
-    if (pspm_i != (logo.get_rows() -1)) {
-      ctx.translate(0, metrics.pad_middle);
-    }
-  }
-  ctx.restore();//s7
-  if (logo.fine_text.length > 0) {
-    ctx.translate(metrics.summed_width - metrics.pad_right, metrics.summed_height - metrics.pad_bottom);
-    ctx.font = metrics.fine_txt_font;
-    ctx.textAlign = "right";
-    ctx.fillText(logo.fine_text, 0,0);
-  }
-  ctx.restore();//s2
-  ctx.restore();//s1
-}
-
-function create_canvas(c_width, c_height, c_id, c_title, c_display) {
-  "use strict";
-  var canvas = document.createElement("canvas");
-  //check for canvas support before attempting anything
-  if (!canvas.getContext) {
-    return null;
-  }
-  var ctx = canvas.getContext('2d');
-  //check for html5 text drawing support
-  if (!supports_text(ctx)) {
-    return null;
-  }
-  //size the canvas
-  canvas.width = c_width;
-  canvas.height = c_height;
-  canvas.id = c_id;
-  canvas.title = c_title;
-  canvas.style.display = c_display;
-  return canvas;
-}
-
-function logo_1(alphabet, fine_text, pspm) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  logo.add_pspm(pspm);
-  return logo;
-}
-
-function logo_2(alphabet, fine_text, target, query, query_offset) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  if (query_offset < 0) {
-    logo.add_pspm(target, -query_offset);
-    logo.add_pspm(query);
-  } else {
-    logo.add_pspm(target);
-    logo.add_pspm(query, query_offset);
-  }      
-  return logo;
-}
-
-/*
- * Specifies an alternate source for an image.
- * If the image with the image_id specified has
- * not loaded then a generated logo will be used 
- * to replace it.
- *
- * Note that the image must either have dimensions
- * or a scale must be set.
- */
-function alternate_logo(logo, image_id, scale) {
-  "use strict";
-  var image = document.getElementById(image_id);
-  if (!image) {
-    alert("Can't find specified image id (" +  image_id + ")");
-    return;
-  }
-  //if the image has loaded then there is no reason to use the canvas
-  if (image_ok(image)) {
-    return;
-  }
-  //the image has failed to load so replace it with a canvas if we can.
-  var canvas = create_canvas(image.width, image.height, image_id, image.title, image.style.display);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the image with the canvas
-  image.parentNode.replaceChild(canvas, image);
-}
-
-/*
- * Specifes that the element with the specified id
- * should be replaced with a generated logo.
- */
-function replace_logo(logo, replace_id, scale, title_txt, display_style) {
-  "use strict";
-  var element = document.getElementById(replace_id);
-  if (!replace_id) {
-    alert("Can't find specified id (" + replace_id + ")");
-    return;
-  }
-  //found the element!
-  var canvas = create_canvas(50, 120, replace_id, title_txt, display_style);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the element with the canvas
-  element.parentNode.replaceChild(canvas, element);
-}
-
-/*
- * Fast string trimming implementation found at
- * http://blog.stevenlevithan.com/archives/faster-trim-javascript
- *
- * Note that regex is good at removing leading space but
- * bad at removing trailing space as it has to first go through
- * the whole string.
- */
-function trim (str) {
-  "use strict";
-  var ws, i;
-  str = str.replace(/^\s\s*/, '');
-  ws = /\s/; i = str.length;
-  while (ws.test(str.charAt(--i)));
-  return str.slice(0, i + 1);
-}
-</script>
-    <script>
-var current_motif = 0;
-var dreme_alphabet = new Alphabet(data.alphabet, data.control_db.freqs);
-
-/*
- * Create a pspm for the given motif data
- */
-function motif_pspm(m) {
-  return new Pspm(m.pwm, m.id, 0, 0, m.nsites, m.evalue);
-}
-
-/*
- * Create a count matrix from the given motif data
- */
-function motif_count_matrix(motif) {
-  return motif_pspm(motif).as_count_matrix();
-}
-
-/*
- * Create a probablity matrix from the given motif data
- */
-function motif_prob_matrix(motif) {
-  return motif_pspm(motif).as_probability_matrix();
-}
-
-/*
- * Create a minimal meme format motif from the given motif data
- */
-function motif_minimal_meme(motif) {
-  return motif_pspm(motif).as_meme({
-    "with_header": true, 
-    "with_pspm": true,
-    "with_pssm": false,
-    "version": data["version"],
-    "alphabet": dreme_alphabet,
-    "strands": (data.options.revcomp ? 2 : 1)
-  });
-}
-
-/*
- * Fill in a template variable
- */
-function set_tvar(template, tvar, value) {
-  var node;
-  node = find_child(template, tvar);
-  if (node === null) {
-    throw new Error("Template does not contain variable " + tvar);
-  }
-  node.innerHTML = "";
-  if (typeof value !== "object") {
-    node.appendChild(document.createTextNode(value));
-  } else {
-    node.appendChild(value);
-  }
-}
-
-/*
- * Make a canvas with the motif logo drawn on it. 
- */
-function make_logo(motif, height, rc) {
-  var pspm = new Pspm(motif["pwm"]);
-  if (rc) pspm = pspm.copy().reverse_complement(dreme_alphabet);
-  var logo = new Logo(dreme_alphabet);
-  logo.add_pspm(pspm, 0);
-  var canvas = document.createElement('canvas');
-  canvas.height = height;
-  canvas.width = 0;
-  draw_logo_on_canvas(logo, canvas, false);
-  return canvas;
-}
-
-/*
- * Create a button designed to contain a single symbol
- */
-function make_sym_btn(symbol, title, action) {
-  var box, sbox;
-  box = document.createElement("div");
-  box.tabIndex = 0;
-  box.className = "sym_btn";
-  sbox = document.createElement("span");
-  if (typeof symbol == "string") {
-    sbox.appendChild(document.createTextNode(symbol));
-  } else {
-    sbox.appendChild(symbol);
-  }
-  box.appendChild(sbox);
-  box.title = title;
-  box.addEventListener('click', action, false);
-  box.addEventListener('keydown', action, false);
-  return box;
-}
-
-/*
- * Create a pair of text spans with different classes.
- * This is useful when using CSS to only display one of them.
- */
-function text_pair(txt1, cls1, txt2, cls2) {
-  var container, part1, part2;
-  container = document.createElement("span");
-  part1 = document.createElement("span");
-  part1.appendChild(document.createTextNode(txt1));
-  part1.className = cls1;
-  container.appendChild(part1);
-  part2 = document.createElement("span");
-  part2.appendChild(document.createTextNode(txt2));
-  part2.className = cls2;
-  container.appendChild(part2);
-  return container;
-}
-
-/*
- * Make a colourised sequence.
- */
-function make_seq(seq) {
-  var i, j, letter, lbox, sbox;
-  sbox = document.createElement("span");
-  for (i = 0; i < seq.length; i = j) {
-    letter = seq.charAt(i);
-    for (j = i+1; j < seq.length; j++) {
-      if (seq.charAt(j) !== letter) {
-        break;
-      }
-    }
-    lbox = document.createElement("span");
-    lbox.style.color = dreme_alphabet.get_colour(dreme_alphabet.get_index(letter));
-    lbox.appendChild(document.createTextNode(seq.substring(i, j)));
-    sbox.appendChild(lbox);
-  }
-  return sbox;
-}
-
-/*
- * Create a description element taking into account the newlines in the source text.
- */
-function make_description(text) {
-  var i, j, lines, p;
-  var container = document.createElement("div");
-  var paragraphs = text.split(/\n\n+/);
-  for (i = 0; i < paragraphs.length; i++) {
-    lines = paragraphs[i].split(/\n/);
-    p = document.createElement("p");
-    p.appendChild(document.createTextNode(lines[0]));
-    for (j = 1; j < lines.length; j++) {
-      p.appendChild(document.createElement("br"));
-      p.appendChild(document.createTextNode(lines[j]));
-    }
-    container.appendChild(p);
-  }
-  return container;
-}
-
-/*
- * Make the table header for the discovered motifs.
- */
-function make_motif_header() {
-  var row = document.createElement("tr");
-  add_text_header_cell(row, "", "", "motif_ordinal");
-  add_text_header_cell(row, "Motif", "pop_motifs_word", "motif_word");
-  add_text_header_cell(row, "Logo", "pop_motifs_logo", "motif_logo");
-  if (data.options.revcomp) {
-    add_text_header_cell(row, "RC Logo", "pop_motifs_rc_logo", "motif_logo");
-  }
-  add_text_header_cell(row, "E-value", "pop_motifs_evalue", "motif_evalue");
-  add_text_header_cell(row, "Unerased E-value", "pop_motifs_uevalue", "motif_evalue");
-  add_text_header_cell(row, "More", "pop_more", "motif_more");
-  add_text_header_cell(row, "Submit/Download", "pop_submit_dl", "motif_submit");
-  row.className = "more";
-  return row;
-}
-
-/*
- * Make a compact motif summary row for the discovered motifs.
- */
-function make_motif_row(tbody, ordinal, motif) {
-  var row = document.createElement("tr");
-  add_text_cell(row, "" + ordinal + ".", "motif_ordinal");
-  add_text_cell(row, motif["id"], "motif_word");
-  add_cell(row, make_logo(motif, 50, false), "motif_logo");
-  if (data.options.revcomp) {
-    add_cell(row, make_logo(motif, 50, true), "motif_logo");
-  }
-  add_text_cell(row, motif["evalue"], "motif_evalue");
-  add_text_cell(row, motif["unerased_evalue"], "motif_evalue");
-  add_cell(row, make_sym_btn(text_pair("\u21A7", "less", "\u21A5", "more"), "Show more information.", function(e) { toggle_class(tbody, "collapsed"); }, "\u21A5", ""), "motif_more");
-  add_cell(row, make_sym_btn("\u21E2", "Submit the motif to another MEME Suite program or download it.", function(e) { action_show_outpop(e, ordinal); }), "motif_submit");
-  return row;
-}
-
-/*
- * Make a sortable table of enriched matching rows.
- */
-function make_motif_words(motif) {
-  var row, i, match;
-  var table = document.createElement("table");
-  var thead = document.createElement("thead");
-  row = document.createElement("tr");
-  add_text_header_cell(row, "Word", "pop_match_word", "match_word", function(e) {sort_table(this, compare_words);});
-  add_text_header_cell(row, "Positives", "pop_match_pos", "match_count", function(e) {sort_table(this, compare_counts);});
-  add_text_header_cell(row, "Negatives", "pop_match_neg", "match_count", function(e) {sort_table(this, compare_counts);});
-  add_text_header_cell(row, "P-value", "pop_match_pval", "match_evalue", function(e) {sort_table(this, compare_evalues);});
-  add_text_header_cell(row, "E-value", "pop_match_eval", "match_evalue", function(e) {sort_table(this, compare_evalues);});
-  thead.appendChild(row);
-  table.appendChild(thead);
-  var tbody = document.createElement("tbody");
-  for (i = 0; i < motif.matches.length; i++) {
-    match = motif.matches[i];
-    row = document.createElement("tr");
-    add_cell(row, make_seq(match.seq), "match_word");
-    add_text_cell(row, match.p + " / " + data.sequence_db.count, "match_count");
-    add_text_cell(row, match.n + " / " + data.control_db.count, "match_count");
-    add_text_cell(row, match.pvalue, "match_evalue");
-    add_text_cell(row, match.evalue, "match_evalue");
-    tbody.appendChild(row);
-  }
-  table.appendChild(tbody);
-  return table;
-}
-
-/*
- * Make an expanded view of a discovered motif.
- */
-function make_motif_exp(tbody, ordinal, motif) {
-  "use strict";
-  var box, pspm, logo_box;
-  box = $("tmpl_motif_expanded").cloneNode(true);
-  toggle_class(box, "template", false);
-  box.id = "";
-  find_child(box, "tvar_logo").appendChild(make_logo(motif, 150, false));
-  if (data.options.revcomp) {
-    find_child(box, "tvar_rclogo").appendChild(make_logo(motif, 150, true));
-  }
-  set_tvar(box, "tvar_p", motif["p"]);
-  set_tvar(box, "tvar_p_total", data.sequence_db.count);
-  set_tvar(box, "tvar_n", motif["n"]);
-  set_tvar(box, "tvar_n_total", data.control_db.count);
-  set_tvar(box, "tvar_pvalue", motif["pvalue"]);
-  set_tvar(box, "tvar_evalue", motif["evalue"]);
-  set_tvar(box, "tvar_uevalue", motif["unerased_evalue"]);
-  set_tvar(box, "tvar_words", make_motif_words(motif));
-  var cell = document.createElement("td");
-  cell.colSpan = 8;
-  cell.appendChild(box);
-  var row = document.createElement("tr");
-  row.className = "more";
-  row.appendChild(cell);
-  return row;
-}
-
-/*
- * Convert a string containing a scientific number into the log of that number
- * without having an intermediate representation of the number.
- * This is intended to avoid underflow problems with the tiny evalues that
- * MEME and DREME can create.
- */
-function sci2log(scinum) {
-  "use strict";
-  var ev_re, match, sig, exp;
-  ev_re = /^(.*)e(.*)$/;
-  if (match = ev_re.exec(scinum)) {
-    sig = parseFloat(match[1]);
-    exp = parseInt(match[2]);
-    return Math.log(sig) + (exp * Math.log(10));
-  }
-  return 0;
-}
-
-/*
- * Create a table of discovered motifs. A fresh table body is used for each
- * motif to make hiding/showing rows with css easier.
- */
-function make_motifs() {
-  "use strict";
-  var i, row, tbody, motif, ordinal;
-  // make the motifs table
-  var container = $("motifs");
-  container.innerHTML = ""; // clear content
-  var table = document.createElement("table");
-  // add a header that is always shown
-  var thead = document.createElement("thead");
-  thead.appendChild(make_motif_header());
-  table.appendChild(thead);
-  for (i = 0; i < data.motifs.length; i++) {
-    ordinal = i + 1;
-    motif = data.motifs[i];
-    tbody = document.createElement("tbody");
-    tbody.className = "collapsed";
-    tbody.appendChild(make_motif_row(tbody, ordinal, motif));
-    tbody.appendChild(make_motif_exp(tbody, ordinal, motif));
-    // create a following header for every row except the last one
-    if ((i + 1) < data.motifs.length) tbody.appendChild(make_motif_header());
-    table.appendChild(tbody);
-  }
-  container.appendChild(table);
-}
-
-/*
- * Create a table showing all the alphabet symbols, their names and frequencies.
- */
-function make_alpha_bg(alph, freqs) {
-  function colour_symbol(index) {
-    var span = document.createElement("span");
-    span.appendChild(document.createTextNode(alph.get_symbol(index)));
-    span.style.color = alph.get_colour(index);
-    span.className = "alpha_symbol";
-    return span;
-  }
-  var table, thead, tbody, row, th, span, i;
-  // create table
-  table = document.createElement("table");
-  table.className = "inputs";
-  // create header
-  thead = document.createElement("thead");
-  table.appendChild(thead);
-  row = thead.insertRow(thead.rows.length);
-  if (alph.has_complement()) {
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-  } else {
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    add_text_header_cell(row, "Bg.", "pop_alph_control");
-  }
-  // add alphabet entries
-  tbody = document.createElement("tbody");
-  table.appendChild(tbody);
-  if (alph.has_complement()) {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      var c = alph.get_complement(i);
-      if (i > c) continue;
-      row = tbody.insertRow(tbody.rows.length);
-      add_text_cell(row, alph.get_name(i));
-      add_text_cell(row, "" + freqs[i].toFixed(3));
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, "~");
-      add_cell(row, colour_symbol(c)); 
-      add_text_cell(row, "" + freqs[c].toFixed(3));
-      add_text_cell(row, alph.get_name(c));
-    }
-  } else {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      row = tbody.insertRow(tbody.rows.length);
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, alph.get_name(i));
-      add_text_cell(row, "" + freqs[i].toFixed(3));
-    }
-  }
-  return table;
-}
-
-/*
- * Updates the format download text in the popup.
- * This is called when either the format or current motif changes.
- */
-function update_outpop_format(index) {
-  var motif = data.motifs[index];
-  var fn = [motif_count_matrix, motif_prob_matrix, motif_minimal_meme];
-  var suffix = ["_counts.txt", "_freqs.txt", ".meme"];
-  var format = parseInt($("text_format").value);
-  var text = fn[format](motif);
-  prepare_download(text, "text/plain", motif.id + suffix[format], $("outpop_text_dl"));
-  $("outpop_text").value = text;
-}
-
-/*
- * Updates the motif logos and format download text in the popup.
- * This is called whenever the current motif changes.
- */
-function update_outpop_motif(index) {
-  "use strict";
-  var motifs, motif, pspm, logo, canvas, num;
-  motifs = data["motifs"];
-  if (index < 0 || index >= motifs.length) {return;}
-  current_motif = index;
-  motif = motifs[index];
-  pspm = new Pspm(motif["pwm"]);
-  logo = new Logo(dreme_alphabet, "");
-  logo.add_pspm(pspm, 0);
-  canvas = $("outpop_logo");
-  canvas.width = canvas.width; // clear canvas
-  draw_logo_on_canvas(logo, canvas, false);
-  canvas = $("outpop_logo_rc");
-  canvas.width = canvas.width; // clear rc canvas
-  if (data.options.revcomp) {
-    pspm.reverse_complement(dreme_alphabet);
-    logo = new Logo(dreme_alphabet, "");
-    logo.add_pspm(pspm, 0);
-    draw_logo_on_canvas(logo, canvas, false);
-  }
-  num = $("outpop_num");
-  num.innerHTML = "";
-  num.appendChild(document.createTextNode("" + (index + 1)));
-  update_outpop_format(index);
-}
-
-
-/*
  * Initialise and display the download popup.
- */
-function action_show_outpop(e, ordinal) {
-  "use strict";
-  function init() {
-    "use strict";
-    var close_btn, next_btn, prev_btn, cancel_btn, do_btn;
-    var tab1, tab2, tab3;
-    var pnl1, pnl2, pnl3;
-    var format_list;
-    var tbl_submit, inputs, i, default_prog;
-    close_btn = $("outpop_close");
-    close_btn.addEventListener("click", action_hide_outpop, false);
-    close_btn.addEventListener("keydown", action_hide_outpop, false);
-    next_btn = $("outpop_next");
-    next_btn.addEventListener("click", action_outpop_next, false);
-    next_btn.addEventListener("keydown", action_outpop_next, false);
-    prev_btn = $("outpop_prev");
-    prev_btn.addEventListener("click", action_outpop_prev, false);
-    prev_btn.addEventListener("keydown", action_outpop_prev, false);
-    cancel_btn = $("outpop_cancel");
-    cancel_btn.addEventListener("click", action_hide_outpop, false);
-    do_btn = $("outpop_do");
-    do_btn.addEventListener("click", action_outpop_submit, false);
-    tab1 = $("outpop_tab_1");
-    tab1.tabIndex = 0;
-    tab1.addEventListener("click", action_outpop_tab, false);
-    tab1.addEventListener("keydown", action_outpop_tab, false);
-    tab2 = $("outpop_tab_2");
-    tab2.tabIndex = 0;
-    tab2.addEventListener("click", action_outpop_tab, false);
-    tab2.addEventListener("keydown", action_outpop_tab, false);
-    tab3 = $("outpop_tab_3");
-    tab3.tabIndex = 0;
-    tab3.addEventListener("click", action_outpop_tab, false);
-    tab3.addEventListener("keydown", action_outpop_tab, false);
-    pnl1 = $("outpop_pnl_1");
-    pnl2 = $("outpop_pnl_2");
-    pnl3 = $("outpop_pnl_3");
-    toggle_class(tab1, "activeTab", true);
-    toggle_class(tab2, "activeTab", false);
-    toggle_class(tab3, "activeTab", false);
-    pnl1.style.display = "block";
-    pnl2.style.display = "none";
-    pnl3.style.display = "none";
-    format_list = $("text_format");
-    format_list.addEventListener("change", action_outpop_format, false);
-    // setup program selection
-    tbl_submit = $("programs");
-    // when not dna, hide the inputs for programs that require dna motifs
-    toggle_class(tbl_submit, "alphabet_dna", dreme_alphabet.has_complement());//TODO FIXME alphabet_dna is a bad name for a field when allowing custom alphabets
-    // add a click listener for the radio buttons
-    inputs = tbl_submit.querySelectorAll("input[type='radio']");
-    for (i = 0; i < inputs.length; i++) {
-      inputs[i].addEventListener("click", action_outpop_program, false);
-    }
-    // ensure that a default program option is selected for DNA and Protein
-    default_prog = document.getElementById(dreme_alphabet.has_complement() ? "submit_tomtom" : "submit_fimo");
-    default_prog.checked = true;
-    action_outpop_program.call(default_prog);
-    // disable reverse-complement when not DNA
-    $("logo_rc_option").disabled = !dreme_alphabet.has_complement(); 
-    // set errorbars on when ssc is on
-    $("logo_ssc").addEventListener("change", action_outpop_ssc, false);
-  }
-  // store the focused element
-  action_hide_outpop.last_active = document.activeElement;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // hide the help popup
-  help_popup();
-  // on first load initilize the popup
-  if (!action_show_outpop.ready) {
-    init();
-    action_show_outpop.ready = true;
-  }
-  update_outpop_motif(ordinal - 1);
-  // display the download popup
-  $("grey_out_page").style.display = "block";
-  $("download").style.display = "block";
-  $("outpop_close").focus();
-}
-
-/*
- * Hide the download popup.
- */
-function action_hide_outpop(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  $("download").style.display = "none";
-  $("grey_out_page").style.display = "none";
-  if (typeof action_hide_outpop.last_active !== "undefined") {
-    action_hide_outpop.last_active.focus();
-  }
-}
-
-/*
- * Show the next motif in the download popup.
- */
-function action_outpop_next(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif + 1);
-}
-
-/*
- * Show the previous motif in the download popup.
- */
-function action_outpop_prev(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif - 1);
-}
-
-/*
- * Highlight the selected row in the program list.
- */
-function action_outpop_program() {
-  "use strict";
-  var table, tr, rows, i;
-  tr = find_parent_tag(this, "TR");
-  table = find_parent_tag(tr, "TABLE");
-  rows = table.querySelectorAll("tr");
-  for (i = 0; i < rows.length; i++) {
-    toggle_class(rows[i], "selected", rows[i] === tr);
-  }
-}
-
-/*
- * Enable error bars when small sample correction is enabled.
- */
-function action_outpop_ssc() {
-  "use strict";
-  $("logo_err").value = $("logo_ssc").value;
-}
-
-/*
- * Submit the motif to the selected program.
- */
-function action_outpop_submit(e) {
-  "use strict";
-  var form, input, program, motifs;
-  // find out which program is selected
-  var radios, i;
-  radios = document.getElementsByName("program");
-  program = "fimo"; // default to fimo, since it works with all alphabet types
-  for (i = 0; i < radios.length; i++) {
-    if (radios[i].checked) program = radios[i].value;
-  }
-
-  motifs = motif_minimal_meme(data.motifs[current_motif]);
-  form = document.createElement("form");
-  form.setAttribute("method", "post");
-  form.setAttribute("action", site_url + "/tools/" + program);
-  
-  input = document.createElement("input");
-  input.setAttribute("type", "hidden");
-  input.setAttribute("name", "motifs_embed");
-  input.setAttribute("value", motifs);
-  form.appendChild(input);
-
-  document.body.appendChild(form);
-  form.submit();
-  document.body.removeChild(form);
-}
-
-/*
- * Download the format text.
- * Wire the link containing the data URI text to a download button so it looks
- * the same as the server submit stuff.
- */
-function action_outpop_download_motif(e) {
-  $("outpop_text_dl").click();
-}
-
-/*
- * Download the motif logo.
- * The EPS format can be calculated locally in Javascript
- */
-function action_outpop_download_logo(e) {
-  "use strict";
-  var pspm, logo, eps;
-  var logo_rc, logo_ssc, logo_width, logo_height;
-  var motif = data.motifs[current_motif];
-  if ($("logo_format").value == "0") { // EPS
-    logo_rc = ($("logo_rc").value == "1");
-    logo_ssc = ($("logo_ssc").value == "1");
-    logo_width = parseFloat($("logo_width").value);
-    if (isNaN(logo_width) || !isFinite(logo_width) || logo_width <= 0) logo_width = null;
-    logo_height = parseFloat($("logo_height").value);
-    if (isNaN(logo_height) || !isFinite(logo_height) || logo_height <= 0) logo_height = null;
-    // create a PSPM from the motif
-    pspm = motif_pspm(motif);
-    if (logo_rc) pspm.reverse_complement(dreme_alphabet);
-    logo = new Logo(dreme_alphabet);
-    logo.add_pspm(pspm, 0);
-    eps = logo.as_eps({"ssc": logo_ssc, "logo_width": logo_width, "logo_height": logo_height});
-    prepare_download(eps, "application/postscript", motif.id + ".eps");
-  } else {
-    $("logo_motifs").value = motif_minimal_meme(motif);
-    $("logo_form").submit();
-  }
-}
-
-/*
- * Change the selected tab in the download popup.
- */
-function action_outpop_tab(e) {
-  "use strict";
-  var tab1, tab2, tab3, pnl1, pnl2, pnl3, do_btn;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  tab1 = $("outpop_tab_1");
-  tab2 = $("outpop_tab_2");
-  tab3 = $("outpop_tab_3");
-  pnl1 = $("outpop_pnl_1");
-  pnl2 = $("outpop_pnl_2");
-  pnl3 = $("outpop_pnl_3");
-  do_btn = $("outpop_do");
-
-  toggle_class(tab1, "activeTab", (this === tab1));
-  toggle_class(tab2, "activeTab", (this === tab2));
-  toggle_class(tab3, "activeTab", (this === tab3));
-  pnl1.style.display = ((this === tab1) ? "block" : "none");
-  pnl2.style.display = ((this === tab2) ? "block" : "none");
-  pnl3.style.display = ((this === tab3) ? "block" : "none");
-  do_btn.value = ((this === tab1) ? "Submit" : "Download");
-  do_btn.removeEventListener("click", action_outpop_submit, false);
-  do_btn.removeEventListener("click", action_outpop_download_logo, false);
-  do_btn.removeEventListener("click", action_outpop_download_motif, false);
-  if (this === tab1) {
-    do_btn.addEventListener("click", action_outpop_submit, false);
-  } else if (this === tab2) {
-    do_btn.addEventListener("click", action_outpop_download_motif, false);
-  } else {
-    do_btn.addEventListener("click", action_outpop_download_logo, false);
-  }
-}
-
-/*
- * Update the text in the download format popup.
- */
-function action_outpop_format() {
-  update_outpop_format(current_motif);
-}
-
-/*
- * Find all text nodes in the given container.
- */
-function text_nodes(container) {
-  var textNodes = [];
-  var stack = [container];
-  // depth first search to maintain ordering when flattened 
-  while (stack.length > 0) {
-    var node = stack.pop();
-    if (node.nodeType == Node.TEXT_NODE) {
-      textNodes.push(node);
-    } else {
-      for (var i = node.childNodes.length-1; i >= 0; i--) {
-        stack.push(node.childNodes[i]);
-      }
-    }
-  }
-  return textNodes;
-}
-
-/*
- * Get the text out of a specific text node.
- */
-function node_text(node) {
-  if (node === undefined) {
-    return '';
-  } else if (node.textContent) {
-    return node.textContent;
-  } else if (node.innerText) {
-    return node.innerText;
-  } else {
-    return '';
-  }
-}
-
-/*
- * Get the text contained within the element.
- */
-function elem_text(elem, separator) {
-  if (separator === undefined) separator = '';
-  return text_nodes(elem).map(node_text).join(separator);
-}
-
-/*
- * Sort all rows in the first table body based on the column of the given element and the comparison function.
- * The sort is not very fast and is intended for small tables only.
- */
-function sort_table(colEle, compare_function) {
-  //find the parent of colEle that is either a td or th
-  var i, j;
-  var cell = colEle;
-  while (true) {
-    if (cell == null) return;
-    if (cell.nodeType == Node.ELEMENT_NODE && 
-        (cell.tagName.toLowerCase() == "td" || cell.tagName.toLowerCase() == "th")) {
-      break;
-    }
-    cell = cell.parentNode;
-  }
-  //find the parent of cell that is a tr
-  var row = cell;
-  while (true) {
-    if (row == null) return;
-    if (row.nodeType == Node.ELEMENT_NODE && row.tagName.toLowerCase() == "tr") {
-      break;
-    }
-    row = row.parentNode;
-  }
-  //find the parent of row that is a table
-  var table = row;
-  while (true) {
-    if (table == null) return;
-    if (table.nodeType == Node.ELEMENT_NODE && table.tagName.toLowerCase() == "table") {
-      break;
-    }
-    table = table.parentNode;
-  }
-  var column_index = cell.cellIndex;
-  // do a bubble sort, because the tables are so small it doesn't matter
-  var change;
-  var trs = table.tBodies[0].getElementsByTagName('tr');
-  var already_sorted = true;
-  var reverse = false;
-  while (true) {
-    do {
-      change = false;
-      for (i = 0; i < trs.length -1; i++) {
-        var v1 = elem_text(trs[i].cells[column_index]);
-        var v2 = elem_text(trs[i+1].cells[column_index]);
-        if (reverse) {
-          var tmp = v1;
-          v1 = v2;
-          v2 = tmp;
-        }
-        if (compare_function(v1, v2) > 0) {
-          exchange(trs[i], trs[i+1], table);
-          change = true;
-          already_sorted = false;
-          trs = table.tBodies[0].getElementsByTagName('tr');
-        }
-      }
-    } while (change);
-    if (reverse) break;// we've sorted twice so exit
-    if (!already_sorted) break;// sort did something so exit
-    // when it's sorted one way already then sort the opposite way
-    reverse = true;
-  }
-  // put arrows on the headers
-  var headers = table.tHead.getElementsByTagName('tr');
-  for (i = 0; i < headers.length; i++) {
-    for (j = 0; j < headers[i].cells.length; j++) {
-      var cell = headers[i].cells[j];
-      var arrows = cell.getElementsByClassName("sort_arrow");
-      var arrow;
-      if (arrows.length == 0) {
-        arrow = document.createElement("span");
-        arrow.className = "sort_arrow";
-        cell.insertBefore(arrow, cell.firstChild);
-      } else {
-        arrow = arrows[0];
-      }
-      arrow.innerHTML = "";
-      if (j == column_index) {
-        arrow.appendChild(document.createTextNode(reverse ? "\u25B2" : "\u25BC"));
-      }
-    }
-  }
-}
-
-/*
- * Swap two rows in a table.
- */
-function exchange(oRowI, oRowJ, oTable) {
-  var i = oRowI.rowIndex;
-  var j = oRowJ.rowIndex;
-   if (i == j+1) {
-    oTable.tBodies[0].insertBefore(oRowI, oRowJ);
-  } if (j == i+1) {
-    oTable.tBodies[0].insertBefore(oRowJ, oRowI);
-  } else {
-    var tmpNode = oTable.tBodies[0].replaceChild(oRowI, oRowJ);
-    if(typeof(oRowI) != "undefined") {
-      oTable.tBodies[0].insertBefore(tmpNode, oRowI);
-    } else {
-      oTable.appendChild(tmpNode);
-    }
-  }
-}
-
-/*
- * Compare two E-values which may be very small.
- */
-function compare_evalues(v1, v2) {
-  var e1 = sci2log(v1);
-  var e2 = sci2log(v2);
-  if (e1 < e2) return -1;
-  else if (e1 > e2) return 1;
-  return 0;
-}
-
-/*
- * Compare two counts.
- */
-function compare_counts(v1, v2) {
-  var re = /(\d+)\s*\/\s*\d+/;
-  var m1 = re.exec(v1);
-  var m2 = re.exec(v2);
-  if (m1 == null && m2 == null) return 0;
-  if (m1 == null) return -1;
-  if (m2 == null) return 1;
-  return parseInt(m2[1]) - parseInt(m1[1]);
-}
-
-/*
- * Compare two sequence words.
- */
-function compare_words(v1, v2) {
-  return v1.localeCompare(v2);
-}
-
-
-</script>
-    <style>
-/* The following is the content of meme.css */
-body { background-color:white; font-size: 12px; font-family: Verdana, Arial, Helvetica, sans-serif;}
-
-div.help {
-  display: inline-block;
-  margin: 0px;
-  padding: 0px;
-  width: 12px;
-  height: 13px;
-  cursor: pointer;
-  background-image: url();
-}
-
-div.help:hover {
-  background-image: url();
-}
-
-p.spaced { line-height: 1.8em;}
-
-span.citation { font-family: "Book Antiqua", "Palatino Linotype", serif; color: #004a4d;}
-
-p.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-td.jump { font-size: 13px; color: #ffffff; background-color: #00666a;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-a.jump { margin: 15px 0 0; font-style: normal; font-variant: small-caps;
-  font-weight: bolder; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.mainh {font-size: 1.5em; font-style: normal; margin: 15px 0 0;
-  font-variant: small-caps; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.line {border-bottom: 1px solid #CCCCCC; font-size: 1.5em; font-style: normal;
-  margin: 15px 0 0; padding-bottom: 3px; font-variant: small-caps;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-h4 {border-bottom: 1px solid #CCCCCC; font-size: 1.2em; font-style: normal;
-  margin: 10px 0 0; padding-bottom: 3px; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h5 {margin: 0px}
-
-a.help { font-size: 9px; font-style: normal; text-transform: uppercase;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-div.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-div.pad1 { margin: 10px 5px;}
-
-div.pad2 { margin: 25px 5px 5px;}
-h2.pad2 { padding: 25px 5px 5px;}
-
-div.pad3 { padding: 5px 0px 10px 30px;}
-
-div.box { border: 2px solid #CCCCCC; padding:10px; overflow: hidden;}
-
-div.bar { border-left: 7px solid #00666a; padding:5px; margin-top:25px; }
-
-div.subsection {margin:25px 0px;}
-
-img {border:0px none;}
-
-th.majorth {text-align:left;}
-th.minorth {font-weight:normal; text-align:left; width:8em; padding: 3px 0px;}
-th.actionth {font-weight:normal; text-align:left;}
-
-.explain h5 {font-size:1em; margin-left: 1em;}
-
-div.doc {margin-left: 2em; margin-bottom: 3em;}
-
-th.trainingset {
-  border-bottom: thin dashed black; 
-  font-weight:normal; 
-  padding:0px 10px;
-}
-div.pop_content {
-  position:absolute;
-  z-index:50;
-  width:300px;
-  padding: 5px;
-  background: #E4ECEC;
-  font-size: 12px;
-  font-family: Arial;
-  border-style: double;
-  border-width: 3px;
-  border-color: #AA2244;
-  display:none;
-}
-
-div.pop_content > *:first-child {
-  margin-top: 0px;
-}
-
-div.pop_content h1, div.pop_content h2, div.pop_content h3, div.pop_content h4, 
-div.pop_content h5, div.pop_content h6, div.pop_content p {
-  margin: 0px;
-}
-
-div.pop_content p + h1, div.pop_content p + h2, div.pop_content p + h3, 
-div.pop_content p + h4, div.pop_content p + h5, div.pop_content p + h6 {
-  margin-top: 5px;
-}
-
-div.pop_content p + p {
-  margin-top: 5px;
-}
-
-div.pop_content > *:last-child {
-  margin-bottom: 0px;
-}
-
-div.pop_content div.pop_close {
-  /* old definition */
-  float:right;
-  bottom: 0;
-}
-
-div.pop_content span.pop_close, div.pop_content span.pop_back {
-  display: inline-block;
-  border: 2px outset #661429;
-  background-color: #CCC;
-  padding-left: 1px;
-  padding-right: 1px;
-  padding-top: 0px;
-  padding-bottom: 0px;
-  cursor: pointer;
-  color: #AA2244; /*#661429;*/
-  font-weight: bold;
-}
-
-div.pop_content span.pop_close:active, div.pop_content span.pop_back:active {
-  border-style: inset;
-}
-
-div.pop_content span.pop_close {
-  float:right;
-  /*border: 2px outset #AA002B;*/
-  /*color: #AA2244;*/
-}
-
-div.pop_content:not(.nested) .nested_only {
-  display: none;
-}
-
-div.pop_back_sec {
-  margin-bottom: 5px;
-}
-
-div.pop_close_sec {
-  margin-top: 5px;
-}
-
-table.hide_advanced tr.advanced {
-  display: none;
-}
-span.show_more {
-  display: none;
-}
-table.hide_advanced span.show_more {
-  display: inline;
-}
-table.hide_advanced span.show_less {
-  display: none;
-}
-
-
-/*****************************************************************************
- * Program logo styling
- ****************************************************************************/
-div.prog_logo {
-  border-bottom: 0.25em solid #0f5f60;
-  height: 4.5em;
-  width: 24em;
-  display:inline-block;
-}
-div.prog_logo img {
-  float:left;
-  width: 4em;
-  border-style: none;
-  margin-right: 0.2em;
-}
-div.prog_logo h1, div.prog_logo h1:hover, div.prog_logo h1:active, div.prog_logo h1:visited {
-  margin:0;
-  padding:0;
-  font-family: Arial, Helvetica,  sans-serif;
-  font-size: 3.2em;
-  line-height: 1em;
-  vertical-align: top;
-  display: block;
-  color: #026666;
-  letter-spacing: -0.06em;
-  text-shadow: 0.04em 0.06em 0.05em #666;
-}
-div.prog_logo h2, div.prog_logo h2:hover, div.prog_logo h2:active, div.prog_logo h2:visited {
-  display: block;
-  margin:0;
-  padding:0;
-  font-family: Helvetica, sans-serif;
-  font-size: 0.9em;
-  line-height: 1em;
-  letter-spacing: -0.06em;
-  color: black;
-}
-
-div.big.prog_logo {
-  font-size: 18px;
-}
-
-</style>
-    <style>
-/* dreme output specific css */
-div.header {
-  position: relative;
-  overflow: hidden;
-  margin-top: 15px;
-  margin-bottom: 5px;
-  margin-right: 3px;
-  margin-left: 3px;
-}
-div.header > h2 {
-  font-size: 1.5em;
-  font-style: normal;
-  margin: 0;
-  font-variant: small-caps; 
-  font-family: Georgia, "Times New Roman", Times, serif;
-}
-div.header > span {
-  position: absolute;
-  right: 0;
-  bottom: 0;
-}
-
-div.template {
-  position: absolute;
-  z-index: 1;
-  left: 0;
-  top: 0;
-  visibility: hidden;
-}
-
-div.sym_btn {
-  display:inline-block;
-  text-decoration: underline;
-  cursor: pointer;
-  font-size: 20px;
-  line-height:20px; 
-  text-align: center;
-  width: 20px;
-  height: 20px;
-  color: blue;
-}
-div.sym_btn:hover {
-  color: white;
-  background-color: blue;
-}
-
-div.sym_btn.positioned {
-  position: absolute;
-  top: 0px;
-}
-
-div.box + div.box {
-  margin-top: 5px;
-}
-
-th.motif_ordinal {
-
-}
-td.motif_ordinal {
-  text-align: right;
-  padding-right: 10px;
-  font-weight: bold;
-  font-size: large;
-}
-th.motif_word {
-  padding-right: 10px;
-}
-td.motif_word {
-  font-size:15px; 
-  font-family: 'Courier New', Courier, monospace;
-  padding-right: 10px;
-}
-th.motif_logo {
-  padding-right: 10px;
-}
-td.motif_logo {
-  padding-right: 10px;
-}
-th.motif_evalue {
-  text-align:right;
-  padding-right: 10px;
-}
-td.motif_evalue {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-th.motif_more {
-  padding: 0 5px;
-}
-td.motif_more {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_submit {
-  padding: 0 5px;
-}
-td.motif_submit {
-  text-align: center;
-  padding: 0 5px;
-}
-th.match_word {
-  padding-right: 10px;
-}
-td.match_word {
-  padding-right: 10px;
-  font-weight: bold;
-  font-size: large; 
-  font-family: 'Courier New', Courier, monospace;
-}
-th.match_evalue, th.match_count {
-  text-align: right;
-  padding-right: 10px;
-}
-td.match_evalue, td.match_count {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-
-div.tabArea {
-  font-size: 80%;
-  font-weight: bold;
-}
-
-.norc div.tabArea {
-  display: none;
-}
-
-span.tab, span.tab:visited {
-  cursor: pointer;
-  color: #888;
-  background-color: #ddd;
-  border: 2px solid #ccc;
-  padding: 2px 1em;
-  text-decoration: none;
-}
-span.tab.middle {
-  border-left-width: 0px;
-}
-div.tabArea.base span.tab {
-  border-top-width: 0px;
-}
-div.tabArea.top span.tab {
-  border-bottom-width: 0px;
-}
-
-span.tab:hover {
-  background-color: #bbb;
-  border-color: #bbb;
-  color: #666;
-}
-span.tab.activeTab, span.tab.activeTab:hover, span.tab.activeTab:visited {
-  background-color: white;
-  color: black;
-  cursor: default;
-}
-div.tabMain {
-  border: 2px solid #ccc;
-  background-color: white;
-  padding: 10px;
-}
-div.tabMain.base {
-  margin-top: 5px;
-  display: inline-block;
-  max-width: 98%;
-}
-
-div.tabMain.top {
-  margin-bottom: 5px;
-}
-
-div.grey_background {
-  position:fixed; 
-  z-index: 8;
-  background-color: #000;
-  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
-  opacity: 0.5;
-  left: 0;
-  top: 0;
-  width: 100%;
-  height: 100%;
-}
-
-div.popup_wrapper {
-  position:fixed; 
-  z-index:9;
-  width:100%; 
-  height:0; 
-  top:50%; 
-  left:0;
-}
-
-div.popup {
-  width: 600px; 
-  z-index:9;
-  margin-left: auto;
-  margin-right: auto;
-  padding: 5px;
-  background-color: #FFF;
-  border-style: double;
-  border-width: 5px;
-  border-color: #00666a;
-  position:relative; 
-}
-div.close {
-  cursor: pointer;
-  border: 1px solid black; 
-  width:15px; 
-  height:15px; 
-  line-height:15px; /* this causes vertical centering */
-  text-align:center; 
-  background-color:#FFF; 
-  color:#000; 
-  font-size:15px;
-  font-family:monospace;
-}
-
-div.close:hover {
-  color:#FFF;
-  background-color:#000; 
-}
-
-div.navnum {
-  width:100%; 
-  height:20px; 
-  line-height:20px; 
-  text-align:center; 
-  font-size:medium;
-}
-
-div.navarrow {
-  font-size: 30px;
-  text-decoration:none;
-  cursor: pointer;
-  -moz-user-select: none;  
-  -webkit-user-select: none;  
-  -ms-user-select: none;
-}
-
-div.navarrow > span.inactive {
-  display: inline;
-}
-div.navarrow > span.active {
-  display: none;
-}
-
-div.navarrow:hover > span.active {
-  display: inline;
-}
-div.navarrow:hover > span.inactive {
-  display: none;
-}
-
-table.programs {
-  width: 100%;
-}
-
-table.programs tr {
-  background-color: #EFE;
-}
-
-table.programs tr.selected {
-  background-color: #262;
-  color: #FFF;
-}
-
-table.programs tr.dna_only {
-  display: none;
-}
-
-table.programs.alphabet_dna tr.dna_only {
-  display: table-row;
-}
-
-table.inputs {
-  margin-top: 20px;
-  border-collapse:collapse;
-}
-table.inputs * td, table.inputs * th {
-  padding-left: 15px;
-  padding-right: 15px;
-  padding-top: 1px;
-  padding-bottom: 1px;
-}
-
-/* program settings */
-span.strand_none, span.strand_given, span.strand_both {
-  display: none;
-}
-td.none span.strand_none, td.given span.strand_given, td.both span.strand_both {
-  display: inline;
-}
-
-/* show the expanded motif only when the collapsed one is hidden */
-tbody *.less, tbody.collapsed *.more {
-  display: none;
-}
-
-tbody.collapsed *.less {
-  display: inline;
-}
-
 </style>
   </head>
   <body data-scrollpad="true">
     <!--  -->
     <div id="grey_out_page" class="grey_background" style="display:none;">
-    </div>
-
-    <!-- Help popups -->
-    <div class="pop_content" id="pop_">
-      <p>Help poup.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_motifs_word">
-      <p>
         The name of the motif uses the IUPAC codes for nucleotides which has 
         a different letter to represent each of the 15 possible combinations.
-      </p>
-      <p>
         The name is itself a representation of the motif though the position
-        weight matrix is not directly equalivant as it is generated from the
+        weight matrix is not directly equivalent as it is generated from the
         sites found that matched the letters given in the name.
-      </p>
-      <p>
-        <a id="doc_alphabets_url" href="#">
-        Read more about the MEME suite's use of the IUPAC alphabets.
-        </a>
-        <script>$("doc_alphabets_url").href = site_url + "/doc/alphabets.html";</script>
-      </p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_logo">
       <p>The logo of the motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_rc_logo">
       <p>The logo of the reverse complement motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_evalue">
       <p>The E-value is the enrichment p-value times the number of candidate 
         motifs tested.</p>
       <p>The enrichment p-value is calculated using Fisher's Exact Test for 
         enrichment of the motif in the positive sequences.</p>
       <p>Note that the counts used in Fisher's Exact Test are made after 
         erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motifs_uevalue">
       <p>The E-value of the motif calculated without erasing the sites of 
         previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_more">
       <p>Show more information on the motif.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_submit_dl">
       <p>Submit your motif to another MEME Suite program or download your motif.</p>
       <h5>Supported Programs</h5>
-      <dl>
         <dt>Tomtom</dt>
         <dd>Tomtom is a tool for searching for similar known motifs. 
-          </dd>
         <dt>MAST</dt>
         <dd>MAST is a tool for searching biological sequence databases for 
           sequences that contain one or more of a group of known motifs.
-          </dd>
         <dt>FIMO</dt>
         <dd>FIMO is a tool for searching biological sequence databases for 
           sequences that contain one or more known motifs.
-          </dd>
-        <dt>GOMO</dt>
-        <dd>GOMO is a tool for identifying possible roles (Gene Ontology 
+        <dt>GOMo</dt>
+        <dd>GOMo is a tool for identifying possible roles (Gene Ontology 
           terms) for DNA binding motifs.
-          </dd>
         <dt>SpaMo</dt>
         <dd>SpaMo is a tool for inferring possible transcription factor
           complexes by finding motifs with enriched spacings.
-          </dd>
-      </dl>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_positives">
-      <p># positive sequences matching the motif / # positive sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_negatives">
-      <p># negative sequences matching the motif / # negative sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_pvalue">
-      <p>The p-value of Fisher's Exact Test for enrichment of the motif in 
-        the positive sequences.</p>
-      <p>Note that the counts used in Fisher's Exact Test are made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_evalue">
-      <p>The E-value is the motif p-value times the number of candidate motifs 
-        tested.</p>
-      <p>Note that the p-value was calculated with counts made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_uevalue">
-      <p>The E-value of the motif calculated without erasing the sites of 
-        previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_word">
-      <p>All words matching the motif whose uncorrected p-value is less than
-      <span id="help_add_pv_thresh"></span>.</p>
-      <script>$("help_add_pv_thresh").innerHTML = data.options.add_pv_thresh;</script>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_pos">
-      <p># positive sequences with matches to the word / # positive sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_neg">
-      <p># negative sequences with matches to the word / # negative sequences.</p>
-      <p>Note these counts are made after erasing sites that match previously
-        found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_pval">
-      <p>The p-value of Fisher's Exact Test for enrichment of the word in 
-        the positive sequences.</p>
-      <p>Note that the counts used in Fisher's Exact Test are made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_match_eval">
-      <p>The word p-value times the number of candidates tested.</p>
-      <p>Note that the p-value was calculated with counts made after 
-        erasing sites that match previously found motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_source">
-      <p>The sequence file used by DREME to find the motifs.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_alph">
-      <p>The alphabet of the sequences.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_count">
-      <p>The count of the sequences.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_name">
-      <p>The name of the alphabet symbol.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_control">
-      <p>The frequency of the alphabet symbol in the control dataset.</p>
-      <div class="pop_close">[<a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <!-- templates -->
-
-    <div class="template box expanded_motif" id="tmpl_motif_expanded">
-      <div>
-        <span class="tvar_logo"></span>
-        <span class="tvar_rclogo"></span>
-      </div>
-      <h4>Details</h4>
-      <table class="details">
-        <thead>
-          <tr>
-            <th class="match_count">Positives <div class="help" data-topic="pop_motif_positives"></div></th>
-            <th class="match_count">Negatives <div class="help" data-topic="pop_motif_negatives"></div></th>
-            <th class="match_evalue">P-value <div class="help" data-topic="pop_motif_pvalue"></div></th>
-            <th class="match_evalue">E-value <div class="help" data-topic="pop_motif_evalue"></div></th>
-            <th class="match_evalue">Unerased E-value <div class="help" data-topic="pop_motif_uevalue"></div></th>
-          </tr>
-        </thead>
-        <tbody>
-          <tr>
-            <td class="match_count">
-              <span class="tvar_p"></span> / <span class="tvar_p_total"></span>
-            </td>
-            <td class="match_count">
-              <span class="tvar_n"></span> / <span class="tvar_n_total"></span>
-            </td>
-            <td class="tvar_pvalue match_evalue"></td>
-            <td class="tvar_evalue match_evalue"></td>
-            <td class="tvar_uevalue match_evalue"></td>
-          </tr>
-        </tbody>
-      </table>
-      <h4>Enriched Matching Words</h4>
-      <div class="tvar_words"></div>
-    </div>
-
-
-    <div class="popup_wrapper">
-      <div class="popup" style="display:none; top: -150px;" id="download">
-        <div>
-          <div style="float:right; ">
-            <div id="outpop_close" class="close" tabindex="0">x</div>
-          </div>
-          <h2 class="mainh" style="margin:0; padding:0;">Submit or Download</h2>
-          <div style="clear:both"></div>
-        </div>
-          <div style="height:100px">
-            <div style="float:right; width: 30px;">
-              <div id="outpop_prev" class="navarrow" tabindex="0">
-                <span class="inactive">&#8679;</span><span class="active">&#11014;</span>
-              </div>
-              <div id="outpop_num" class="navnum"></div>
-              <div id="outpop_next" class="navarrow" tabindex="0">
-                <span class="inactive">&#8681;</span><span class="active">&#11015;</span>
-              </div>
-            </div>
-            <div id="logo_box" style="height: 100px; margin-right: 40px;">
-              <canvas id="outpop_logo" height="100" width="250"></canvas>
-              <canvas id="outpop_logo_rc" height="100" width="250"></canvas>
-            </div>
-          </div>
-          <div>
-            <!-- tabs start -->
-            <div class="tabArea top">
-              <span id="outpop_tab_1" class="tab">Submit Motif</span><span
-                id="outpop_tab_2" class="tab middle">Download Motif</span><span 
-                id="outpop_tab_3" class="tab middle">Download Logo</span>
-            </div>
-            <div class="tabMain top">
-              <!-- Submit to another program -->
-              <div id="outpop_pnl_1">
-                <h4 class="compact">Submit to program</h4>
-                <table id="programs" class="programs">
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="tomtom" id="submit_tomtom"></td>
-                    <td><label for="submit_tomtom">Tomtom</label></td>
-                    <td><label for="submit_tomtom">Find similar motifs in
-                        published libraries or a library you supply.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="fimo" id="submit_fimo"></td>
-                    <td><label for="submit_fimo">FIMO</label></td>
-                    <td><label for="submit_fimo">Find motif occurrences in
-                        sequence data.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="mast" id="submit_mast"></td>
-                    <td><label for="submit_mast">MAST</label></td>
-                    <td><label for="submit_mast">Rank sequences by affinity to
-                        groups of motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="gomo" id="submit_gomo"></td>
-                    <td><label for="submit_gomo">GOMo</label></td>
-                    <td><label for="submit_gomo">Identify possible roles (Gene
-                        Ontology terms) for motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="spamo" id="submit_spamo"></td>
-                    <td><label for="submit_spamo">SpaMo</label></td>
-                    <td><label for="submit_spamo">Find other motifs that are
-                        enriched at specific close spacings which might imply the existance of a complex.</label></td>
-                  </tr>
-                </table>
-              </div>
-              <!-- download text format  -->
-              <div id="outpop_pnl_2">
-                <div>
-                  <label for="text_format">Format:</label>
-                  <select id="text_format">
-                    <option value="0">Count Matrix</option>
-                    <option value="1">Probability Matrix</option>
-                    <option value="2">Minimal MEME</option>
-                  </select>
-                </div>
-                <textarea id="outpop_text" name="content"
-                  style="width:99%; white-space: pre; word-wrap: normal; overflow-x: scroll;" 
-                  rows="8" readonly="readonly" wrap="off"></textarea>
-                <a id="outpop_text_dl" download="meme.txt" href=""></a>
-              </div>
-              <!-- download logo format -->
-              <div id="outpop_pnl_3">
-                <form id="logo_form" method="post" action="">
-                  <script>$("logo_form").action = site_url + "/utilities/generate_logo";</script>
-                  <input type="hidden" name="program" value="DREME"/>
-                  <input type="hidden" id="logo_motifs" name="motifs" value=""/>
-                  <table>
-                    <tr>
-                      <td><label for="logo_format">Format:</label></td>
-                      <td>
-                        <select id="logo_format" name="png">
-                          <option value="1">PNG (for web)</option>
-                          <option value="0">EPS (for publication)</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_rc">Orientation:</label></td>
-                      <td>
-                        <select id="logo_rc" name="rc1">
-                          <option value="0">Normal</option>
-                          <option value="1" id="logo_rc_option">Reverse Complement</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_ssc">Small Sample Correction:</label></td>
-                      <td>
-                        <input type="hidden" id="logo_err" name="errbars" value="0"/>
-                        <select id="logo_ssc" name="ssc">
-                          <option value="0">Off</option>
-                          <option value="1">On</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_width">Width:</label></td>
-                      <td>
-                        <input type="text" id="logo_width" size="4" placeholder="default" name="width"/>&nbsp;cm
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_height">Height:</label></td>
-                      <td>
-                        <input type="text" id="logo_height" size="4" placeholder="default" name="height"/>&nbsp;cm
-                      </td>
-                    </tr>
-                  </table>
-                </form>
-              </div>
-              <!-- Buttons -->
-              <div>
-                <div style="float:left;">
-                  <input type="button" id="outpop_do" value="Submit" />
-                </div>
-                <div style="float:right;">
-                  <input id="outpop_cancel" type="button" value="Cancel" />
-                </div>
-                <div style="clear:both;"></div>
-              </div>
-            </div>
-        </div>
-      </div>
-    </div>
-
-
-
     <!-- Page starts here -->
-    <div id="top" class="pad1">
-      <div class="prog_logo big">
-        <img src="" alt="DREME Logo"/>
         <h1>DREME</h1>
         <h2>Discriminative Regular Expression Motif Elicitation</h2>
-      </div>
-      <p class="spaced">
-        For further information on how to interpret these results or to get a 
-        copy of the MEME software please access 
-        <a href="http://meme.nbcr.net/">http://meme.nbcr.net</a>. 
-      </p>
-      <p>
+        For further information on how to interpret these results please access
+        To get a copy of the MEME software please access 
         If you use DREME in your research please cite the following paper:<br />
-        <span class="citation">
           Timothy L. Bailey, "DREME: Motif discovery in transcription factor ChIP-seq data", <i>Bioinformatics</i>, <b>27</b>(12):1653-1659, 2011.
-          <a href="http://bioinformatics.oxfordjournals.org/content/27/12/1653">[full text]</a>
-        </span>
-      </p>
-    </div>
-    <!-- navigation -->
-    <div class="pad2">
-      <a class="jump" href="#motifs_sec">Discovered Motifs</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#inputs_sec">Inputs &amp; Settings</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#info_sec">Program information</a>
-    </div>
-    <!-- alert the user when their browser is not up to the task -->
-    <noscript><h1 style="color:red">Javascript is required to view these results!</h1></noscript>
-    <h1 id="html5_warning" style="color:red; display:none;">Your browser does not support canvas!</h1>
-    <script>
-      if (!window.HTMLCanvasElement) $("html5_warning").style.display = "block";
-    </script>
-    <!-- description -->
-    <div id="description_section" style="display:none">
-      <div id="description" class="header">
-        <h2>Description</h2>
-      </div>
-      <div id="description_text" class="box">
-      </div>
-    </div>
-    <script>
-      if (data.description) {
-        $("description_text").innerHTML = "";
-        $("description_text").appendChild(make_description(data.description));
-        $("description_section").style.display = "block";
-      }
-    </script>
-    <!-- motifs -->
-    <div id="motifs_sec" class="header">
-      <h2>Discovered Motifs</h2>
-      <span><a href="#inputs_sec">Next</a>&nbsp;<a href="#">Top</a></span>
-    </div>
-    <div id="motifs" class="box">
-      <p>No motifs were discovered!</p>
-    </div>
-    <script>make_motifs();</script>
-    <!-- inputs and settings -->
-    <div id="inputs_sec" class="header">
-      <h2>Inputs &amp; Settings</h2>
-      <span><a href="#motifs_sec">Previous</a>&nbsp;<a href="#info_sec">Next</a>&nbsp;<a href="#">Top</a></span>
-    </div>
-    <div class="box">
-      <h4>Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th>Alphabet <div class="help" data-topic="pop_seq_alph"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_seq_source"></td>
-          <td id="ins_seq_alphabet"></td>
-          <td id="ins_seq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.sequence_db;
-        $("ins_seq_source").innerHTML = db.file;
-        $("ins_seq_alphabet").innerHTML = dreme_alphabet.get_alphabet_name();
-        $("ins_seq_count").innerHTML = db.count;
-      }
-      </script>
-      <h4>Control Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_cseq_source"></td>
-          <td id="ins_cseq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.control_db;
-        if (db.from == "shuffled") {
-          $("ins_cseq_source").innerHTML = "Shuffled Sequences";
-        } else {
-          $("ins_cseq_source").innerHTML = db.file;
-        }
-        $("ins_cseq_count").innerHTML = db.count;
-      }
-      </script>
-      <h4>Background</h4>
-      <span id="alpha_bg"></span>
-      <script>
-      {
-        $("alpha_bg").appendChild(make_alpha_bg(dreme_alphabet, data.control_db.freqs));
-      }
-      </script>
-      <h4>Other Settings</h4>
-      <table id="tbl_settings" class="inputs hide_advanced">
-        <tr>
-          <th>Strand Handling</th>
-          <td id="opt_strand">
-            <span class="strand_none">This alphabet only has one strand</span>
-            <span class="strand_given">Only the given strand is processed</span>
-            <span class="strand_both">Both the given and reverse complement strands are processed</span>
-          </td>
-        </tr>
-        <tr><th># REs to Generalize</th><td id="opt_ngen"></td></tr>
-        <tr><th>Shuffle Seed</th><td id="opt_seed"></td></tr>
-        <tr><th>E-value Threshold</th><td id="opt_stop_evalue"></td></tr>
-        <tr><th>Max Motif Count</th><td id="opt_stop_count"></td></tr>
-        <tr><th>Max Run Time</th><td id="opt_stop_time"></td></tr>
-      </table>
-      <script>
-      {
-        $("opt_strand").className = (dreme_alphabet.has_complement() ? (data.options.revcomp ? "both" : "given") : "none");
-        $("opt_ngen").innerHTML = data.options.ngen;
-        $("opt_seed").innerHTML = data.options.seed;
-        $("opt_stop_evalue").innerHTML = data.options.stop.evalue;
-        $("opt_stop_count").innerHTML = (typeof data.options.stop.count == "number" ? data.options.stop.count : "No maximum motif count.");
-        $("opt_stop_time").innerHTML = (typeof data.options.stop.time == "number" ? data.options.stop.time + " seconds." : "No maximum running time.");
-      }
-      </script>
-    </div>
-    <!-- list information on this program -->
-    <div id="info_sec" class="bar" style="position:relative">
-      <div style="position: absolute; right: 0;"><a href="#inputs_sec">Previous</a> <a href="#">Top</a></div>
-      <div class="subsection">
-        <h5 id="version">DREME version</h5>
-        <span id="ins_version"></span> 
-        (Release date: <span id="ins_release"></span>)<br>
-      </div>
-      <script>
-        $("ins_version").innerHTML = data["version"];
-        $("ins_release").innerHTML = data["release"];
-      </script>
-      <div class="subsection">
-        <h5 id="reference">Reference</h5>
-        <span class="citation">
-          Timothy L. Bailey, "DREME: Motif discovery in transcription factor ChIP-seq data", <i>Bioinformatics</i>, <b>27</b>(12):1653-1659, 2011.
-          <a href="http://bioinformatics.oxfordjournals.org/content/27/12/1653">[full text]</a>
-        </span>
-      </div>
-      <div class="subsection">
-        <h5 id="command">Command line</h5>
-        <textarea id="cmd" rows="3" style="width:100%;" readonly="readonly">
-        </textarea>
-        <script>$("cmd").value = data["cmd"].join(" ");</script>
-      </div>
-    </div>
-    
   </body>
 </html>
--- a/test-data/dreme_output_test2.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test2.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,12 +1,7 @@
-# DREME 4.12.0
-#     command: dreme -o ./dreme_test2_out -p dreme_test_sites.fa -norc -rna -s 1 -e 1e-05 -g 100 -mink 4 -maxk 10
-#   positives: 1000 from dreme_test_sites.fa (Thu Apr 26 15:09:03 CEST 2018)
+# DREME 5.0.5
 #   negatives: 1000 from shuffled positives
-#        host: ThinkPad-T450s
-#        when: Thu May 03 13:22:11 CEST 2018
 
-MEME version 4.12.0
-
+MEME version 5.0.5
 ALPHABET "RNA" RNA-LIKE
 A "Adenine" CC0000
 C "Cytosine" 0000CC
@@ -27,20 +22,15 @@
 K "Keto" = GU
 T = U
 END ALPHABET
-
 Background letter frequencies (from dataset):
 A 0.221 C 0.245 G 0.221 U 0.312
-
-
 MOTIF UUYUCY DREME-1
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST      UUYUCY        387        210   2.6e-018   3.3e-013
 #           UUUUCC        147         75   1.8e-007   2.2e-002
 #           UUUUCU        155         94   2.2e-005   2.8e+000
 #           UUCUCU         94         51   1.3e-004   1.7e+001
 #           UUCUCC         75         42   1.1e-003   1.4e+002
-
 letter-probability matrix: alength= 4 w= 6 nsites= 459 E= 3.3e-013
 0.000000 0.000000 0.000000 1.000000
 0.000000 0.000000 0.000000 1.000000
@@ -48,21 +38,14 @@
 0.000000 0.000000 0.000000 1.000000
 0.000000 1.000000 0.000000 0.000000
 0.000000 0.474946 0.000000 0.525054
-
-
 MOTIF YAGG DREME-2
-
 #             Word        Pos        Neg    P-value    E-value
 # BEST        YAGG        600        416   1.1e-016   1.4e-011
 #             CAGG        441        304   1.5e-010   1.8e-005
 #             UAGG        232        165   1.1e-004   1.3e+001
-
 letter-probability matrix: alength= 4 w= 4 nsites= 793 E= 1.4e-011
 0.000000 0.692308 0.000000 0.307692
 1.000000 0.000000 0.000000 0.000000
 0.000000 0.000000 1.000000 0.000000
 0.000000 0.000000 1.000000 0.000000
-
-
 # Stopping reason: E-value threshold exceeded
-#    Running time: 15.97 seconds
--- a/test-data/dreme_output_test2.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/dreme_output_test2.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,7 +1,5 @@
-<dreme version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
+<dreme version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
   <model>
-    <command_line>dreme -o ./dreme_test2_out -p dreme_test_sites.fa -norc -rna -s 1 -e 1e-05 -g 100 -mink 4 -maxk 10</command_line>
-    <positives name="dreme test sites" count="1000" file="dreme_test_sites.fa" last_mod_date="Thu Apr 26 15:09:03 CEST 2018" />
     <negatives name="shuffled positive sequences" count="1000" from="shuffled"/>
     <alphabet name="RNA" like="rna">
       <letter id="A" symbol="A" name="Adenine" colour="CC0000"/>
@@ -26,8 +24,6 @@
     <ngen>100</ngen>
     <add_pv_thresh>0.01</add_pv_thresh>
     <seed>1</seed>
-    <host>ThinkPad-T450s</host>
-    <when>Thu May 03 13:22:11 CEST 2018</when>
   </model>
   <motifs>
     <motif id="m01" alt="DREME-1" seq="UUYUCY" length="6" nsites="459" p="387" n="210" pvalue="2.6e-018" evalue="3.3e-013" unerased_evalue="3.3e-013">
@@ -51,5 +47,4 @@
       <match seq="UAGG" p="232" n="165" pvalue="1.1e-004" evalue="1.3e+001"/>
     </motif>
   </motifs>
-  <run_time cpu="15.97" real="15.97" stop="evalue"/>
 </dreme>
--- a/test-data/fimo_output_test1.gff	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test1.gff	Wed Dec 11 18:05:15 2019 -0500
@@ -1,9 +1,9 @@
 ##gff-version 3
-chrM	fimo	nucleotide_motif	2299	2306	46.6	-	.	Name=TACTAAYM_chrM-;Alias=MEME-1;ID=TACTAAYM-MEME-1-1-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
-chrM	fimo	nucleotide_motif	6529	6536	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-2-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
-chrM	fimo	nucleotide_motif	7741	7748	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-3-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
-chrM	fimo	nucleotide_motif	13656	13663	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-4-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
-chrM	fimo	nucleotide_motif	13740	13747	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-5-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
+chrM	fimo	nucleotide_motif	6529	6536	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-1-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
+chrM	fimo	nucleotide_motif	7741	7748	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-2-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
+chrM	fimo	nucleotide_motif	13656	13663	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-3-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
+chrM	fimo	nucleotide_motif	13740	13747	46.6	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-4-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
+chrM	fimo	nucleotide_motif	2299	2306	46.6	-	.	Name=TACTAAYM_chrM-;Alias=MEME-1;ID=TACTAAYM-MEME-1-5-chrM;pvalue=2.18e-05;qvalue= 0.142;sequence=TACTAACA;
 chrM	fimo	nucleotide_motif	861	868	 44	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-6-chrM;pvalue=3.96e-05;qvalue= 0.185;sequence=TACTAACC;
 chrM	fimo	nucleotide_motif	9346	9353	 44	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-7-chrM;pvalue=3.96e-05;qvalue= 0.185;sequence=TACTAACC;
 chrM	fimo	nucleotide_motif	3767	3774	41.8	+	.	Name=TACTAAYM_chrM+;Alias=MEME-1;ID=TACTAAYM-MEME-1-8-chrM;pvalue=6.62e-05;qvalue= 0.216;sequence=TACTAATA;
--- a/test-data/fimo_output_test1.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test1.html	Wed Dec 11 18:05:15 2019 -0500
@@ -7,9 +7,8 @@
 <style type="text/css">
 td.left {text-align: left;}
 td.right {text-align: right; padding-right: 1cm;}
-</style>
 </head>
-<body bgcolor="#D5F0FF">
+<body color="#000000">
 <a name="top_buttons"></a>
 <hr>
 <table summary="buttons" align="left" cellspacing="0">
@@ -17,98 +16,36 @@
 <td bgcolor="#00FFFF"><a href="#database_and_motifs"><b>Database and Motifs</b></a></td>
 <td bgcolor="#DDFFDD"><a href="#sec_i"><b>High-scoring Motif Occurences</b></a></td>
 <td bgcolor="#DDDDFF"><a href="#debugging_information"><b>Debugging Information</b></a></td>
+<td bgcolor="#FFDD00"><a href="fimo.tsv""><b>Results in TSV Format</b></a></td>
+<td bgcolor="#FFDDFF"><a href="fimo.gff""><b>Results in GFF3 Format</b></a></td>
 </tr>
 </table>
-<br/>
-<br/>
-<hr/>
 <center><big><b>FIMO - Motif search tool</b></big></center>
-<hr>
-<p>
-FIMO version 4.12.0, (Release date: Tue Jun 27 16:22:50 2017 -0700)
-</p>
-<p>
-For further information on how to interpret these results
-or to get a copy of the FIMO software please access
-<a href="http://meme.nbcr.net">http://meme.nbcr.net</a></p>
+FIMO version 5.0.5, (Release date: Mon Mar 18 20:12:19 2019 -0700)
+For further information on how to interpret these results please access <a href="http://meme-suite.org/doc/fimo-output-format.html">http://meme-suite.org/doc/fimo-output-format.html</a>.<br>
+To get a copy of the FIMO software please access <a href="http://meme-suite.org">http://meme-suite.org</a>
 <p>If you use FIMO in your research, please cite the following paper:<br>
 Charles E. Grant, Timothy L. Bailey, and William Stafford Noble,
 "FIMO: Scanning for occurrences of a given motif",
 <i>Bioinformatics</i>, <b>27</b>(7):1017-1018, 2011.
-<a href="http://bioinformatics.oxfordjournals.org/content/27/7/1017">[full text]</a></p>
-<hr>
 <center><big><b><a name="database_and_motifs">DATABASE AND MOTIFS</a></b></big></center>
-<hr>
-<div style="padding-left: 0.75in; line-height: 1em; font-family: monospace;">
-<p>
-  DATABASE hsa_chrM.fa
-  <br />
   Database contains 1 sequences, 16569 residues
-</p>
-<p>
-  MOTIFS meme_fimo_input_1.xml (DNA)
-  <table>
-    <thead>
-      <tr>
-        <th style="border-bottom: 1px dashed;">MOTIF</th>
-        <th style="border-bottom: 1px dashed; padding-left: 1em;">WIDTH</th>
-        <th style="border-bottom: 1px dashed; padding-left: 1em;text-align:left;" >
          BEST POSSIBLE MATCH
-        </th>
-      </tr>
-    </thead>
-    <tbody>
-      <tr>
-        <td style="text-align:right;">TACTAAYM</td>
-        <td style="text-align:right;padding-left: 1em;">8</td>
-        <td style="text-align:left;padding-left: 1em;">TACTAACA</td>
-       </tr>
-    </tbody>
-  </table>
-</p>
-<p>
 Random model letter frequencies (--nrdb--):
-<br/>
-
 A 0.275 C 0.225 G 0.225 T 0.275 </p>
-</div>
-<hr>
 <center><big><b><a name="sec_i">SECTION I: HIGH-SCORING MOTIF OCCURENCES</a></b></big></center>
-<hr>
-<ul>
-<li>
 There were 11 motif occurences with a p-value less than 0.0001.
-
 The full set of motif occurences can be seen in the
-tab-delimited plain text output file
-<a href="fimo.txt">fimo.txt</a>, 
-the GFF file 
-<a href="fimo.gff">fimo.gff</a> 
-which may be suitable for uploading to the 
-<a href="http://genome.ucsc.edu/cgi-bin/hgTables">UCSC Genome Table Browser</a>
-(assuming the FASTA input sequences included genomic coordinates in UCSC or Galaxy format),
-or the XML file 
-<a href="fimo.xml">fimo.xml</a>.
-</li>
-<li>
-The p-value of a motif occurrence is defined as the
+TSV (tab-delimited values) output file
+The <i>p</i>-value of a motif occurrence is defined as the
 probability of a random sequence of the same length as the motif
 matching that position of the sequence with as good or better a score.
-</li>
-<li>
 The score for the match of a position in a sequence to a motif
 is computed by summing the appropriate entries from each column of
 the position-dependent scoring matrix that represents the motif.
-</li>
-<li>
 The q-value of a motif occurrence is defined as the
 false discovery rate if the occurrence is accepted as significant.
-</li>
-<li>The table is sorted by increasing p-value.</li>
-</ul>
-<table border="1">
-<thead>
-<tr>
+<li>The table is sorted by increasing <i>p</i>-value.</li>
 <th>Motif ID</th>
 <th>Alt ID</th>
 <th>Sequence Name</th>
@@ -118,21 +55,6 @@
 <th>p-value</th>
 <th>q-value</th>
 <th>Matched Sequence</th>
-</tr>
-</thead>
-<tbody>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2299</td>
-      <td style="text-align:left;">2306</td>
-      <td style="text-align:left;">2.18e-05</td>
-      <td style="text-align:left;">0.142</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACA</td>
-   </tr>
-    <tr>
       <td style="text-align:left;">TACTAAYM</td>
       <td style="text-align:left;">MEME-1</td>
       <td style="text-align:left;">chrM</td>
@@ -142,159 +64,10 @@
       <td style="text-align:left;">2.18e-05</td>
       <td style="text-align:left;">0.142</td>
       <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7741</td>
-      <td style="text-align:left;">7748</td>
-      <td style="text-align:left;">2.18e-05</td>
-      <td style="text-align:left;">0.142</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13656</td>
-      <td style="text-align:left;">13663</td>
-      <td style="text-align:left;">2.18e-05</td>
-      <td style="text-align:left;">0.142</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13740</td>
-      <td style="text-align:left;">13747</td>
-      <td style="text-align:left;">2.18e-05</td>
-      <td style="text-align:left;">0.142</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">861</td>
-      <td style="text-align:left;">868</td>
-      <td style="text-align:left;">3.96e-05</td>
-      <td style="text-align:left;">0.185</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9346</td>
-      <td style="text-align:left;">9353</td>
-      <td style="text-align:left;">3.96e-05</td>
-      <td style="text-align:left;">0.185</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3767</td>
-      <td style="text-align:left;">3774</td>
-      <td style="text-align:left;">6.62e-05</td>
-      <td style="text-align:left;">0.216</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5497</td>
-      <td style="text-align:left;">5504</td>
-      <td style="text-align:left;">6.62e-05</td>
-      <td style="text-align:left;">0.216</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10105</td>
-      <td style="text-align:left;">10112</td>
-      <td style="text-align:left;">6.62e-05</td>
-      <td style="text-align:left;">0.216</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">TACTAAYM</td>
-      <td style="text-align:left;">MEME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10959</td>
-      <td style="text-align:left;">10966</td>
-      <td style="text-align:left;">8.79e-05</td>
-      <td style="text-align:left;">0.261</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TACTAACT</td>
-   </tr>
-</tbody>
 </table>
-
 <hr>
 <center><big><b><a name="debugging_information">DEBUGGING INFORMATION</a></b></big></center>
-<hr>
-<p>
-Command line:
-</p>
-<pre>
-fimo -oc fimo_test1_out meme_fimo_input_1.xml hsa_chrM.fa
-</pre>
-<p>
-Settings:
-</p>
-<pre>
-<table>
-  <tr>
-    <td style="padding-right: 2em">output_directory = fimo_test1_out</td>
-    <td style="padding-left: 5em; padding-right: 2em">MEME file name = meme_fimo_input_1.xml</td>
-    <td style="padding-left: 5em; padding-right: 2em">sequence file name = hsa_chrM.fa</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">background file name = --nrdb--</td>
-    <td style="padding-left: 5em; padding-right: 2em">alphabet = DNA</td>
-    <td style="padding-left: 5em; padding-right: 2em">max stored scores = 100000</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">allow clobber = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">compute q-values = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">parse genomic coord. = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">text only = false</td>
-    <td style="padding-left: 5em; padding-right: 2em">scan both strands = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">max strand = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">threshold type = p-value</td>
-    <td style="padding-left: 5em; padding-right: 2em">output theshold = 0.0001</td>
-    <td style="padding-left: 5em; padding-right: 2em">pseudocount = 0.1</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">alpha = 1</td>
-    <td style="padding-left: 5em; padding-right: 2em">verbosity = 2</td>
-    <td style="padding-left: 5em; padding-right: 2em"></td>
-  </tr>
-
-</table>
-</pre>
-<p>
 This information can be useful in the event you wish to report a
 problem with the FIMO software.
-</p>
-<hr>
-<span style="background-color: #DDDDFF"><a href="#top_buttons"><b>Go to top</b></a></span>
 </body>
 </html>
--- a/test-data/fimo_output_test1.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test1.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,9 +1,9 @@
-# motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
-TACTAAYM	MEME-1	chrM	2299	2306	-	12.9701	2.18e-05	0.142	TACTAACA
+motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
 TACTAAYM	MEME-1	chrM	6529	6536	+	12.9701	2.18e-05	0.142	TACTAACA
 TACTAAYM	MEME-1	chrM	7741	7748	+	12.9701	2.18e-05	0.142	TACTAACA
 TACTAAYM	MEME-1	chrM	13656	13663	+	12.9701	2.18e-05	0.142	TACTAACA
 TACTAAYM	MEME-1	chrM	13740	13747	+	12.9701	2.18e-05	0.142	TACTAACA
+TACTAAYM	MEME-1	chrM	2299	2306	-	12.9701	2.18e-05	0.142	TACTAACA
 TACTAAYM	MEME-1	chrM	861	868	+	12.2836	3.96e-05	0.185	TACTAACC
 TACTAAYM	MEME-1	chrM	9346	9353	+	12.2836	3.96e-05	0.185	TACTAACC
 TACTAAYM	MEME-1	chrM	3767	3774	+	11.7164	6.62e-05	0.216	TACTAATA
--- a/test-data/fimo_output_test1.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test1.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,16 +1,12 @@
 <?xml version="1.0" encoding="UTF-8" standalone="no"?>
 <!-- Begin document body -->
-<fimo version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
+<fimo version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation=  xmlns:fimo="http://noble.gs.washington.edu/schema/fimo"
 >
-<command-line>fimo -oc fimo_test1_out meme_fimo_input_1.xml hsa_chrM.fa</command-line>
 <settings>
-<setting name="output directory">fimo_test1_out</setting>
-<setting name="MEME file name">meme_fimo_input_1.xml</setting>
-<setting name="sequence file name">hsa_chrM.fa</setting>
 <setting name="background file name">--nrdb--</setting>
-<setting name="allow clobber">true</setting>
+<setting name="allow clobber">false</setting>
 <setting name="compute q-values">true</setting>
 <setting name="parse genomic coord.">false</setting>
 <setting name="text only">false</setting>
--- a/test-data/fimo_output_test2.gff	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test2.gff	Wed Dec 11 18:05:15 2019 -0500
@@ -1,12 +1,12 @@
 ##gff-version 3
-chrM	fimo	nucleotide_motif	440	446	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-1-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	2093	2099	40.9	-	.	Name=ACTAAYH_chrM-;Alias=DREME-1;ID=ACTAAYH-DREME-1-2-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	2299	2305	40.9	-	.	Name=ACTAAYH_chrM-;Alias=DREME-1;ID=ACTAAYH-DREME-1-3-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	5186	5192	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-4-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	6530	6536	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-5-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	7742	7748	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-6-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	13657	13663	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-7-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	13741	13747	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-8-chrM;pvalue=8.2e-05;qvalue= 0.327;sequence=ACTAACA;
-chrM	fimo	nucleotide_motif	510	516	43.8	+	.	Name=CCAGCAY_chrM+;Alias=DREME-5;ID=CCAGCAY-DREME-5-1-chrM;pvalue=4.15e-05;qvalue= 0.668;sequence=CCAGCAC;
-chrM	fimo	nucleotide_motif	5137	5143	43.8	+	.	Name=CCAGCAY_chrM+;Alias=DREME-5;ID=CCAGCAY-DREME-5-2-chrM;pvalue=4.15e-05;qvalue= 0.668;sequence=CCAGCAC;
+chrM	fimo	nucleotide_motif	440	446	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-1-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	2093	2099	40.9	-	.	Name=ACTAAYH_chrM-;Alias=DREME-1;ID=ACTAAYH-DREME-1-2-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	2299	2305	40.9	-	.	Name=ACTAAYH_chrM-;Alias=DREME-1;ID=ACTAAYH-DREME-1-3-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	5186	5192	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-4-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	6530	6536	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-5-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	7742	7748	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-6-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	13657	13663	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-7-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	13741	13747	40.9	+	.	Name=ACTAAYH_chrM+;Alias=DREME-1;ID=ACTAAYH-DREME-1-8-chrM;pvalue=8.2e-05;qvalue= 0.332;sequence=ACTAACA;
+chrM	fimo	nucleotide_motif	510	516	43.8	+	.	Name=CCAGCAY_chrM+;Alias=DREME-5;ID=CCAGCAY-DREME-5-1-chrM;pvalue=4.15e-05;qvalue= 0.683;sequence=CCAGCAC;
+chrM	fimo	nucleotide_motif	5137	5143	43.8	+	.	Name=CCAGCAY_chrM+;Alias=DREME-5;ID=CCAGCAY-DREME-5-2-chrM;pvalue=4.15e-05;qvalue= 0.683;sequence=CCAGCAC;
 chrM	fimo	nucleotide_motif	4241	4247	40.3	+	.	Name=CCAGCAY_chrM+;Alias=DREME-5;ID=CCAGCAY-DREME-5-3-chrM;pvalue=9.37e-05;qvalue= 1;sequence=CCAGCAT;
--- a/test-data/fimo_output_test2.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test2.html	Wed Dec 11 18:05:15 2019 -0500
@@ -9,7 +9,7 @@
 td.right {text-align: right; padding-right: 1cm;}
 </style>
 </head>
-<body bgcolor="#D5F0FF">
+<body color="#000000">
 <a name="top_buttons"></a>
 <hr>
 <table summary="buttons" align="left" cellspacing="0">
@@ -17,123 +17,44 @@
 <td bgcolor="#00FFFF"><a href="#database_and_motifs"><b>Database and Motifs</b></a></td>
 <td bgcolor="#DDFFDD"><a href="#sec_i"><b>High-scoring Motif Occurences</b></a></td>
 <td bgcolor="#DDDDFF"><a href="#debugging_information"><b>Debugging Information</b></a></td>
+<td bgcolor="#FFDD00"><a href="fimo.tsv""><b>Results in TSV Format</b></a></td>
+<td bgcolor="#FFDDFF"><a href="fimo.gff""><b>Results in GFF3 Format</b></a></td>
 </tr>
 </table>
-<br/>
-<br/>
-<hr/>
 <center><big><b>FIMO - Motif search tool</b></big></center>
-<hr>
-<p>
-FIMO version 4.12.0, (Release date: Tue Jun 27 16:22:50 2017 -0700)
-</p>
-<p>
-For further information on how to interpret these results
-or to get a copy of the FIMO software please access
-<a href="http://meme.nbcr.net">http://meme.nbcr.net</a></p>
+FIMO version 5.0.5, (Release date: Mon Mar 18 20:12:19 2019 -0700)
+For further information on how to interpret these results please access <a href="http://meme-suite.org/doc/fimo-output-format.html">http://meme-suite.org/doc/fimo-output-format.html</a>.<br>
+To get a copy of the FIMO software please access <a href="http://meme-suite.org">http://meme-suite.org</a>
 <p>If you use FIMO in your research, please cite the following paper:<br>
 Charles E. Grant, Timothy L. Bailey, and William Stafford Noble,
 "FIMO: Scanning for occurrences of a given motif",
 <i>Bioinformatics</i>, <b>27</b>(7):1017-1018, 2011.
-<a href="http://bioinformatics.oxfordjournals.org/content/27/7/1017">[full text]</a></p>
-<hr>
 <center><big><b><a name="database_and_motifs">DATABASE AND MOTIFS</a></b></big></center>
-<hr>
-<div style="padding-left: 0.75in; line-height: 1em; font-family: monospace;">
-<p>
-  DATABASE hsa_chrM.fa
-  <br />
   Database contains 1 sequences, 16569 residues
-</p>
-<p>
-  MOTIFS dreme_fimo_input_1.xml (DNA)
   <table>
     <thead>
-      <tr>
-        <th style="border-bottom: 1px dashed;">MOTIF</th>
-        <th style="border-bottom: 1px dashed; padding-left: 1em;">WIDTH</th>
-        <th style="border-bottom: 1px dashed; padding-left: 1em;text-align:left;" >
-         BEST POSSIBLE MATCH
-        </th>
-      </tr>
     </thead>
     <tbody>
-      <tr>
-        <td style="text-align:right;">ACTAAYH</td>
-        <td style="text-align:right;padding-left: 1em;">7</td>
-        <td style="text-align:left;padding-left: 1em;">ACTAACA</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">YTAACA</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">TTAACA</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">TCTGT</td>
-        <td style="text-align:right;padding-left: 1em;">5</td>
-        <td style="text-align:left;padding-left: 1em;">TCTGT</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">SCCAGG</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">CCCAGG</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">CCAGCAY</td>
-        <td style="text-align:right;padding-left: 1em;">7</td>
-        <td style="text-align:left;padding-left: 1em;">CCAGCAC</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">GMATGT</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">GAATGT</td>
-       </tr>
     </tbody>
   </table>
-</p>
-<p>
-Random model letter frequencies (fimo_background_probs_hsa_chrM.txt):
-<br/>
-
 A 0.278 C 0.222 G 0.222 T 0.278 </p>
-</div>
-<hr>
 <center><big><b><a name="sec_i">SECTION I: HIGH-SCORING MOTIF OCCURENCES</a></b></big></center>
-<hr>
-<ul>
-<li>
 There were 11 motif occurences with a p-value less than 0.0001.
-
 The full set of motif occurences can be seen in the
-tab-delimited plain text output file
-<a href="fimo.txt">fimo.txt</a>, 
-the GFF file 
-<a href="fimo.gff">fimo.gff</a> 
+TSV (tab-delimited values) output file
+the GFF3 file 
 which may be suitable for uploading to the 
-<a href="http://genome.ucsc.edu/cgi-bin/hgTables">UCSC Genome Table Browser</a>
 (assuming the FASTA input sequences included genomic coordinates in UCSC or Galaxy format),
 or the XML file 
-<a href="fimo.xml">fimo.xml</a>.
-</li>
-<li>
-The p-value of a motif occurrence is defined as the
+The <i>p</i>-value of a motif occurrence is defined as the
 probability of a random sequence of the same length as the motif
 matching that position of the sequence with as good or better a score.
-</li>
-<li>
 The score for the match of a position in a sequence to a motif
 is computed by summing the appropriate entries from each column of
 the position-dependent scoring matrix that represents the motif.
-</li>
-<li>
 The q-value of a motif occurrence is defined as the
 false discovery rate if the occurrence is accepted as significant.
-</li>
-<li>The table is sorted by increasing p-value.</li>
-</ul>
-<table border="1">
-<thead>
-<tr>
+<li>The table is sorted by increasing <i>p</i>-value.</li>
 <th>Motif ID</th>
 <th>Alt ID</th>
 <th>Sequence Name</th>
@@ -143,9 +64,6 @@
 <th>p-value</th>
 <th>q-value</th>
 <th>Matched Sequence</th>
-</tr>
-</thead>
-<tbody>
     <tr>
       <td style="text-align:left;">CCAGCAY</td>
       <td style="text-align:left;">DREME-5</td>
@@ -154,172 +72,19 @@
       <td style="text-align:left;">510</td>
       <td style="text-align:left;">516</td>
       <td style="text-align:left;">4.15e-05</td>
-      <td style="text-align:left;">0.668</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCAGCAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">CCAGCAY</td>
-      <td style="text-align:left;">DREME-5</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5137</td>
-      <td style="text-align:left;">5143</td>
-      <td style="text-align:left;">4.15e-05</td>
-      <td style="text-align:left;">0.668</td>
+      <td style="text-align:left;">0.683</td>
       <td style="text-align:left;font-size:x-large;font-family:monospace;">CCAGCAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">440</td>
-      <td style="text-align:left;">446</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
       <td style="text-align:left;">2093</td>
       <td style="text-align:left;">2099</td>
       <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2299</td>
-      <td style="text-align:left;">2305</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5186</td>
-      <td style="text-align:left;">5192</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6530</td>
-      <td style="text-align:left;">6536</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7742</td>
-      <td style="text-align:left;">7748</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13657</td>
-      <td style="text-align:left;">13663</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
+      <td style="text-align:left;">0.332</td>
       <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
    </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13741</td>
-      <td style="text-align:left;">13747</td>
-      <td style="text-align:left;">8.2e-05</td>
-      <td style="text-align:left;">0.327</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">CCAGCAY</td>
-      <td style="text-align:left;">DREME-5</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4241</td>
-      <td style="text-align:left;">4247</td>
-      <td style="text-align:left;">9.37e-05</td>
-      <td style="text-align:left;">1</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCAGCAT</td>
-   </tr>
-</tbody>
-</table>
-
 <hr>
 <center><big><b><a name="debugging_information">DEBUGGING INFORMATION</a></b></big></center>
-<hr>
-<p>
 Command line:
-</p>
-<pre>
-fimo -oc fimo_test2_out --bgfile fimo_background_probs_hsa_chrM.txt dreme_fimo_input_1.xml hsa_chrM.fa
-</pre>
-<p>
 Settings:
-</p>
-<pre>
-<table>
-  <tr>
-    <td style="padding-right: 2em">output_directory = fimo_test2_out</td>
-    <td style="padding-left: 5em; padding-right: 2em">MEME file name = dreme_fimo_input_1.xml</td>
-    <td style="padding-left: 5em; padding-right: 2em">sequence file name = hsa_chrM.fa</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">background file name = fimo_background_probs_hsa_chrM.txt</td>
-    <td style="padding-left: 5em; padding-right: 2em">alphabet = DNA</td>
-    <td style="padding-left: 5em; padding-right: 2em">max stored scores = 100000</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">allow clobber = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">compute q-values = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">parse genomic coord. = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">text only = false</td>
-    <td style="padding-left: 5em; padding-right: 2em">scan both strands = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">max strand = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">threshold type = p-value</td>
-    <td style="padding-left: 5em; padding-right: 2em">output theshold = 0.0001</td>
-    <td style="padding-left: 5em; padding-right: 2em">pseudocount = 0.1</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">alpha = 1</td>
-    <td style="padding-left: 5em; padding-right: 2em">verbosity = 2</td>
-    <td style="padding-left: 5em; padding-right: 2em"></td>
-  </tr>
-
-</table>
-</pre>
-<p>
 This information can be useful in the event you wish to report a
 problem with the FIMO software.
-</p>
-<hr>
-<span style="background-color: #DDDDFF"><a href="#top_buttons"><b>Go to top</b></a></span>
 </body>
 </html>
--- a/test-data/fimo_output_test2.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test2.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,12 +1,12 @@
-# motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
-CCAGCAY	DREME-5	chrM	510	516	+	13.5843	4.15e-05	0.668	CCAGCAC
-CCAGCAY	DREME-5	chrM	5137	5143	+	13.5843	4.15e-05	0.668	CCAGCAC
-ACTAAYH	DREME-1	chrM	440	446	+	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	2093	2099	-	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	2299	2305	-	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	5186	5192	+	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	6530	6536	+	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	7742	7748	+	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	13657	13663	+	11.7385	8.2e-05	0.327	ACTAACA
-ACTAAYH	DREME-1	chrM	13741	13747	+	11.7385	8.2e-05	0.327	ACTAACA
+motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
+CCAGCAY	DREME-5	chrM	510	516	+	13.5843	4.15e-05	0.683	CCAGCAC
+CCAGCAY	DREME-5	chrM	5137	5143	+	13.5843	4.15e-05	0.683	CCAGCAC
+ACTAAYH	DREME-1	chrM	440	446	+	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	2093	2099	-	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	2299	2305	-	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	5186	5192	+	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	6530	6536	+	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	7742	7748	+	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	13657	13663	+	11.7286	8.2e-05	0.332	ACTAACA
+ACTAAYH	DREME-1	chrM	13741	13747	+	11.7286	8.2e-05	0.332	ACTAACA
 CCAGCAY	DREME-5	chrM	4241	4247	+	13.1461	9.37e-05	1	CCAGCAT
--- a/test-data/fimo_output_test2.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test2.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,16 +1,11 @@
 <?xml version="1.0" encoding="UTF-8" standalone="no"?>
 <!-- Begin document body -->
-<fimo version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
+<fimo version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation=  xmlns:fimo="http://noble.gs.washington.edu/schema/fimo"
 >
-<command-line>fimo -oc fimo_test2_out --bgfile fimo_background_probs_hsa_chrM.txt dreme_fimo_input_1.xml hsa_chrM.fa</command-line>
 <settings>
-<setting name="output directory">fimo_test2_out</setting>
-<setting name="MEME file name">dreme_fimo_input_1.xml</setting>
-<setting name="sequence file name">hsa_chrM.fa</setting>
-<setting name="background file name">fimo_background_probs_hsa_chrM.txt</setting>
-<setting name="allow clobber">true</setting>
+<setting name="allow clobber">false</setting>
 <setting name="compute q-values">true</setting>
 <setting name="parse genomic coord.">false</setting>
 <setting name="text only">false</setting>
@@ -45,7 +40,6 @@
 <motif name="SCCAGG" alt="DREME-4" width="6" best-possible-match="CCCAGG"/>
 <motif name="CCAGCAY" alt="DREME-5" width="7" best-possible-match="CCAGCAC"/>
 <motif name="GMATGT" alt="DREME-6" width="6" best-possible-match="GAATGT"/>
-<background source="fimo_background_probs_hsa_chrM.txt">
 <value letter="A">0.278</value>
 <value letter="C">0.222</value>
 <value letter="G">0.222</value>
--- a/test-data/fimo_output_test3.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test3.html	Wed Dec 11 18:05:15 2019 -0500
@@ -5,48 +5,23 @@
 <meta charset="UTF-8">
 <title>FIMO Results</title>
 <style type="text/css">
-td.left {text-align: left;}
-td.right {text-align: right; padding-right: 1cm;}
-</style>
 </head>
-<body bgcolor="#D5F0FF">
-<a name="top_buttons"></a>
-<hr>
-<table summary="buttons" align="left" cellspacing="0">
-<tr>
+<body color="#000000">
 <td bgcolor="#00FFFF"><a href="#database_and_motifs"><b>Database and Motifs</b></a></td>
 <td bgcolor="#DDFFDD"><a href="#sec_i"><b>High-scoring Motif Occurences</b></a></td>
 <td bgcolor="#DDDDFF"><a href="#debugging_information"><b>Debugging Information</b></a></td>
-</tr>
-</table>
-<br/>
-<br/>
-<hr/>
+<td bgcolor="#FFDD00"><a href="fimo.tsv""><b>Results in TSV Format</b></a></td>
+<td bgcolor="#FFDDFF"><a href="fimo.gff""><b>Results in GFF3 Format</b></a></td>
 <center><big><b>FIMO - Motif search tool</b></big></center>
-<hr>
-<p>
-FIMO version 4.12.0, (Release date: Tue Jun 27 16:22:50 2017 -0700)
-</p>
-<p>
-For further information on how to interpret these results
-or to get a copy of the FIMO software please access
-<a href="http://meme.nbcr.net">http://meme.nbcr.net</a></p>
+FIMO version 5.0.5, (Release date: Mon Mar 18 20:12:19 2019 -0700)
+For further information on how to interpret these results please access <a href="http://meme-suite.org/doc/fimo-output-format.html">http://meme-suite.org/doc/fimo-output-format.html</a>.<br>
+To get a copy of the FIMO software please access <a href="http://meme-suite.org">http://meme-suite.org</a>
 <p>If you use FIMO in your research, please cite the following paper:<br>
 Charles E. Grant, Timothy L. Bailey, and William Stafford Noble,
 "FIMO: Scanning for occurrences of a given motif",
 <i>Bioinformatics</i>, <b>27</b>(7):1017-1018, 2011.
-<a href="http://bioinformatics.oxfordjournals.org/content/27/7/1017">[full text]</a></p>
-<hr>
 <center><big><b><a name="database_and_motifs">DATABASE AND MOTIFS</a></b></big></center>
-<hr>
-<div style="padding-left: 0.75in; line-height: 1em; font-family: monospace;">
-<p>
-  DATABASE hsa_chrM.fa
-  <br />
   Database contains 1 sequences, 16569 residues
-</p>
-<p>
-  MOTIFS dreme_fimo_input_1.xml (DNA)
   <table>
     <thead>
       <tr>
@@ -63,74 +38,29 @@
         <td style="text-align:right;padding-left: 1em;">7</td>
         <td style="text-align:left;padding-left: 1em;">ACTAACA</td>
        </tr>
-      <tr>
-        <td style="text-align:right;">YTAACA</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">TTAACA</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">TCTGT</td>
-        <td style="text-align:right;padding-left: 1em;">5</td>
-        <td style="text-align:left;padding-left: 1em;">TCTGT</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">SCCAGG</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">CCCAGG</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">CCAGCAY</td>
-        <td style="text-align:right;padding-left: 1em;">7</td>
-        <td style="text-align:left;padding-left: 1em;">CCAGCAC</td>
-       </tr>
-      <tr>
-        <td style="text-align:right;">GMATGT</td>
-        <td style="text-align:right;padding-left: 1em;">6</td>
-        <td style="text-align:left;padding-left: 1em;">GAATGT</td>
-       </tr>
     </tbody>
   </table>
 </p>
 <p>
 Random model letter frequencies (--uniform--):
-<br/>
-
 A 0.250 C 0.250 G 0.250 T 0.250 </p>
-</div>
-<hr>
 <center><big><b><a name="sec_i">SECTION I: HIGH-SCORING MOTIF OCCURENCES</a></b></big></center>
-<hr>
-<ul>
-<li>
 There were 517 motif occurences with a p-value less than 0.01.
-
 The full set of motif occurences can be seen in the
-tab-delimited plain text output file
-<a href="fimo.txt">fimo.txt</a>, 
-the GFF file 
-<a href="fimo.gff">fimo.gff</a> 
+TSV (tab-delimited values) output file
+the GFF3 file 
 which may be suitable for uploading to the 
-<a href="http://genome.ucsc.edu/cgi-bin/hgTables">UCSC Genome Table Browser</a>
 (assuming the FASTA input sequences included genomic coordinates in UCSC or Galaxy format),
 or the XML file 
-<a href="fimo.xml">fimo.xml</a>.
-</li>
-<li>
-The p-value of a motif occurrence is defined as the
+The <i>p</i>-value of a motif occurrence is defined as the
 probability of a random sequence of the same length as the motif
 matching that position of the sequence with as good or better a score.
-</li>
-<li>
 The score for the match of a position in a sequence to a motif
 is computed by summing the appropriate entries from each column of
 the position-dependent scoring matrix that represents the motif.
-</li>
-<li>
 The q-value of a motif occurrence is defined as the
 false discovery rate if the occurrence is accepted as significant.
-</li>
-<li>The table is sorted by increasing p-value.</li>
-</ul>
+<li>The table is sorted by increasing <i>p</i>-value.</li>
 <table border="1">
 <thead>
 <tr>
@@ -156,5736 +86,7 @@
       <td style="text-align:left;">6.1e-05</td>
       <td style="text-align:left;">0.239</td>
       <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2093</td>
-      <td style="text-align:left;">2099</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2299</td>
-      <td style="text-align:left;">2305</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5186</td>
-      <td style="text-align:left;">5192</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6530</td>
-      <td style="text-align:left;">6536</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7742</td>
-      <td style="text-align:left;">7748</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13657</td>
-      <td style="text-align:left;">13663</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13741</td>
-      <td style="text-align:left;">13747</td>
-      <td style="text-align:left;">6.1e-05</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3768</td>
-      <td style="text-align:left;">3774</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5498</td>
-      <td style="text-align:left;">5504</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7736</td>
-      <td style="text-align:left;">7742</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9872</td>
-      <td style="text-align:left;">9878</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10106</td>
-      <td style="text-align:left;">10112</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10313</td>
-      <td style="text-align:left;">10319</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11818</td>
-      <td style="text-align:left;">11824</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15903</td>
-      <td style="text-align:left;">15909</td>
-      <td style="text-align:left;">0.000122</td>
-      <td style="text-align:left;">0.239</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7732</td>
-      <td style="text-align:left;">7738</td>
-      <td style="text-align:left;">0.000183</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10960</td>
-      <td style="text-align:left;">10966</td>
-      <td style="text-align:left;">0.000183</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">862</td>
-      <td style="text-align:left;">868</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1832</td>
-      <td style="text-align:left;">1838</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8679</td>
-      <td style="text-align:left;">8685</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8770</td>
-      <td style="text-align:left;">8776</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9347</td>
-      <td style="text-align:left;">9353</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9359</td>
-      <td style="text-align:left;">9365</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10302</td>
-      <td style="text-align:left;">10308</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14765</td>
-      <td style="text-align:left;">14771</td>
-      <td style="text-align:left;">0.000244</td>
-      <td style="text-align:left;">0.294</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4466</td>
-      <td style="text-align:left;">4472</td>
-      <td style="text-align:left;">0.000305</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11248</td>
-      <td style="text-align:left;">11254</td>
-      <td style="text-align:left;">0.000305</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">475</td>
-      <td style="text-align:left;">481</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7930</td>
-      <td style="text-align:left;">7936</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8649</td>
-      <td style="text-align:left;">8655</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8670</td>
-      <td style="text-align:left;">8676</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10768</td>
-      <td style="text-align:left;">10774</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11053</td>
-      <td style="text-align:left;">11059</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11101</td>
-      <td style="text-align:left;">11107</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12720</td>
-      <td style="text-align:left;">12726</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13149</td>
-      <td style="text-align:left;">13155</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14216</td>
-      <td style="text-align:left;">14222</td>
-      <td style="text-align:left;">0.000366</td>
-      <td style="text-align:left;">0.302</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">678</td>
-      <td style="text-align:left;">684</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1435</td>
-      <td style="text-align:left;">1441</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1524</td>
-      <td style="text-align:left;">1530</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2035</td>
-      <td style="text-align:left;">2041</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8440</td>
-      <td style="text-align:left;">8446</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9995</td>
-      <td style="text-align:left;">10001</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10225</td>
-      <td style="text-align:left;">10231</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12725</td>
-      <td style="text-align:left;">12731</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14393</td>
-      <td style="text-align:left;">14399</td>
-      <td style="text-align:left;">0.000549</td>
-      <td style="text-align:left;">0.366</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2294</td>
-      <td style="text-align:left;">2300</td>
-      <td style="text-align:left;">0.00061</td>
-      <td style="text-align:left;">0.398</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAATG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">206</td>
-      <td style="text-align:left;">212</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">237</td>
-      <td style="text-align:left;">243</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">370</td>
-      <td style="text-align:left;">376</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1630</td>
-      <td style="text-align:left;">1636</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1702</td>
-      <td style="text-align:left;">1708</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2309</td>
-      <td style="text-align:left;">2315</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2363</td>
-      <td style="text-align:left;">2369</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2370</td>
-      <td style="text-align:left;">2376</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2395</td>
-      <td style="text-align:left;">2401</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2761</td>
-      <td style="text-align:left;">2767</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2784</td>
-      <td style="text-align:left;">2790</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3191</td>
-      <td style="text-align:left;">3197</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3756</td>
-      <td style="text-align:left;">3762</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3873</td>
-      <td style="text-align:left;">3879</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3991</td>
-      <td style="text-align:left;">3997</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">4445</td>
-      <td style="text-align:left;">4451</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4734</td>
-      <td style="text-align:left;">4740</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5061</td>
-      <td style="text-align:left;">5067</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5177</td>
-      <td style="text-align:left;">5183</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5391</td>
-      <td style="text-align:left;">5397</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5680</td>
-      <td style="text-align:left;">5686</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">5686</td>
-      <td style="text-align:left;">5692</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6595</td>
-      <td style="text-align:left;">6601</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7146</td>
-      <td style="text-align:left;">7152</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7286</td>
-      <td style="text-align:left;">7292</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7714</td>
-      <td style="text-align:left;">7720</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7720</td>
-      <td style="text-align:left;">7726</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8344</td>
-      <td style="text-align:left;">8350</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8374</td>
-      <td style="text-align:left;">8380</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8460</td>
-      <td style="text-align:left;">8466</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9010</td>
-      <td style="text-align:left;">9016</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9257</td>
-      <td style="text-align:left;">9263</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9351</td>
-      <td style="text-align:left;">9357</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10127</td>
-      <td style="text-align:left;">10133</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10295</td>
-      <td style="text-align:left;">10301</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10496</td>
-      <td style="text-align:left;">10502</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10792</td>
-      <td style="text-align:left;">10798</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10798</td>
-      <td style="text-align:left;">10804</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10939</td>
-      <td style="text-align:left;">10945</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11023</td>
-      <td style="text-align:left;">11029</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11258</td>
-      <td style="text-align:left;">11264</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11314</td>
-      <td style="text-align:left;">11320</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11593</td>
-      <td style="text-align:left;">11599</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11650</td>
-      <td style="text-align:left;">11656</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11768</td>
-      <td style="text-align:left;">11774</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">11901</td>
-      <td style="text-align:left;">11907</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11941</td>
-      <td style="text-align:left;">11947</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12026</td>
-      <td style="text-align:left;">12032</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12245</td>
-      <td style="text-align:left;">12251</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12412</td>
-      <td style="text-align:left;">12418</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12530</td>
-      <td style="text-align:left;">12536</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12617</td>
-      <td style="text-align:left;">12623</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12736</td>
-      <td style="text-align:left;">12742</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13161</td>
-      <td style="text-align:left;">13167</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13626</td>
-      <td style="text-align:left;">13632</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13797</td>
-      <td style="text-align:left;">13803</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13830</td>
-      <td style="text-align:left;">13836</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13858</td>
-      <td style="text-align:left;">13864</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14185</td>
-      <td style="text-align:left;">14191</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14189</td>
-      <td style="text-align:left;">14195</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14548</td>
-      <td style="text-align:left;">14554</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14569</td>
-      <td style="text-align:left;">14575</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15469</td>
-      <td style="text-align:left;">15475</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15599</td>
-      <td style="text-align:left;">15605</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16227</td>
-      <td style="text-align:left;">16233</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16277</td>
-      <td style="text-align:left;">16283</td>
-      <td style="text-align:left;">0.00165</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">852</td>
-      <td style="text-align:left;">858</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">1449</td>
-      <td style="text-align:left;">1455</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4913</td>
-      <td style="text-align:left;">4919</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11278</td>
-      <td style="text-align:left;">11284</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13686</td>
-      <td style="text-align:left;">13692</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14582</td>
-      <td style="text-align:left;">14588</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14636</td>
-      <td style="text-align:left;">14642</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15703</td>
-      <td style="text-align:left;">15709</td>
-      <td style="text-align:left;">0.00177</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAGC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">152</td>
-      <td style="text-align:left;">158</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">234</td>
-      <td style="text-align:left;">240</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">472</td>
-      <td style="text-align:left;">478</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">645</td>
-      <td style="text-align:left;">651</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">671</td>
-      <td style="text-align:left;">677</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2305</td>
-      <td style="text-align:left;">2311</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2529</td>
-      <td style="text-align:left;">2535</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2744</td>
-      <td style="text-align:left;">2750</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2880</td>
-      <td style="text-align:left;">2886</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4158</td>
-      <td style="text-align:left;">4164</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4206</td>
-      <td style="text-align:left;">4212</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4301</td>
-      <td style="text-align:left;">4307</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4679</td>
-      <td style="text-align:left;">4685</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4728</td>
-      <td style="text-align:left;">4734</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4754</td>
-      <td style="text-align:left;">4760</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5036</td>
-      <td style="text-align:left;">5042</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5103</td>
-      <td style="text-align:left;">5109</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5153</td>
-      <td style="text-align:left;">5159</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">5962</td>
-      <td style="text-align:left;">5968</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6110</td>
-      <td style="text-align:left;">6116</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6155</td>
-      <td style="text-align:left;">6161</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6527</td>
-      <td style="text-align:left;">6533</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">6973</td>
-      <td style="text-align:left;">6979</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7295</td>
-      <td style="text-align:left;">7301</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7301</td>
-      <td style="text-align:left;">7307</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7300</td>
-      <td style="text-align:left;">7306</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7349</td>
-      <td style="text-align:left;">7355</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7351</td>
-      <td style="text-align:left;">7357</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7522</td>
-      <td style="text-align:left;">7528</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8739</td>
-      <td style="text-align:left;">8745</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8738</td>
-      <td style="text-align:left;">8744</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8945</td>
-      <td style="text-align:left;">8951</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8982</td>
-      <td style="text-align:left;">8988</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9613</td>
-      <td style="text-align:left;">9619</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9656</td>
-      <td style="text-align:left;">9662</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10055</td>
-      <td style="text-align:left;">10061</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10103</td>
-      <td style="text-align:left;">10109</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10246</td>
-      <td style="text-align:left;">10252</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10315</td>
-      <td style="text-align:left;">10321</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10336</td>
-      <td style="text-align:left;">10342</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10368</td>
-      <td style="text-align:left;">10374</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10526</td>
-      <td style="text-align:left;">10532</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10525</td>
-      <td style="text-align:left;">10531</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10574</td>
-      <td style="text-align:left;">10580</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10657</td>
-      <td style="text-align:left;">10663</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10699</td>
-      <td style="text-align:left;">10705</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10788</td>
-      <td style="text-align:left;">10794</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10858</td>
-      <td style="text-align:left;">10864</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10954</td>
-      <td style="text-align:left;">10960</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11873</td>
-      <td style="text-align:left;">11879</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">11958</td>
-      <td style="text-align:left;">11964</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12333</td>
-      <td style="text-align:left;">12339</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12349</td>
-      <td style="text-align:left;">12355</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12425</td>
-      <td style="text-align:left;">12431</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12471</td>
-      <td style="text-align:left;">12477</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12933</td>
-      <td style="text-align:left;">12939</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12972</td>
-      <td style="text-align:left;">12978</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13269</td>
-      <td style="text-align:left;">13275</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">13274</td>
-      <td style="text-align:left;">13280</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">13566</td>
-      <td style="text-align:left;">13572</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14210</td>
-      <td style="text-align:left;">14216</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14213</td>
-      <td style="text-align:left;">14219</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14251</td>
-      <td style="text-align:left;">14257</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14314</td>
-      <td style="text-align:left;">14320</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14510</td>
-      <td style="text-align:left;">14516</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14545</td>
-      <td style="text-align:left;">14551</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14773</td>
-      <td style="text-align:left;">14779</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">15627</td>
-      <td style="text-align:left;">15633</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15838</td>
-      <td style="text-align:left;">15844</td>
-      <td style="text-align:left;">0.00269</td>
-      <td style="text-align:left;">0.441</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">193</td>
-      <td style="text-align:left;">199</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">714</td>
-      <td style="text-align:left;">720</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1860</td>
-      <td style="text-align:left;">1866</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1870</td>
-      <td style="text-align:left;">1876</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2220</td>
-      <td style="text-align:left;">2226</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2901</td>
-      <td style="text-align:left;">2907</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4154</td>
-      <td style="text-align:left;">4160</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">4283</td>
-      <td style="text-align:left;">4289</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5099</td>
-      <td style="text-align:left;">5105</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5156</td>
-      <td style="text-align:left;">5162</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">5555</td>
-      <td style="text-align:left;">5561</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6142</td>
-      <td style="text-align:left;">6148</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6678</td>
-      <td style="text-align:left;">6684</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7169</td>
-      <td style="text-align:left;">7175</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8304</td>
-      <td style="text-align:left;">8310</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8456</td>
-      <td style="text-align:left;">8462</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8817</td>
-      <td style="text-align:left;">8823</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8949</td>
-      <td style="text-align:left;">8955</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9120</td>
-      <td style="text-align:left;">9126</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9852</td>
-      <td style="text-align:left;">9858</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10025</td>
-      <td style="text-align:left;">10031</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10964</td>
-      <td style="text-align:left;">10970</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11293</td>
-      <td style="text-align:left;">11299</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11347</td>
-      <td style="text-align:left;">11353</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12226</td>
-      <td style="text-align:left;">12232</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12516</td>
-      <td style="text-align:left;">12522</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13850</td>
-      <td style="text-align:left;">13856</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13862</td>
-      <td style="text-align:left;">13868</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14206</td>
-      <td style="text-align:left;">14212</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15185</td>
-      <td style="text-align:left;">15191</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15189</td>
-      <td style="text-align:left;">15195</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15603</td>
-      <td style="text-align:left;">15609</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15844</td>
-      <td style="text-align:left;">15850</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15848</td>
-      <td style="text-align:left;">15854</td>
-      <td style="text-align:left;">0.0036</td>
-      <td style="text-align:left;">0.501</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">21</td>
-      <td style="text-align:left;">27</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">381</td>
-      <td style="text-align:left;">387</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">529</td>
-      <td style="text-align:left;">535</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">547</td>
-      <td style="text-align:left;">553</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">823</td>
-      <td style="text-align:left;">829</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">873</td>
-      <td style="text-align:left;">879</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">910</td>
-      <td style="text-align:left;">916</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">978</td>
-      <td style="text-align:left;">984</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">1569</td>
-      <td style="text-align:left;">1575</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1596</td>
-      <td style="text-align:left;">1602</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1991</td>
-      <td style="text-align:left;">1997</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2578</td>
-      <td style="text-align:left;">2584</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2765</td>
-      <td style="text-align:left;">2771</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3031</td>
-      <td style="text-align:left;">3037</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3225</td>
-      <td style="text-align:left;">3231</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3883</td>
-      <td style="text-align:left;">3889</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4101</td>
-      <td style="text-align:left;">4107</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4191</td>
-      <td style="text-align:left;">4197</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4598</td>
-      <td style="text-align:left;">4604</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4874</td>
-      <td style="text-align:left;">4880</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5237</td>
-      <td style="text-align:left;">5243</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5839</td>
-      <td style="text-align:left;">5845</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5931</td>
-      <td style="text-align:left;">5937</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6335</td>
-      <td style="text-align:left;">6341</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7228</td>
-      <td style="text-align:left;">7234</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7781</td>
-      <td style="text-align:left;">7787</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8315</td>
-      <td style="text-align:left;">8321</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8508</td>
-      <td style="text-align:left;">8514</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8721</td>
-      <td style="text-align:left;">8727</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8805</td>
-      <td style="text-align:left;">8811</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9003</td>
-      <td style="text-align:left;">9009</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9076</td>
-      <td style="text-align:left;">9082</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9124</td>
-      <td style="text-align:left;">9130</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11548</td>
-      <td style="text-align:left;">11554</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11852</td>
-      <td style="text-align:left;">11858</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11876</td>
-      <td style="text-align:left;">11882</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11905</td>
-      <td style="text-align:left;">11911</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12013</td>
-      <td style="text-align:left;">12019</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12336</td>
-      <td style="text-align:left;">12342</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12363</td>
-      <td style="text-align:left;">12369</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13295</td>
-      <td style="text-align:left;">13301</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13672</td>
-      <td style="text-align:left;">13678</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13854</td>
-      <td style="text-align:left;">13860</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13998</td>
-      <td style="text-align:left;">14004</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14124</td>
-      <td style="text-align:left;">14130</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14384</td>
-      <td style="text-align:left;">14390</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14401</td>
-      <td style="text-align:left;">14407</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14624</td>
-      <td style="text-align:left;">14630</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14786</td>
-      <td style="text-align:left;">14792</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14910</td>
-      <td style="text-align:left;">14916</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15193</td>
-      <td style="text-align:left;">15199</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15631</td>
-      <td style="text-align:left;">15637</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15748</td>
-      <td style="text-align:left;">15754</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16066</td>
-      <td style="text-align:left;">16072</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16281</td>
-      <td style="text-align:left;">16287</td>
-      <td style="text-align:left;">0.00452</td>
-      <td style="text-align:left;">0.505</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">211</td>
-      <td style="text-align:left;">217</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">210</td>
-      <td style="text-align:left;">216</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">214</td>
-      <td style="text-align:left;">220</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">1961</td>
-      <td style="text-align:left;">1967</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2188</td>
-      <td style="text-align:left;">2194</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3771</td>
-      <td style="text-align:left;">3777</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3923</td>
-      <td style="text-align:left;">3929</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">4469</td>
-      <td style="text-align:left;">4475</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4543</td>
-      <td style="text-align:left;">4549</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5085</td>
-      <td style="text-align:left;">5091</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6146</td>
-      <td style="text-align:left;">6152</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7087</td>
-      <td style="text-align:left;">7093</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7304</td>
-      <td style="text-align:left;">7310</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8041</td>
-      <td style="text-align:left;">8047</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8221</td>
-      <td style="text-align:left;">8227</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8220</td>
-      <td style="text-align:left;">8226</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8795</td>
-      <td style="text-align:left;">8801</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8946</td>
-      <td style="text-align:left;">8952</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8973</td>
-      <td style="text-align:left;">8979</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9042</td>
-      <td style="text-align:left;">9048</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9111</td>
-      <td style="text-align:left;">9117</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9538</td>
-      <td style="text-align:left;">9544</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9680</td>
-      <td style="text-align:left;">9686</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9953</td>
-      <td style="text-align:left;">9959</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10004</td>
-      <td style="text-align:left;">10010</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10029</td>
-      <td style="text-align:left;">10035</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10028</td>
-      <td style="text-align:left;">10034</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10109</td>
-      <td style="text-align:left;">10115</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10112</td>
-      <td style="text-align:left;">10118</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10402</td>
-      <td style="text-align:left;">10408</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10438</td>
-      <td style="text-align:left;">10444</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10852</td>
-      <td style="text-align:left;">10858</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10855</td>
-      <td style="text-align:left;">10861</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10876</td>
-      <td style="text-align:left;">10882</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11500</td>
-      <td style="text-align:left;">11506</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12378</td>
-      <td style="text-align:left;">12384</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12584</td>
-      <td style="text-align:left;">12590</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12679</td>
-      <td style="text-align:left;">12685</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12708</td>
-      <td style="text-align:left;">12714</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">13013</td>
-      <td style="text-align:left;">13019</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13350</td>
-      <td style="text-align:left;">13356</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13611</td>
-      <td style="text-align:left;">13617</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">14296</td>
-      <td style="text-align:left;">14302</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14782</td>
-      <td style="text-align:left;">14788</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">14781</td>
-      <td style="text-align:left;">14787</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14793</td>
-      <td style="text-align:left;">14799</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15178</td>
-      <td style="text-align:left;">15184</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15856</td>
-      <td style="text-align:left;">15862</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16003</td>
-      <td style="text-align:left;">16009</td>
-      <td style="text-align:left;">0.00543</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATT</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">1074</td>
-      <td style="text-align:left;">1080</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2270</td>
-      <td style="text-align:left;">2276</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3081</td>
-      <td style="text-align:left;">3087</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3345</td>
-      <td style="text-align:left;">3351</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3824</td>
-      <td style="text-align:left;">3830</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3924</td>
-      <td style="text-align:left;">3930</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4470</td>
-      <td style="text-align:left;">4476</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4520</td>
-      <td style="text-align:left;">4526</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4737</td>
-      <td style="text-align:left;">4743</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4747</td>
-      <td style="text-align:left;">4753</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4757</td>
-      <td style="text-align:left;">4763</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5120</td>
-      <td style="text-align:left;">5126</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5354</td>
-      <td style="text-align:left;">5360</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5378</td>
-      <td style="text-align:left;">5384</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5453</td>
-      <td style="text-align:left;">5459</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5501</td>
-      <td style="text-align:left;">5507</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5707</td>
-      <td style="text-align:left;">5713</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5921</td>
-      <td style="text-align:left;">5927</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6095</td>
-      <td style="text-align:left;">6101</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">6145</td>
-      <td style="text-align:left;">6151</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6158</td>
-      <td style="text-align:left;">6164</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6307</td>
-      <td style="text-align:left;">6313</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6467</td>
-      <td style="text-align:left;">6473</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6659</td>
-      <td style="text-align:left;">6665</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6682</td>
-      <td style="text-align:left;">6688</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">6982</td>
-      <td style="text-align:left;">6988</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8007</td>
-      <td style="text-align:left;">8013</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8422</td>
-      <td style="text-align:left;">8428</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8589</td>
-      <td style="text-align:left;">8595</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9093</td>
-      <td style="text-align:left;">9099</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9214</td>
-      <td style="text-align:left;">9220</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10079</td>
-      <td style="text-align:left;">10085</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10337</td>
-      <td style="text-align:left;">10343</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10387</td>
-      <td style="text-align:left;">10393</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10658</td>
-      <td style="text-align:left;">10664</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10700</td>
-      <td style="text-align:left;">10706</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11007</td>
-      <td style="text-align:left;">11013</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11065</td>
-      <td style="text-align:left;">11071</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11134</td>
-      <td style="text-align:left;">11140</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11239</td>
-      <td style="text-align:left;">11245</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11290</td>
-      <td style="text-align:left;">11296</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11734</td>
-      <td style="text-align:left;">11740</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11959</td>
-      <td style="text-align:left;">11965</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12676</td>
-      <td style="text-align:left;">12682</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12699</td>
-      <td style="text-align:left;">12705</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12952</td>
-      <td style="text-align:left;">12958</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13113</td>
-      <td style="text-align:left;">13119</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13419</td>
-      <td style="text-align:left;">13425</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14118</td>
-      <td style="text-align:left;">14124</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14136</td>
-      <td style="text-align:left;">14142</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14366</td>
-      <td style="text-align:left;">14372</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14890</td>
-      <td style="text-align:left;">14896</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14907</td>
-      <td style="text-align:left;">14913</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15475</td>
-      <td style="text-align:left;">15481</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15652</td>
-      <td style="text-align:left;">15658</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15832</td>
-      <td style="text-align:left;">15838</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15951</td>
-      <td style="text-align:left;">15957</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAATC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16013</td>
-      <td style="text-align:left;">16019</td>
-      <td style="text-align:left;">0.00635</td>
-      <td style="text-align:left;">0.514</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATTC</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">197</td>
-      <td style="text-align:left;">203</td>
-      <td style="text-align:left;">0.00647</td>
-      <td style="text-align:left;">0.521</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8713</td>
-      <td style="text-align:left;">8719</td>
-      <td style="text-align:left;">0.00647</td>
-      <td style="text-align:left;">0.521</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAAAG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">28</td>
-      <td style="text-align:left;">34</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">1322</td>
-      <td style="text-align:left;">1328</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2910</td>
-      <td style="text-align:left;">2916</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3035</td>
-      <td style="text-align:left;">3041</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5106</td>
-      <td style="text-align:left;">5112</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7218</td>
-      <td style="text-align:left;">7224</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8381</td>
-      <td style="text-align:left;">8387</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACCG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10580</td>
-      <td style="text-align:left;">10586</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATCG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11760</td>
-      <td style="text-align:left;">11766</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13546</td>
-      <td style="text-align:left;">13552</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13663</td>
-      <td style="text-align:left;">13669</td>
-      <td style="text-align:left;">0.00739</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAACG</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">57</td>
-      <td style="text-align:left;">63</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">284</td>
-      <td style="text-align:left;">290</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">331</td>
-      <td style="text-align:left;">337</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">361</td>
-      <td style="text-align:left;">367</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">608</td>
-      <td style="text-align:left;">614</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTGAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">682</td>
-      <td style="text-align:left;">688</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">946</td>
-      <td style="text-align:left;">952</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">972</td>
-      <td style="text-align:left;">978</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1019</td>
-      <td style="text-align:left;">1025</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1057</td>
-      <td style="text-align:left;">1063</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1142</td>
-      <td style="text-align:left;">1148</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1162</td>
-      <td style="text-align:left;">1168</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1384</td>
-      <td style="text-align:left;">1390</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1864</td>
-      <td style="text-align:left;">1870</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1894</td>
-      <td style="text-align:left;">1900</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1922</td>
-      <td style="text-align:left;">1928</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">1932</td>
-      <td style="text-align:left;">1938</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2124</td>
-      <td style="text-align:left;">2130</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2148</td>
-      <td style="text-align:left;">2154</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2175</td>
-      <td style="text-align:left;">2181</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2192</td>
-      <td style="text-align:left;">2198</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2224</td>
-      <td style="text-align:left;">2230</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2350</td>
-      <td style="text-align:left;">2356</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2463</td>
-      <td style="text-align:left;">2469</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2500</td>
-      <td style="text-align:left;">2506</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">2658</td>
-      <td style="text-align:left;">2664</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2798</td>
-      <td style="text-align:left;">2804</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">2855</td>
-      <td style="text-align:left;">2861</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">3065</td>
-      <td style="text-align:left;">3071</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3262</td>
-      <td style="text-align:left;">3268</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3378</td>
-      <td style="text-align:left;">3384</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3441</td>
-      <td style="text-align:left;">3447</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3486</td>
-      <td style="text-align:left;">3492</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3558</td>
-      <td style="text-align:left;">3564</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">3677</td>
-      <td style="text-align:left;">3683</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4021</td>
-      <td style="text-align:left;">4027</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4087</td>
-      <td style="text-align:left;">4093</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4259</td>
-      <td style="text-align:left;">4265</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4334</td>
-      <td style="text-align:left;">4340</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">4586</td>
-      <td style="text-align:left;">4592</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4602</td>
-      <td style="text-align:left;">4608</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4778</td>
-      <td style="text-align:left;">4784</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4784</td>
-      <td style="text-align:left;">4790</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">4807</td>
-      <td style="text-align:left;">4813</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">4868</td>
-      <td style="text-align:left;">4874</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">5002</td>
-      <td style="text-align:left;">5008</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">5075</td>
-      <td style="text-align:left;">5081</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5128</td>
-      <td style="text-align:left;">5134</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5280</td>
-      <td style="text-align:left;">5286</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5405</td>
-      <td style="text-align:left;">5411</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5533</td>
-      <td style="text-align:left;">5539</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5670</td>
-      <td style="text-align:left;">5676</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">5938</td>
-      <td style="text-align:left;">5944</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">6106</td>
-      <td style="text-align:left;">6112</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">6376</td>
-      <td style="text-align:left;">6382</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">6451</td>
-      <td style="text-align:left;">6457</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">7445</td>
-      <td style="text-align:left;">7451</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7581</td>
-      <td style="text-align:left;">7587</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7692</td>
-      <td style="text-align:left;">7698</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">7800</td>
-      <td style="text-align:left;">7806</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8230</td>
-      <td style="text-align:left;">8236</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8323</td>
-      <td style="text-align:left;">8329</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8335</td>
-      <td style="text-align:left;">8341</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8494</td>
-      <td style="text-align:left;">8500</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8521</td>
-      <td style="text-align:left;">8527</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8531</td>
-      <td style="text-align:left;">8537</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">8757</td>
-      <td style="text-align:left;">8763</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8881</td>
-      <td style="text-align:left;">8887</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">TCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">8887</td>
-      <td style="text-align:left;">8893</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9173</td>
-      <td style="text-align:left;">9179</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">9236</td>
-      <td style="text-align:left;">9242</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9706</td>
-      <td style="text-align:left;">9712</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9796</td>
-      <td style="text-align:left;">9802</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">9987</td>
-      <td style="text-align:left;">9993</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10075</td>
-      <td style="text-align:left;">10081</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10243</td>
-      <td style="text-align:left;">10249</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10333</td>
-      <td style="text-align:left;">10339</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10376</td>
-      <td style="text-align:left;">10382</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10379</td>
-      <td style="text-align:left;">10385</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">10630</td>
-      <td style="text-align:left;">10636</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">10762</td>
-      <td style="text-align:left;">10768</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11029</td>
-      <td style="text-align:left;">11035</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">11367</td>
-      <td style="text-align:left;">11373</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11602</td>
-      <td style="text-align:left;">11608</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">11646</td>
-      <td style="text-align:left;">11652</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11751</td>
-      <td style="text-align:left;">11757</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">11757</td>
-      <td style="text-align:left;">11763</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12152</td>
-      <td style="text-align:left;">12158</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12295</td>
-      <td style="text-align:left;">12301</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">12311</td>
-      <td style="text-align:left;">12317</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12327</td>
-      <td style="text-align:left;">12333</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12352</td>
-      <td style="text-align:left;">12358</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTATAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12416</td>
-      <td style="text-align:left;">12422</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACAAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12509</td>
-      <td style="text-align:left;">12515</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">12662</td>
-      <td style="text-align:left;">12668</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">13109</td>
-      <td style="text-align:left;">13115</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AGTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13263</td>
-      <td style="text-align:left;">13269</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13422</td>
-      <td style="text-align:left;">13428</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13667</td>
-      <td style="text-align:left;">13673</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACGAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13791</td>
-      <td style="text-align:left;">13797</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13866</td>
-      <td style="text-align:left;">13872</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTTAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">13872</td>
-      <td style="text-align:left;">13878</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">13894</td>
-      <td style="text-align:left;">13900</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14007</td>
-      <td style="text-align:left;">14013</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14023</td>
-      <td style="text-align:left;">14029</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">CCTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14405</td>
-      <td style="text-align:left;">14411</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACCAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14501</td>
-      <td style="text-align:left;">14507</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ATTAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14687</td>
-      <td style="text-align:left;">14693</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14732</td>
-      <td style="text-align:left;">14738</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">14776</td>
-      <td style="text-align:left;">14782</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15072</td>
-      <td style="text-align:left;">15078</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15607</td>
-      <td style="text-align:left;">15613</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15874</td>
-      <td style="text-align:left;">15880</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTCAAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">-</td>
-      <td style="text-align:left;">15892</td>
-      <td style="text-align:left;">15898</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTACAA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">15995</td>
-      <td style="text-align:left;">16001</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">GCTAAGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16269</td>
-      <td style="text-align:left;">16275</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">ACTAGGA</td>
-   </tr>
-    <tr>
-      <td style="text-align:left;">ACTAAYH</td>
-      <td style="text-align:left;">DREME-1</td>
-      <td style="text-align:left;">chrM</td>
-      <td style="text-align:center;">+</td>
-      <td style="text-align:left;">16553</td>
-      <td style="text-align:left;">16559</td>
-      <td style="text-align:left;">0.00922</td>
-      <td style="text-align:left;">0.559</td>
-      <td style="text-align:left;font-size:x-large;font-family:monospace;">AATAAGA</td>
-   </tr>
-</tbody>
-</table>
-
-<hr>
-<center><big><b><a name="debugging_information">DEBUGGING INFORMATION</a></b></big></center>
-<hr>
-<p>
-Command line:
-</p>
-<pre>
-fimo -o ./fimo_test4_out --thresh 0.01 --bgfile --uniform-- --max-stored-scores 100000 --motif ACTAAYH --motif-pseudo 0.1 dreme_fimo_input_1.xml hsa_chrM.fa
-</pre>
-<p>
-Settings:
-</p>
-<pre>
-<table>
-  <tr>
-    <td style="padding-right: 2em">output_directory = ./fimo_test4_out</td>
-    <td style="padding-left: 5em; padding-right: 2em">MEME file name = dreme_fimo_input_1.xml</td>
-    <td style="padding-left: 5em; padding-right: 2em">sequence file name = hsa_chrM.fa</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">background file name = --uniform--</td>
-    <td style="padding-left: 5em; padding-right: 2em">alphabet = DNA</td>
-    <td style="padding-left: 5em; padding-right: 2em">max stored scores = 100000</td>
-  </tr>  <tr>
-    <td style="padding-right: 2em">allow clobber = false</td>
-    <td style="padding-left: 5em; padding-right: 2em">compute q-values = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">parse genomic coord. = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">text only = false</td>
-    <td style="padding-left: 5em; padding-right: 2em">scan both strands = true</td>
-    <td style="padding-left: 5em; padding-right: 2em">max strand = false</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">threshold type = p-value</td>
-    <td style="padding-left: 5em; padding-right: 2em">output theshold = 0.01</td>
-    <td style="padding-left: 5em; padding-right: 2em">pseudocount = 0.1</td>
-  </tr>
-  <tr>
-    <td style="padding-right: 2em">alpha = 1</td>
-    <td style="padding-left: 5em; padding-right: 2em">verbosity = 2</td>
-    <td style="padding-left: 5em; padding-right: 2em"></td>
-  </tr>
-
-</table>
-</pre>
-<p>
 This information can be useful in the event you wish to report a
 problem with the FIMO software.
-</p>
-<hr>
-<span style="background-color: #DDDDFF"><a href="#top_buttons"><b>Go to top</b></a></span>
 </body>
 </html>
--- a/test-data/fimo_output_test3.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test3.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,4 +1,4 @@
-# motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
+motif_id	motif_alt_id	sequence_name	start	stop	strand	score	p-value	q-value	matched_sequence
 ACTAAYH	DREME-1	chrM	440	446	+	12.1831	6.1e-05	0.239	ACTAACA
 ACTAAYH	DREME-1	chrM	2093	2099	-	12.1831	6.1e-05	0.239	ACTAACA
 ACTAAYH	DREME-1	chrM	2299	2305	-	12.1831	6.1e-05	0.239	ACTAACA
@@ -20,499 +20,3 @@
 ACTAAYH	DREME-1	chrM	862	868	+	11.2394	0.000244	0.294	ACTAACC
 ACTAAYH	DREME-1	chrM	1832	1838	+	11.2394	0.000244	0.294	ACTAACC
 ACTAAYH	DREME-1	chrM	8679	8685	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	8770	8776	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	9347	9353	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	9359	9365	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	10302	10308	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	14765	14771	+	11.2394	0.000244	0.294	ACTAACC
-ACTAAYH	DREME-1	chrM	4466	4472	+	10.8592	0.000305	0.302	ACTAATT
-ACTAAYH	DREME-1	chrM	11248	11254	+	10.8592	0.000305	0.302	ACTAATT
-ACTAAYH	DREME-1	chrM	475	481	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	7930	7936	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	8649	8655	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	8670	8676	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	10768	10774	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	11053	11059	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	11101	11107	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	12720	12726	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	13149	13155	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	14216	14222	+	10.6479	0.000366	0.302	ACTAATC
-ACTAAYH	DREME-1	chrM	678	684	-	-1.07042	0.000549	0.366	ACTAAGA
-ACTAAYH	DREME-1	chrM	1435	1441	+	-1.07042	0.000549	0.366	ACTAAGA
-ACTAAYH	DREME-1	chrM	1524	1530	+	-1.07042	0.000549	0.366	ACTAAAA
-ACTAAYH	DREME-1	chrM	2035	2041	-	-1.07042	0.000549	0.366	ACTAAGA
-ACTAAYH	DREME-1	chrM	8440	8446	+	-1.07042	0.000549	0.366	ACTAAAA
-ACTAAYH	DREME-1	chrM	9995	10001	-	-1.07042	0.000549	0.366	ACTAAAA
-ACTAAYH	DREME-1	chrM	10225	10231	-	-1.07042	0.000549	0.366	ACTAAGA
-ACTAAYH	DREME-1	chrM	12725	12731	-	-1.07042	0.000549	0.366	ACTAAGA
-ACTAAYH	DREME-1	chrM	14393	14399	+	-1.07042	0.000549	0.366	ACTAAAA
-ACTAAYH	DREME-1	chrM	2294	2300	+	-1.30986	0.00061	0.398	ACTAATG
-ACTAAYH	DREME-1	chrM	206	212	-	-1.80282	0.00165	0.441	ATTAACA
-ACTAAYH	DREME-1	chrM	237	243	+	-1.80282	0.00165	0.441	AATAACA
-ACTAAYH	DREME-1	chrM	370	376	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	1630	1636	+	-1.80282	0.00165	0.441	ACTTACA
-ACTAAYH	DREME-1	chrM	1702	1708	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	2309	2315	+	-1.80282	0.00165	0.441	AGTAACA
-ACTAAYH	DREME-1	chrM	2363	2369	+	-1.80282	0.00165	0.441	ACTGACA
-ACTAAYH	DREME-1	chrM	2370	2376	+	-1.80282	0.00165	0.441	ATTAACA
-ACTAAYH	DREME-1	chrM	2395	2401	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	2761	2767	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	2784	2790	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	3191	3197	-	-1.80282	0.00165	0.441	ACTAAGT
-ACTAAYH	DREME-1	chrM	3756	3762	+	-1.80282	0.00165	0.441	ACTATCA
-ACTAAYH	DREME-1	chrM	3873	3879	+	-1.80282	0.00165	0.441	ACTAGCA
-ACTAAYH	DREME-1	chrM	3991	3997	+	-1.80282	0.00165	0.441	ACAAACA
-ACTAAYH	DREME-1	chrM	4445	4451	-	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	4734	4740	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	5061	5067	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	5177	5183	+	-1.80282	0.00165	0.441	GCTAACA
-ACTAAYH	DREME-1	chrM	5391	5397	+	-1.80282	0.00165	0.441	TCTAACA
-ACTAAYH	DREME-1	chrM	5680	5686	+	-1.80282	0.00165	0.441	ACAAACA
-ACTAAYH	DREME-1	chrM	5686	5692	-	-1.80282	0.00165	0.441	ACTAAGT
-ACTAAYH	DREME-1	chrM	6595	6601	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	7146	7152	+	-1.80282	0.00165	0.441	ACTATCA
-ACTAAYH	DREME-1	chrM	7286	7292	+	-1.80282	0.00165	0.441	TCTAACA
-ACTAAYH	DREME-1	chrM	7714	7720	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	7720	7726	+	-1.80282	0.00165	0.441	ACTCACA
-ACTAAYH	DREME-1	chrM	8344	8350	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	8374	8380	+	-1.80282	0.00165	0.441	ACTAAAT
-ACTAAYH	DREME-1	chrM	8460	8466	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	9010	9016	+	-1.80282	0.00165	0.441	GCTAACA
-ACTAAYH	DREME-1	chrM	9257	9263	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	9351	9357	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	10127	10133	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	10295	10301	+	-1.80282	0.00165	0.441	ACAAACA
-ACTAAYH	DREME-1	chrM	10496	10502	+	-1.80282	0.00165	0.441	ACTAGCA
-ACTAAYH	DREME-1	chrM	10792	10798	+	-1.80282	0.00165	0.441	ACTACCA
-ACTAAYH	DREME-1	chrM	10798	10804	+	-1.80282	0.00165	0.441	ACTGACA
-ACTAAYH	DREME-1	chrM	10939	10945	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	11023	11029	+	-1.80282	0.00165	0.441	ACTATCA
-ACTAAYH	DREME-1	chrM	11258	11264	+	-1.80282	0.00165	0.441	ACTCACA
-ACTAAYH	DREME-1	chrM	11314	11320	+	-1.80282	0.00165	0.441	ACTATCA
-ACTAAYH	DREME-1	chrM	11593	11599	+	-1.80282	0.00165	0.441	ACAAACA
-ACTAAYH	DREME-1	chrM	11650	11656	+	-1.80282	0.00165	0.441	AGTAACA
-ACTAAYH	DREME-1	chrM	11768	11774	+	-1.80282	0.00165	0.441	ACTCACA
-ACTAAYH	DREME-1	chrM	11901	11907	-	-1.80282	0.00165	0.441	ACTAGCA
-ACTAAYH	DREME-1	chrM	11941	11947	+	-1.80282	0.00165	0.441	ACTTACA
-ACTAAYH	DREME-1	chrM	12026	12032	+	-1.80282	0.00165	0.441	ATTAACA
-ACTAAYH	DREME-1	chrM	12245	12251	+	-1.80282	0.00165	0.441	TCTAACA
-ACTAAYH	DREME-1	chrM	12412	12418	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	12530	12536	+	-1.80282	0.00165	0.441	ACTGACA
-ACTAAYH	DREME-1	chrM	12617	12623	-	-1.80282	0.00165	0.441	ACGAACA
-ACTAAYH	DREME-1	chrM	12736	12742	+	-1.80282	0.00165	0.441	GCTAACA
-ACTAAYH	DREME-1	chrM	13161	13167	+	-1.80282	0.00165	0.441	TCTAACA
-ACTAAYH	DREME-1	chrM	13626	13632	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	13797	13803	+	-1.80282	0.00165	0.441	ACTCACA
-ACTAAYH	DREME-1	chrM	13830	13836	+	-1.80282	0.00165	0.441	TCTAACA
-ACTAAYH	DREME-1	chrM	13858	13864	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	14185	14191	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	14189	14195	+	-1.80282	0.00165	0.441	ACAAACA
-ACTAAYH	DREME-1	chrM	14548	14554	+	-1.80282	0.00165	0.441	AATAACA
-ACTAAYH	DREME-1	chrM	14569	14575	+	-1.80282	0.00165	0.441	GCTAACA
-ACTAAYH	DREME-1	chrM	15469	15475	+	-1.80282	0.00165	0.441	ATTAACA
-ACTAAYH	DREME-1	chrM	15599	15605	+	-1.80282	0.00165	0.441	CCTAACA
-ACTAAYH	DREME-1	chrM	16227	16233	+	-1.80282	0.00165	0.441	ACTATCA
-ACTAAYH	DREME-1	chrM	16277	16283	+	-1.80282	0.00165	0.441	ACCAACA
-ACTAAYH	DREME-1	chrM	852	858	+	-2.01408	0.00177	0.441	ACTAAGC
-ACTAAYH	DREME-1	chrM	1449	1455	-	-2.01408	0.00177	0.441	ACTAAGC
-ACTAAYH	DREME-1	chrM	4913	4919	+	-2.01408	0.00177	0.441	ACTAAAC
-ACTAAYH	DREME-1	chrM	11278	11284	+	-2.01408	0.00177	0.441	ACTAAAC
-ACTAAYH	DREME-1	chrM	13686	13692	+	-2.01408	0.00177	0.441	ACTAAAC
-ACTAAYH	DREME-1	chrM	14582	14588	+	-2.01408	0.00177	0.441	ACTAAAC
-ACTAAYH	DREME-1	chrM	14636	14642	+	-2.01408	0.00177	0.441	ACTAAAC
-ACTAAYH	DREME-1	chrM	15703	15709	+	-2.01408	0.00177	0.441	ACTAAGC
-ACTAAYH	DREME-1	chrM	152	158	-	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	234	240	+	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	472	478	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	645	651	+	-2.39437	0.00269	0.441	ACAAATA
-ACTAAYH	DREME-1	chrM	671	677	-	-2.39437	0.00269	0.441	GCTAATA
-ACTAAYH	DREME-1	chrM	2305	2311	-	-2.39437	0.00269	0.441	ACTTATA
-ACTAAYH	DREME-1	chrM	2529	2535	-	-2.39437	0.00269	0.441	TCTAATA
-ACTAAYH	DREME-1	chrM	2744	2750	-	-2.39437	0.00269	0.441	ATTAATA
-ACTAAYH	DREME-1	chrM	2880	2886	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	4158	4164	+	-2.39437	0.00269	0.441	ACTCATA
-ACTAAYH	DREME-1	chrM	4206	4212	+	-2.39437	0.00269	0.441	ACTTATA
-ACTAAYH	DREME-1	chrM	4301	4307	+	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	4679	4685	+	-2.39437	0.00269	0.441	TCTAATA
-ACTAAYH	DREME-1	chrM	4728	4734	+	-2.39437	0.00269	0.441	ACCAATA
-ACTAAYH	DREME-1	chrM	4754	4760	+	-2.39437	0.00269	0.441	ATTAATA
-ACTAAYH	DREME-1	chrM	5036	5042	+	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	5103	5109	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	5153	5159	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	5962	5968	-	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	6110	6116	+	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	6155	6161	+	-2.39437	0.00269	0.441	CCTAATA
-ACTAAYH	DREME-1	chrM	6527	6533	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	6973	6979	-	-2.39437	0.00269	0.441	GCTAATA
-ACTAAYH	DREME-1	chrM	7295	7301	+	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	7301	7307	+	-2.39437	0.00269	0.441	ATTAATA
-ACTAAYH	DREME-1	chrM	7300	7306	-	-2.39437	0.00269	0.441	ATTAATA
-ACTAAYH	DREME-1	chrM	7349	7355	+	-2.39437	0.00269	0.441	CCTAATA
-ACTAAYH	DREME-1	chrM	7351	7357	-	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	7522	7528	-	-2.39437	0.00269	0.441	TCTAATA
-ACTAAYH	DREME-1	chrM	8739	8745	+	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	8738	8744	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	8945	8951	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	8982	8988	+	-2.39437	0.00269	0.441	ACCAATA
-ACTAAYH	DREME-1	chrM	9613	9619	-	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	9656	9662	+	-2.39437	0.00269	0.441	TCTAATA
-ACTAAYH	DREME-1	chrM	10055	10061	+	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	10103	10109	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	10246	10252	-	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	10315	10321	-	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	10336	10342	-	-2.39437	0.00269	0.441	ATTAATA
-ACTAAYH	DREME-1	chrM	10368	10374	-	-2.39437	0.00269	0.441	ACTCATA
-ACTAAYH	DREME-1	chrM	10526	10532	+	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	10525	10531	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	10574	10580	+	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	10657	10663	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	10699	10705	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	10788	10794	-	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	10858	10864	-	-2.39437	0.00269	0.441	GCTAATA
-ACTAAYH	DREME-1	chrM	10954	10960	+	-2.39437	0.00269	0.441	CCTAATA
-ACTAAYH	DREME-1	chrM	11873	11879	+	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	11958	11964	-	-2.39437	0.00269	0.441	ACTAGTA
-ACTAAYH	DREME-1	chrM	12333	12339	+	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	12349	12355	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	12425	12431	+	-2.39437	0.00269	0.441	ACTCATA
-ACTAAYH	DREME-1	chrM	12471	12477	-	-2.39437	0.00269	0.441	ACTGATA
-ACTAAYH	DREME-1	chrM	12933	12939	+	-2.39437	0.00269	0.441	ACAAATA
-ACTAAYH	DREME-1	chrM	12972	12978	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	13269	13275	+	-2.39437	0.00269	0.441	ACTCATA
-ACTAAYH	DREME-1	chrM	13274	13280	-	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	13566	13572	-	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	14210	14216	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	14213	14219	+	-2.39437	0.00269	0.441	ACTACTA
-ACTAAYH	DREME-1	chrM	14251	14257	+	-2.39437	0.00269	0.441	ACCAATA
-ACTAAYH	DREME-1	chrM	14314	14320	+	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	14510	14516	+	-2.39437	0.00269	0.441	ACTATTA
-ACTAAYH	DREME-1	chrM	14545	14551	+	-2.39437	0.00269	0.441	AATAATA
-ACTAAYH	DREME-1	chrM	14773	14779	+	-2.39437	0.00269	0.441	CCTAATA
-ACTAAYH	DREME-1	chrM	15627	15633	-	-2.39437	0.00269	0.441	AGTAATA
-ACTAAYH	DREME-1	chrM	15838	15844	+	-2.39437	0.00269	0.441	CCTAATA
-ACTAAYH	DREME-1	chrM	193	199	+	-2.53521	0.0036	0.501	ACTTACT
-ACTAAYH	DREME-1	chrM	714	720	-	-2.53521	0.0036	0.501	ACTCACT
-ACTAAYH	DREME-1	chrM	1860	1866	+	-2.53521	0.0036	0.501	ATTAACT
-ACTAAYH	DREME-1	chrM	1870	1876	+	-2.53521	0.0036	0.501	AATAACT
-ACTAAYH	DREME-1	chrM	2220	2226	+	-2.53521	0.0036	0.501	ACTACCT
-ACTAAYH	DREME-1	chrM	2901	2907	+	-2.53521	0.0036	0.501	AATAACT
-ACTAAYH	DREME-1	chrM	4154	4160	+	-2.53521	0.0036	0.501	ACCAACT
-ACTAAYH	DREME-1	chrM	4283	4289	-	-2.53521	0.0036	0.501	AGTAACT
-ACTAAYH	DREME-1	chrM	5099	5105	+	-2.53521	0.0036	0.501	CCTAACT
-ACTAAYH	DREME-1	chrM	5156	5162	+	-2.53521	0.0036	0.501	ACTATCT
-ACTAAYH	DREME-1	chrM	5555	5561	-	-2.53521	0.0036	0.501	ACTTACT
-ACTAAYH	DREME-1	chrM	6142	6148	+	-2.53521	0.0036	0.501	ACTGACT
-ACTAAYH	DREME-1	chrM	6678	6684	+	-2.53521	0.0036	0.501	ACTTACT
-ACTAAYH	DREME-1	chrM	7169	7175	+	-2.53521	0.0036	0.501	TCTAACT
-ACTAAYH	DREME-1	chrM	8304	8310	+	-2.53521	0.0036	0.501	GCTAACT
-ACTAAYH	DREME-1	chrM	8456	8462	+	-2.53521	0.0036	0.501	ACAAACT
-ACTAAYH	DREME-1	chrM	8817	8823	+	-2.53521	0.0036	0.501	ACTATCT
-ACTAAYH	DREME-1	chrM	8949	8955	-	-2.53521	0.0036	0.501	AATAACT
-ACTAAYH	DREME-1	chrM	9120	9126	+	-2.53521	0.0036	0.501	ACTGACT
-ACTAAYH	DREME-1	chrM	9852	9858	+	-2.53521	0.0036	0.501	ACTATCT
-ACTAAYH	DREME-1	chrM	10025	10031	+	-2.53521	0.0036	0.501	ATTAACT
-ACTAAYH	DREME-1	chrM	10964	10970	+	-2.53521	0.0036	0.501	ACTACCT
-ACTAAYH	DREME-1	chrM	11293	11299	+	-2.53521	0.0036	0.501	ACTCACT
-ACTAAYH	DREME-1	chrM	11347	11353	+	-2.53521	0.0036	0.501	ACTAGCT
-ACTAAYH	DREME-1	chrM	12226	12232	+	-2.53521	0.0036	0.501	GCTAACT
-ACTAAYH	DREME-1	chrM	12516	12522	-	-2.53521	0.0036	0.501	AATAACT
-ACTAAYH	DREME-1	chrM	13850	13856	+	-2.53521	0.0036	0.501	ACTACCT
-ACTAAYH	DREME-1	chrM	13862	13868	+	-2.53521	0.0036	0.501	ACAAACT
-ACTAAYH	DREME-1	chrM	14206	14212	+	-2.53521	0.0036	0.501	AGTAACT
-ACTAAYH	DREME-1	chrM	15185	15191	+	-2.53521	0.0036	0.501	ACAAACT
-ACTAAYH	DREME-1	chrM	15189	15195	+	-2.53521	0.0036	0.501	ACTTACT
-ACTAAYH	DREME-1	chrM	15603	15609	+	-2.53521	0.0036	0.501	ACAAACT
-ACTAAYH	DREME-1	chrM	15844	15850	+	-2.53521	0.0036	0.501	ACCAACT
-ACTAAYH	DREME-1	chrM	15848	15854	+	-2.53521	0.0036	0.501	ACTATCT
-ACTAAYH	DREME-1	chrM	21	27	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	381	387	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	529	535	+	-2.74648	0.00452	0.505	GCTAACC
-ACTAAYH	DREME-1	chrM	547	553	+	-2.74648	0.00452	0.505	ACCAACC
-ACTAAYH	DREME-1	chrM	823	829	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	873	879	-	-2.74648	0.00452	0.505	ACCAACC
-ACTAAYH	DREME-1	chrM	910	916	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	978	984	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	1569	1575	-	-2.74648	0.00452	0.505	ACTTACC
-ACTAAYH	DREME-1	chrM	1596	1602	+	-2.74648	0.00452	0.505	ACGAACC
-ACTAAYH	DREME-1	chrM	1991	1997	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	2578	2584	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	2765	2771	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	3031	3037	-	-2.74648	0.00452	0.505	ACGAACC
-ACTAAYH	DREME-1	chrM	3225	3231	-	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	3883	3889	+	-2.74648	0.00452	0.505	ACCAACC
-ACTAAYH	DREME-1	chrM	4101	4107	+	-2.74648	0.00452	0.505	TCTAACC
-ACTAAYH	DREME-1	chrM	4191	4197	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	4598	4604	+	-2.74648	0.00452	0.505	TCTAACC
-ACTAAYH	DREME-1	chrM	4874	4880	+	-2.74648	0.00452	0.505	ACTAGCC
-ACTAAYH	DREME-1	chrM	5237	5243	+	-2.74648	0.00452	0.505	GCTAACC
-ACTAAYH	DREME-1	chrM	5839	5845	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	5931	5937	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	6335	6341	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	7228	7234	+	-2.74648	0.00452	0.505	ACTACCC
-ACTAAYH	DREME-1	chrM	7781	7787	+	-2.74648	0.00452	0.505	ACTATCC
-ACTAAYH	DREME-1	chrM	8315	8321	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	8508	8514	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	8721	8727	+	-2.74648	0.00452	0.505	ACGAACC
-ACTAAYH	DREME-1	chrM	8805	8811	+	-2.74648	0.00452	0.505	ACCAACC
-ACTAAYH	DREME-1	chrM	9003	9009	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	9076	9082	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	9124	9130	+	-2.74648	0.00452	0.505	ACTATCC
-ACTAAYH	DREME-1	chrM	11548	11554	+	-2.74648	0.00452	0.505	ACTATCC
-ACTAAYH	DREME-1	chrM	11852	11858	+	-2.74648	0.00452	0.505	GCTAACC
-ACTAAYH	DREME-1	chrM	11876	11882	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	11905	11911	+	-2.74648	0.00452	0.505	AGTAACC
-ACTAAYH	DREME-1	chrM	12013	12019	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	12336	12342	+	-2.74648	0.00452	0.505	AATAACC
-ACTAAYH	DREME-1	chrM	12363	12369	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	13295	13301	+	-2.74648	0.00452	0.505	ACCAACC
-ACTAAYH	DREME-1	chrM	13672	13678	+	-2.74648	0.00452	0.505	AATAACC
-ACTAAYH	DREME-1	chrM	13854	13860	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	13998	14004	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	14124	14130	+	-2.74648	0.00452	0.505	CCTAACC
-ACTAAYH	DREME-1	chrM	14384	14390	+	-2.74648	0.00452	0.505	GCTAACC
-ACTAAYH	DREME-1	chrM	14401	14407	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	14624	14630	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	14786	14792	+	-2.74648	0.00452	0.505	ATTAACC
-ACTAAYH	DREME-1	chrM	14910	14916	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	15193	15199	+	-2.74648	0.00452	0.505	ACTATCC
-ACTAAYH	DREME-1	chrM	15631	15637	+	-2.74648	0.00452	0.505	ACTATCC
-ACTAAYH	DREME-1	chrM	15748	15754	+	-2.74648	0.00452	0.505	TCTAACC
-ACTAAYH	DREME-1	chrM	16066	16072	+	-2.74648	0.00452	0.505	ACTCACC
-ACTAAYH	DREME-1	chrM	16281	16287	+	-2.74648	0.00452	0.505	ACAAACC
-ACTAAYH	DREME-1	chrM	211	217	+	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	210	216	-	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	214	220	-	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	1961	1967	-	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	2188	2194	+	-3.12676	0.00543	0.514	ACCAATT
-ACTAAYH	DREME-1	chrM	3771	3777	-	-3.12676	0.00543	0.514	ACTTATT
-ACTAAYH	DREME-1	chrM	3923	3929	-	-3.12676	0.00543	0.514	ACTAGTT
-ACTAAYH	DREME-1	chrM	4469	4475	-	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	4543	4549	+	-3.12676	0.00543	0.514	ACTGATT
-ACTAAYH	DREME-1	chrM	5085	5091	+	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	6146	6152	+	-3.12676	0.00543	0.514	ACTAGTT
-ACTAAYH	DREME-1	chrM	7087	7093	+	-3.12676	0.00543	0.514	ACTGATT
-ACTAAYH	DREME-1	chrM	7304	7310	+	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	8041	8047	+	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	8221	8227	+	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	8220	8226	-	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	8795	8801	+	-3.12676	0.00543	0.514	ACTCATT
-ACTAAYH	DREME-1	chrM	8946	8952	+	-3.12676	0.00543	0.514	ACTAGTT
-ACTAAYH	DREME-1	chrM	8973	8979	+	-3.12676	0.00543	0.514	ACTCATT
-ACTAAYH	DREME-1	chrM	9042	9048	+	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	9111	9117	+	-3.12676	0.00543	0.514	TCTAATT
-ACTAAYH	DREME-1	chrM	9538	9544	-	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	9680	9686	+	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	9953	9959	+	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	10004	10010	-	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	10029	10035	+	-3.12676	0.00543	0.514	ACTAGTT
-ACTAAYH	DREME-1	chrM	10028	10034	-	-3.12676	0.00543	0.514	ACTAGTT
-ACTAAYH	DREME-1	chrM	10109	10115	+	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	10112	10118	-	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	10402	10408	-	-3.12676	0.00543	0.514	ACCAATT
-ACTAAYH	DREME-1	chrM	10438	10444	+	-3.12676	0.00543	0.514	ACTCATT
-ACTAAYH	DREME-1	chrM	10852	10858	+	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	10855	10861	-	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	10876	10882	+	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	11500	11506	+	-3.12676	0.00543	0.514	ACTCATT
-ACTAAYH	DREME-1	chrM	12378	12384	+	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	12584	12590	+	-3.12676	0.00543	0.514	ACTACTT
-ACTAAYH	DREME-1	chrM	12679	12685	-	-3.12676	0.00543	0.514	ACTGATT
-ACTAAYH	DREME-1	chrM	12708	12714	+	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	13013	13019	-	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	13350	13356	+	-3.12676	0.00543	0.514	ACTATTT
-ACTAAYH	DREME-1	chrM	13611	13617	+	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	14296	14302	-	-3.12676	0.00543	0.514	AATAATT
-ACTAAYH	DREME-1	chrM	14782	14788	+	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	14781	14787	-	-3.12676	0.00543	0.514	ATTAATT
-ACTAAYH	DREME-1	chrM	14793	14799	+	-3.12676	0.00543	0.514	ACTCATT
-ACTAAYH	DREME-1	chrM	15178	15184	+	-3.12676	0.00543	0.514	AGTAATT
-ACTAAYH	DREME-1	chrM	15856	15862	+	-3.12676	0.00543	0.514	CCTAATT
-ACTAAYH	DREME-1	chrM	16003	16009	+	-3.12676	0.00543	0.514	TCTAATT
-ACTAAYH	DREME-1	chrM	1074	1080	-	-3.33803	0.00635	0.514	TCTAATC
-ACTAAYH	DREME-1	chrM	2270	2276	+	-3.33803	0.00635	0.514	ACCAATC
-ACTAAYH	DREME-1	chrM	3081	3087	+	-3.33803	0.00635	0.514	AGTAATC
-ACTAAYH	DREME-1	chrM	3345	3351	+	-3.33803	0.00635	0.514	TCTAATC
-ACTAAYH	DREME-1	chrM	3824	3830	-	-3.33803	0.00635	0.514	AGTAATC
-ACTAAYH	DREME-1	chrM	3924	3930	+	-3.33803	0.00635	0.514	ACTAGTC
-ACTAAYH	DREME-1	chrM	4470	4476	+	-3.33803	0.00635	0.514	ATTAATC
-ACTAAYH	DREME-1	chrM	4520	4526	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	4737	4743	+	-3.33803	0.00635	0.514	ACCAATC
-ACTAAYH	DREME-1	chrM	4747	4753	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	4757	4763	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	5120	5126	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	5354	5360	+	-3.33803	0.00635	0.514	CCTAATC
-ACTAAYH	DREME-1	chrM	5378	5384	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	5453	5459	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	5501	5507	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	5707	5713	+	-3.33803	0.00635	0.514	CCTAATC
-ACTAAYH	DREME-1	chrM	5921	5927	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	6095	6101	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	6145	6151	-	-3.33803	0.00635	0.514	ACTAGTC
-ACTAAYH	DREME-1	chrM	6158	6164	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	6307	6313	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	6467	6473	+	-3.33803	0.00635	0.514	CCTAATC
-ACTAAYH	DREME-1	chrM	6659	6665	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	6682	6688	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	6982	6988	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	8007	8013	-	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	8422	8428	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	8589	8595	+	-3.33803	0.00635	0.514	ACTGATC
-ACTAAYH	DREME-1	chrM	9093	9099	+	-3.33803	0.00635	0.514	ACTTATC
-ACTAAYH	DREME-1	chrM	9214	9220	+	-3.33803	0.00635	0.514	ACCAATC
-ACTAAYH	DREME-1	chrM	10079	10085	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	10337	10343	+	-3.33803	0.00635	0.514	ATTAATC
-ACTAAYH	DREME-1	chrM	10387	10393	-	-3.33803	0.00635	0.514	TCTAATC
-ACTAAYH	DREME-1	chrM	10658	10664	+	-3.33803	0.00635	0.514	ACTAGTC
-ACTAAYH	DREME-1	chrM	10700	10706	+	-3.33803	0.00635	0.514	ACTAGTC
-ACTAAYH	DREME-1	chrM	11007	11013	+	-3.33803	0.00635	0.514	ACTTATC
-ACTAAYH	DREME-1	chrM	11065	11071	+	-3.33803	0.00635	0.514	ACAAATC
-ACTAAYH	DREME-1	chrM	11134	11140	+	-3.33803	0.00635	0.514	ACTTATC
-ACTAAYH	DREME-1	chrM	11239	11245	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	11290	11296	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	11734	11740	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	11959	11965	+	-3.33803	0.00635	0.514	ACTAGTC
-ACTAAYH	DREME-1	chrM	12676	12682	+	-3.33803	0.00635	0.514	ATTAATC
-ACTAAYH	DREME-1	chrM	12699	12705	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	12952	12958	+	-3.33803	0.00635	0.514	GCTAATC
-ACTAAYH	DREME-1	chrM	13113	13119	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	13419	13425	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	14118	14124	+	-3.33803	0.00635	0.514	ACTCATC
-ACTAAYH	DREME-1	chrM	14136	14142	+	-3.33803	0.00635	0.514	CCTAATC
-ACTAAYH	DREME-1	chrM	14366	14372	+	-3.33803	0.00635	0.514	ACCAATC
-ACTAAYH	DREME-1	chrM	14890	14896	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	14907	14913	+	-3.33803	0.00635	0.514	ACTACTC
-ACTAAYH	DREME-1	chrM	15475	15481	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	15652	15658	+	-3.33803	0.00635	0.514	AATAATC
-ACTAAYH	DREME-1	chrM	15832	15838	+	-3.33803	0.00635	0.514	CCTAATC
-ACTAAYH	DREME-1	chrM	15951	15957	+	-3.33803	0.00635	0.514	ACAAATC
-ACTAAYH	DREME-1	chrM	16013	16019	+	-3.33803	0.00635	0.514	ACTATTC
-ACTAAYH	DREME-1	chrM	197	203	+	-13.9718	0.00647	0.521	ACTAAAG
-ACTAAYH	DREME-1	chrM	8713	8719	+	-13.9718	0.00647	0.521	ACTAAAG
-ACTAAYH	DREME-1	chrM	28	34	+	-14.7042	0.00739	0.559	ACTCACG
-ACTAAYH	DREME-1	chrM	1322	1328	-	-14.7042	0.00739	0.559	CCTAACG
-ACTAAYH	DREME-1	chrM	2910	2916	+	-14.7042	0.00739	0.559	ACCAACG
-ACTAAYH	DREME-1	chrM	3035	3041	-	-14.7042	0.00739	0.559	ACAAACG
-ACTAAYH	DREME-1	chrM	5106	5112	+	-14.7042	0.00739	0.559	ACTACCG
-ACTAAYH	DREME-1	chrM	7218	7224	-	-14.7042	0.00739	0.559	AGTAACG
-ACTAAYH	DREME-1	chrM	8381	8387	+	-14.7042	0.00739	0.559	ACTACCG
-ACTAAYH	DREME-1	chrM	10580	10586	+	-14.7042	0.00739	0.559	ACTATCG
-ACTAAYH	DREME-1	chrM	11760	11766	+	-14.7042	0.00739	0.559	ACGAACG
-ACTAAYH	DREME-1	chrM	13546	13552	+	-14.7042	0.00739	0.559	ACAAACG
-ACTAAYH	DREME-1	chrM	13663	13669	+	-14.7042	0.00739	0.559	ATTAACG
-ACTAAYH	DREME-1	chrM	57	63	-	-15.0563	0.00922	0.559	ACGAAAA
-ACTAAYH	DREME-1	chrM	284	290	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	331	337	+	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	361	367	+	-15.0563	0.00922	0.559	ACAAAGA
-ACTAAYH	DREME-1	chrM	608	614	+	-15.0563	0.00922	0.559	ACTGAAA
-ACTAAYH	DREME-1	chrM	682	688	+	-15.0563	0.00922	0.559	AGTAAGA
-ACTAAYH	DREME-1	chrM	946	952	-	-15.0563	0.00922	0.559	TCTAAAA
-ACTAAYH	DREME-1	chrM	972	978	+	-15.0563	0.00922	0.559	GCTAAAA
-ACTAAYH	DREME-1	chrM	1019	1025	+	-15.0563	0.00922	0.559	ACTACGA
-ACTAAYH	DREME-1	chrM	1057	1063	+	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	1142	1148	+	-15.0563	0.00922	0.559	ACTACGA
-ACTAAYH	DREME-1	chrM	1162	1168	+	-15.0563	0.00922	0.559	ACTCAAA
-ACTAAYH	DREME-1	chrM	1384	1390	+	-15.0563	0.00922	0.559	ACTACGA
-ACTAAYH	DREME-1	chrM	1864	1870	+	-15.0563	0.00922	0.559	ACTAGAA
-ACTAAYH	DREME-1	chrM	1894	1900	+	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	1922	1928	+	-15.0563	0.00922	0.559	CCTAAGA
-ACTAAYH	DREME-1	chrM	1932	1938	+	-15.0563	0.00922	0.559	GCTAAAA
-ACTAAYH	DREME-1	chrM	2124	2130	+	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	2148	2154	+	-15.0563	0.00922	0.559	AGTAAAA
-ACTAAYH	DREME-1	chrM	2175	2181	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	2192	2198	+	-15.0563	0.00922	0.559	ATTAAGA
-ACTAAYH	DREME-1	chrM	2224	2230	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	2350	2356	+	-15.0563	0.00922	0.559	ATTAAAA
-ACTAAYH	DREME-1	chrM	2463	2469	+	-15.0563	0.00922	0.559	AGTAAAA
-ACTAAYH	DREME-1	chrM	2500	2506	+	-15.0563	0.00922	0.559	ACCAAAA
-ACTAAYH	DREME-1	chrM	2658	2664	-	-15.0563	0.00922	0.559	AGTAAGA
-ACTAAYH	DREME-1	chrM	2798	2804	+	-15.0563	0.00922	0.559	ATTAAAA
-ACTAAYH	DREME-1	chrM	2855	2861	+	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	3065	3071	-	-15.0563	0.00922	0.559	ACTCAGA
-ACTAAYH	DREME-1	chrM	3262	3268	+	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	3378	3384	+	-15.0563	0.00922	0.559	ACGAAAA
-ACTAAYH	DREME-1	chrM	3441	3447	+	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	3486	3492	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	3558	3564	+	-15.0563	0.00922	0.559	ACTATGA
-ACTAAYH	DREME-1	chrM	3677	3683	+	-15.0563	0.00922	0.559	ACTCAAA
-ACTAAYH	DREME-1	chrM	4021	4027	+	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	4087	4093	+	-15.0563	0.00922	0.559	ACCAAGA
-ACTAAYH	DREME-1	chrM	4259	4265	+	-15.0563	0.00922	0.559	CCTAAGA
-ACTAAYH	DREME-1	chrM	4334	4340	+	-15.0563	0.00922	0.559	ACTATGA
-ACTAAYH	DREME-1	chrM	4586	4592	-	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	4602	4608	+	-15.0563	0.00922	0.559	ACCAAAA
-ACTAAYH	DREME-1	chrM	4778	4784	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	4784	4790	+	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	4807	4813	-	-15.0563	0.00922	0.559	ACTCAGA
-ACTAAYH	DREME-1	chrM	4868	4874	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	5002	5008	-	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	5075	5081	-	-15.0563	0.00922	0.559	ATTAAGA
-ACTAAYH	DREME-1	chrM	5128	5134	+	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	5280	5286	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	5405	5411	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	5533	5539	+	-15.0563	0.00922	0.559	ACCAAGA
-ACTAAYH	DREME-1	chrM	5670	5676	+	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	5938	5944	+	-15.0563	0.00922	0.559	ACAAAGA
-ACTAAYH	DREME-1	chrM	6106	6112	-	-15.0563	0.00922	0.559	ACTATGA
-ACTAAYH	DREME-1	chrM	6376	6382	-	-15.0563	0.00922	0.559	CCTAAGA
-ACTAAYH	DREME-1	chrM	6451	6457	-	-15.0563	0.00922	0.559	ACGAAGA
-ACTAAYH	DREME-1	chrM	7445	7451	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	7581	7587	-	-15.0563	0.00922	0.559	ATTAAGA
-ACTAAYH	DREME-1	chrM	7692	7698	-	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	7800	7806	-	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	8230	8236	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	8323	8329	-	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	8335	8341	+	-15.0563	0.00922	0.559	ATTAAGA
-ACTAAYH	DREME-1	chrM	8494	8500	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	8521	8527	+	-15.0563	0.00922	0.559	ACCAAAA
-ACTAAYH	DREME-1	chrM	8531	8537	+	-15.0563	0.00922	0.559	ACGAAAA
-ACTAAYH	DREME-1	chrM	8757	8763	-	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	8881	8887	+	-15.0563	0.00922	0.559	TCTAAGA
-ACTAAYH	DREME-1	chrM	8887	8893	+	-15.0563	0.00922	0.559	ATTAAAA
-ACTAAYH	DREME-1	chrM	9173	9179	-	-15.0563	0.00922	0.559	ACTAGAA
-ACTAAYH	DREME-1	chrM	9236	9242	+	-15.0563	0.00922	0.559	AGTAAAA
-ACTAAYH	DREME-1	chrM	9706	9712	-	-15.0563	0.00922	0.559	AGTAAAA
-ACTAAYH	DREME-1	chrM	9796	9802	-	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	9987	9993	-	-15.0563	0.00922	0.559	AGTAAGA
-ACTAAYH	DREME-1	chrM	10075	10081	-	-15.0563	0.00922	0.559	ATTAAAA
-ACTAAYH	DREME-1	chrM	10243	10249	-	-15.0563	0.00922	0.559	AATAAGA
-ACTAAYH	DREME-1	chrM	10333	10339	-	-15.0563	0.00922	0.559	AATAAGA
-ACTAAYH	DREME-1	chrM	10376	10382	+	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	10379	10385	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	10630	10636	-	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	10762	10768	+	-15.0563	0.00922	0.559	GCTAAAA
-ACTAAYH	DREME-1	chrM	11029	11035	+	-15.0563	0.00922	0.559	ACGAAAA
-ACTAAYH	DREME-1	chrM	11367	11373	-	-15.0563	0.00922	0.559	ACTATAA
-ACTAAYH	DREME-1	chrM	11602	11608	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	11646	11652	-	-15.0563	0.00922	0.559	ACTACGA
-ACTAAYH	DREME-1	chrM	11751	11757	+	-15.0563	0.00922	0.559	ACTCAAA
-ACTAAYH	DREME-1	chrM	11757	11763	+	-15.0563	0.00922	0.559	ACTACGA
-ACTAAYH	DREME-1	chrM	12152	12158	+	-15.0563	0.00922	0.559	ACCAAAA
-ACTAAYH	DREME-1	chrM	12295	12301	-	-15.0563	0.00922	0.559	CCTAAGA
-ACTAAYH	DREME-1	chrM	12311	12317	-	-15.0563	0.00922	0.559	ACCAAAA
-ACTAAYH	DREME-1	chrM	12327	12333	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	12352	12358	+	-15.0563	0.00922	0.559	ACTATAA
-ACTAAYH	DREME-1	chrM	12416	12422	+	-15.0563	0.00922	0.559	ACAAAAA
-ACTAAYH	DREME-1	chrM	12509	12515	+	-15.0563	0.00922	0.559	ACCAAGA
-ACTAAYH	DREME-1	chrM	12662	12668	+	-15.0563	0.00922	0.559	ACTCAGA
-ACTAAYH	DREME-1	chrM	13109	13115	-	-15.0563	0.00922	0.559	AGTAAGA
-ACTAAYH	DREME-1	chrM	13263	13269	+	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	13422	13428	+	-15.0563	0.00922	0.559	ACTCAAA
-ACTAAYH	DREME-1	chrM	13667	13673	+	-15.0563	0.00922	0.559	ACGAAAA
-ACTAAYH	DREME-1	chrM	13791	13797	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	13866	13872	+	-15.0563	0.00922	0.559	ACTTAAA
-ACTAAYH	DREME-1	chrM	13872	13878	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	13894	13900	-	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	14007	14013	+	-15.0563	0.00922	0.559	ACTAGAA
-ACTAAYH	DREME-1	chrM	14023	14029	+	-15.0563	0.00922	0.559	CCTAAAA
-ACTAAYH	DREME-1	chrM	14405	14411	+	-15.0563	0.00922	0.559	ACCAAGA
-ACTAAYH	DREME-1	chrM	14501	14507	+	-15.0563	0.00922	0.559	ATTAAAA
-ACTAAYH	DREME-1	chrM	14687	14693	+	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	14732	14738	+	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	14776	14782	+	-15.0563	0.00922	0.559	AATAAAA
-ACTAAYH	DREME-1	chrM	15072	15078	+	-15.0563	0.00922	0.559	ACTCAGA
-ACTAAYH	DREME-1	chrM	15607	15613	+	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	15874	15880	+	-15.0563	0.00922	0.559	ACTCAAA
-ACTAAYH	DREME-1	chrM	15892	15898	-	-15.0563	0.00922	0.559	ACTACAA
-ACTAAYH	DREME-1	chrM	15995	16001	+	-15.0563	0.00922	0.559	GCTAAGA
-ACTAAYH	DREME-1	chrM	16269	16275	+	-15.0563	0.00922	0.559	ACTAGGA
-ACTAAYH	DREME-1	chrM	16553	16559	+	-15.0563	0.00922	0.559	AATAAGA
--- a/test-data/fimo_output_test3.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/fimo_output_test3.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -1,14 +1,10 @@
 <?xml version="1.0" encoding="UTF-8" standalone="no"?>
 <!-- Begin document body -->
-<fimo version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
+<fimo version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation=  xmlns:fimo="http://noble.gs.washington.edu/schema/fimo"
 >
-<command-line>fimo -o ./fimo_test4_out --thresh 0.01 --bgfile --uniform-- --max-stored-scores 100000 --motif ACTAAYH --motif-pseudo 0.1 dreme_fimo_input_1.xml hsa_chrM.fa</command-line>
 <settings>
-<setting name="output directory">./fimo_test4_out</setting>
-<setting name="MEME file name">dreme_fimo_input_1.xml</setting>
-<setting name="sequence file name">hsa_chrM.fa</setting>
 <setting name="background file name">--uniform--</setting>
 <setting name="allow clobber">false</setting>
 <setting name="compute q-values">true</setting>
--- a/test-data/meme_output_test1.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test1.html	Wed Dec 11 18:05:15 2019 -0500
@@ -7,7999 +7,18 @@
       // @JSON_VAR data
       var data = {
         "program": "MEME",
-        "version": "4.12.0",
-        "release": "Tue Jun 27 16:22:50 2017 -0700",
+        "version": "5.0.5",
+        "release": "Mon Mar 18 20:12:19 2019 -0700",
         "stop_reason": "Stopped because requested number of motifs (1) found.",
         "cmd": [
-          "meme", "meme_input_1.fasta", "-o", "meme_test1_out", "-nostatus",
-          "-maxsize", "1000000"
+          "meme",
+          "-o",
+          "-nostatus", "-maxsize", "1000000"
         ],
         "options": {
-          "mod": "zoops",
-          "revcomp": false,
-          "nmotifs": 1,
-          "minw": 8,
-          "maxw": 50,
-          "minsites": 2,
-          "maxsites": 30,
-          "wnsites": 0.8,
-          "spmap": "pam",
-          "spfuzz": 120,
-          "maxwords": -1,
-          "prior": "megap",
-          "b": 7500,
-          "maxiter": 50,
-          "distance": 1e-05,
-          "wg": 11,
-          "ws": 1,
-          "noendgaps": false,
-          "substring": true
-        },
-        "alphabet": {
-          "name": "Protein",
-          "like": "protein",
-          "ncore": 20,
-          "symbols": [
-            {
-              "symbol": "A",
-              "name": "Alanine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "C",
-              "name": "Cysteine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "D",
-              "name": "Aspartic acid",
-              "colour": "FF00FF"
-            }, {
-              "symbol": "E",
-              "name": "Glutamic acid",
-              "colour": "FF00FF"
-            }, {
-              "symbol": "F",
-              "name": "Phenylalanine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "G",
-              "name": "Glycine",
-              "colour": "FFB300"
-            }, {
-              "symbol": "H",
-              "name": "Histidine",
-              "colour": "FFCCCC"
-            }, {
-              "symbol": "I",
-              "name": "Isoleucine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "K",
-              "name": "Lysine",
-              "colour": "CC0000"
-            }, {
-              "symbol": "L",
-              "name": "Leucine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "M",
-              "name": "Methionine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "N",
-              "name": "Asparagine",
-              "colour": "008000"
-            }, {
-              "symbol": "P",
-              "name": "Proline",
-              "colour": "FFFF00"
-            }, {
-              "symbol": "Q",
-              "name": "Glutamine",
-              "colour": "008000"
-            }, {
-              "symbol": "R",
-              "name": "Arginine",
-              "colour": "CC0000"
-            }, {
-              "symbol": "S",
-              "name": "Serine",
-              "colour": "008000"
-            }, {
-              "symbol": "T",
-              "name": "Threonine",
-              "colour": "008000"
-            }, {
-              "symbol": "V",
-              "name": "Valine",
-              "colour": "0000CC"
-            }, {
-              "symbol": "W",
-              "name": "Tryptophan",
-              "colour": "0000CC"
-            }, {
-              "symbol": "Y",
-              "name": "Tyrosine",
-              "colour": "33E6CC"
-            }, {
-              "symbol": "X",
-              "aliases": "*.",
-              "name": "Any amino acid",
-              "equals": "ACDEFGHIKLMNPQRSTVWY"
-            }, {
-              "symbol": "B",
-              "name": "Asparagine or Aspartic acid",
-              "equals": "DN"
-            }, {
-              "symbol": "Z",
-              "name": "Glutamine or Glutamic acid",
-              "equals": "EQ"
-            }, {
-              "symbol": "J",
-              "name": "Leucine or Isoleucine",
-              "equals": "IL"
-            }
-          ]
-        },
-        "background": {
-          "freqs": [
-            0.291, 0.229, 0.001, 0.001, 0.001, 0.255, 0.001, 0.001, 0.001,
-            0.001, 0.001, 0.001, 0.001, 0.001, 0.001, 0.001, 0.215, 0.001,
-            0.001, 0.001
-          ]
-        },
-        "sequence_db": {
-          "source": "meme_input_1.fasta",
-          "psp_source": "prior30.plib",
-          "freqs": [
-            0.294, 0.231, 0.000, 0.000, 0.000, 0.257, 0.000, 0.000, 0.000,
-            0.000, 0.000, 0.000, 0.000, 0.000, 0.000, 0.000, 0.217, 0.000,
-            0.000, 0.000
-          ],
-          "sequences": [
-            {
-              "name": "chr21_19617074_19617124_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_26934381_26934431_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_28217753_28217803_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31710037_31710087_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31744582_31744632_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31768316_31768366_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31914206_31914256_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31933633_31933683_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31962741_31962791_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31964683_31964733_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31973364_31973414_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31992870_31992920_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32185595_32185645_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32202076_32202126_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32253899_32253949_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32410820_32410870_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_36411748_36411798_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_37838750_37838800_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45705687_45705737_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45971413_45971463_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45978668_45978718_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45993530_45993580_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46020421_46020471_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46031920_46031970_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46046964_46047014_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46057197_46057247_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46086869_46086919_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46102103_46102153_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_47517957_47518007_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_47575506_47575556_-",
-              "length": 50,
-              "weight": 1.000000
-            }
-          ]
         },
         "motifs": [
-          {
-            "db": 0,
-            "id": "GGGGTATAAAA",
-            "alt": "MEME-1",
-            "len": 11,
-            "nsites": 25,
-            "evalue": "2.4e-011",
-            "ic": 40.0,
-            "re": 13.8,
-            "llr": 239,
-            "bt": 5.33554,
-            "time": 0.772000,
-            "psm": [
-              [
-                -32, -680, 91, 77, 7, 138, -20, 55, 64, 107, 11, 150, 142, 72,
-                87, 396, -148, 221, -140, -36
-              ], [
-                -11, -680, 89, 76, 7, 137, -21, 55, 63, 107, 10, 149, 141, 71,
-                87, 396, -239, 220, -140, -36
-              ], [
-                -79, 41, 4, 21, -7, 44, -62, 42, -5, 99, 0, 99, 138, 52, 42,
-                399, -46, 223, -173, -68
-              ], [
-                11, -677, 48, 47, -2, 127, -43, 46, 27, 101, 3, 124, 138, 60,
-                62, 397, -235, 220, -160, -55
-              ], [
-                -596, -820, 12, -21, -53, -267, -74, 37, 16, 44, -37, 98, 31,
-                9, 19, 319, 212, 127, -193, -95
-              ], [
-                165, -261, 70, 110, 77, -521, -4, 147, 95, 201, 90, 121, 124,
-                91, 107, 425, -527, 314, -95, 8
-              ], [
-                -838, -990, -89, -149, -151, -841, -161, -117, -113, -66,
-                -209, -68, -69, -129, -91, 111, 221, -55, -255, -173
-              ], [
-                176, -858, -79, -103, -115, -717, -148, -95, -108, -17, -162,
-                -61, -12, -95, -69, 193, -737, 52, -240, -153
-              ], [
-                134, -686, 0, 16, -12, -553, -68, 44, -8, 96, -9, 88, 124, 41,
-                36, 384, 11, 216, -177, -71
-              ], [
-                165, -261, 70, 110, 77, -521, -4, 147, 95, 201, 90, 121, 124,
-                91, 107, 425, -527, 314, -95, 8
-              ], [
-                147, -614, 89, 129, 93, -121, 12, 160, 113, 217, 108, 144,
-                144, 111, 125, 447, -241, 332, -81, 22
-              ]
-            ],
-            "pwm": [
-              [
-                0.240000, 0.000000, 0.000000, 0.000000, 0.000000, 0.680000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.080000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.280000, 0.000000, 0.000000, 0.000000, 0.000000, 0.680000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.040000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.160000, 0.320000, 0.000000, 0.000000, 0.000000, 0.360000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.160000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.320000, 0.000000, 0.000000, 0.000000, 0.000000, 0.640000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.040000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.040000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.960000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.960000, 0.040000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 1.000000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                1.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.760000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.240000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.960000, 0.040000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000
-              ], [
-                0.840000, 0.000000, 0.000000, 0.000000, 0.000000, 0.120000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.000000, 0.000000,
-                0.000000, 0.000000, 0.000000, 0.000000, 0.040000, 0.000000,
-                0.000000, 0.000000
-              ]
-            ],
-            "sites": [
-              {
-                "seq": 24,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 1.06e-06,
-                "lflank": "AAGGCCAGGA",
-                "match": "GGGGTATAAAA",
-                "rflank": "GCCTGAGAGC"
-              }, {
-                "seq": 25,
-                "pos": 36,
-                "rc": false,
-                "pvalue": 3.41e-06,
-                "lflank": "ACAGGCCCTG",
-                "match": "GGCATATAAAA",
-                "rflank": "GCC"
-              }, {
-                "seq": 19,
-                "pos": 9,
-                "rc": false,
-                "pvalue": 3.41e-06,
-                "lflank": "CAGGCCCTG",
-                "match": "GGCATATAAAA",
-                "rflank": "GCCCCAGCAG"
-              }, {
-                "seq": 9,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 3.41e-06,
-                "lflank": "GATTCACTGA",
-                "match": "GGCATATAAAA",
-                "rflank": "GGCCCTCTGC"
-              }, {
-                "seq": 21,
-                "pos": 7,
-                "rc": false,
-                "pvalue": 4.00e-06,
-                "lflank": "CCAAGGA",
-                "match": "GGAGTATAAAA",
-                "rflank": "GCCCCACAAA"
-              }, {
-                "seq": 13,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 5.01e-06,
-                "lflank": "CCACCAGCTT",
-                "match": "GAGGTATAAAA",
-                "rflank": "AGCCCTGTAC"
-              }, {
-                "seq": 23,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 6.06e-06,
-                "lflank": "ATACCCAGGG",
-                "match": "AGGGTATAAAA",
-                "rflank": "CCTCAGCAGC"
-              }, {
-                "seq": 15,
-                "pos": 21,
-                "rc": false,
-                "pvalue": 8.67e-06,
-                "lflank": "AATCACTGAG",
-                "match": "GATGTATAAAA",
-                "rflank": "GTCCCAGGGA"
-              }, {
-                "seq": 12,
-                "pos": 18,
-                "rc": false,
-                "pvalue": 8.67e-06,
-                "lflank": "CACCAGAGCT",
-                "match": "GGGATATATAA",
-                "rflank": "AGAAGGTTCT"
-              }, {
-                "seq": 11,
-                "pos": 16,
-                "rc": false,
-                "pvalue": 8.67e-06,
-                "lflank": "CACTATTGAA",
-                "match": "GATGTATAAAA",
-                "rflank": "TTTCATTTGC"
-              }, {
-                "seq": 22,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 1.21e-05,
-                "lflank": "GA",
-                "match": "GACATATAAAA",
-                "rflank": "GCCAACATCC"
-              }, {
-                "seq": 28,
-                "pos": 32,
-                "rc": false,
-                "pvalue": 1.59e-05,
-                "lflank": "CCGGCGGGGC",
-                "match": "GGGGTATAAAG",
-                "rflank": "GGGGCGG"
-              }, {
-                "seq": 20,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 1.59e-05,
-                "lflank": "CAGA",
-                "match": "GGGGTATAAAG",
-                "rflank": "GTTCCGACCA"
-              }, {
-                "seq": 6,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 1.68e-05,
-                "lflank": "CCCACTACTT",
-                "match": "AGAGTATAAAA",
-                "rflank": "TCATTCTGAG"
-              }, {
-                "seq": 14,
-                "pos": 19,
-                "rc": false,
-                "pvalue": 2.03e-05,
-                "lflank": "CACCAGCAAG",
-                "match": "GATATATAAAA",
-                "rflank": "GCTCAGGAGT"
-              }, {
-                "seq": 4,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 3.06e-05,
-                "lflank": "CAGGTCTAAG",
-                "match": "AGCATATATAA",
-                "rflank": "CTTGGAGTCC"
-              }, {
-                "seq": 0,
-                "pos": 39,
-                "rc": false,
-                "pvalue": 3.06e-05,
-                "lflank": "CCTCGGGACG",
-                "match": "TGGGTATATAA",
-                "rflank": ""
-              }, {
-                "seq": 18,
-                "pos": 37,
-                "rc": false,
-                "pvalue": 3.82e-05,
-                "lflank": "CGTGGTCGCG",
-                "match": "GGGGTATAACA",
-                "rflank": "GC"
-              }, {
-                "seq": 5,
-                "pos": 0,
-                "rc": false,
-                "pvalue": 3.82e-05,
-                "lflank": "",
-                "match": "AACGTATATAA",
-                "rflank": "ATGGTCCTGT"
-              }, {
-                "seq": 29,
-                "pos": 30,
-                "rc": false,
-                "pvalue": 4.02e-05,
-                "lflank": "GCTGCCGGTG",
-                "match": "AGCGTATAAAG",
-                "rflank": "GCCCTGGCG"
-              }, {
-                "seq": 1,
-                "pos": 27,
-                "rc": false,
-                "pvalue": 5.52e-05,
-                "lflank": "AGTCACAAGT",
-                "match": "GAGTTATAAAA",
-                "rflank": "GGGTCGCACG"
-              }, {
-                "seq": 3,
-                "pos": 14,
-                "rc": false,
-                "pvalue": 5.94e-05,
-                "lflank": "CCCAGGTTTC",
-                "match": "TGAGTATATAA",
-                "rflank": "TCGCCGCACC"
-              }, {
-                "seq": 16,
-                "pos": 22,
-                "rc": false,
-                "pvalue": 6.78e-05,
-                "lflank": "AGTTTCAGTT",
-                "match": "GGCATCTAAAA",
-                "rflank": "attatataac"
-              }, {
-                "seq": 7,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 2.08e-04,
-                "lflank": "TC",
-                "match": "AGAGTATATAT",
-                "rflank": "AAATGTTCCT"
-              }, {
-                "seq": 8,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 4.05e-04,
-                "lflank": "TATAACTCAG",
-                "match": "GTTGGATAAAA",
-                "rflank": "TAATTTGTAC"
-              }
-            ]
-          }
-        ],
         "scan": [
-          {
-            "pvalue": 1.22e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 39,
-                "rc": false,
-                "pvalue": 3.06e-05
-              }
-            ]
-          }, {
-            "pvalue": 2.21e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 27,
-                "rc": false,
-                "pvalue": 5.52e-05
-              }
-            ]
-          }, {
-            "pvalue": 7.29e-01,
-            "sites": []
-          }, {
-            "pvalue": 2.37e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 14,
-                "rc": false,
-                "pvalue": 5.94e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.22e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 3.06e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.53e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 0,
-                "rc": false,
-                "pvalue": 3.82e-05
-              }
-            ]
-          }, {
-            "pvalue": 6.70e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 1.68e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.81e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 4.54e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.61e-02,
-            "sites": []
-          }, {
-            "pvalue": 1.36e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 3.41e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.99e-01,
-            "sites": []
-          }, {
-            "pvalue": 3.47e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 16,
-                "rc": false,
-                "pvalue": 8.67e-06
-              }
-            ]
-          }, {
-            "pvalue": 3.47e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 18,
-                "rc": false,
-                "pvalue": 8.67e-06
-              }
-            ]
-          }, {
-            "pvalue": 2.01e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 5.01e-06
-              }
-            ]
-          }, {
-            "pvalue": 8.11e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 19,
-                "rc": false,
-                "pvalue": 2.03e-05
-              }
-            ]
-          }, {
-            "pvalue": 3.47e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 21,
-                "rc": false,
-                "pvalue": 8.67e-06
-              }
-            ]
-          }, {
-            "pvalue": 2.71e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 22,
-                "rc": false,
-                "pvalue": 6.78e-05
-              }
-            ]
-          }, {
-            "pvalue": 8.23e-02,
-            "sites": []
-          }, {
-            "pvalue": 1.53e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 37,
-                "rc": false,
-                "pvalue": 3.82e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.36e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 9,
-                "rc": false,
-                "pvalue": 3.41e-06
-              }
-            ]
-          }, {
-            "pvalue": 6.37e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 1.59e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.60e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 7,
-                "rc": false,
-                "pvalue": 4.00e-06
-              }
-            ]
-          }, {
-            "pvalue": 4.83e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 1.21e-05
-              }
-            ]
-          }, {
-            "pvalue": 2.43e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 6.06e-06
-              }
-            ]
-          }, {
-            "pvalue": 4.26e-05,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 1.06e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.36e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 36,
-                "rc": false,
-                "pvalue": 3.41e-06
-              }
-            ]
-          }, {
-            "pvalue": 4.30e-02,
-            "sites": []
-          }, {
-            "pvalue": 4.30e-02,
-            "sites": []
-          }, {
-            "pvalue": 6.37e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 32,
-                "rc": false,
-                "pvalue": 1.59e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.61e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 30,
-                "rc": false,
-                "pvalue": 4.02e-05
-              }
-            ]
-          }
-        ]
-      };
     </script>
-    <script>
 var site_url = "http://meme-suite.org";
-</script>
-    <script>
-
-/*
- * $
- *
- * Shorthand function for getElementById
- */
-function $(el) {
-  return document.getElementById(el);
-}
-
-
-/*
- * See http://stackoverflow.com/a/5450113/66387
- * Does string multiplication like the perl x operator.
- */
-function string_mult(pattern, count) {
-    if (count < 1) return '';
-    var result = '';
-    while (count > 1) {
-        if (count & 1) result += pattern;
-        count >>= 1, pattern += pattern;
-    }
-    return result + pattern;
-}
-
-/*
- * See http://stackoverflow.com/questions/814613/how-to-read-get-data-from-a-url-using-javascript
- * Slightly modified with information from
- * https://developer.mozilla.org/en/DOM/window.location
- */
-function parse_params() {
-  "use strict";
-  var search, queryStart, queryEnd, query, params, nvPairs, i, nv, n, v;
-  search = window.location.search;
-  queryStart = search.indexOf("?") + 1;
-  queryEnd   = search.indexOf("#") + 1 || search.length + 1;
-  query      = search.slice(queryStart, queryEnd - 1);
-
-  if (query === search || query === "") return {};
-
-  params  = {};
-  nvPairs = query.replace(/\+/g, " ").split("&");
-
-  for (i = 0; i < nvPairs.length; i++) {
-    nv = nvPairs[i].split("=");
-    n  = decodeURIComponent(nv[0]);
-    v  = decodeURIComponent(nv[1]);
-    // allow a name to be used multiple times
-    // storing each value in the array
-    if (!(n in params)) {
-      params[n] = [];
-    }
-    params[n].push(nv.length === 2 ? v : null);
-  }
-  return params;
-}
-
-/*
- * coords
- *
- * Calculates the x and y offset of an element.
- * From http://www.quirksmode.org/js/findpos.html
- * with alterations to take into account scrolling regions
- */
-function coords(elem) {
-  var myX = myY = 0;
-  if (elem.getBoundingClientRect) {
-    var rect;
-    rect = elem.getBoundingClientRect();
-    myX = rect.left + ((typeof window.pageXOffset !== "undefined") ?
-        window.pageXOffset : document.body.scrollLeft);
-    myY = rect.top + ((typeof window.pageYOffset !== "undefined") ?
-        window.pageYOffset : document.body.scrollTop);
-  } else {
-    // this fall back doesn't properly handle absolutely positioned elements
-    // inside a scrollable box
-    var node;
-    if (elem.offsetParent) {
-      // subtract all scrolling
-      node = elem;
-      do {
-        myX -= node.scrollLeft ? node.scrollLeft : 0;
-        myY -= node.scrollTop ? node.scrollTop : 0;
-      } while (node = node.parentNode);
-      // this will include the page scrolling (which is unwanted) so add it back on
-      myX += (typeof window.pageXOffset !== "undefined") ? window.pageXOffset : document.body.scrollLeft;
-      myY += (typeof window.pageYOffset !== "undefined") ? window.pageYOffset : document.body.scrollTop;
-      // sum up offsets
-      node = elem;
-      do {
-        myX += node.offsetLeft;
-        myY += node.offsetTop;
-      } while (node = node.offsetParent);
-    }
-  }
-  return [myX, myY];
-}
-
-/*
- * position_popup
- *
- * Positions a popup relative to an anchor element.
- *
- * The avaliable positions are:
- * 0 - Centered below the anchor.
- */
-function position_popup(anchor, popup, position) {
-  "use strict";
-  var a_x, a_y, a_w, a_h, p_x, p_y, p_w, p_h;
-  var a_xy, spacer, margin, scrollbar, page_w;
-  // define constants
-  spacer = 5;
-  margin = 15;
-  scrollbar = 15;
-  // define the positions and widths
-  a_xy = coords(anchor);
-  a_x = a_xy[0];
-  a_y = a_xy[1];
-  a_w = anchor.offsetWidth;
-  a_h = anchor.offsetHeight;
-  p_w = popup.offsetWidth;
-  p_h = popup.offsetHeight;
-  page_w = null;
-  if (window.innerWidth) {
-    page_w = window.innerWidth;
-  } else if (document.body) {
-    page_w = document.body.clientWidth;
-  }
-  // check the position type is defined
-  if (typeof position !== "number") {
-    position = 0;
-  }
-  // calculate the popup position
-  switch (position) {
-    case 1:
-      p_x = a_x + a_w + spacer;
-      p_y = a_y + (a_h / 2) - (p_h / 2);
-      break;
-    case 0:
-    default:
-      p_x = a_x + (a_w / 2) - (p_w / 2);
-      p_y = a_y + a_h + spacer;
-      break;
-  }
-  // constrain the popup position
-  if (p_x < margin) {
-    p_x = margin;
-  } else if (page_w != null && (p_x + p_w) > (page_w - margin - scrollbar)) {
-    p_x = page_w - margin - scrollbar - p_w;
-  }
-  if (p_y < margin) {
-    p_y = margin;
-  }
-  // position the popup
-  popup.style.left = p_x + "px";
-  popup.style.top = p_y + "px";
-}
-
-function lookup_help_popup(popup_id) {
-  var _body, pop, info;
-  pop = document.getElementById(popup_id);
-  if (pop == null) {
-    _body = document.getElementsByTagName("body")[0];
-    pop = document.createElement("div");
-    pop.className = "pop_content";
-    pop.id = popup_id;
-    pop.style.backgroundColor = "#FFC";
-    pop.style.borderColor = "black";
-    info = document.createElement("p");
-    info.style.fontWeight = "bold";
-    info.appendChild(document.createTextNode("Error: No popup for topic \"" + popup_id + "\"."));
-    pop.appendChild(info);
-    // this might cause problems with the menu, but as this only happens
-    // when something is already wrong I don't think that's too much of a problem
-    _body.insertBefore(pop, _body.firstChild);
-  }
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-autobtns")) {
-    if (!/\bauto_buttons\b/.test(pop.className)) {
-      pop.className += " auto_buttons";
-      var back_btn_sec = document.createElement("div");
-      back_btn_sec.className = "nested_only pop_back_sec";
-      var back_btn = document.createElement("span");
-      back_btn.className = "pop_back";
-      back_btn.appendChild(document.createTextNode("<< back"));
-      back_btn.addEventListener("click", function(e) {
-        help_return();
-      }, false);
-      back_btn_sec.appendChild(back_btn);
-      pop.insertBefore(back_btn_sec, pop.firstChild);
-      var close_btn_sec = document.createElement("div");
-      close_btn_sec.className = "pop_close_sec";
-      var close_btn = document.createElement("span");
-      close_btn.className = "pop_close";
-      close_btn.appendChild(document.createTextNode("close"));
-      close_btn.addEventListener("click", function(e) {
-        help_popup();
-      }, false);
-      close_btn_sec.appendChild(close_btn);
-      pop.appendChild(close_btn_sec);
-    }
-  }
-  return pop;
-}
-
-/*
- * help_popup
- *
- * Moves around help pop-ups so they appear
- * below an activator.
- */
-function help_popup(activator, popup_id) {
-  "use strict";
-  var pop;
-  // set default values
-  if (typeof help_popup.popup === "undefined") {
-    help_popup.popup = [];
-  }
-  if (typeof help_popup.activator === "undefined") {
-    help_popup.activator = null;
-  }
-  var last_pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (typeof(activator) == "undefined") { // no activator so hide
-    if (last_pop != null) {
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-    }
-    return;
-  }
-  pop = lookup_help_popup(popup_id);
-  if (pop == last_pop) {
-    if (activator == help_popup.activator) {
-      //hide popup (as we've already shown it for the current help button)
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-      return; // toggling complete!
-    }
-  } else if (last_pop != null) {
-    //activating different popup so hide current one
-    last_pop.style.display = 'none';
-  }
-  help_popup.popup = [pop];
-  help_popup.activator = activator;
-  toggle_class(pop, "nested", false);
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = 'block';
-  position_popup(activator, pop);
-}
-
-/*
- * help_refine
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_refine(popup_id) {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not refine a help popup when one is not shown!");
-  }
-  var pop = lookup_help_popup(popup_id);
-  var last_pop = help_popup.popup[help_popup.popup.length - 1];
-  if (pop == last_pop) return; // slightly odd, but no real cause for alarm
-  help_popup.popup.push(pop);
-  toggle_class(pop, "nested", true);
-  last_pop.style.display = "none";
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = "block";
-  position_popup(help_popup.activator, pop);
-}
-
-/*
- * help_return
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_return() {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not return to a earlier help popup when one is not shown!");
-  }
-  var last_pop = help_popup.popup.pop();
-  last_pop.style.display = "none";
-  var pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (pop != null) {
-    toggle_class(pop, "nested", help_popup.popup.length > 1);
-    pop.style.display = "block";
-    position_popup(help_popup.activator, pop);
-  } else {
-    help_popup.activator = null;
-  }
-}
-
-/*
- * update_scroll_pad
- *
- * Creates padding at the bottom of the page to allow
- * scrolling of anything into view.
- */
-function update_scroll_pad() {
-  var page, pad;
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  pad = $("scrollpad");
-  if (pad === null) {
-    pad = document.createElement("div");
-    pad.id = 'scrollpad';
-    document.getElementsByTagName('body')[0].appendChild(pad);
-  }
-  pad.style.height = Math.abs(page.clientHeight - 100) + "px";
-}
-
-function substitute_classes(node, remove, add) {
-  "use strict";
-  var list, all, i, cls, classes;
-  list = node.className.split(/\s+/);
-  all = {};
-  for (i = 0; i < list.length; i++) {
-    if (list[i].length > 0) all[list[i]] = true;
-  }
-  for (i = 0; i < remove.length; i++) {
-    if (all.hasOwnProperty(remove[i])) {
-      delete all[remove[i]];
-    }
-  }
-  for (i = 0; i < add.length; i++) {
-    all[add[i]] = true;
-  }
-  classes = "";
-  for (cls in all) {
-    classes += cls + " ";
-  }
-  node.className = classes;
-}
-
-/*
- * toggle_class
- *
- * Adds or removes a class from the node. If the parameter 'enabled' is not 
- * passed then the existence of the class will be toggled, otherwise it will be
- * included if enabled is true.
- */
-function toggle_class(node, cls, enabled) {
-  var classes = node.className;
-  var list = classes.replace(/^\s+/, '').replace(/\s+$/, '').split(/\s+/);
-  var found = false;
-  for (var i = 0; i < list.length; i++) {
-    if (list[i] == cls) {
-      list.splice(i, 1);
-      i--;
-      found = true;
-    }
-  }
-  if (typeof enabled == "undefined") {
-    if (!found) list.push(cls);
-  } else {
-    if (enabled) list.push(cls);
-  }
-  node.className = list.join(" ");
-}
-
-/*
- * find_child
- *
- * Searches child nodes in depth first order and returns the first it finds
- * with the className specified.
- * TODO replace with querySelector
- */
-function find_child(node, className) {
-  var pattern;
-  if (node == null || typeof node !== "object") {
-    return null;
-  }
-  if (typeof className === "string") {
-    pattern = new RegExp("\\b" + className + "\\b");
-  } else {
-    pattern = className;
-  }
-  if (node.nodeType == Node.ELEMENT_NODE && 
-      pattern.test(node.className)) {
-    return node;
-  } else {
-    var result = null;
-    for (var i = 0; i < node.childNodes.length; i++) {
-      result = find_child(node.childNodes[i], pattern);
-      if (result != null) break;
-    }
-    return result;
-  }
-}
-
-/*
- * find_parent
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the className specified.
- */
-function find_parent(node, className) {
-  var pattern;
-  pattern = new RegExp("\\b" + className + "\\b");
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && 
-        pattern.test(node.className)) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * find_parent_tag
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the tag name specified. HTML tags should be specified in upper case.
- */
-function find_parent_tag(node, tag_name) {
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && node.tagName == tag_name) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * __toggle_help
- *
- * Uses the 'topic' property of the this object to
- * toggle display of a help topic.
- *
- * This function is not intended to be called directly.
- */
-function __toggle_help(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-
-  help_popup(this, this.getAttribute("data-topic"));
-}
-
-function setup_help_button(button) {
-  "use strict";
-  var topic;
-  if (button.hasAttribute("data-topic")) {
-    topic = button.getAttribute("data-topic");
-    if (document.getElementById(topic) != null) {
-      button.tabIndex = "0"; // make keyboard selectable
-      button.addEventListener("click", function() {
-        help_popup(button, topic);
-      }, false);
-      button.addEventListener("keydown", function(e) {
-        // toggle only on Enter or Spacebar, let other keys do their thing
-        if (e.keyCode !== 13 && e.keyCode !== 32) return;
-        // stop a submit or something like that
-        e.preventDefault();
-        help_popup(button, topic);
-      }, false);
-    } else {
-      button.style.visibility = "hidden";
-    }
-  }
-  button.className += " active";
-}
-
-/*
- * help_button
- *
- * Makes a help button for the passed topic.
- */
-function help_button(topic) {
-  var btn = document.createElement("div");
-  btn.className = "help";
-  btn.setAttribute("data-topic", topic);
-  setup_help_button(btn);
-  return btn;
-}
-
-/*
- * prepare_download
- *
- * Sets the attributes of a link to setup a file download using the given content.
- * If no link is provided then create one and click it.
- */
-function prepare_download(content, mimetype, filename, link) {
-  "use strict";
-  // if no link is provided then create one and click it
-  var click_link = false;
-  if (!link) {
-    link = document.createElement("a");
-    click_link = true;
-  }
-  try {
-    // Use a BLOB to convert the text into a data URL.
-    // We could do this manually with a base 64 conversion.
-    // This will only be supported on modern browsers,
-    // hence the try block.
-    var blob = new Blob([content], {type: mimetype});
-    var reader = new FileReader();
-    reader.onloadend = function() {
-      // If we're lucky the browser will also support the download
-      // attribute which will let us suggest a file name to save the link.
-      // Otherwise it is likely that the filename will be unintelligible. 
-      link.setAttribute("download", filename);
-      link.href = reader.result;
-      if (click_link) {
-        // must add the link to click it
-        document.body.appendChild(link);
-        link.click();
-        document.body.removeChild(link);
-      }
-    }
-    reader.readAsDataURL(blob);
-  } catch (error) {
-    if (console && console.log) console.log(error);
-    // probably an old browser
-    link.href = "";
-    link.visible = false;
-  }
-}
-
-/*
- * add_cell
- *
- * Add a cell to the table row.
- */
-function add_cell(row, node, cls, click_action) {
-  var cell = row.insertCell(row.cells.length);
-  if (node) cell.appendChild(node);
-  if (cls && cls !== "") cell.className = cls;
-  if (click_action) cell.addEventListener("click", click_action, false);
-}
-
-/*
- * add_header_cell
- *
- * Add a header cell to the table row.
- */
-function add_header_cell(row, node, help_topic, cls, colspan) {
-  var th = document.createElement("th");
-  if (node) th.appendChild(node);
-  if (help_topic && help_topic !== "") th.appendChild(help_button(help_topic));
-  if (cls && cls !== "") th.className = cls;
-  if (typeof colspan == "number" && colspan > 1) th.colSpan = colspan;
-  row.appendChild(th);
-}
-
-/*
- * add_text_cell
- *
- * Add a text cell to the table row.
- */
-function add_text_cell(row, text, cls, action) {
-  var node = null;
-  if (typeof(text) != 'undefined') node = document.createTextNode(text);
-  add_cell(row, node, cls, action);
-}
-
-/*
- * add_text_header_cell
- *
- * Add a text header cell to the table row.
- */
-function add_text_header_cell(row, text, help_topic, cls, action, colspan) {
-  var node = null;
-  if (typeof(text) != 'undefined') {
-    var nbsp = (help_topic ? "\u00A0" : "");
-    var str = "" + text;
-    var parts = str.split(/\n/);
-    if (parts.length === 1) {
-      if (action) {
-        node = document.createElement("span");
-        node.appendChild(document.createTextNode(str + nbsp));
-      } else {
-        node = document.createTextNode(str + nbsp);
-      }
-    } else {
-      node = document.createElement("span");
-      for (var i = 0; i < parts.length; i++) {
-        if (i !== 0) {
-          node.appendChild(document.createElement("br"));
-        }
-        node.appendChild(document.createTextNode(parts[i]));
-      }
-    }
-    if (action) {
-      node.addEventListener("click", action, false);
-      node.style.cursor = "pointer";
-    }
-  }
-  add_header_cell(row, node, help_topic, cls, colspan);
-}
-
-function setup_help() {
-  "use strict";
-  var help_buttons, i;
-  help_buttons = document.querySelectorAll(".help:not(.active)");
-  for (i = 0; i < help_buttons.length; i++) {
-    setup_help_button(help_buttons[i]);
-  }
-}
-
-function setup_scrollpad() {
-  "use strict";
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-scrollpad") && document.getElementById("scrollpad") == null) {
-    window.addEventListener("resize", update_scroll_pad, false);
-    update_scroll_pad();
-  }
-}
-
-// anon function to avoid polluting global scope
-(function() {
-  "use strict";
-  window.addEventListener("load", function load(evt) {
-    window.removeEventListener("load", load, false);
-    setup_help();
-    setup_scrollpad();
-  }, false);
-})();
-
-/*
- *  make_link
- *
- *  Creates a text node and if a URL is specified it surrounds it with a link.
- *  If the URL doesn't begin with "http://" it automatically adds it, as
- *  relative links don't make much sense in this context.
- */
-function make_link(text, url) {
-  var textNode = null;
-  var link = null;
-  if (typeof text !== "undefined" && text !== null) textNode = document.createTextNode(text);
-  if (typeof url === "string") {
-    if (url.indexOf("//") == -1) {
-      url = "http://" + url;
-    }
-    link = document.createElement('a');
-    link.href = url;
-    if (textNode) link.appendChild(textNode);
-    return link;
-  }
-  return textNode;
-}
-</script>
-    <script>
-      // 
-      // return true if any part of the passed element is visible in the viewport
-      //
-      function element_in_viewport(elem) {
-        var rect;
-        try {
-          rect = elem.getBoundingClientRect();
-        } catch (e) {
-          return false;
-        }
-        return (
-            rect.top < (window.innerHeight || document.body.clientHeight) &&
-            rect.bottom > 0 &&
-            rect.left < (window.innerWidth || document.body.clientWidth) &&
-            rect.right > 0
-            );
-      }
-
-      //
-      // Functions to delay a drawing task until it is required or it would not lag the display to do so
-      //
-
-      // a list of items still to be drawn
-      var drawable_list = [];
-      // the delay between drawing objects that are not currently visible
-      var draw_delay = 1;
-      // the delay after a user interaction
-      var user_delay = 300;
-      // the delay after a user has stopped scrolling and is viewing the stuff drawn on the current page
-      var stop_delay = 300;
-      // the timer handle; allows resetting of the timer after user interactions
-      var draw_timer = null;
-
-      //
-      // Drawable
-      //
-      // elem - a page element which defines the position on the page that drawing is to be done
-      // task - an object with the method run which takes care of painting the object
-      //
-      var Drawable = function(elem, task) {
-        this.elem = elem;
-        this.task = task;
-      }
-
-      //
-      // Drawable.is_visible
-      //
-      // Determines if the element is visible in the viewport
-      //
-      Drawable.prototype.is_visible = function() {
-        return element_in_viewport(this.elem);
-      }
-
-      //
-      // Drawable.run
-      //
-      // Run the task held by the drawable
-      Drawable.prototype.run = function() {
-        if (this.task) this.task.run();
-        this.task = null;
-      }
-
-      //
-      // Drawable.run
-      //
-      // Run the task iff visible
-      // returns true if the task ran or has already run
-      Drawable.prototype.run_visible = function() {
-        if (this.task) {
-          if (element_in_viewport(this.elem)) {
-            this.task.run();
-            this.task = null;
-            return true;
-          }
-          return false;
-        } else {
-          return true;
-        }
-      }
-
-      //
-      // draw_on_screen
-      //
-      // Checks each drawable object and draws those on screen.
-      //
-      function draw_on_screen() {
-        var found = false;
-        for (var i = 0; i < drawable_list.length; i++) {
-          if (drawable_list[i].run_visible()) {
-            drawable_list.splice(i--, 1);
-            found = true;
-          }
-        }
-        return found;
-      }
-
-      //
-      // process_draw_tasks
-      //
-      // Called on a delay to process the next avaliable
-      // draw task.
-      //
-      function process_draw_tasks() {
-        var delay = draw_delay;
-        draw_timer = null;
-        if (drawable_list.length == 0) return; //no more tasks
-        if (draw_on_screen()) {
-          delay = stop_delay; //give the user a chance to scroll
-        } else {
-          //get next task
-          var drawable = drawable_list.shift();
-          drawable.task.run();
-        }
-        //allow UI updates between tasks
-        draw_timer = window.setTimeout("process_draw_tasks()", delay);
-      }
-
-      //
-      // delayed_process_draw_tasks
-      //
-      // Call process_draw_tasks after a short delay.
-      // The delay serves to group multiple redundant events.       
-      // Should be set as event handler for onscroll and onresize.
-      //
-      function delayed_process_draw_tasks() {
-        //reset the timer
-        if (drawable_list.length > 0) { 
-          if (draw_timer != null) clearTimeout(draw_timer);
-          draw_timer = window.setTimeout("process_draw_tasks()", user_delay);
-        }
-      }
-
-      //
-      // add_draw_task
-      //
-      // Add a drawing task to be called immediately if it is
-      // visible, or to be called on a delay to reduce stuttering
-      // effect on the web browser.
-      function add_draw_task(elem, task) {
-        drawable = new Drawable(elem, task);
-        if (drawable.is_visible()) {
-          task.run();
-        } else {
-          drawable_list.push(drawable);
-          //reset timer
-          if (draw_timer != null) clearTimeout(draw_timer);
-          draw_timer = window.setTimeout("process_draw_tasks()", user_delay);
-        }
-      }
-
-</script>
-    <script>
-//======================================================================
-// start Alphabet object
-//======================================================================
-var Alphabet = function(alphabet, background) {
-  "use strict";
-  var i, j, sym, aliases, complement, comp_e_sym, ambigs, generate_background;
-  generate_background = (background == null);
-  if (generate_background) {
-    background = [];
-    for (i = 0; i < alphabet.ncore; i++) background[i] = 1.0 / alphabet.ncore;
-  } else if (alphabet.ncore != background.length) {
-    throw new Error("The background length does not match the alphabet length.");
-  }
-  this.name = alphabet.name;
-  this.like = (alphabet.like != null ? alphabet.like.toUpperCase() : null);
-  this.ncore = alphabet.ncore;
-  this.symbols = alphabet.symbols;
-  this.background = background;
-  this.genbg = generate_background;
-  this.encode = {};
-  this.encode2core = {};
-  this.complement = {};
-  // check if all symbols are same case
-  var seen_uc = false;
-  var seen_lc = false;
-  var check_case = function (syms) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        if (sym >= 'a' && sym <= 'z') seen_lc = true;
-        else if (sym >= 'A' && sym <= 'Z') seen_uc = true;
-      }
-    }
-  };
-  for (i = 0; i < this.symbols.length; i++) {
-    check_case(this.symbols[i].symbol);
-    check_case(this.symbols[i].aliases);
-  }
-  // now map symbols to indexes
-  var update_array = function(array, syms, index) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        array[sym] = index;
-        // when only a single case is used, then encode as case insensitive
-        if (seen_uc != seen_lc) {
-          if (sym >= 'a' && sym <= 'z') {
-            array[sym.toUpperCase()] = index;
-          } else if (sym >= 'A' && sym <= 'Z') {
-            array[sym.toLowerCase()] = index;
-          }
-        }
-      }
-    }
-  }
-  // map core symbols to index
-  for (i = 0; i < this.ncore; i++) {
-    update_array(this.encode2core, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode2core, this.symbols[i].aliases, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-  }
-  // map ambigous symbols to index
-  ambigs = {};
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-    ambigs[this.symbols[i].equals] = i;
-  }
-  // determine complements
-  for (i = 0; i < this.ncore; i++) {
-    complement = this.symbols[i].complement;
-    if (typeof complement === "string") {
-      this.complement[i] = this.encode2core[complement];
-    }
-  }
-  next_symbol:
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    complement = "";
-    for (j = 0; j < this.symbols[i].equals.length; j++) {
-      comp_e_sym = this.complement[this.encode2core[this.symbols[i].equals.charAt(j)]];
-      if (typeof comp_e_sym !== "number") continue next_symbol;
-      complement += this.symbols[comp_e_sym].symbol;
-    }
-    complement = complement.split("").sort().join("");
-    if (typeof ambigs[complement] === "number") {
-      this.complement[i] = ambigs[complement];
-    }
-  }
-  // determine case insensitivity
-  this.case_insensitive = true;
-  if (seen_uc == seen_lc) {
-    // when there is a mixture of cases it probably won't
-    // be case insensitive but we still need to check
-    loop:
-    for (i = 0; i < this.symbols.length; i++) {
-      sym = this.symbols[i].symbol;
-      if (sym >= 'A' && sym <= 'Z') {
-        if (this.encode[sym.toLowerCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      } else if (sym >= 'a' && sym <= 'z') {
-        if (this.encode[sym.toUpperCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      }
-      aliases = this.symbols[i].aliases;
-      if (aliases != null) {
-        for (j = 0; j < aliases.length; j++) {
-          sym = aliases.charAt(j);
-          if (sym >= 'A' && sym <= 'Z') {
-            if (this.encode[sym.toLowerCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          } else if (sym >= 'a' && sym <= 'z') {
-            if (this.encode[sym.toUpperCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          }
-        }
-      }
-    }
-  }
-  // normalise aliases to remove the prime symbol and eliminate
-  // the alternate cases when the alphabet is case insensitive
-  var seen, out;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym = this.symbols[i].symbol;
-    aliases = this.symbols[i].aliases;
-    if (typeof aliases != "string") aliases = "";
-    seen = {};
-    out = [];
-    if (this.case_insensitive) {
-      sym = sym.toUpperCase();
-      aliases = aliases.toUpperCase();
-    }
-    seen[sym] = true;
-    for (j = 0; j < aliases.length; j++) {
-      if (!seen[aliases.charAt(j)]) {
-        seen[aliases.charAt(j)] = true;
-        out.push(aliases.charAt(j));
-      }
-    }
-    this.symbols[i].aliases = out.sort().join("");
-  }
-};
-// return the name of the alphabet
-Alphabet.prototype.get_alphabet_name = function() {
-  return this.name;
-};
-// return if the alphabet can be complemented
-Alphabet.prototype.has_complement = function() {
-  return (typeof this.symbols[0].complement === "string");
-};
-// return true if an uppercase letter has the same meaning as the lowercase form
-Alphabet.prototype.is_case_insensitive = function() {
-  return this.case_insensitive;
-};
-// return the information content of an alphabet letter
-Alphabet.prototype.get_ic = function() {
-  return Math.log(this.ncore) / Math.LN2;
-};
-// return the count of the core alphabet symbols
-Alphabet.prototype.get_size_core = function() {
-  return this.ncore;
-};
-// return the count of all alphabet symbols
-Alphabet.prototype.get_size_full = function() {
-  return this.symbols.length;
-};
-// return the symbol for the given alphabet index
-Alphabet.prototype.get_symbol = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  return this.symbols[alph_index].symbol;
-};
-// return the aliases for the given alphabet index
-Alphabet.prototype.get_aliases = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  var sym_obj = this.symbols[alph_index];
-  return (sym_obj.aliases != null ? sym_obj.aliases : "");
-};
-// return the name for the given alphabet index
-Alphabet.prototype.get_name = function(alph_index) {
-  "use strict";
-  var sym;
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  sym = this.symbols[alph_index];
-  return (typeof sym.name === "string" ? sym.name : sym.symbol);
-};
-// return the alphabet it is like or null
-Alphabet.prototype.get_like = function() {
-  "use strict";
-  return this.like;
-};
-// return the index of the complement for the given alphabet index
-Alphabet.prototype.get_complement = function(alph_index) {
-  var comp_e_sym = this.complement[alph_index];
-  if (typeof comp_e_sym === "number") {
-    return comp_e_sym;
-  } else {
-    return -1;
-  }
-};
-// return a string containing the core symbols
-Alphabet.prototype.get_symbols = function() {
-  "use strict";
-  var i, core_symbols;
-  core_symbols = "";
-  for (i = 0; i < this.ncore; i++) {
-    core_symbols += this.symbols[i].symbol;
-  }
-  return core_symbols;
-};
-// return if the background was not a uniform generated background
-Alphabet.prototype.has_bg = function() {
-  "use strict";
-  return !this.genbg;
-};
-// get the background frequency for the index
-Alphabet.prototype.get_bg_freq = function(alph_index) {
-  "use strict";
-  var freq, i, symbols;
-  if (alph_index >= 0) {
-    if (alph_index < this.ncore) {
-      return this.background[alph_index];
-    } else if (alph_index < this.symbols.length) {
-      freq = 0;
-      symbols = this.symbols[alph_index].equals;
-      for (i = 0; i < symbols.length; i++) {
-        freq += this.background[this.encode2core[symbols.charAt(i)]];
-      }
-      return freq;
-    } 
-  }
-  throw new Error("The alphabet index is out of range.");
-};
-// get the colour of the index
-Alphabet.prototype.get_colour = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return "black";
-  }
-  return "#" + this.symbols[alph_index].colour;
-};
-// get the rgb componets of the colour at the index
-Alphabet.prototype.get_rgb = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return {"red": 0, "green": 0, "blue": 0};
-  }
-  var colour = this.symbols[alph_index].colour;
-  var red = parseInt(colour.substr(0, 2), 16) / 255;
-  var green = parseInt(colour.substr(2, 2), 16) / 255;
-  var blue = parseInt(colour.substr(4, 2), 16) / 255;
-  return {"red": red, "green": green, "blue": blue};
-};
-// convert a symbol into the index
-Alphabet.prototype.get_index = function(letter) {
-  "use strict";
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    return -1;
-  }
-  return alph_index;
-};
-// convert a symbol into the list of core indexes that it equals
-Alphabet.prototype.get_indexes = function(letter) {
-  "use strict";
-  var alph_index, comprise_str, i, comprise_list;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    throw new Error("Unknown letter");
-  }
-  comprise_str = this.symbols[alph_index].equals;
-  comprise_list = [];
-  if (typeof comprise_str == "string") {
-    for (i = 0; i < comprise_str.length; i++) {
-      comprise_list.push(this.encode2core[comprise_str.charAt(i)]);
-    }
-  } else {
-    comprise_list.push(alph_index);
-  }
-  return comprise_list;
-};
-// check if a symbol is the primary way of representing the symbol in the alphabet
-Alphabet.prototype.is_prime_symbol = function(letter) {
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (alph_index == null) return false;
-  if (this.is_case_insensitive()) {
-    return (this.symbols[alph_index].symbol.toUpperCase() == letter.toUpperCase());
-  } else {
-    return (this.symbols[alph_index].symbol == letter);
-  }
-};
-// compare 2 alphabets
-Alphabet.prototype.equals = function(other) {
-  "use strict";
-  var i, sym1, sym2;
-  // first check that it's actually an alphabet object
-  if (!(typeof other === "object" && other != null && other instanceof Alphabet)) {
-    return false;
-  }
-  // second shortcircuit if it's the same object
-  if (this === other) return true;
-  // compare
-  if (this.name !== other.name) return false;
-  if (this.ncore !== other.ncore) return false;
-  if (this.symbols.length !== other.symbols.length) return false;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym1 = this.symbols[i];
-    sym2 = other.symbols[i];
-    if (sym1.symbol !== sym2.symbol) return false;
-    if (sym1.aliases !== sym2.aliases) return false;
-    if (sym1.name !== sym2.name) return false;
-    if (typeof sym1.colour !== typeof sym2.colour || 
-        (typeof sym1.colour === "string" && typeof sym2.colour === "string" &&
-         parseInt(sym1.colour, 16) != parseInt(sym2.colour, 16))) {
-      return false;
-    }
-    if (sym1.complement !== sym2.complement) return false;
-    if (sym1.equals !== sym2.equals) return false;
-  }
-  return true;
-};
-Alphabet.prototype.check_core_subset = function(super_alph) {
-  var complement_same = true;
-  var seen_set = {};
-  var sub_i, sub_symbol, super_i, super_symbol;
-  for (sub_i = 0; sub_i < this.ncore; sub_i++) {
-    sub_symbol = this.symbols[sub_i];
-    super_i = super_alph.encode[sub_symbol.symbol]; 
-    if (super_i == null) return 0;
-    super_symbol = super_alph.symbols[super_i];
-    if (seen_set[super_i]) return 0;
-    seen_set[super_i] = true;
-    // check complement
-    if (sub_symbol.complement != null && super_symbol.complement != null) {
-      if (super_alph.encode[sub_symbol.complement] != super_alph.encode[super_symbol.complement]) {
-        complement_same = false;
-      }
-    } else if (sub_symbol.complement != null || super_symbol.complement != null) {
-      complement_same = false;
-    }
-  }
-  return (complement_same ? 1 : -1);
-};
-// convert a sequence to its reverse complement
-Alphabet.prototype.invcomp_seq = function(seq) {
-  "use strict";
-  var syms, i, e_sym, comp_e_sym;
-  if (!this.has_complement()) throw new Error("Alphabet must be complementable");
-  syms = seq.split("");
-  for (i = 0; i < syms.length; i++) {
-    e_sym = this.encode[syms[i]];
-    if (typeof e_sym === "undefined") {
-      e_sym = this.ncore; // wildcard
-    }
-    comp_e_sym = this.complement[e_sym];
-    if (typeof comp_e_sym === "undefined") {
-      comp_e_sym = e_sym; // not complementable
-    }
-    syms[i] = this.symbols[comp_e_sym].symbol;
-  }
-  return syms.reverse().join("");
-};
-// convert the alphabet to the text version
-Alphabet.prototype.as_text = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  function symbol_as_text(sym) {
-    var out;
-    out = sym.symbol;
-    if (typeof sym.name === "string" && sym.name != sym.symbol) {
-      out += " " + name_as_text(sym.name);
-    }
-    if (typeof sym.colour === "string") {
-      out += " " + sym.colour;
-    }
-    return out;
-  }
-  var out, i, j, c, sym;
-  out = "";
-  // output core symbols with 2 way complements
-  for (i = 0; i < this.ncore; i++) {
-    c = this.complement[i];
-    if (typeof c === "number" && i < c && this.complement[c] === i) {
-      out += symbol_as_text(this.symbols[i]) + " ~ " + symbol_as_text(this.symbols[c]) + "\n";  
-    }
-  }
-  // output core symbols with no complement
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.complement[i] === "undefined") {
-      out += symbol_as_text(this.symbols[i]) + "\n";
-    }
-  }
-  // output ambiguous symbols that have comprising characters
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    if (this.symbols[i].equals.length == 0) break;
-    out += symbol_as_text(this.symbols[i]) + " = " + this.symbols[i].equals + "\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].equals + "\n";
-      }
-    }
-  }
-  // output aliases of core symbols
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].symbol + "\n";
-      }
-    }
-  }
-  // output gap symbols
-  i = this.symbols.length - 1;
-  if (this.symbols[i].equals.length == 0) {
-    out += symbol_as_text(this.symbols[i]) + " =\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " =\n";
-      }
-    }
-  }
-  return out;
-};
-// output the alphabet as it appears in minimal MEME format
-Alphabet.prototype.as_meme = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  if (this.equals(AlphStd.DNA)) {
-    return "ALPHABET= ACGT\n";
-  } else if (this.equals(AlphStd.PROTEIN)) {
-    return "ALPHABET= ACDEFGHIKLMNPQRSTVWY\n";
-  } else {
-    return "ALPHABET" + 
-      (this.name != null ? " " + name_as_text(this.name) : "") + 
-      (this.like != null ? " " + this.like + "-LIKE" : "") + "\n" +
-      this.as_text() + "END ALPHABET\n";
-  }
-};
-
-// Returns a table showing all the letters in the alphabet
-Alphabet.prototype.as_table = function() {
-  "use strict";
-  var i, j, row, th, td, aliases, equals, sym;
-  var table = document.createElement("table");
-  // create the core symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  if (this.has_complement()) {
-    th.appendChild(document.createTextNode("Complement"));
-  }
-  row.appendChild(th);
-  // list the core symbols
-  for (i = 0; i < this.ncore; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].complement != null) {
-      td.style.color = this.get_colour(this.get_index(this.symbols[i].complement));
-      td.appendChild(document.createTextNode(this.symbols[i].complement));
-    }
-    row.appendChild(td);
-  }
-  // create the ambiguous symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Matches"));
-  row.appendChild(th);
-  // list the ambiguous symbols
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    equals = this.symbols[i].equals.split('');
-    for (j = 0; j < equals.length; j++) {
-      if (j != 0) td.appendChild(document.createTextNode(' '));
-      sym = document.createElement("span");
-      sym.style.color = this.get_colour(this.get_index(equals[j]));
-      sym.appendChild(document.createTextNode(equals[j]));
-      td.appendChild(sym);
-    }
-    row.appendChild(td);
-  }
-  return table;
-};
-
-// returns a dictionary of the colours for EPS
-Alphabet.prototype._as_eps_dict = function() {
-  "use strict";
-  var i, sym, rgb;
-  var out = "/fullColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = this.get_rgb(i);
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  out += "/mutedColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = Alphabet.lighten_colour(this.get_rgb(i));
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  return out;
-};
-
-// return the alphabet name or a list of primary symbols
-Alphabet.prototype.toString = function() {
-  "use strict";
-  if (this.name != null) {
-    return this.name;
-  } else {
-    return this.get_symbols();
-  }
-};
-
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-// Helper functions
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-// Convert a colour specified in RGB colourspace values into LAB colourspace
-Alphabet.rgb2lab = function(rgb) {
-  "use strict";
-  var xyzHelper, labHelper;
-  // XYZ helper
-  xyzHelper = function(value) {
-    if (value > 0.0445) {
-      value = (value + 0.055) / 1.055;
-      value = Math.pow(value, 2.4);
-    } else {
-      value /= 12.92;
-    }
-    value *= 100;
-    return value;
-  };
-  // lab helper
-  labHelper = function(value) {
-    if (value > 0.008856) {
-      value = Math.pow(value, 1.0 / 3.0);
-    } else {
-      value = (7.787 * value) + (16.0 / 116.0);
-    }
-    return value;
-  };
-  // convert into XYZ colourspace
-  var c1, c2, c3;
-  if (typeof rgb == "number") {
-    c1 = xyzHelper(((rgb >> 16) & 0xFF) / 255.0);
-    c2 = xyzHelper(((rgb >> 8) & 0xFF) / 255.0);
-    c3 = xyzHelper((rgb & 0xFF) / 255.0);
-  } else {
-    c1 = xyzHelper(rgb.red);
-    c2 = xyzHelper(rgb.green);
-    c3 = xyzHelper(rgb.blue);
-  }
-  var x = (c1 * 0.4124) + (c2 * 0.3576) + (c3 * 0.1805);
-  var y = (c1 * 0.2126) + (c2 * 0.7152) + (c3 * 0.0722);
-  var z = (c1 * 0.0193) + (c2 * 0.1192) + (c3 * 0.9505);
-  // convert into Lab colourspace
-  c1 = labHelper(x / 95.047);
-  c2 = labHelper(y / 100.0);
-  c3 = labHelper(z / 108.883);
-  var l = (116.0 * c2) - 16;
-  var a = 500.0 * (c1 - c2);
-  var b = 200.0 * (c2 - c3);
-  return {"l": l, "a": a, "b": b};
-};
-
-// Convert a colour specified in HSV colourspace into RGB colourspace
-Alphabet.hsv2rgb = function(hue, sat, value, output_object) {
-  // achromatic (grey)
-  var r = value;
-  var g = value;
-  var b = value;
-  if (sat != 0) {
-    var h = hue / 60.0;
-    var i = Math.floor(h);
-    var f = h - i;
-    var p = value * (1.0 - sat);
-    var q = value * (1.0 - (sat * f));
-    var t = value * (1.0 - (sat * (1.0 - f)));
-    if (i == 0) {
-      r = value;
-      g = t;
-      b = p;
-    } else if (i == 1) {
-      r = q;
-      g = value;
-      b = p;
-    } else if (i == 2) {
-      r = p;
-      g = value;
-      b = t;
-    } else if (i == 3) {
-      r = p;
-      g = q;
-      b = value;
-    } else if (i == 4) {
-      r = t;
-      g = p;
-      b = value;
-    } else {
-      r = value;
-      g = p;
-      b = q;
-    }
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-// Calculate a distance score between two colours in LAB colourspace
-Alphabet.lab_dist = function(lab1, lab2) {
-  var c1 = Math.sqrt((lab1.l * lab1.l) + (lab1.a * lab1.a));
-  var c2 = Math.sqrt((lab2.l * lab2.l) + (lab2.a * lab2.a));
-  var dc = c1 - c2;
-  var dl = lab1.l - lab2.l;
-  var da = lab1.a - lab2.a;
-  var db = lab1.b - lab2.b;
-  // we don't want NaN due to rounding errors so fudge things a bit...
-  var dh = 0;
-  var dh_squared = (da * da) + (db * db) - (dc * dc);
-  if (dh_squared > 0) {
-    dh = Math.sqrt(dh_squared);
-  }
-  var first = dl;
-  var second = dc / (1.0 + (0.045 * c1));
-  var third = dh / (1.0 + (0.015 * c1));
-  return Math.sqrt((first * first) + (second * second) + (third * third));
-};
-
-// convert an RGB value into a HSL value
-Alphabet.rgb2hsl = function(rgb) {
-  "use strict";
-  var min, max, delta, h, s, l, r, g, b;
-  if (typeof rgb == "number") {
-    r = ((rgb >> 16) & 0xFF) / 255.0;
-    g = ((rgb >> 8) & 0xFF) / 255.0;
-    b = (rgb & 0xFF) / 255.0;
-  } else {
-    r = rgb.red;
-    g = rgb.green;
-    b = rgb.blue;
-  }
-  min = Math.min(r, g, b);
-  max = Math.max(r, g, b);
-  delta = max - min;
-  l = min + (delta / 2);
-  if (max == min) {
-    h = 0; // achromatic (grayscale)
-    s = 0;
-  } else {
-    if (l > 0.5) {
-      s = delta / (2 - max - min);
-    } else {
-      s = delta / (max + min);
-    }
-    if (max == r) {
-      h = (g - b) / delta;
-      if (g < b) h += 6;
-    } else if (max == g) {
-      h = ((b - r) / delta) + 2;
-    } else {
-      h = ((r - g) / delta) + 4;
-    }
-    h /= 6;
-  }
-  return {"h": h, "s": s, "l": l};
-};
-
-// convert a HSL value into an RGB value
-Alphabet.hsl2rgb = function(hsl, output_object) {
-  "use strict";
-  function _hue(p, q, t) {
-    "use strict";
-    if (t < 0) t += 1;
-    else if (t > 1) t -= 1;
-    if (t < (1.0 / 6.0)) {
-      return p + ((q - p) * 6.0 * t);
-    } else if (t < 0.5) {
-      return q;
-    } else if (t < (2.0 / 3.0)) {
-      return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-    } else {
-      return p;
-    }
-  }
-  var r, g, b, p, q;
-  if (hsl.s == 0) {
-    // achromatic (grayscale)
-    r = hsl.l;
-    g = hsl.l;
-    b = hsl.l;
-  } else {
-    if (hsl.l < 0.5) {
-      q = hsl.l * (1 + hsl.s);
-    } else {
-      q = hsl.l + hsl.s - (hsl.l * hsl.s);
-    }
-    p = (2 * hsl.l) - q;
-    r = _hue(p, q, hsl.h + (1.0 / 3.0));
-    g = _hue(p, q, hsl.h);
-    b = _hue(p, q, hsl.h - (1.0 / 3.0));
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-Alphabet.lighten_colour = function(rgb) {
-  "use strict";
-  var hsl = Alphabet.rgb2hsl(rgb);
-  hsl.l += (1.0 - hsl.l) * 2 / 3;
-  return Alphabet.hsl2rgb(hsl, typeof rgb != "number");
-};
-
-//======================================================================
-// end Alphabet object
-//======================================================================
-
-//======================================================================
-// start StandardAlphabet object
-//======================================================================
-
-// an extension of the alphabet object to support some additional fields 
-// only present in standard alphabets.
-var StandardAlphabet = function(enum_code, enum_name, alphabet_data) {
-  Alphabet.apply(this, [alphabet_data]);
-  this.enum_code = enum_code;
-  this.enum_name = enum_name;
-};
-StandardAlphabet.prototype = Alphabet.prototype;
-StandardAlphabet.prototype.constructor = StandardAlphabet;
-
-// A unique code for this standard alphabet.
-// This code will be a power of 2 to enable creation of bitsets for
-// a selection of standard alphabets.
-StandardAlphabet.prototype.get_code = function() {
-  return this.enum_code;
-};
-
-// A unique name for this standard alphabet.
-// this name will be all upper case and the same as the property that
-// refers to this alphabet in the AlphStd collection.
-StandardAlphabet.prototype.get_enum = function() {
-  return this.enum_name;
-};
-
-//======================================================================
-// end StandardAlphabet object
-//======================================================================
-
-// A collection of standard alphabets.
-var AlphStd = {
-  RNA: new StandardAlphabet(1, "RNA", {
-    "name": "RNA",
-    "like": "RNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300"},
-      {"symbol": "U", "name": "Uracil", "colour": "008000",
-        "aliases": "T"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGU", "aliases": "X."},
-      {"symbol": "V", "name": "Not U", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACU"},
-      {"symbol": "D", "name": "Not C", "equals": "AGU"},
-      {"symbol": "B", "name": "Not A", "equals": "CGU"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AU"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CU"},
-      {"symbol": "K", "name": "Keto", "equals": "GU"}
-    ]
-  }), 
-  DNA: new StandardAlphabet(2, "DNA", {
-    "name": "DNA",
-    "like": "DNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000", "complement": "T"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC", "complement": "G"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300", "complement": "C"},
-      {"symbol": "T", "name": "Thymine", "colour": "008000", "complement": "A",
-        "aliases": "U"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGT", "aliases": "X."},
-      {"symbol": "V", "name": "Not T", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACT"},
-      {"symbol": "D", "name": "Not C", "equals": "AGT"},
-      {"symbol": "B", "name": "Not A", "equals": "CGT"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AT"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CT"},
-      {"symbol": "K", "name": "Keto", "equals": "GT"}
-    ]
-  }), 
-  PROTEIN: new StandardAlphabet(4, "PROTEIN", {
-    "name": "Protein",
-    "like": "PROTEIN",
-    "ncore": 20,
-    "symbols": [
-      {"symbol": "A", "name": "Alanine", "colour": "0000CC"},
-      {"symbol": "C", "name": "Cysteine", "colour": "0000CC"},
-      {"symbol": "D", "name": "Aspartic acid", "colour": "FF00FF"},
-      {"symbol": "E", "name": "Glutamic acid", "colour": "FF00FF"},
-      {"symbol": "F", "name": "Phenylalanine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Glycine", "colour": "FFB300"},
-      {"symbol": "H", "name": "Histidine", "colour": "FFCCCC"},
-      {"symbol": "I", "name": "Isoleucine", "colour": "0000CC"},
-      {"symbol": "K", "name": "Lysine", "colour": "CC0000"},
-      {"symbol": "L", "name": "Leucine", "colour": "0000CC"},
-      {"symbol": "M", "name": "Methionine", "colour": "0000CC"},
-      {"symbol": "N", "name": "Asparagine", "colour": "008000"},
-      {"symbol": "P", "name": "Proline", "colour": "FFFF00"},
-      {"symbol": "Q", "name": "Glutamine", "colour": "008000"},
-      {"symbol": "R", "name": "Arginine", "colour": "CC0000"},
-      {"symbol": "S", "name": "Serine", "colour": "008000"},
-      {"symbol": "T", "name": "Threonine", "colour": "008000"},
-      {"symbol": "V", "name": "Valine", "colour": "0000CC"},
-      {"symbol": "W", "name": "Tryptophan", "colour": "0000CC"},
-      {"symbol": "Y", "name": "Tyrosine", "colour": "33E6CC"},
-      {"symbol": "X", "name": "Any amino acid", "equals": "ACDEFGHIKLMNPQRSTVWY", "aliases": "*."},
-      {"symbol": "B", "name": "Asparagine or Aspartic acid", "equals": "DN"}, 
-      {"symbol": "Z", "name": "Glutamine or Glutamic acid", "equals": "EQ"}, 
-      {"symbol": "J", "name": "Leucine or Isoleucine", "equals": "IL"}
-    ]
-  })
-};
-
-//======================================================================
-// start Symbol object
-//======================================================================
-var Symbol = function(alph_index, scale, alphabet) {
-  "use strict";
-  //variable prototype
-  this.symbol = alphabet.get_symbol(alph_index);
-  this.scale = scale;
-  this.colour = alphabet.get_colour(alph_index);
-};
-
-Symbol.prototype.get_symbol = function() {
-  "use strict";
-  return this.symbol;
-};
-
-Symbol.prototype.get_scale = function() {
-  "use strict";
-  return this.scale;
-};
-
-Symbol.prototype.get_colour = function() {
-  "use strict";
-  return this.colour;
-};
-
-Symbol.prototype.toString = function() {
-  "use strict";
-  return this.symbol + " " + (Math.round(this.scale*1000)/10) + "%";
-};
-
-function compare_symbol(sym1, sym2) {
-  "use strict";
-  if (sym1.get_scale() < sym2.get_scale()) {
-    return -1;
-  } else if (sym1.get_scale() > sym2.get_scale()) {
-    return 1;
-  } else {
-    return 0;
-  }
-}
-//======================================================================
-// end Symbol object
-//======================================================================
-
-//======================================================================
-// start Pspm object
-//======================================================================
-var Pspm = function(matrix, name, ltrim, rtrim, nsites, evalue, pssm, alt) {
-  "use strict";
-  var row, col, data, row_sum, delta, evalue_re;
-  if (typeof name !== "string") {
-    name = "";
-  }
-  this.name = name;
-  //construct
-  if (matrix instanceof Pspm) {
-    // copy constructor
-    this.alph_length = matrix.alph_length;
-    this.motif_length = matrix.motif_length;
-    this.name = matrix.name;
-    this.alt = matrix.alt;
-    this.nsites = matrix.nsites;
-    this.evalue = matrix.evalue;
-    this.ltrim = matrix.ltrim;
-    this.rtrim = matrix.rtrim;
-    this.pspm = [];
-    for (row = 0; row < matrix.motif_length; row++) {
-      this.pspm[row] = [];
-      for (col = 0; col < matrix.alph_length; col++) {
-        this.pspm[row][col] = matrix.pspm[row][col];
-      }
-    }
-    if (matrix.pssm != null) {
-      this.pssm = [];
-      for (row = 0; row < matrix.motif_length; row++) {
-        this.pspm[row] = [];
-        for (col = 0; col < matrix.alph_length; col++) {
-          this.pssm[row][col] = matrix.pssm[row][col];
-        }
-      }
-    }
-  } else {
-    // check parameters
-    if (ltrim == null) {
-      ltrim = 0;
-    } else if (typeof ltrim !== "number" || ltrim % 1 !== 0 || ltrim < 0) {
-      throw new Error("ltrim must be a non-negative integer, got: " + ltrim);
-    }
-    if (rtrim == null) {
-      rtrim = 0;
-    } else if (typeof rtrim !== "number" || rtrim % 1 !== 0 || rtrim < 0) {
-      throw new Error("rtrim must be a non-negative integer, got: " + rtrim);
-    }
-    if (nsites != null) {
-      if (typeof nsites !== "number" || nsites < 0) {
-        throw new Error("nsites must be a positive number, got: " + nsites);
-      } else if (nsites == 0) {
-        nsites = null;
-      }
-    }
-    if (evalue != null) {
-      if (typeof evalue === "number") {
-        if (evalue < 0) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else if (typeof evalue === "string") {
-        evalue_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-        if (!evalue_re.test(evalue)) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else {
-        throw new Error("evalue must be a non-negative number, got: " + evalue);
-      }
-    }
-    // set properties
-    this.name = name;
-    this.alt = alt;
-    this.nsites = nsites;
-    this.evalue = evalue;
-    this.ltrim = ltrim;
-    this.rtrim = rtrim;
-    if (typeof matrix === "string") {
-      // string constructor
-      data = parse_pspm_string(matrix);
-      this.alph_length = data["alph_length"];
-      this.motif_length = data["motif_length"];
-      this.pspm = data["pspm"];
-      if (this.evalue == null) {
-        if (data["evalue"] != null) {
-          this.evalue = data["evalue"];
-        } else {
-          this.evalue = 0;
-        }
-      }
-      if (this.nsites == null) {
-        if (typeof data["nsites"] === "number") {
-          this.nsites = data["nsites"];
-        } else {
-          this.nsites = 20;
-        }
-      }
-    } else {
-      // assume pspm is a nested array
-      this.motif_length = matrix.length;
-      this.alph_length = (matrix.length > 0 ? matrix[0].length : 0);
-      if (this.nsites == null) {
-        this.nsites = 20;
-      }
-      if (this.evalue == null) {
-        this.evalue = 0;
-      }
-      this.pspm = [];
-      // copy pspm and check
-      for (row = 0; row < this.motif_length; row++) {
-        if (this.alph_length != matrix[row].length) {
-          throw new Error("COLUMN_MISMATCH");
-        }
-        this.pspm[row] = [];
-        row_sum = 0;
-        for (col = 0; col < this.alph_length; col++) {
-          this.pspm[row][col] = matrix[row][col];
-          row_sum += this.pspm[row][col];
-        }
-        delta = 0.1;
-        if (isNaN(row_sum) || (row_sum > 1 && (row_sum - 1) > delta) || 
-            (row_sum < 1 && (1 - row_sum) > delta)) {
-          throw new Error("INVALID_SUM");
-        }
-      }
-      // copy pssm
-      if (pssm != null) {
-        this.pssm = [];
-        for (row = 0; row < this.motif_length; row++) {
-          this.pssm[row] = [];
-          for (col = 0; col < this.alph_length; col++) {
-            this.pssm[row][col] = pssm[row][col];
-          }
-        }
-      }
-    }
-  }
-};
-
-Pspm.prototype.copy = function() {
-  "use strict";
-  return new Pspm(this);
-};
-
-Pspm.prototype.reverse = function() {
-  "use strict";
-  var x, y, temp, temp_trim;
-  //reverse
-  x = 0;
-  y = this.motif_length-1;
-  while (x < y) {
-    temp = this.pspm[x];
-    this.pspm[x] = this.pspm[y];
-    this.pspm[y] = temp;
-    x++;
-    y--;
-  }
-  // reverse pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //reverse
-    x = 0;
-    y = this.motif_length-1;
-    while (x < y) {
-      temp = this.pssm[x];
-      this.pspm[x] = this.pssm[y];
-      this.pssm[y] = temp;
-      x++;
-      y--;
-    }
-  }
-  //swap triming
-  temp_trim = this.ltrim;
-  this.ltrim = this.rtrim;
-  this.rtrim = temp_trim;
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.reverse_complement = function(alphabet) {
-  "use strict";
-  var x, y, temp, i, row, c, temp_trim;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  if (!alphabet.has_complement()) {
-    throw new Error("The specified alphabet can not be complemented.");
-  }
-  // reverse motif
-  this.reverse();
-  //complement
-  for (x = 0; x < this.motif_length; x++) {
-    row = this.pspm[x];
-    for (i = 0; i < row.length; i++) {
-      c = alphabet.get_complement(i);
-      if (c < i) continue;
-      temp = row[i];
-      row[i] = row[c];
-      row[c] = temp;
-    }
-  }
-  // complement pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //complement
-    for (x = 0; x < this.motif_length; x++) {
-      row = this.pssm[x];
-      for (i = 0; i < row.length; i++) {
-        c = alphabet.get_complement(i);
-        if (c < i) continue;
-        temp = row[i];
-        row[i] = row[c];
-        row[c] = temp;
-      }
-    }
-  }
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.get_stack = function(position, alphabet, ssc) {
-  "use strict";
-  var row, stack_ic, alphabet_ic, stack, i, sym;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  row = this.pspm[position];
-  stack_ic = this.get_stack_ic(position, alphabet);
-  if (ssc) stack_ic -= this.get_error(alphabet);
-  alphabet_ic = alphabet.get_ic();
-  stack = [];
-  for (i = 0; i < this.alph_length; i++) {
-    sym = new Symbol(i, row[i]*stack_ic/alphabet_ic, alphabet);
-    if (sym.get_scale() <= 0) {
-      continue;
-    }
-    stack.push(sym);
-  }
-  stack.sort(compare_symbol);
-  return stack;
-};
-
-Pspm.prototype.get_stack_ic = function(position, alphabet) {
-  "use strict";
-  var row, H, i;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size fo the pspm.");
-  }
-  row = this.pspm[position];
-  H = 0;
-  for (i = 0; i < this.alph_length; i++) {
-    if (row[i] === 0) {
-      continue;
-    }
-    H -= (row[i] * (Math.log(row[i]) / Math.LN2));
-  }
-  return alphabet.get_ic() - H;
-};
-
-Pspm.prototype.get_error = function(alphabet) {
-  "use strict";
-  if (this.nsites === 0) {
-    return 0;
-  }
-  return (alphabet.get_size_core()-1) / (2 * Math.LN2 * this.nsites);
-};
-
-Pspm.prototype.get_motif_length = function() {
-  "use strict";
-  return this.motif_length;
-};
-
-Pspm.prototype.get_alph_length = function() {
-  "use strict";
-  return this.alph_length;
-};
-
-Pspm.prototype.get_left_trim = function() {
-  "use strict";
-  return this.ltrim;
-};
-
-Pspm.prototype.get_right_trim = function() {
-  "use strict";
-  return this.rtrim;
-};
-
-Pspm.prototype.as_best_match = function(alphabet) {
-  "use strict";
-  var match, odds, best_odds, best_index;
-  var i, j;
-  match = "";
-  for (i = 0; i < this.motif_length; i++) {
-    best_index = 0;
-    best_odds = this.pspm[i][0] / alphabet.get_bg_freq(0);
-    for (j = 1; j < this.alph_length; j++) {
-      odds = this.pspm[i][j] / alphabet.get_bg_freq(j);
-      if (odds > best_odds) {
-        best_odds = odds;
-        best_index = j;
-      }
-    }
-    match += alphabet.get_symbol(best_index);
-  }
-  return match;
-};
-
-Pspm.prototype.as_count_matrix = function() {
-  "use strict";
-  var count, count_text, text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      count = Math.round(this.nsites * this.pspm[i][j]);
-      count_text = "" + count;
-      // pad up to length of 4
-      if (count_text.length < 4) {
-        text += (new Array(5 - count_text.length)).join(" ") + count_text;
-      } else {
-        text += count_text;
-      }
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_probability_matrix = function() {
-  "use strict";
-  var text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      text += this.pspm[i][j].toFixed(6);
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_score_matrix = function(alphabet, pseudo) {
-  "use strict";
-  var me, score, out, row, col, score_text;
-  me = this;
-  if (typeof this.pssm === "undefined") {
-    if (!(typeof alphabet === "object" && alphabet != null && alphabet instanceof Alphabet)) {
-      throw new Error("The alphabet is required to generate the pssm.");
-    }
-    if (typeof pseudo === "undefined") {
-      pseudo = 0.01;
-    } else if (typeof pseudo !== "number" || pseudo < 0) {
-      throw new Error("Expected positive number for pseudocount");
-    }
-    score = function(row, col) {
-      "use strict";
-      var p, bg, p2;
-      p = me.pspm[row][col];
-      bg = alphabet.get_bg_freq(col);
-      p2 = (p * me.nsites + bg * pseudo) / (me.nsites + pseudo);
-      return (p2 > 0 ? Math.round((Math.log(p2 / bg) / Math.LN2) * 100) : -10000);
-    };
-  } else {
-    score = function(row, col) {
-      "use strict";
-      return me.pssm[row][col];
-    };
-  }
-  out = "";
-  for (row = 0; row < this.motif_length; row++) {
-    for (col = 0; col < this.alph_length; col++) {
-      if (col !== 0) {
-        out += " ";
-      }
-      score_text = "" + score(row, col);
-      // pad out to 6 characters
-      if (score_text.length < 6) {
-        out += (new Array(7 - score_text.length)).join(" ") + score_text;
-      } else {
-        out += score_text;
-      }
-    }
-    out += "\n";
-  }
-  return out;
-}
-
-Pspm.prototype.as_pspm = function() {
-  "use strict";
-  return "letter-probability matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + " nsites= " + this.nsites + 
-      " E= " + (typeof this.evalue === "number" ? 
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_probability_matrix();
-};
-
-Pspm.prototype.as_pssm = function(alphabet, pseudo) {
-  "use strict";
-  return "log-odds matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + 
-      " E= " + (typeof this.evalue == "number" ?
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_score_matrix(alphabet, pseudo);
-};
-
-Pspm.prototype.as_meme = function(options) {
-  var with_header, with_pspm, with_pssm, version, alphabet, bg_source, pseudocount, strands;
-  var out, alen, i;
-  // get the options
-  if (typeof options !== "object" || options === null) {
-    options = {};
-  }
-  with_header = (typeof options["with_header"] === "boolean" ? options["with_header"] : false);
-  with_pspm = (typeof options["with_pspm"] === "boolean" ? options["with_pspm"] : false);
-  with_pssm = (typeof options["with_pssm"] === "boolean" ? options["with_pssm"] : false);
-  if (!with_pspm && !with_pssm) with_pspm = true;
-  if (with_header) {
-    if (typeof options["version"] === "string" && /^\d+(?:\.\d+){0,2}$/.test(options["version"])) {
-      version = options["version"];
-    } else if (typeof options["version"] === "number") {
-      version = options["version"].toFixed(0);
-    } else {
-      version = "4";
-    }
-    if (typeof options["strands"] === "number" && options["strands"] === 1) {
-      strands = 1;
-    } else {
-      strands = 2;
-    }
-    if (typeof options["bg_source"] === "string") {
-      bg_source = options["bg_source"];
-    } else {
-      bg_source = "unknown source";
-    }
-    if (typeof options["alphabet"] === "object" && options["alphabet"] != null
-        && options["alphabet"] instanceof Alphabet) {
-      alphabet = options["alphabet"];
-    } else {
-      throw new Error("The alphabet is required to generate the header.");
-    }
-  }
-  // now create the output
-  out = "";
-  if (with_header) {
-    out = "MEME version " + version + "\n\n";
-    out += alphabet.as_meme() + "\n";
-    if (alphabet.has_complement()) { // assume DNA has both strands unless otherwise specified
-      out += "strands: " + (strands === 1 ? "+" : "+ -") + "\n\n";
-    }
-    out += "Background letter frequencies (from " + bg_source + "):\n";
-    alen = alphabet.get_size_core();
-    for (i = 0; i < alen; i++) {
-      if (i !== 0) {
-        if (i % 9 === 0) { // maximum of nine entries per line
-          out += "\n";
-        } else {
-          out += " ";
-        }
-      }
-      out += alphabet.get_symbol(i) + " " + alphabet.get_bg_freq(i).toFixed(3);
-    }
-  }
-  out += "\n\n";
-  out += "MOTIF " + this.name + (this.alt == null ? "" : " " + this.alt);
-  if (with_pssm) {
-    out += "\n\n";
-    out += this.as_pssm(options["alphabet"], options["pseudocount"]);
-  }
-  if (with_pspm) {
-    out += "\n\n";
-    out += this.as_pspm();
-  }
-  return out;
-}
-
-Pspm.prototype.toString = function() {
-  "use strict";
-  var str, i, row;
-  str = "";
-  for (i = 0; i < this.pspm.length; i++) {
-    row = this.pspm[i];
-    str += row.join("\t") + "\n";
-  }
-  return str;
-};
-
-function parse_pspm_properties(str) {
-  "use strict";
-  var parts, i, eqpos, before, after, properties, prop, num, num_re;
-  num_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-  parts = trim(str).split(/\s+/);
-  // split up words containing =
-  for (i = 0; i < parts.length;) {
-    eqpos = parts[i].indexOf("=");
-    if (eqpos != -1) {
-      before = parts[i].substr(0, eqpos);
-      after = parts[i].substr(eqpos+1);
-      if (before.length > 0 && after.length > 0) {
-        parts.splice(i, 1, before, "=", after);
-        i += 3;
-      } else if (before.length > 0) {
-        parts.splice(i, 1, before, "=");
-        i += 2;
-      } else if (after.length > 0) {
-        parts.splice(i, 1, "=", after);
-        i += 2;
-      } else {
-        parts.splice(i, 1, "=");
-        i++;
-      }
-    } else {
-      i++;
-    }
-  }
-  properties = {};
-  for (i = 0; i < parts.length; i += 3) {
-    if (parts.length - i < 3) {
-      throw new Error("Expected PSPM property was incomplete. "+
-          "Remaing parts are: " + parts.slice(i).join(" "));
-    }
-    if (parts[i+1] !== "=") {
-      throw new Error("Expected '=' in PSPM property between key and " +
-          "value but got " + parts[i+1]); 
-    }
-    prop = parts[i].toLowerCase();
-    num = parts[i+2];
-    if (!num_re.test(num)) {
-      throw new Error("Expected numeric value for PSPM property '" + 
-          prop + "' but got '" + num + "'");
-    }
-    properties[prop] = num;
-  }
-  return properties;
-}
-
-function parse_pspm_string(pspm_string) {
-  "use strict";
-  var header_re, lines, first_line, line_num, col_num, alph_length, 
-      motif_length, nsites, evalue, pspm, i, line, match, props, parts,
-      j, prob;
-  header_re = /^letter-probability\s+matrix:(.*)$/i;
-  lines = pspm_string.split(/\n/);
-  first_line = true;
-  line_num = 0;
-  col_num = 0;
-  alph_length;
-  motif_length;
-  nsites;
-  evalue;
-  pspm = [];
-  for (i = 0; i < lines.length; i++) {
-    line = trim(lines[i]);
-    if (line.length === 0) { 
-      continue;
-    }
-    // check the first line for a header though allow matrices without it
-    if (first_line) {
-      first_line = false;
-      match = header_re.exec(line);
-      if (match !== null) {
-        props = parse_pspm_properties(match[1]);
-        if (props.hasOwnProperty("alength")) {
-          alph_length = parseFloat(props["alength"]);
-          if (alph_length != 4 && alph_length != 20) {
-            throw new Error("PSPM property alength should be 4 or 20" +
-                " but got " + alph_length);
-          }
-        }
-        if (props.hasOwnProperty("w")) {
-          motif_length = parseFloat(props["w"]);
-          if (motif_length % 1 !== 0 || motif_length < 1) {
-            throw new Error("PSPM property w should be an integer larger " +
-                "than zero but got " + motif_length);
-          }
-        }
-        if (props.hasOwnProperty("nsites")) {
-          nsites = parseFloat(props["nsites"]);
-          if (nsites <= 0) {
-            throw new Error("PSPM property nsites should be larger than " +
-                "zero but got " + nsites);
-          }
-        }
-        if (props.hasOwnProperty("e")) {
-          evalue = props["e"];
-          if (evalue < 0) {
-            throw new Error("PSPM property evalue should be " +
-                "non-negative but got " + evalue);
-          }
-        }
-        continue;
-      }
-    }
-    pspm[line_num] = [];
-    col_num = 0;
-    parts = line.split(/\s+/);
-    for (j = 0; j < parts.length; j++) {
-      prob = parseFloat(parts[j]);
-      if (prob != parts[j] || prob < 0 || prob > 1) {
-        throw new Error("Expected probability but got '" + parts[j] + "'"); 
-      }
-      pspm[line_num][col_num] = prob;
-      col_num++;
-    }
-    line_num++;
-  }
-  if (typeof motif_length === "number") {
-    if (pspm.length != motif_length) {
-      throw new Error("Expected PSPM to have a motif length of " + 
-          motif_length + " but it was actually " + pspm.length);
-    }
-  } else {
-    motif_length = pspm.length;
-  }
-  if (typeof alph_length !== "number") {
-    alph_length = pspm[0].length;
-    if (alph_length != 4 && alph_length != 20) {
-      throw new Error("Expected length of first row in the PSPM to be " +
-          "either 4 or 20 but got " + alph_length);
-    }
-  }
-  for (i = 0; i < pspm.length; i++) {
-    if (pspm[i].length != alph_length) {
-      throw new Error("Expected PSPM row " + i + " to have a length of " + 
-          alph_length + " but the length was " + pspm[i].length);
-    }
-  }
-  return {"pspm": pspm, "motif_length": motif_length, 
-    "alph_length": alph_length, "nsites": nsites, "evalue": evalue};
-}
-//======================================================================
-// end Pspm object
-//======================================================================
-
-//======================================================================
-// start Logo object
-//======================================================================
-
-var Logo = function(alphabet, options) {
-  "use strict";
-  this.alphabet = alphabet;
-  this.fine_text = "";
-  this.x_axis = 1;
-  this.y_axis = true;
-  this.xlate_nsyms = 1;
-  this.xlate_start = null;
-  this.xlate_end = null;
-  this.pspm_list = [];
-  this.pspm_column = [];
-  this.rows = 0;
-  this.columns = 0;
-  if (typeof options === "string") {
-    // the old method signature had fine_text here so we support that
-    this.fine_text = options;
-  } else if (typeof options === "object" && options != null) {
-    this.fine_text = (typeof options.fine_text === "string" ? options.fine_text : "");
-    this.x_axis = (typeof options.x_axis === "boolean" ? (options.x_axis ? 1 : 0) : 1);
-    if (options.x_axis_hidden != null && options.x_axis_hidden) this.x_axis = -1;
-    this.y_axis = (typeof options.y_axis === "boolean" ? options.y_axis : true);
-    this.xlate_nsyms = (typeof options.xlate_nsyms === "number" ? options.xlate_nsyms : this.xlate_nsyms);
-    this.xlate_start = (typeof options.xlate_start === "number" ? options.xlate_start : this.xlate_start);
-    this.xlate_end = (typeof options.xlate_end === "number" ? options.xlate_end : this.xlate_end);
-  }
-};
-
-Logo.prototype.add_pspm = function(pspm, column) {
-  "use strict";
-  var col;
-  if (typeof column === "undefined") {
-    column = 0;
-  } else if (column < 0) {
-    throw new Error("Column index out of bounds.");
-  }
-  this.pspm_list[this.rows] = pspm;
-  this.pspm_column[this.rows] = column;
-  this.rows++;
-  col = column + pspm.get_motif_length();
-  if (col > this.columns) {
-    this.columns = col;
-  }
-};
-
-Logo.prototype.get_columns = function() {
-  "use strict";
-  return this.columns;
-};
-
-Logo.prototype.get_xlate_nsyms = function() {
-  "use strict";
-  return this.xlate_nsyms;
-};
-
-Logo.prototype.get_xlate_start = function() {
-  "use strict";
-  return (this.xlate_start != null ? this.xlate_start : 0);
-};
-
-Logo.prototype.get_xlate_end = function() {
-  "use strict";
-  return (this.xlate_end != null ? this.xlate_end : this.columns * this.xlate_nsyms);
-};
-
-Logo.prototype.get_xlate_columns = function() {
-  "use strict";
-  return this.get_xlate_end() - this.get_xlate_start();
-};
-
-Logo.prototype.get_rows = function() {
-  "use strict";
-  return this.rows;
-};
-
-Logo.prototype.get_pspm = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_list[row_index];
-};
-
-Logo.prototype.get_offset = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_column[row_index];
-};
-
-Logo.prototype._as_eps_data = function(ssc, errbars) {
-  var i, j, pos, stack_pos, pspm, stack, sym, out;
-  out = "";
-  for (i = 0; i < this.rows; i++) {
-    out += "\nStartLine\n";
-    // Indent
-    for (j = 0; j < this.pspm_column[i]; j++) {
-      out += "() startstack\nendstack\n\n";
-    }
-    pspm = this.pspm_list[i];
-    if (pspm.get_left_trim() > 0) {
-      out += "MuteColour\nDrawTrimEdge\n" + pspm.get_left_trim() + " DrawTrimBg\n";
-    }
-    for (pos = 0; pos < pspm.get_motif_length(); pos++) {
-      if (pos != 0 && pos == pspm.get_left_trim()) { // enable full colour
-        out += "DrawTrimEdge\nRestoreColour\n";
-      } else if (pos == (pspm.get_motif_length() - pspm.get_right_trim())) {
-        out += "MuteColour\n" + pspm.get_right_trim() + " DrawTrimBg\n";
-      }
-      out += "(" + (pos + 1) + ") startstack\n";
-      stack = pspm.get_stack(pos, this.alphabet, ssc);
-      for (stack_pos = 0; stack_pos < stack.length; stack_pos++) {
-        sym = stack[stack_pos];
-        out += " " + (sym.get_scale() * this.alphabet.get_ic()) + " (" + sym.get_symbol() + ") numchar\n";
-      }
-      if (errbars) {
-        out += " " + pspm.get_error(this.alphabet) + " Ibeam\n";
-      }
-      out += "endstack\n\n";
-    }
-    if (pspm.get_right_trim() > 0 || pspm.get_left_trim() == pspm.get_motif_length()) {
-      out += "RestoreColour\n";
-    }
-    out += "EndLine\n";
-  }
-  return out;
-};
-
-Logo.prototype.as_eps = function(options) {
-  "use strict";
-  if (this.xlate_nsyms != 1) throw new Error("Unsupported setting xlate_nsyms for EPS");
-  if (this.xlate_start != null) throw new Error("Unsupported setting xlate_start for EPS");
-  if (this.xlate_end != null) throw new Error("Unsupported setting xlate_end for EPS");
-
-  var LOGOHEIGHT = 7.5; // default height of line in cm
-  var cm2pts, height, width, now, ssc, errbars;
-  if (typeof options === "undefined") {
-    options = {};
-  }
-  cm2pts = 72 / 2.54;
-  if (typeof options.logo_height == "number") {
-    height = options.logo_height;
-  } else {
-    height = LOGOHEIGHT * this.rows;
-  }
-  if (typeof options.logo_width == "number") {
-    width = options.logo_width;
-  } else {
-    width = this.columns + 2;
-  }
-  now = new Date();
-  ssc = (typeof options.ssc == "boolean" ? options.ssc : false);
-  errbars = (typeof options.show_error_bar == "boolean" ? options.show_error_bar : ssc);
-  var values = {
-    "LOGOHEIGHT": height,
-    "LOGOWIDTH": width,
-    "BOUNDINGHEIGHT": Math.round(height * cm2pts),
-    "BOUNDINGWIDTH": Math.round(width * cm2pts),
-    "LOGOLINEHEIGHT": (height / this.rows),
-    "CHARSPERLINE": this.columns,
-    "BARBITS": this.alphabet.get_ic(),
-    "LOGOTYPE": (this.alphabet.has_complement() ? "NA" : "AA"),
-    "CREATIONDATE": now.getDate() + "." + (now.getMonth() + 1) + "." + now.getFullYear() + " " + now.getHours() + ":" + now.getMinutes() + ":" + now.getSeconds(),
-    "ERRORBARFRACTION": (typeof options.error_bar_fraction == "number" ? options.error_bar_fraction : 1.0),
-    "TICBITS": (typeof options.ticbits == "number" ? options.ticbits : 1.0),
-    "TITLE": (typeof options.title == "string" ? options.title : ""),
-    "FINEPRINT": (typeof options.fineprint == "string" ? options.fineprint : this.fine_text),
-    "XAXISLABEL": (typeof options.xaxislabel == "string" ? options.xaxislabel : ""),
-    "YAXISLABEL": (typeof options.yaxislabel == "string" ? options.yaxislabel : "bits"),
-    "SSC": ssc,
-    "YAXIS": (typeof options.show_y_axis == "boolean" ? options.show_y_axis : this.y_axis),
-    "SHOWENDS": (typeof options.show_ends == "boolean" ? options.show_ends : false),
-    "ERRBAR": errbars,
-    "OUTLINE": (typeof options.show_outline == "boolean" ? options.show_outline : false),
-    "NUMBERING": (typeof options.show_numbering == "boolean" ? options.show_numbering : this.x_axis != 0),
-    "SHOWINGBOX": (typeof options.show_box == "boolean" ? options.show_box : false),
-    "CREATOR": (typeof options.creator == "string" ? options.creator : "motif_logo.js"),
-    "FONTSIZE": (typeof options.label_font_size == "number" ? options.label_font_size : 12),
-    "TITLEFONTSIZE": (typeof options.title_font_size == "number" ? options.title_font_size : 12),
-    "SMALLFONTSIZE": (typeof options.small_font_size == "number" ? options.small_font_size : 6),
-    "TOPMARGIN" : (typeof options.top_margin == "number" ? options.top_margin : 0.9),
-    "BOTTOMMARGIN": (typeof options.bottom_margin == "number" ? options.bottom_margin : 0.9),
-    "COLORDICT": this.alphabet._as_eps_dict(),
-    "DATA": this._as_eps_data(ssc, errbars)
-  };
-  // now this requires that the script containing the template has been imported!
-  return motif_logo_template(values);
-};
-
-//======================================================================
-// end Logo object
-//======================================================================
-
-// calculate the exact size (in pixels) of an object drawn on the
-// canvas assuming that the background of the canvas is transparent.
-function canvas_bounds(ctx, cwidth, cheight) {
-  "use strict";
-  var data, r, c, top_line, bottom_line, left_line, right_line, 
-      txt_width, txt_height;
-
-  // extract the image data
-  data = ctx.getImageData(0, 0, cwidth, cheight).data;
-
-  // set initial values
-  top_line = -1; bottom_line = -1; left_line = -1; right_line = -1;
-  txt_width = 0; txt_height = 0;
-
-  // Find the top-most line with a non-transparent pixel
-  for (r = 0; r < cheight; r++) {
-    for (c = 0; c < cwidth; c++) {
-      if (data[r * cwidth * 4 + c * 4 + 3]) {
-        top_line = r;
-        break;
-      }
-    }
-    if (top_line != -1) {
-      break;
-    }
-  }
-  
-  // Only bother looking if we found at least one set pixel... 
-  if (top_line != -1) {
-
-    //find the last line with a non-transparent pixel
-    for (r = cheight-1; r >= top_line; r--) {
-      for(c = 0; c < cwidth; c++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          bottom_line = r;
-          break;
-        }
-      }
-      if (bottom_line != -1) {
-        break;
-      }
-    }
-    // calculate height
-    txt_height = bottom_line - top_line + 1;
-
-    // Find the left-most line with a non-transparent pixel
-    for (c = 0; c < cwidth; c++) {
-      for (r = top_line; r <= bottom_line; r++) {
-        if (data[r * cwidth * 4 + c * 4 + 3]) {
-          left_line = c;
-          break;
-        }
-      }
-      if (left_line != -1) {
-        break;
-      }
-    }
-
-    //find the right most line with a non-transparent pixel
-    for (c = cwidth-1; c >= left_line; c--) {
-      for(r = top_line; r <= bottom_line; r++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          right_line = c;
-          break;
-        }
-      }
-      if (right_line != -1) {
-        break;
-      }
-    }
-    txt_width = right_line - left_line + 1;
-  }
-
-  //return the bounds
-  return {bound_top: top_line, bound_bottom: bottom_line, 
-    bound_left: left_line, bound_right: right_line, width: txt_width, 
-    height: txt_height};
-}
-
-//======================================================================
-// start RasterizedAlphabet
-//======================================================================
-
-// Rasterize Alphabet
-// 1) Measure width of text at default font for all symbols in alphabet
-// 2) sort in width ascending
-// 3) Drop the top and bottom 10% (designed to ignore outliers like 'W' and 'I')
-// 4) Calculate the average as the maximum scaling factor (designed to stop I becoming a rectangular blob).
-// 5) Assume scale of zero would result in width of zero, interpolate scale required to make perfect width font
-// 6) Draw text onto temp canvas at calculated scale
-// 7) Find bounds of drawn text
-// 8) Paint on to another canvas at the desired height (but only scaling width to fit if larger).
-var RasterizedAlphabet = function(alphabet, logo_scale, font, width) {
-  "use strict";
-  var default_size, safety_pad, canvas, ctx, middle, baseline, widths, sizes,
-      i, sym, size, tenpercent, avg_width, scale, 
-      target_width, target_height;
-  //variable prototypes
-  this.alphabet = alphabet;
-  this.scale = logo_scale;
-  this.sym_cache = {};
-  this.stack_num_cache = [];
-  this.scale_num_cache = [];
-  // size of canvas
-  default_size = 60; // size of measuring canvas
-  safety_pad = 20; // pixels to pad around so we don't miss the edges
-  // create a canvas to do our measuring
-  canvas = document.createElement("canvas");
-  if (!canvas.getContext) throw new Error("No canvas support");
-  canvas.width = default_size + 2 * safety_pad;
-  canvas.height = default_size + 2 * safety_pad;
-  middle = Math.round(canvas.width / 2);
-  baseline = Math.round(canvas.height - safety_pad);
-  ctx = canvas.getContext('2d');
-  if (!supports_text(ctx)) throw new Error("Canvas does not support text");
-  ctx.font = font;
-  ctx.textAlign = "center";
-  ctx.translate(middle, baseline);
-  // list of widths
-  widths = [];
-  sizes = [];
-  //now measure each letter in the alphabet
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    // reset the canvas
-    ctx.clearRect(0, 0, canvas.width, canvas.height);
-    ctx.fillStyle = alphabet.get_colour(i);
-    // draw the test text
-    ctx.fillText(alphabet.get_symbol(i), 0, 0);
-    //measure
-    size = canvas_bounds(ctx, canvas.width, canvas.height);
-    if (size.width === 0) throw new Error("Invisible symbol!");
-    widths.push(size.width);
-    sizes[i] = size;
-  }
-  //sort the widths
-  widths.sort(function(a,b) {return a - b;});
-  //drop 10% of the items off each end
-  tenpercent = Math.floor(widths.length / 10);
-  for (i = 0; i < tenpercent; ++i) {
-    widths.pop();
-    widths.shift();
-  }
-  //calculate average width
-  avg_width = 0;
-  for (i = 0; i < widths.length; ++i) {
-    avg_width += widths[i];
-  }
-  avg_width /= widths.length;
-  // calculate the target width
-  target_width = width * this.scale * 2;
-  // calculate scales
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    sym = alphabet.get_symbol(i);
-    size = sizes[i];
-    // calculate scale
-    scale = target_width / Math.max(avg_width, size.width);
-    // estimate scaled height
-    target_height = size.height * scale;
-    // create an appropriately sized canvas
-    canvas = document.createElement("canvas");
-    canvas.width = target_width;
-    canvas.height = target_height + safety_pad * 2;
-    // calculate the middle
-    middle = Math.round(canvas.width / 2);
-    // calculate the baseline
-    baseline = Math.round(canvas.height - safety_pad);
-    // get the context and prepare to draw the rasterized text
-    ctx = canvas.getContext('2d');
-    ctx.font = font;
-    ctx.fillStyle = alphabet.get_colour(i);
-    ctx.textAlign = "center";
-    ctx.translate(middle, baseline);
-    ctx.save();
-    ctx.scale(scale, scale);
-    // draw the text
-    ctx.fillText(sym, 0, 0);
-    ctx.restore();
-    this.sym_cache[sym] = {"image": canvas, "size": canvas_bounds(ctx, canvas.width, canvas.height)};
-  }
-};
-
-RasterizedAlphabet.prototype.get_alphabet = function() {
-  return this.alphabet;
-};
-
-RasterizedAlphabet.prototype.get_scale = function() {
-  return this.scale;
-};
-
-RasterizedAlphabet.prototype.draw_stack_sym = function(ctx, letter, dx, dy, dWidth, dHeight) {
-  "use strict";
-  var entry, image, size;
-  entry = this.sym_cache[letter];
-  image = entry.image;
-  size = entry.size;
-  ctx.drawImage(image, 0, size.bound_top -1, image.width, size.height+1, dx, dy, dWidth, dHeight);
-};
-
-RasterizedAlphabet.prototype.draw_stack_num = function(ctx, font, stack_width, index) {
-  var image, image_ctx, text_length;
-  if (index >= this.stack_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.save();
-    image_ctx.font = font;
-    text_length = image_ctx.measureText("" + (index + 1)).width;
-    image_ctx.restore();
-    // resize the canvas to fit
-    image.width = Math.ceil(stack_width);
-    image.height = Math.ceil(text_length);
-    // draw the text
-    image_ctx = image.getContext('2d');
-    image_ctx.translate(Math.round(stack_width / 2), 0);
-    image_ctx.font = font;
-    image_ctx.textBaseline = "middle";
-    image_ctx.textAlign = "right";
-    image_ctx.rotate(-(Math.PI / 2));
-    image_ctx.fillText("" + (index + 1), 0, 0);
-    this.stack_num_cache[index] = image;
-  } else {
-    image = this.stack_num_cache[index];
-  }
-  ctx.drawImage(image, 0, 0);
-}
-
-RasterizedAlphabet.prototype.draw_scale_num = function(ctx, font, num) {
-  var image, image_ctx, text_size, m_length;
-  if (num >= this.scale_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.font = font;
-    text_size = image_ctx.measureText("" + num);
-    if (text_size.actualBoundingBoxAscent && text_size.actualBoundingBoxDesent) {
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(text_size.actualBoundingBoxAscent + text_size.actualBoundingBoxDesent);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.fillText("" + num, image.width, text_size.actualBoundingBoxAscent);
-    } else {
-      // measure width of 'm' to approximate height, we double it later anyway
-      m_length = image_ctx.measureText("m").width;
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(2 * m_length);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.textBaseline = "middle";
-      image_ctx.fillText("" + num, image.width, m_length);
-    }
-    this.scale_num_cache[num] = image;
-  } else {
-    image = this.scale_num_cache[num];
-  }
-  ctx.drawImage(image, -image.width, -Math.round(image.height / 2))
-}
-
-//======================================================================
-// end RasterizedAlphabet
-//======================================================================
-
-//======================================================================
-// start LogoMetrics object
-//======================================================================
-
-var LogoMetrics = function(ctx, logo_columns, logo_rows, has_names, has_finetext, x_axis, y_axis) {
-  "use strict";
-  var i, row_height;
-  //variable prototypes
-  this.pad_top = (has_names ? 5 : 0);
-  this.pad_left = (y_axis ? 10 : 0);
-  this.pad_right = (has_finetext ? 15 : 0);
-  this.pad_bottom = 0;
-  this.pad_middle = 20;
-  this.name_height = 14;
-  this.name_font = "bold " + this.name_height + "px Times, sans-serif";
-  this.name_spacer = 0;
-  this.y_axis = y_axis;
-  this.y_label = "bits";
-  this.y_label_height = 12;
-  this.y_label_font = "bold " + this.y_label_height + "px Helvetica, sans-serif";
-  this.y_label_spacer = 3;
-  this.y_num_height = 12;
-  this.y_num_width = 0;
-  this.y_num_font = "bold " + this.y_num_height + "px Helvetica, sans-serif";
-  this.y_tic_width = 5;
-  this.stack_pad_left = 0;
-  this.stack_font = "bold 25px Helvetica, sans-serif";
-  this.stack_height = 90;
-  this.stack_width = 26;
-  this.stacks_pad_right = 5;
-  this.x_axis = x_axis;
-  this.x_num_above = 2;
-  this.x_num_height = 12;
-  this.x_num_width = 0;
-  this.x_num_font = "bold " + this.x_num_height + "px Helvetica, sans-serif";
-  this.fine_txt_height = 6;
-  this.fine_txt_above = 2;
-  this.fine_txt_font = "normal " + this.fine_txt_height + "px Helvetica, sans-serif";
-  this.letter_metrics = new Array();
-  this.summed_width = 0;
-  this.summed_height = 0;
-  //calculate the width of the y axis numbers
-  ctx.font = this.y_num_font;
-  for (i = 0; i <= 2; i++) {
-    this.y_num_width = Math.max(this.y_num_width, ctx.measureText("" + i).width);
-  }
-  //calculate the width of the x axis numbers (but they are rotated so it becomes height)
-  if (x_axis == 1) {
-    ctx.font = this.x_num_font;
-    for (i = 1; i <= logo_columns; i++) {
-      this.x_num_width = Math.max(this.x_num_width, ctx.measureText("" + i).width);
-    }
-  } else if (x_axis == 0) {
-    this.x_num_height = 4;
-    this.x_num_width = 4;
-  } else {
-    this.x_num_height = 0;
-    this.x_num_width = 0;
-  }
-  
-  //calculate how much vertical space we want to draw this
-  //first we add the padding at the top and bottom since that's always there
-  this.summed_height += this.pad_top + this.pad_bottom;
-  //all except the last row have the same amount of space allocated to them
-  if (logo_rows > 1) {
-    row_height = this.stack_height + this.pad_middle;
-    if (has_names) {
-      row_height += this.name_height;
-      //the label is allowed to overlap into the spacer
-      row_height += Math.max(this.y_num_height/2, this.name_spacer); 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    } else {
-      row_height += this.y_num_height/2; 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    }
-    this.summed_height += row_height * (logo_rows - 1);
-  }
-  //the last row has the name and fine text below it but no padding
-  this.summed_height += this.stack_height + (this.y_axis ? this.y_num_height/2 : 0);
-
-  var fine_txt_total = (has_finetext ? this.fine_txt_height + this.fine_txt_above : 0);
-  if (has_names) {
-    this.summed_height += fine_txt_total + this.name_height;
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + this.name_spacer);
-  } else {
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + fine_txt_total);
-  }
-
-  //calculate how much horizontal space we want to draw this
-  //first add the padding at the left and right since that's always there
-  this.summed_width += this.pad_left + this.pad_right;
-  if (this.y_axis) {
-    //add on the space for the y-axis label
-    this.summed_width += this.y_label_height + this.y_label_spacer;
-    //add on the space for the y-axis
-    this.summed_width += this.y_num_width + this.y_tic_width;
-  }
-  //add on the space for the stacks
-  this.summed_width += (this.stack_pad_left + this.stack_width) * logo_columns;
-  //add on the padding after the stacks (an offset from the fine text)
-  this.summed_width += this.stacks_pad_right;
-
-};
-
-//======================================================================
-// end LogoMetrics object
-//======================================================================
-
-//found this trick at http://talideon.com/weblog/2005/02/detecting-broken-images-js.cfm
-function image_ok(img) {
-  "use strict";
-  // During the onload event, IE correctly identifies any images that
-  // weren't downloaded as not complete. Others should too. Gecko-based
-  // browsers act like NS4 in that they report this incorrectly.
-  if (!img.complete) {
-    return false;
-  }
-  // However, they do have two very useful properties: naturalWidth and
-  // naturalHeight. These give the true size of the image. If it failed
-  // to load, either of these should be zero.
-  if (typeof img.naturalWidth !== "undefined" && img.naturalWidth === 0) {
-    return false;
-  }
-  // No other way of checking: assume it's ok.
-  return true;
-}
-  
-function supports_text(ctx) {
-  "use strict";
-  if (!ctx.fillText) {
-    return false;
-  }
-  if (!ctx.measureText) {
-    return false;
-  }
-  return true;
-}
-
-//draws the scale, returns the width
-function draw_scale(ctx, metrics, alphabet_ic, raster) {
-  "use strict";
-  var tic_height, i;
-  tic_height = metrics.stack_height / alphabet_ic;
-  ctx.save();
-  ctx.translate(metrics.y_label_height, metrics.y_num_height/2);
-  //draw the axis label
-  ctx.save();
-  ctx.font = metrics.y_label_font;
-  ctx.translate(0, metrics.stack_height/2);
-  ctx.rotate(-(Math.PI / 2));
-  ctx.textAlign = "center";
-  ctx.fillText("bits", 0, 0);
-  ctx.restore();
-
-  ctx.translate(metrics.y_label_spacer + metrics.y_num_width, 0);
-
-  //draw the axis tics
-  ctx.save();
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i <= alphabet_ic; i++) {
-    //draw the number
-    ctx.save();
-    ctx.translate(-1, 0);
-    raster.draw_scale_num(ctx, metrics.y_num_font, i);
-    ctx.restore();
-    //draw the tic
-    ctx.fillRect(0, -1, metrics.y_tic_width, 2);
-    //prepare for next tic
-    ctx.translate(0, -tic_height);
-  }
-  ctx.restore();
-
-  ctx.fillRect(metrics.y_tic_width - 2, 0, 2, metrics.stack_height)
-
-  ctx.restore();
-}
-
-function draw_stack_num(ctx, metrics, row_index, raster) {
-  "use strict";
-  ctx.save();
-  ctx.translate(0, Math.round(metrics.stack_height + metrics.x_num_above));
-  if (metrics.x_axis == 1) {
-    raster.draw_stack_num(ctx, metrics.x_num_font, metrics.stack_width, row_index);
-  } else if (metrics.x_axis == 0) {
-    // draw dots instead of the numbers (good for small logos)
-    ctx.beginPath();
-    var radius = Math.round(metrics.x_num_height / 2);
-    ctx.arc(Math.round(metrics.stack_width / 2), radius, radius, 0, 2 * Math.PI, false);
-    ctx.fill();
-  }
-  ctx.restore();
-}
-
-function draw_stack(ctx, metrics, symbols, raster) {
-  "use strict";
-  var preferred_pad, sym_min, i, sym, sym_height, pad;
-  preferred_pad = 0;
-  sym_min = 5;
-
-  ctx.save();//1
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i < symbols.length; i++) {
-    sym = symbols[i];
-    sym_height = metrics.stack_height * sym.get_scale();
-    
-    pad = preferred_pad;
-    if (sym_height - pad < sym_min) {
-      pad = Math.min(pad, Math.max(0, sym_height - sym_min));
-    }
-    sym_height -= pad;
-
-    //translate to the correct position
-    ctx.translate(0, -(pad/2 + sym_height));
-
-    //draw
-    raster.draw_stack_sym(ctx, sym.get_symbol(), 0, 0, metrics.stack_width, sym_height);
-    //translate past the padding
-    ctx.translate(0, -(pad/2));
-  }
-  ctx.restore();//1
-}
-
-function draw_dashed_line(ctx, pattern, start, x1, y1, x2, y2) {
-  "use strict";
-  var x, y, len, i, dx, dy, tlen, theta, mulx, muly, lx, ly;
-  dx = x2 - x1;
-  dy = y2 - y1;
-  tlen = Math.pow(dx*dx + dy*dy, 0.5);
-  theta = Math.atan2(dy,dx);
-  mulx = Math.cos(theta);
-  muly = Math.sin(theta);
-  lx = [];
-  ly = [];
-  for (i = 0; i < pattern; ++i) {
-    lx.push(pattern[i] * mulx);
-    ly.push(pattern[i] * muly);
-  }
-  i = start;
-  x = x1;
-  y = y1;
-  len = 0;
-  ctx.beginPath();
-  while (len + pattern[i] < tlen) {
-    ctx.moveTo(x, y);
-    x += lx[i];
-    y += ly[i];
-    ctx.lineTo(x, y);
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-    x += lx[i];
-    y += ly[i];
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-  }
-  if (len < tlen) {
-    ctx.moveTo(x, y);
-    x += mulx * (tlen - len);
-    y += muly * (tlen - len);
-    ctx.lineTo(x, y);
-  }
-  ctx.stroke();
-}
-
-function draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider) {
-  "use strict";
-  var left_size = left_end - left_start;
-  var right_size = right_end - right_start;
-  var line_x;
-
-  ctx.save();//s8
-  ctx.fillStyle = "rgb(240, 240, 240)";
-  if (left_size > 0) {
-    ctx.fillRect(left_start * metrics.stack_width, 0, left_size * metrics.stack_width, metrics.stack_height);
-  }
-  if (right_size > 0) {
-    ctx.fillRect(right_start * metrics.stack_width, 0, right_size * metrics.stack_width, metrics.stack_height);
-  }
-  ctx.fillStyle = "rgb(51, 51, 51)";
-  if (left_size > 0 && left_divider) {
-    line_x = (left_end * metrics.stack_width) - 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  if (right_size > 0 && right_divider) {
-    line_x = (right_start * metrics.stack_width) + 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  ctx.restore();//s8
-}
-
-function size_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var draw_name, draw_finetext, metrics;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  if (canvas.width !== 0 && canvas.height !== 0) {
-    return;
-  }
-  metrics = new LogoMetrics(canvas.getContext('2d'), 
-      logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      canvas.width = metrics.summed_width * (canvas.height / metrics.summed_height);
-    } else if (canvas.height === 0) {
-      canvas.height = metrics.summed_height * (canvas.width / metrics.summed_width);
-    }
-  }
-}
 
-function draw_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var i, draw_name, draw_finetext, ctx, metrics, raster, pspm_i, pspm, 
-      offset, col_index, motif_position, ssc;
-  ssc = false;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  ctx = canvas.getContext('2d');
-  //assume that the user wants the canvas scaled equally so calculate what the best width for this image should be
-  metrics = new LogoMetrics(ctx, logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      scale = 1;
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      scale = canvas.height / metrics.summed_height;
-      canvas.width = metrics.summed_width * scale;
-    } else if (canvas.height === 0) {
-      scale = canvas.width / metrics.summed_width;
-      canvas.height = metrics.summed_height * scale;
-    } else {
-      scale = Math.min(canvas.width / metrics.summed_width, canvas.height / metrics.summed_height);
-    }
-  }
-  // cache the raster based on the assumption that we will be drawing a lot
-  // of logos the same size and alphabet
-  if (typeof draw_logo_on_canvas.raster_cache === "undefined") {
-    draw_logo_on_canvas.raster_cache = [];
-  }
-  for (i = 0; i < draw_logo_on_canvas.raster_cache.length; i++) {
-    raster = draw_logo_on_canvas.raster_cache[i];
-    if (raster.get_alphabet().equals(logo.alphabet) &&
-        Math.abs(raster.get_scale() - scale) < 0.1) break;
-    raster = null;
-  }
-  if (raster == null) {
-    raster = new RasterizedAlphabet(logo.alphabet, scale, metrics.stack_font, metrics.stack_width);
-    draw_logo_on_canvas.raster_cache.push(raster);
-  }
-  ctx = canvas.getContext('2d');
-  ctx.save();//s1
-  ctx.scale(scale, scale);
-  ctx.save();//s2
-  ctx.save();//s7
-  //create margin
-  ctx.translate(Math.round(metrics.pad_left), Math.round(metrics.pad_top));
-  for (pspm_i = 0; pspm_i < logo.get_rows(); ++pspm_i) {
-    pspm = logo.get_pspm(pspm_i);
-    offset = logo.get_offset(pspm_i);
-    //optionally draw name if this isn't the last row or is the only row 
-    if (draw_name && (logo.get_rows() == 1 || pspm_i != (logo.get_rows()-1))) {
-      ctx.save();//s4
-      ctx.translate(Math.round(metrics.summed_width/2), Math.round(metrics.name_height));
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s4
-      ctx.translate(0, Math.round(metrics.name_height + 
-          Math.min(0, metrics.name_spacer - metrics.y_num_height/2)));
-    }
-    //draw scale
-    if (logo.y_axis) draw_scale(ctx, metrics, logo.alphabet.get_ic(), raster);
-    ctx.save();//s5
-    //translate across past the scale
-    if (logo.y_axis) {
-      ctx.translate(Math.round(metrics.y_label_height + metrics.y_label_spacer + 
-        metrics.y_num_width + metrics.y_tic_width), Math.round(metrics.y_num_height / 2));
-    }
-    //draw the trimming background
-    if (pspm.get_left_trim() > 0 || pspm.get_right_trim() > 0) {
-      var left_start = offset * logo.get_xlate_nsyms();
-      var left_end = (offset + pspm.get_left_trim()) * logo.get_xlate_nsyms();
-      var left_divider = true;
-      if (left_end < logo.get_xlate_start() || left_start > logo.get_xlate_end()) {
-        // no overlap
-        left_start = 0;
-        left_end = 0;
-        left_divider = false;
-      } else {
-        if (left_start < logo.get_xlate_start()) {
-          left_start = logo.get_xlate_start();
-        }
-        if (left_end > logo.get_xlate_end()) {
-          left_end = logo.get_xlate_end();
-          left_divider = false;
-        }
-        left_start -= logo.get_xlate_start();
-        left_end -= logo.get_xlate_start();
-        if (left_end < left_start) {
-          left_start = 0;
-          left_end = 0;
-          left_divider = false;
-        }
-      }
-      var right_end = (offset + pspm.get_motif_length()) * logo.get_xlate_nsyms();
-      //var right_start = right_end - (pspm.get_left_trim() * logo.get_xlate_nsyms());
-      var right_start = right_end - (pspm.get_right_trim() * logo.get_xlate_nsyms());
-      var right_divider = true;
-      if (right_end < logo.get_xlate_start() || right_start > logo.get_xlate_end()) {
-        // no overlap
-        right_start = 0;
-        right_end = 0;
-        right_divider = false;
-      } else {
-        if (right_start < logo.get_xlate_start()) {
-          right_start = logo.get_xlate_start();
-          right_divider = false;
-        }
-        if (right_end > logo.get_xlate_end()) {
-          right_end = logo.get_xlate_end();
-        }
-        right_start -= logo.get_xlate_start();
-        right_end -= logo.get_xlate_start();
-        if (right_end < right_start) {
-          right_start = 0;
-          right_end = 0;
-          right_divider = false;
-        }
-      }
-      draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider);
-    }
-    //draw letters
-    var xlate_col;
-    for (xlate_col = logo.get_xlate_start(); xlate_col < logo.get_xlate_end(); xlate_col++) {
-      ctx.translate(metrics.stack_pad_left,0);
-      col_index = Math.floor(xlate_col / logo.get_xlate_nsyms());
-      if (xlate_col % logo.get_xlate_nsyms() == 0) {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          motif_position = col_index - offset;
-          draw_stack_num(ctx, metrics, motif_position, raster);
-          draw_stack(ctx, metrics, pspm.get_stack(motif_position, logo.alphabet, ssc), raster);
-        }
-      } else {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          ctx.save();// s5.1
-          ctx.translate(0, Math.round(metrics.stack_height));
-          // TODO draw a dot or dash or something to indicate continuity of the motif
-          ctx.restore(); //s5.1
-        }
-      }
-      ctx.translate(Math.round(metrics.stack_width), 0);
-    }
-    ctx.restore();//s5
-    ////optionally draw name if this is the last row but isn't the only row 
-    if (draw_name && (logo.get_rows() != 1 && pspm_i == (logo.get_rows()-1))) {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width + metrics.name_spacer));
-
-      ctx.save();//s6
-      ctx.translate(metrics.summed_width/2, metrics.name_height);
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s6
-      ctx.translate(0, metrics.name_height);
-    } else {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width));
-    }
-    //if not the last row then add middle padding
-    if (pspm_i != (logo.get_rows() -1)) {
-      ctx.translate(0, metrics.pad_middle);
-    }
-  }
-  ctx.restore();//s7
-  if (logo.fine_text.length > 0) {
-    ctx.translate(metrics.summed_width - metrics.pad_right, metrics.summed_height - metrics.pad_bottom);
-    ctx.font = metrics.fine_txt_font;
-    ctx.textAlign = "right";
-    ctx.fillText(logo.fine_text, 0,0);
-  }
-  ctx.restore();//s2
-  ctx.restore();//s1
-}
-
-function create_canvas(c_width, c_height, c_id, c_title, c_display) {
-  "use strict";
-  var canvas = document.createElement("canvas");
-  //check for canvas support before attempting anything
-  if (!canvas.getContext) {
-    return null;
-  }
-  var ctx = canvas.getContext('2d');
-  //check for html5 text drawing support
-  if (!supports_text(ctx)) {
-    return null;
-  }
-  //size the canvas
-  canvas.width = c_width;
-  canvas.height = c_height;
-  canvas.id = c_id;
-  canvas.title = c_title;
-  canvas.style.display = c_display;
-  return canvas;
-}
-
-function logo_1(alphabet, fine_text, pspm) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  logo.add_pspm(pspm);
-  return logo;
-}
-
-function logo_2(alphabet, fine_text, target, query, query_offset) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  if (query_offset < 0) {
-    logo.add_pspm(target, -query_offset);
-    logo.add_pspm(query);
-  } else {
-    logo.add_pspm(target);
-    logo.add_pspm(query, query_offset);
-  }      
-  return logo;
-}
-
-/*
- * Specifies an alternate source for an image.
- * If the image with the image_id specified has
- * not loaded then a generated logo will be used 
- * to replace it.
- *
- * Note that the image must either have dimensions
- * or a scale must be set.
- */
-function alternate_logo(logo, image_id, scale) {
-  "use strict";
-  var image = document.getElementById(image_id);
-  if (!image) {
-    alert("Can't find specified image id (" +  image_id + ")");
-    return;
-  }
-  //if the image has loaded then there is no reason to use the canvas
-  if (image_ok(image)) {
-    return;
-  }
-  //the image has failed to load so replace it with a canvas if we can.
-  var canvas = create_canvas(image.width, image.height, image_id, image.title, image.style.display);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the image with the canvas
-  image.parentNode.replaceChild(canvas, image);
-}
-
-/*
- * Specifes that the element with the specified id
- * should be replaced with a generated logo.
- */
-function replace_logo(logo, replace_id, scale, title_txt, display_style) {
-  "use strict";
-  var element = document.getElementById(replace_id);
-  if (!replace_id) {
-    alert("Can't find specified id (" + replace_id + ")");
-    return;
-  }
-  //found the element!
-  var canvas = create_canvas(50, 120, replace_id, title_txt, display_style);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the element with the canvas
-  element.parentNode.replaceChild(canvas, element);
-}
-
-/*
- * Fast string trimming implementation found at
- * http://blog.stevenlevithan.com/archives/faster-trim-javascript
- *
- * Note that regex is good at removing leading space but
- * bad at removing trailing space as it has to first go through
- * the whole string.
- */
-function trim (str) {
-  "use strict";
-  var ws, i;
-  str = str.replace(/^\s\s*/, '');
-  ws = /\s/; i = str.length;
-  while (ws.test(str.charAt(--i)));
-  return str.slice(0, i + 1);
-}
-</script>
-    <script>
-
-// PRIVATE GLOBAL (uhoh)
-var _block_colour_lookup = {};
-
-function block_colour(index) {
-  function hsl2rgb(hue, saturation, lightness) {
-    "use strict";
-    function _hue(p, q, t) {
-      "use strict";
-      if (t < 0) t += 1;
-      else if (t > 1) t -= 1;
-      if (t < (1.0 / 6.0)) {
-        return p + ((q - p) * 6.0 * t);
-      } else if (t < 0.5) {
-        return q;
-      } else if (t < (2.0 / 3.0)) {
-        return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-      } else {
-        return p;
-      }
-    }
-    function _pad_hex(value) {
-      var hex = Math.round(value * 255).toString(16);
-      if (hex.length < 2) hex = "0" + hex;
-      return hex;
-    }
-    var r, g, b, p, q;
-    if (saturation == 0) {
-      // achromatic (grayscale)
-      r = lightness;
-      g = lightness;
-      b = lightness;
-    } else {
-      if (lightness < 0.5) {
-        q = lightness * (1 + saturation);
-      } else {
-        q = lightness + saturation - (lightness * saturation);
-      }
-      p = (2 * lightness) - q;
-      r = _hue(p, q, hue + (1.0 / 3.0));
-      g = _hue(p, q, hue);
-      b = _hue(p, q, hue - (1.0 / 3.0));
-    }
-    return "#" + _pad_hex(r) + _pad_hex(g) + _pad_hex(b);
-  }
-  if (typeof index !== "number" || index % 1 !== 0 || index < 0) return "#000000";
-  // check for override
-  if (_block_colour_lookup[index] == null) {
-    var start = 0; //red
-    var sat = 100;
-    var light = 50;
-    var divisions = 1 << Math.ceil(Math.log(index + 1) / Math.LN2);
-    hue = start + (360 / divisions) * ((index - (divisions >> 1)) * 2 + 1);
-    // colour input fields only support values in the form #RRGGBB
-    _block_colour_lookup[index] = hsl2rgb(hue / 360, sat / 100, light / 100);
-  }
-  return _block_colour_lookup[index];
-}
-
-function set_block_colour(index, new_colour) {
-  _block_colour_lookup[index] = new_colour;
-  var blocks = document.querySelectorAll("div.block_motif[data-colour-index=\"" + index + "\"]");
-  var i;
-  for (i = 0; i < blocks.length; i++) {
-    blocks[i].style.backgroundColor = new_colour;
-  }
-  var swatches = document.querySelectorAll("div.legend_swatch[data-colour-index=\"" + index + "\"]");
-  var picker;
-  for (i = 0; i < swatches.length; i++) {
-    swatches[i].style.backgroundColor = new_colour;
-    picker = swatches[i].querySelector("input[type=\"color\"]");
-    if (picker != null) picker.value = new_colour;
-  }
-}
-
-function make_block_legend_entry(motif_name, motif_colour_index) {
-  if (typeof make_block_legend_entry.has_colour_picker !== "boolean") {
-    // test if colour picker is supported, based off Modernizer
-    // see http://stackoverflow.com/a/7787648/66387
-    make_block_legend_entry.has_colour_picker = (function() {
-      var doc_ele = document.documentElement;
-      // We first check to see if the type we give it sticks..
-      var input_ele = document.createElement('input');
-      input_ele.setAttribute('type', 'color');
-      var value_ok = input_ele.type !== 'text';
-      if (value_ok) {
-        // If the type does, we feed it a textual value, which shouldn't be valid.
-        // If the value doesn't stick, we know there's input sanitization which infers a custom UI
-        var smile = ':)';
-        input_ele.value = smile;
-        input_ele.style.cssText = 'position:absolute;visibility:hidden;';
-        // chuck into DOM and force reflow for Opera bug in 11.00
-        // github.com/Modernizr/Modernizr/issues#issue/159
-        doc_ele.appendChild(input_ele);
-        doc_ele.offsetWidth;
-        value_ok = input_ele.value != smile;
-        doc_ele.removeChild(input_ele);
-      }
-      return value_ok;
-    })();
-  }
-  var entry = document.createElement("div");
-  entry.className = "legend_entry";
-  var swatch;
-  swatch = document.createElement("div");
-  swatch.className = "legend_swatch";
-  swatch.setAttribute("data-colour-index", motif_colour_index);
-  swatch.style.backgroundColor = block_colour(motif_colour_index);
-  if (make_block_legend_entry.has_colour_picker) {
-    var picker = document.createElement("input");
-    picker.type = "color";
-    picker.value = block_colour(motif_colour_index);
-    picker.addEventListener("change", function(e) {
-      set_block_colour(motif_colour_index, picker.value);
-    }, false);
-    swatch.addEventListener("click", function(e) {
-      picker.click();
-    }, false);
-    swatch.appendChild(picker);
-  }
-  entry.appendChild(swatch);
-  var name = document.createElement("div");
-  name.className = "legend_text";
-  name.appendChild(document.createTextNode(motif_name));
-  entry.appendChild(name);
-  return entry;
-}
-
-function make_block_ruler(max_len) {
-  var container = document.createElement("div");
-  container.className = "block_container";
-  var step;
-  if (max_len < 50) {
-    step = 1;
-  } else if (max_len < 100) {
-    step = 2;
-  } else if (max_len < 200) {
-    step = 4;
-  } else if (max_len < 500) {
-    step = 10;
-  } else if (max_len < 1000) {
-    step = 20;
-  } else if (max_len < 2000) {
-    step = 40;
-  } else if (max_len < 5000) {
-    step = 100;
-  } else if (max_len < 10000) {
-    step = 200;
-  } else if (max_len < 20000) {
-    step = 400;
-  } else {
-    step = Math.floor(max_len / 20000) * 400;
-  }
-  var peroid;
-  if (max_len < 10) {
-    peroid = 1;
-  } else if (max_len < 20) {
-    peroid = 2;
-  } else {
-    peroid = 5;
-  }
-  var i, cycle, offset, tic, label;
-  for (i = 0, cycle = 0; i < max_len; i += step, cycle = (cycle + 1) % peroid) {
-    offset = "" + ((i / max_len) * 100) + "%";
-    tic = document.createElement("div");
-    tic.style.left = offset;
-    tic.className = (cycle == 0 ? "tic_major" : "tic_minor");
-    container.appendChild(tic);
-    if (cycle == 0) {
-      label = document.createElement("div");
-      label.className = "tic_label";
-      label.style.left = offset;
-      label.appendChild(document.createTextNode(i));
-      container.appendChild(label);
-    }
-  }
-  return container;
-}
-
-function _calculate_block_needle_drag_pos(e, data) {
-  var mouse;
-  e = e || window.event;
-  if (e.pageX || ev.pageY) {
-    mouse = {"x": e.pageX, "y": e.pageY};
-  } else {
-    mouse = {
-      x:e.clientX + document.body.scrollLeft - document.body.clientLeft, 
-      y:e.clientY + document.body.scrollTop  - document.body.clientTop 
-    };
-  }
-  var cont = data.container;
-  var dragable_length = cont.clientWidth - 
-    (cont.style.paddingLeft ? cont.style.paddingLeft : 0) -
-    (cont.style.paddingRight ? cont.style.paddingRight : 0);
-  //I believe that the offset parent is the body
-  //otherwise I would need to make this recursive
-  //maybe clientLeft would work, but the explanation of
-  //it is hard to understand and it apparently doesn't work
-  //in firefox 2.
-  var diff = mouse.x - cont.offsetLeft;
-  if (diff < 0) diff = 0;
-  if (diff > dragable_length) diff = dragable_length;
-  var pos = Math.round(diff / dragable_length * data.max);
-  if (pos > data.len) pos = data.len;
-  return pos;
-}
-
-function _update_block_needle_drag(e, data, done) {
-  "use strict";
-  var pos = _calculate_block_needle_drag_pos(e, data);
-  // read the needle positions
-  var left = parseInt(data.llabel.textContent, 10) - data.off - 1;
-  var right = parseInt(data.rlabel.textContent, 10) - data.off;
-  // validate needle positions
-  if (left >= data.len) left = data.len - 1;
-  if (left < 0) left = 0;
-  if (right > data.len) right = data.len;
-  if (right <= left) right = left + 1;
-  // calculate the new needle positions
-  if (data.moveboth) {
-    var size = right - left;
-    if (data.isleft) {
-      if ((pos + size) > data.len) pos = data.len - size;
-      left = pos;
-      right = pos + size;
-    } else {
-      if ((pos - size) < 0) pos = size;
-      left = pos - size;
-      right = pos;
-    }
-  } else {
-    if (data.isleft) {
-      if (pos >= right) pos = right - 1;
-      left = pos;
-    } else {
-      if (pos <= left) pos = left + 1;
-      right = pos;
-    }
-  }
-  // update the needle positions
-  data.lneedle.style.left = "" + (left / data.max * 100) + "%";
-  data.llabel.textContent = "" + (left + data.off + 1);
-  data.rneedle.style.left = "" + (right / data.max * 100) + "%";
-  data.rlabel.textContent = "" + (right + data.off);
-  data.handler(left, right, done);
-}
-
-function _make_block_needle_drag_start_handler(isleft, data) {
-  return function (e) {
-    data.isleft = isleft;
-    data.moveboth = !(e.shiftKey);
-    document.addEventListener("mousemove", data.drag_during, false);
-    document.addEventListener("mouseup", data.drag_end, false);
-  };
-}
-
-function _make_block_needle_drag_end_handler(data) {
-  return function (e) {
-    document.removeEventListener("mousemove", data.drag_during, false);
-    document.removeEventListener("mouseup", data.drag_end, false);
-    _update_block_needle_drag(e, data, true);
-  };
-}
-
-function _make_block_needle_drag_during_handler(data) {
-  return function (e) {
-    _update_block_needle_drag(e, data, false);
-  };
-}
-
-// private function used by make_block_container
-function _make_block_needle(isleft, value, data) {
-  var vbar = document.createElement('div');
-  vbar.className = "block_needle " + (isleft ? "left" : "right");
-  vbar.style.left = "" + (value / data.max * 100)+ "%";
-  var label = document.createElement('div');
-  label.className = "block_handle " + (isleft ? "left" : "right");
-  // The needles sit between the sequence positions, so the left one sits at the
-  // start and the right at the end. This is why 1 is added to the displayed
-  // value for a left handle as the user doesn't need to know about this detail
-  label.textContent = "" + (isleft ? value + data.off + 1 : value + data.off);
-  label.unselectable = "on"; // so IE and Opera don't select the text, others are done in css
-  label.title = "Drag to move the displayed range. Hold shift and drag to change " + (isleft ? "lower" : "upper") + " bound of the range.";
-  vbar.appendChild(label);
-  if (isleft) {
-    data.lneedle = vbar;
-    data.llabel = label;
-  } else {
-    data.rneedle = vbar;
-    data.rlabel = label;
-  }
-  label.addEventListener("mousedown", _make_block_needle_drag_start_handler(isleft, data), false);
-  return vbar;
-}
-
-function make_block_container(is_stranded, has_both_strands, max_len, show_len, offset, range_handler) {
-  offset = (offset != null ? offset : 0);
-  // make the container for the block diagram
-  var container = document.createElement("div");
-  container.className = "block_container";
-  container.setAttribute("data-max", max_len);
-  container.setAttribute("data-off", offset);
-  if (is_stranded) {
-    var plus = document.createElement("div");
-    plus.appendChild(document.createTextNode("+"));
-    plus.className = "block_plus_sym";
-    container.appendChild(plus);
-    if (has_both_strands) {
-      var minus = document.createElement("div");
-      minus.appendChild(document.createTextNode("-"));
-      minus.className = "block_minus_sym";
-      container.appendChild(minus);
-    }
-  }
-  var rule = document.createElement("div");
-  rule.className = "block_rule";
-  rule.style.width = ((show_len / max_len) * 100) + "%";
-  container.appendChild(rule);
-  if (range_handler != null) {
-    var range_data = {
-      "max": max_len,
-      "len": show_len,
-      "off": offset,
-      "handler": range_handler,
-      "container": container,
-      "lneedle": null, "llabel": null,
-      "rneedle": null, "rlabel": null,
-      "isleft": false, "moveboth" : false
-    };
-    range_data.drag_during = _make_block_needle_drag_during_handler(range_data);
-    range_data.drag_end = _make_block_needle_drag_end_handler(range_data);
-    container.appendChild(_make_block_needle(false, 1, range_data)); // add right first so z-index works
-    container.appendChild(_make_block_needle(true, 0, range_data));
-  }
-  return container;
-}
-
-function make_block_label(container, max_len, pos, length, message) {
-  "use strict";
-  var label = document.createElement("div");
-  label.className = "block_label";
-  label.style.left = (((pos + (length / 2)) / max_len) * 100) + "%";
-  label.appendChild(document.createTextNode(message));
-  container.appendChild(label);
-}
-
-function make_block(container, max_len,
-    site_pos, site_len, site_pvalue, site_rc, site_colour_index, site_secondary) {
-  "use strict";
-  var block_height, block, block_region1, block_region2;
-  var max_block_height = 12;
-  var max_pvalue = 1e-10;
-  // calculate the height of the block
-  block_height = (site_pvalue < max_pvalue ? max_block_height : 
-      (Math.log(site_pvalue) / Math.log(max_pvalue)) * max_block_height);
-  if (block_height < 1) block_height = 1;
-  // create a block to represent the motif
-  block = document.createElement("div");
-  block.className = "block_motif" + (site_secondary ? " scanned_site" : "") + (site_rc ? " bottom" : " top");
-  block.style.left = ((site_pos / max_len) * 100) + "%";
-  block.style.top = (!site_rc ? max_block_height - block_height : 
-      max_block_height + 1) + "px";
-  block.style.width = ((site_len / max_len) * 100) + "%";
-  block.style.height = block_height + "px";
-  block.style.backgroundColor = block_colour(site_colour_index);
-  block.setAttribute("data-colour-index", site_colour_index);
-  // add to container
-  container.appendChild(block);
-  var activator = function (e) {
-    toggle_class(block, "active", true);
-    var new_e = new e.constructor(e.type, e);
-    block.dispatchEvent(new_e);
-  };
-  var deactivator = function (e) {
-    toggle_class(block, "active", false);
-    var new_e = new e.constructor(e.type, e);
-    block.dispatchEvent(new_e);
-  }
-  // create a larger region to detect mouseover for the block
-  block_region1 = document.createElement("div");
-  block_region1.className = "block_region top" + 
-    (site_secondary ? " scanned_site" : "") + (site_rc ? "" : " main");
-  block_region1.style.left = block.style.left;
-  block_region1.style.width = block.style.width;
-  block_region1.addEventListener('mouseover', activator, false);
-  block_region1.addEventListener('mouseout', deactivator, false);
-  container.appendChild(block_region1);
-  block_region2 = document.createElement("div");
-  block_region2.className = "block_region bottom" + 
-    (site_secondary ? " scanned_site" : "") + (site_rc ? " main" : "");
-  block_region2.style.left = block.style.left;
-  block_region2.style.width = block.style.width;
-  block_region2.addEventListener('mouseover', activator, false);
-  block_region2.addEventListener('mouseout', deactivator, false);
-  container.appendChild(block_region2);
-  return block;
-}
-
-function set_block_needle_positions(containingNode, start, end) {
-  var container, lneedle, llabel, rneedle, rlabel, max, off, left, right;
-  container = (/\bblock_container\b/.test(containingNode.className) ? containingNode : containingNode.querySelector(".block_container"));
-  max = parseInt(container.getAttribute("data-max"), 10);
-  off = parseInt(container.getAttribute("data-off"), 10);
-  left = start - off;
-  right = end - off;
-  lneedle = containingNode.querySelector(".block_needle.left");
-  llabel = lneedle.querySelector(".block_handle.left");
-  rneedle = containingNode.querySelector(".block_needle.right");
-  rlabel = rneedle.querySelector(".block_handle.right");
-  // update the needle positions
-  lneedle.style.left = "" + (left / max * 100) + "%";
-  llabel.textContent = "" + (left + off + 1);
-  rneedle.style.left = "" + (right / max * 100) + "%";
-  rlabel.textContent = "" + (right + off);
-}
-
-function get_block_needle_positions(containingNode) {
-  var container, llabel, rlabel, max, off, left, right;
-  container = (/\bblock_container\b/.test(containingNode.className) ? containingNode : containingNode.querySelector(".block_container"));
-  max = parseInt(container.getAttribute("data-max"), 10);
-  off = parseInt(container.getAttribute("data-off"), 10);
-  llabel = containingNode.querySelector(".block_needle.left > .block_handle.left");
-  rlabel = containingNode.querySelector(".block_needle.right > .block_handle.right");
-  left = parseInt(llabel.textContent, 10) - off - 1;
-  right = parseInt(rlabel.textContent, 10) - off;
-  return {"start": left + off, "end": right + off};
-}
-</script>
-    <script>
-function make_alpha_bg_table(alph, freqs) {
-  function colour_symbol(index) {
-    var span = document.createElement("span");
-    span.appendChild(document.createTextNode(alph.get_symbol(index)));
-    span.style.color = alph.get_colour(index);
-    span.className = "alpha_symbol";
-    return span;
-  }
-  var table, thead, tbody, row, th, span, i;
-  // create table
-  table = document.createElement("table");
-  table.className = "alpha_bg_table";
-  // create header
-  thead = document.createElement("thead");
-  table.appendChild(thead);
-  row = thead.insertRow(thead.rows.length);
-  if (alph.has_complement()) {
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-  } else {
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-  }
-  // add alphabet entries
-  tbody = document.createElement("tbody");
-  table.appendChild(tbody);
-  if (alph.has_complement()) {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      var c = alph.get_complement(i);
-      if (i > c) continue;
-      row = tbody.insertRow(tbody.rows.length);
-      add_text_cell(row, alph.get_name(i));
-      if (freqs != null) add_text_cell(row, "" + freqs[i].toFixed(3));
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(i).toFixed(3));
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, "~");
-      add_cell(row, colour_symbol(c)); 
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(c).toFixed(3));
-      if (freqs != null) add_text_cell(row, "" + freqs[c].toFixed(3));
-      add_text_cell(row, alph.get_name(c));
-    }
-  } else {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      row = tbody.insertRow(tbody.rows.length);
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, alph.get_name(i));
-      if (freqs != null) add_text_cell(row, "" + freqs[i].toFixed(3));
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(i).toFixed(3));
-    }
-  }
-  return table;
-}
-
-</script>
-    <script>
-var current_motif = 0;
-var meme_alphabet = new Alphabet(data.alphabet, data.background.freqs);
-
-var DelayLogoTask = function(logo, canvas) {
-  this.logo = logo;
-  this.canvas = canvas;
-};
-
-DelayLogoTask.prototype.run = function () {
-  draw_logo_on_canvas(this.logo, this.canvas, false);
-};
-
-function motif_pspm(index) {
-  var motif, pwm, psm, name, ltrim, rtrim, nsites, evalue;
-  // get motif
-  motif = data["motifs"][index];
-  // get motif paramters
-  pwm = motif["pwm"]; 
-  psm = motif["psm"];
-  name = "" + (index + 1); ltrim = 0; rtrim = 0; 
-  nsites = motif["nsites"]; evalue = motif["evalue"];
-  // make pspm
-  return new Pspm(pwm, name, ltrim, rtrim, nsites, evalue, psm);
-}
-
-function motif_count_matrix(index) {
-  return motif_pspm(index).as_count_matrix();
-}
-
-function motif_prob_matrix(index) {
-  return motif_pspm(index).as_probability_matrix();
-}
-
-function motif_minimal_meme(index) {
-  return motif_pspm(index).as_meme({
-    "with_header": true, 
-    "with_pspm": true,
-    "with_pssm": true,
-    "version": data["version"],
-    "alphabet": meme_alphabet,
-    "strands": (meme_alphabet.has_complement() && data.options.revcomp ? 2 : 1)
-  });
-}
-
-function motif_fasta(index) {
-  "use strict";
-  var motif, sites, site, seq, sequences, sequence, i, num, counter, out;
-  counter = {};
-  sequences = data["sequence_db"]["sequences"];
-  motif = data["motifs"][index];
-  sites = motif["sites"];
-  out = "";
-  for (i = 0; i < sites.length; i++) {
-    site = sites[i];
-    seq = site["seq"];
-    sequence = sequences[seq];
-    counter[seq] = (num = counter[seq]) ? (++num) : (num = 1); // inc counter
-    if (i !== 0) {out += "\n";}
-    out += ">" + sequence["name"] + "_site_" + num + " offset= " + site["pos"] + 
-      (site["rc"] ? " RC\n" : "\n");
-    out += site["match"];
-  }
-  return out;
-}
-
-function motif_raw(index) {
-  "use strict";
-  var sites, i, out;
-  sites = data["motifs"][index]["sites"];
-  out = "";
-  for (i = 0; i < sites.length; i++) {
-    if (i !== 0) {out += "\n";}
-    out += sites[i]["match"];
-  }
-  return out;
-}
-
-function clone_template(template) {
-  "use strict";
-  var node, help_btns, i, button;
-  node = $(template).cloneNode(true);
-  toggle_class(node, "template", false);
-  node.id = "";
-  help_btns = node.querySelectorAll(".help");
-  for (i = 0; i < help_btns.length; i++) {
-    button = help_btns[i];
-    if (button.hasAttribute("data-topic")) {
-      button.tabIndex = "0";
-      button.addEventListener("click", __toggle_help, false);
-      button.addEventListener("keydown", __toggle_help, false);
-    }
-  }
-  return node;
-}
-
-function set_tvar(template, tvar, value) {
-  var node;
-  node = find_child(template, tvar);
-  if (node === null) {
-    throw new Error("Template does not contain variable " + tvar);
-  }
-  node.innerHTML = "";
-  if (typeof value !== "object") {
-    node.appendChild(document.createTextNode(value));
-  } else {
-    node.appendChild(value);
-  }
-}
-
-function make_logo(alphabet, pspm, rc, offset, className) {
-  if (rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, "");
-  logo.add_pspm(pspm, offset);
-  var canvas = document.createElement('canvas');
-  canvas.height = 50;
-  canvas.width = 0;
-  canvas.className = className;
-  size_logo_on_canvas(logo, canvas, false);
-  add_draw_task(canvas, new DelayLogoTask(logo, canvas));
-  return canvas;
-}
-
-function make_small_logo(alphabet, pspm, options) {
-  if (typeof options === "undefined") options = {};
-  if (options.rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, {x_axis: false, y_axis: false});
-  logo.add_pspm(pspm, (typeof options.offset === "number" ? options.offset : 0));
-  var canvas = document.createElement('canvas');
-  if (typeof options.className === "string") canvas.className = options.className;
-  if (typeof options.width === "number" && options.width > 0) {
-    canvas.height = 0;
-    canvas.width = options.width;
-    draw_logo_on_canvas(logo, canvas, false);
-  } else {
-    draw_logo_on_canvas(logo, canvas, false, 1/3);
-  }
-  return canvas;
-}
-
-function make_large_logo(alphabet, pspm, rc, offset, className) {
-  if (rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, "");
-  logo.add_pspm(pspm, offset);
-  var canvas = document.createElement('canvas');
-  canvas.height = 200;
-  canvas.width = 0;
-  canvas.className = className;
-  size_logo_on_canvas(logo, canvas, false);
-  add_draw_task(canvas, new DelayLogoTask(logo, canvas));
-  return canvas;
-}
-
-function make_sym_btn(symbol, title, action) {
-  var box;
-  box = document.createElement("div");
-  box.tabIndex = 0;
-  box.className = "sym_btn";
-  box.appendChild(document.createTextNode(symbol));
-  box.title = title;
-  box.addEventListener('click', action, false);
-  box.addEventListener('keydown', action, false);
-  return box;
-}
-
-function make_seq(alphabet, seq) {
-  var i, j, letter, lbox, sbox;
-  sbox = document.createElement("span");
-  for (i = 0; i < seq.length; i = j) {
-    letter = seq.charAt(i);
-    for (j = i+1; j < seq.length; j++) {
-      if (seq.charAt(j) !== letter) {
-        break;
-      }
-    }
-    lbox = document.createElement("span");
-    lbox.style.color = alphabet.get_colour(alphabet.get_index(letter));
-    lbox.appendChild(document.createTextNode(seq.substring(i, j)));
-    sbox.appendChild(lbox);
-  }
-  return sbox;
-}
-
-//
-// make_pv_text
-//
-// Returns the string p-value, with the p italicised.
-///
-function make_pv_text() {
-  var pv_text = document.createElement("span");
-  var pv_italic_text = document.createElement("span");
-  pv_italic_text.appendChild(document.createTextNode("p"));
-  pv_italic_text.style.fontStyle = "italic";
-  pv_text.appendChild(pv_italic_text);
-  pv_text.appendChild(document.createTextNode("-value"));
-  return pv_text;
-}
-
-function append_site_entries(tbody, motif, site_index, count) {
-  "use strict";
-  var i, end;
-  var sites, site, sequences, sequence;
-  var rbody;
-  if (typeof count !== "number") {
-    count = 20;
-  }
-  sequences = data["sequence_db"]["sequences"];
-  sites = motif["sites"];
-  end = Math.min(site_index + count, sites.length);
-  for (i = site_index; i < end; i++) {
-    site = sites[i];
-    sequence = sequences[site["seq"]];
-
-    rbody = tbody.insertRow(tbody.rows.length);
-    add_text_cell(rbody, "" + (site["seq"] + 1) + ".", "site_num");
-    add_text_cell(rbody, sequence["name"], "site_name");
-    add_text_cell(rbody, site["rc"] ? "-" : "+", "site_strand");
-    add_text_cell(rbody, site["pos"] + 1, "site_start");
-    add_text_cell(rbody, site["pvalue"].toExponential(2), "site_pvalue");
-    add_text_cell(rbody, site["lflank"], "site lflank");
-    add_cell(rbody, make_seq(meme_alphabet, site["match"]), "site match");
-    add_text_cell(rbody, site["rflank"], "site rflank");
-  }
-  return i;
-}
-
-function make_site_entries() {
-  "use strict";
-  var region;
-  region = this;
-  if (region.data_site_index >= region.data_motif["sites"].length) {
-    // all sites created
-    region.removeEventListener('scroll', make_site_entries, false);
-    return;
-  }
-  // if there's still 100 pixels to scroll than don't do anything yet
-  if (region.scrollHeight - (region.scrollTop + region.offsetHeight) > 100) {
-    return;
-  }
-
-  region.data_site_index = append_site_entries(
-      find_child(region, "sites_tbl").tBodies[0], 
-      region.data_motif, region.data_site_index, 20
-    ); 
-}
-
-function make_sites(motif) {
-  "use strict";
-  function add_site_header(row, title, nopad, help_topic, tag_class) {
-    var div, divcp, th;
-    th = document.createElement("th");
-    div = document.createElement("div");
-    div.className = "sites_th_inner";
-    if (typeof title !== "object") {
-      title = document.createTextNode("" + title);
-    }
-    div.appendChild(title);
-    if (help_topic) {
-      div.appendChild(document.createTextNode("\xA0"));
-      div.appendChild(help_button(help_topic));
-    }
-    divcp = div.cloneNode(true);
-    divcp.className = "sites_th_hidden";
-    th.appendChild(div);
-    th.appendChild(divcp);
-    if (nopad) {
-      th.className = "nopad";
-    }
-    if (tag_class) {
-      th.className += " " + tag_class;
-    }
-    row.appendChild(th);
-  }
-  var outer_tbl, inner_tbl, tbl, thead, tbody, rhead;
-
-  outer_tbl = document.createElement("div");
-  outer_tbl.className = "sites_outer";
-
-  inner_tbl = document.createElement("div");
-  inner_tbl.className = "sites_inner";
-  outer_tbl.appendChild(inner_tbl);
-
-  tbl = document.createElement("table");
-  tbl.className = "sites_tbl";
-  inner_tbl.appendChild(tbl);
-
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-
-  rhead = thead.insertRow(thead.rows.length);
-  add_site_header(rhead, "", true);
-  add_site_header(rhead, "Name", false, "pop_seq_name");
-  add_site_header(rhead, "Strand", false, "pop_site_strand", "site_strand_title");
-  add_site_header(rhead, "Start", false, "pop_site_start");
-  add_site_header(rhead, make_pv_text(), false, "pop_site_pvalue");
-  add_site_header(rhead, "", false);
-  add_site_header(rhead, "Sites", true, "pop_site_match");
-  add_site_header(rhead, "", false);
-
-  inner_tbl.data_motif = motif;
-  inner_tbl.data_site_index = append_site_entries(tbody, motif, 0, 20);
-  if (inner_tbl.data_site_index < motif["sites"].length) {
-    inner_tbl.addEventListener('scroll', make_site_entries, false);
-  }
-  return outer_tbl;
-}
-
-function make_motif_table_entry(row, alphabet, ordinal, motif, colw) {
-  "use strict";
-  function ev_sig(evalue_str) {
-    "use strict";
-    var ev_re, match, sig, exp, num;
-    ev_re = /^(.*)e(.*)$/;
-    if (match = ev_re.exec(evalue_str)) {
-      sig = parseFloat(match[1]);
-      exp = parseInt(match[2]);
-      if (exp >= 0) {
-        return false;
-      } else if (exp <= -3) {
-        return true;
-      } else {
-        return sig * Math.pow(10, exp) <= 0.05;
-      }
-    }
-    return true;
-  }
-  function make_preview(alphabet, motif) {
-    "use strict";
-    var pspm, preview, preview_rc;
-    var box, btn_box, logo_box, btn_plus, btn_minus;
-    if (motif["preview_logo"]) {
-      preview = motif["preview_logo"];
-      preview_rc = motif["preview_logo_rc"];
-    } else {
-      pspm = new Pspm(motif["pwm"]);
-      preview = make_logo(alphabet, pspm);
-      motif["preview_logo"] = preview;
-      if (alphabet.has_complement()) {
-        preview_rc = make_logo(alphabet, pspm, true, 0, "logo_rc");
-        motif["preview_logo_rc"] = preview_rc;
-      }
-    }
-    if (preview_rc) {
-      btn_plus = document.createElement("div");
-      btn_plus.appendChild(document.createTextNode("+"));
-      btn_plus.className = "preview_btn plus";
-      btn_plus.tabIndex = "0";
-      btn_plus.addEventListener("click", action_btn_rc, false);
-      btn_plus.addEventListener("keydown", action_btn_rc, false);
-      btn_minus = document.createElement("div");
-      btn_minus.appendChild(document.createTextNode("-"));
-      btn_minus.className = "preview_btn minus";
-      btn_minus.tabIndex = "0";
-      btn_minus.addEventListener("click", action_btn_rc, false);
-      btn_minus.addEventListener("keydown", action_btn_rc, false);
-      btn_box = document.createElement("div");
-      btn_box.className = "preview_btn_box";
-      btn_box.appendChild(btn_plus);
-      btn_box.appendChild(btn_minus);
-    }
-    logo_box = document.createElement("div");
-    logo_box.className = "preview_logo_box";
-    logo_box.appendChild(preview);
-    if (preview_rc) logo_box.appendChild(preview_rc);
-    box = document.createElement("div");
-    box.className = "preview_box";
-    if (preview_rc) box.appendChild(btn_box);
-    box.appendChild(logo_box);
-    if (preview_rc) {
-      if (motif["rc"]) {
-        btn_minus.className += " active";
-        logo_box.className += " show_rc_logo";
-      } else {
-        btn_plus.className += " active";
-      }
-    }
-    return box;
-  }
-  var pspm, preview, preview_rc, c;
-  row.data_motif = motif;
-  row.data_ordinal = ordinal;
-  if (!ev_sig(motif["evalue"])) {
-    row.style.opacity = 0.4;
-  }
-  add_text_cell(row, "" + ordinal + ".", "motif_ordinal");
-  add_cell(row, make_preview(alphabet, motif), "motif_logo");
-  add_text_cell(row, motif["evalue"], "motif_evalue");
-  add_text_cell(row, motif["nsites"], "motif_nsites");
-  add_text_cell(row, motif["len"], "motif_width");
-  add_cell(row, make_sym_btn("\u21A7", "Show more information.", 
-        action_show_more), "motif_more");
-  add_cell(row, 
-      make_sym_btn("\u21E2", 
-        "Submit the motif to another MEME Suite program or download it.",
-        action_show_outpop), 
-      "motif_submit");
-  if (colw) {
-    for (c = 0; c < row.cells.length; c++) {
-      row.cells[c].style.minWidth = colw[c] + "px";
-    }
-  }
-}
-
-function make_motifs_table(alphabet, start_ordinal, motifs, colw, stop_reason) {
-  var i, j;
-  var tbl, thead, tbody, tfoot, row, preview;
-  var motif, pspm;
-
-  tbl = document.createElement("table");
-  
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-  tfoot = document.createElement("tfoot");
-  tbl.appendChild(tfoot);
-
-  row = thead.insertRow(thead.rows.length);
-  add_text_header_cell(row, "", "", "motif_ordinal");
-  add_text_header_cell(row, "Logo", "", "motif_logo");
-  add_text_header_cell(row, "E-value", "pop_ev", "motif_evalue");
-  add_text_header_cell(row, "Sites", "pop_sites", "motif_nsites");
-  add_text_header_cell(row, "Width", "pop_width", "motif_width");
-  add_text_header_cell(row, "More", "pop_more", "motif_more");
-  add_text_header_cell(row, "Submit/Download", "pop_submit_dl", "motif_submit");
-
-  for (i = 0; i < motifs.length; i++) {
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, alphabet, start_ordinal + i, motifs[i], colw);
-  }
-
-  row = tfoot.insertRow(tfoot.rows.length);
-  add_text_header_cell(row, stop_reason, "", "stop_reason", "", 6);
-
-  return tbl;
-}
-
-function make_expanded_motif(alphabet, ordinal, motif, less_x, submit_x) {
-  "use strict";
-  var box, pspm, logo_box, large_logo, large_logo_rc, tab_logo, tab_logo_rc;
-  var btn, offset, norc;
-
-  box = clone_template("tmpl_motif_expanded");
-  box.data_motif = motif;
-  box.data_ordinal = ordinal;
-
-  pspm = new Pspm(motif["pwm"]);
-  if (typeof motif["rc"] !== "boolean") {
-    motif["rc"] = false;
-  }
-  if (motif["large_logo"]) {
-    large_logo = motif["large_logo"];
-    large_logo_rc = motif["large_logo_rc"];
-  } else {
-    large_logo = make_large_logo(alphabet, pspm, false, 0);
-    motif["large_logo"] = large_logo;
-    if (alphabet.has_complement()) {
-      large_logo_rc = make_large_logo(alphabet, pspm, true, 0, "logo_rc");
-      motif["large_logo_rc"] = large_logo_rc;
-    }
-  }
-  norc = (large_logo_rc == null);
-  toggle_class(box, "norc", norc);
-
-  logo_box = find_child(box, "tvar_logo");
-  logo_box.appendChild(large_logo);
-  if (large_logo_rc) logo_box.appendChild(large_logo_rc);
-  toggle_class(logo_box, "show_rc_logo", motif["rc"]);
-
-  tab_logo = find_child(box, "tvar_tab");
-  tab_logo_rc = find_child(box, "tvar_tab_rc");
-
-  toggle_class(tab_logo, "activeTab", !motif["rc"]);
-  toggle_class(tab_logo_rc, "activeTab", motif["rc"]);
-
-  tab_logo.addEventListener('click', action_rc_tab, false);
-  tab_logo.addEventListener('keydown', action_rc_tab, false);
-  tab_logo_rc.addEventListener('click', action_rc_tab, false);
-  tab_logo_rc.addEventListener('keydown', action_rc_tab, false);
-
-  set_tvar(box, "tvar_ordinal", ordinal); 
-  set_tvar(box, "tvar_evalue", motif["evalue"]);
-  set_tvar(box, "tvar_width", motif["len"]);
-  set_tvar(box, "tvar_site_count", motif["nsites"]);
-  set_tvar(box, "tvar_llr", motif["llr"]);
-  set_tvar(box, "tvar_ic", motif["ic"]);
-  set_tvar(box, "tvar_re", motif["re"]);
-  set_tvar(box, "tvar_bt", motif["bt"]);
-  set_tvar(box, "tvar_sites", make_sites(motif));
-
-  offset = 32; // 1* 5px padding + 2 * 10px padding + 2 * 2px border + 3px ??
-
-  btn = find_child(box, "tvar_less");
-  btn.style.left = (less_x - offset) + "px";
-  btn.addEventListener('click', action_show_less, false);
-  btn.addEventListener('keydown', action_show_less, false);
-  btn = find_child(box, "tvar_submit");
-  btn.style.left = (submit_x - offset) + "px";
-  btn.addEventListener('click', action_show_outpop, false);
-  btn.addEventListener('keydown', action_show_outpop, false);
-  return box;
-}
-
-
-//
-//
-///
-function make_motifs() {
-  "use strict";
-  function pixel_value(str_in) {
-    "use strict";
-    var px_re, match;
-    px_re = /^(\d+)px$/;
-    if (match = px_re.exec(str_in)) {
-      return parseInt(match[1], 10);
-    }
-    return 0;
-  }
-  var container, tbl;
-  var colw, r, row, c, cell, cell_style, pad_left, pad_right;
-
-  // make the motifs table
-  container = $("motifs");
-  container.innerHTML = ""; // clear content
-
-  tbl = make_motifs_table(meme_alphabet, 1, data["motifs"], colw, data["stop_reason"]);
-  container.appendChild(tbl);
-
-  // measure table column widths
-  colw = [];
-  row = tbl.tBodies[0].rows[0];
-  for (c = 0; c < row.cells.length; c++) {
-    var padLeft, padRight;
-    cell = row.cells[c];
-    cell_style = window.getComputedStyle(cell, null);
-    pad_left = pixel_value(cell_style.getPropertyValue("padding-left"));
-    pad_right = pixel_value(cell_style.getPropertyValue("padding-right"));
-    colw[c] = cell.clientWidth - pad_left - pad_right;
-    if (typeof colw[c] !== "number" || colw[c] < 0) {
-      colw[c] = 1;
-    }
-  }
-
-  // set minimum table column widths on each row so later when we remove rows it still aligns
-  for (r = 0; r < tbl.tBodies[0].rows.length; r++) {
-    row = tbl.tBodies[0].rows[r];
-    for (c = 0; c < row.cells.length; c++) {
-      row.cells[c].style.minWidth = colw[c] + "px";
-    }
-  }
-
-  // store the table column widths so we can create rows latter with the same minimums
-  container.data_colw = colw;
-
-  // calculate the x offset for the buttons
-  row = tbl.tBodies[0].rows[0];
-  container.data_more_x = coords(find_child(find_child(row, "motif_more"), "sym_btn"))[0];
-  container.data_submit_x = coords(find_child(find_child(row, "motif_submit"), "sym_btn"))[0];
-
-  draw_on_screen();
-}
-
-function make_meme_block(container, max_seq_len, is_scan, site) {
-  "use strict";
-  var motif = data.motifs[site.motif];
-  var block = make_block(container, max_seq_len, site.pos, motif.len,
-      site.pvalue, site.rc, site.motif, is_scan);
-  var handler = (is_scan ?
-      make_scan_popup(site, motif, block) :
-      make_block_popup(site, motif, block));
-  block.addEventListener("mouseover", handler, false);
-  block.addEventListener("mouseout", handler, false);
-}
-
-function append_blocks_entries(tbody, seq_index, count) {
-  "use strict";
-  var i, end, j;
-  var max_pvalue, max_block_height, max_seq_len, sequences;
-  var sequence, sites, scans, scan;
-  var container, plus, minus, rule, row;
-  // define some constants
-  max_seq_len = data.sequence_db.max_length;
-  // determine how many to load
-  end = Math.min(seq_index + count, data.sequence_db.sequences.length);
-  for (i = seq_index; i < end; i++) {
-    // get the sequence
-    sequence = data.sequence_db.sequences[i];
-    // make the containers for the block diagram
-    container = make_block_container(meme_alphabet.has_complement(),
-        data.options.revcomp, max_seq_len, sequence.length);
-    // create blocks for the motif sites
-    sites = sequence["sites"];
-    for (j = 0; j < sites.length; j++)
-      make_meme_block(container, max_seq_len, false, sites[j]);
-    // create blocks for the scanned sites
-    scan = data.scan[i];
-    for (j = 0; j < scan.sites.length; j++)
-      make_meme_block(container, max_seq_len, true, scan.sites[j]);
-    // create a row for the sequence
-    row = tbody.insertRow(tbody.rows.length);
-    toggle_class(row, "empty_seq", sites.length == 0 && scan.sites.length == 0);
-    toggle_class(row, "only_scan", sites.length == 0 && scan.sites.length > 0);
-    add_text_cell(row, (i + 1) + ".", "blockdiag_num");
-    add_text_cell(row, sequence["name"], "blockdiag_name");
-    add_text_cell(row, scan["pvalue"].toExponential(2), "blockdiag_pvalue");
-    add_cell(row, container, "block_td"); 
-  }
-  return end;
-}
-
-function make_blocks_entries() {
-  "use strict";
-  var region;
-  region = this;
-  if (region.data_blocks_index >= data["sequence_db"]["sequences"].length) {
-    // all sites created
-    region.removeEventListener('scroll', make_blocks_entries, false);
-    return;
-  }
-  // if there's still 100 pixels to scroll than don't do anything yet
-  if (region.scrollHeight - (region.scrollTop + region.offsetHeight) > 100) {
-    return;
-  }
-
-  region.data_blocks_index = append_blocks_entries(
-      find_child(region, "blocks_tbl").tBodies[0], 
-      region.data_blocks_index, 20
-    ); 
-}
-
-function make_blocks() {
-  "use strict";
-  function add_seqs_filter(container, id, checked, label_text, help_topic) {
-    "use strict";
-    var label, radio;
-    radio = document.createElement("input");
-    radio.type = "radio";
-    radio.name = "seqs_display";
-    radio.id = id;
-    radio.checked = checked;
-    radio.addEventListener('click', action_seqs_filter, false);
-    label = document.createElement("label");
-    label.appendChild(document.createTextNode(label_text));
-    label.htmlFor = id;
-    container.appendChild(radio);
-    container.appendChild(label);
-    if (help_topic) {
-      container.appendChild(document.createTextNode("\xA0"));
-      container.appendChild(help_button(help_topic));
-    }
-  }
-  function add_blocks_header(row, title, nopad, help_topic) {
-    "use strict";
-    var div, divcp, th;
-    th = document.createElement("th");
-    div = document.createElement("div");
-    div.className = "blocks_th_inner";
-    if (typeof title !== "object") {
-      title = document.createTextNode("" + title);
-    }
-    div.appendChild(title);
-    if (help_topic) {
-      div.appendChild(document.createTextNode("\xA0"));
-      div.appendChild(help_button(help_topic));
-    }
-    divcp = div.cloneNode(true);
-    divcp.className = "blocks_th_hidden";
-    th.appendChild(div);
-    th.appendChild(divcp);
-    if (nopad) {
-      th.className = "nopad";
-    }
-    row.appendChild(th);
-  }
-  var container;
-  var page, view_height, outer_tbl, inner_tbl, tbl, thead, tbody, rhead;
-  var in_view, i, seq_count;
-  
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  view_height = Math.max(page.clientHeight - 300, 300);
-
-  container = $("blocks");
-  toggle_class(container, "hide_empty_seqs", true);
-  toggle_class(container, "hide_only_scan", true);
-  container.innerHTML = "";
-  add_seqs_filter(container, "rdo_sites_only", true, "Only Motif Sites", "pop_motif_sites");
-  add_seqs_filter(container, "rdo_sites_and_scan", false, "Motif Sites+Scanned Sites", "pop_scanned_sites");
-  add_seqs_filter(container, "rdo_all_seqs", false, "All Sequences", "pop_all_sequences");
-
-  outer_tbl = document.createElement("div");
-  outer_tbl.className = "blocks_outer";
-
-  inner_tbl = document.createElement("div");
-  inner_tbl.id = "blocks_scroll";
-  inner_tbl.className = "blocks_inner";
-  inner_tbl.style.maxHeight = view_height + "px";
-  outer_tbl.appendChild(inner_tbl);
-
-  tbl = document.createElement("table");
-  tbl.className = "blocks_tbl";
-  inner_tbl.appendChild(tbl);
-
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-
-  rhead = thead.insertRow(thead.rows.length);
-  add_blocks_header(rhead, "", true);
-  add_blocks_header(rhead, "Name", false, "pop_seq_name");
-  add_blocks_header(rhead, make_pv_text(), false, "pop_seq_pvalue");
-  add_blocks_header(rhead, "Motif Location", false, "pop_motif_location");
-
-  container.appendChild(outer_tbl);
-
-  
-  seq_count = data["sequence_db"]["sequences"].length;
-  in_view = Math.max(Math.ceil(view_height / 25), 1);
-  i = append_blocks_entries(tbody, 0, in_view);
-
-  while (i < seq_count && inner_tbl.scrollHeight - (inner_tbl.scrollTop + inner_tbl.offsetHeight) < 400) {
-    i = append_blocks_entries(tbody, i, 20);
-  }
-  inner_tbl.data_blocks_index = i;
-  if (i < seq_count) {
-    inner_tbl.addEventListener('scroll', make_blocks_entries, false);
-  }
-}
-
-function make_scan_popup(site, motif) {
-  return function (e) {
-    "use strict";
-    var pop, xy, padding, edge_padding, pop_left, pop_top, page_width;
-    var lflank, match, rflank, pspm;
-    if (!e) var e = window.event;
-    pop = make_scan_popup.pop;
-    if (e.type === "mouseover") {
-      if (pop) return;
-      pop = clone_template("tmpl_scan_info");
-      pspm = new Pspm(motif.pwm);
-      if (site.rc) pspm.reverse_complement(meme_alphabet);
-      set_tvar(pop, "tvar_logo", make_small_logo(meme_alphabet, pspm, {"className": "scan_logo"}));
-      set_tvar(pop, "tvar_motif", motif.id);
-      set_tvar(pop, "tvar_pvalue", site.pvalue.toExponential(2));
-      set_tvar(pop, "tvar_start", site.pos + 1);
-      set_tvar(pop, "tvar_end", site.pos + motif.len);
-
-      document.body.appendChild(pop);
-      position_popup(this, pop);
-      make_scan_popup.pop = pop;
-    } else if (e.type === "mouseout") {
-      if (pop) {
-        pop.parentNode.removeChild(pop);
-        make_scan_popup.pop = null;
-      }
-    }
-  };
-}
-
-function make_block_popup(site, motif, block) {
-  return function (e) {
-    "use strict";
-    var pop;
-    var lflank, match, rflank, pspm, ruler, match_seq, match_width;
-    if (!e) var e = window.event;
-    pop = make_block_popup.pop;
-    if (e.type === "mouseover") {
-      if (pop) return;
-      pop = clone_template("tmpl_block_info");
-      pspm = new Pspm(motif.pwm);
-      if (site.rc) { // must be dna
-        pspm.reverse_complement(meme_alphabet);
-        lflank = meme_alphabet.invcomp_seq(site.rflank);
-        match = meme_alphabet.invcomp_seq(site.match);
-        rflank = meme_alphabet.invcomp_seq(site.lflank);
-      } else {
-        lflank = site.lflank;
-        match = site.match;
-        rflank = site.rflank;
-      }
-      ruler = document.getElementById("measure_match");
-      match_seq = make_seq(meme_alphabet, match);
-      ruler.innerHTML = "";
-      ruler.appendChild(match_seq);
-      match_width = ruler.clientWidth;
-      ruler.removeChild(match_seq);
-      set_tvar(pop, "tvar_lflank", lflank);
-      set_tvar(pop, "tvar_match", match_seq);
-      set_tvar(pop, "tvar_rflank", rflank);
-      set_tvar(pop, "tvar_logo_pad", lflank);
-      set_tvar(pop, "tvar_logo", make_small_logo(meme_alphabet, pspm, {"width": match_width}));
-      set_tvar(pop, "tvar_motif", motif.id);
-      set_tvar(pop, "tvar_pvalue", site.pvalue.toExponential(2));
-      set_tvar(pop, "tvar_start", site.pos + 1);
-      set_tvar(pop, "tvar_end", site.pos + motif.len);
-
-      document.body.appendChild(pop);
-      position_popup(block, pop);
-      make_block_popup.pop = pop;
-    } else if (e.type === "mouseout") {
-      if (pop) {
-        pop.parentNode.removeChild(pop);
-        make_block_popup.pop = null;
-      }
-    }
-  };
-}
-
-function update_outpop_format(index) {
-  switch(parseInt($("text_format").value)) {
-    case 0: // count matrix
-      $("outpop_text").value = motif_count_matrix(index);
-      $("text_name").value = "motif_" + (index + 1) + "_counts.txt";
-      break;
-    case 1: // prob matrix
-      $("outpop_text").value = motif_prob_matrix(index);
-      $("text_name").value = "motif_" + (index + 1) + "_freqs.txt";
-      break;
-    case 2: // minimal meme
-      $("outpop_text").value = motif_minimal_meme(index);
-      $("text_name").value = "motif_" + (index + 1) + ".txt";
-      break;
-    case 3: // fasta
-      $("outpop_text").value = motif_fasta(index);
-      $("text_name").value = "motif_" + (index + 1) + "_fasta.txt";
-      break;
-    case 4: // raw
-      $("outpop_text").value = motif_raw(index);
-      $("text_name").value = "motif_" + (index + 1) + "_raw.txt";
-      break;
-    default:
-      throw new Error("Unknown motif format");
-  }
-}
-
-function update_outpop_motif(index) {
-  "use strict";
-  var motifs, motif, pspm, logo, canvas, num;
-  motifs = data["motifs"];
-  if (index < 0 || index >= motifs.length) {return;}
-  current_motif = index;
-  motif = motifs[index];
-  pspm = new Pspm(motif["pwm"]);
-  logo = new Logo(meme_alphabet, "");
-  logo.add_pspm(pspm, 0);
-  canvas = $("outpop_logo");
-  canvas.width = canvas.width; // clear canvas
-  draw_logo_on_canvas(logo, canvas, false);
-  if (meme_alphabet.has_complement()) {
-    pspm.reverse_complement(meme_alphabet);
-    logo = new Logo(meme_alphabet, "");
-    canvas = $("outpop_logo_rc");
-    canvas.width = canvas.width; // clear canvas
-    draw_logo_on_canvas(logo, canvas, false);
-  }
-  num = $("outpop_num");
-  num.innerHTML = "";
-  num.appendChild(document.createTextNode("" + (index + 1)));
-  update_outpop_format(index);
-}
-
-//
-// action_show_more
-//
-// Show more information on the motif.
-///
-function action_show_more(e) {
-  var node, tr, tbody, table, container, motif, ordinal;
-  var expanded_motif;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // find the row that contains the cell
-  node = this;
-  do {
-    if (node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find row!?");
-  tr = node;
-  // get info
-  motif = tr.data_motif;
-  ordinal = tr.data_ordinal;
-  // find tbody
-  do {
-    if (node.tagName === "TBODY") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find tbody!?");
-  tbody = node;
-  // find table
-  do {
-    if (node.tagName === "TABLE") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find table!?");
-  table = node;
-  // find container
-  container = node.parentNode;
-  // make a expanded motif
-  motif["expanded"] = true;
-  expanded_motif = make_expanded_motif(meme_alphabet, ordinal, motif, 
-      container.data_more_x, container.data_submit_x);
-  // now determine how to place it
-  if (tbody.rows.length === 1) {
-    // only us in the table so the table can be replaced
-    container.replaceChild(expanded_motif, table);
-  } else if (tbody.rows[0] === tr) {
-    // first row, so remove and insert an expanded motif before
-    table.deleteRow(tr.rowIndex);
-    container.insertBefore(expanded_motif, table);
-  } else if (tbody.rows[tbody.rows.length -1] === tr) {
-    // last row, so remove and insert an expanded motif after
-    table.deleteRow(tr.rowIndex);
-    container.insertBefore(expanded_motif, table.nextSibling);
-  } else {
-    var table2, tbody2;
-    table2 = table.cloneNode(false);
-    table2.appendChild(table.tHead.cloneNode(true));
-    tbody2 = table.tBodies[0].cloneNode(false);
-    table2.appendChild(tbody2);
-    container.insertBefore(table2, table.nextSibling);
-    for (i = tbody.rows.length - 1; i >= 0; i--) {
-      row = tbody.rows[i];
-      row.parentNode.removeChild(row);
-      if (row === tr) {
-        break;
-      }
-      tbody2.insertBefore(row, tbody2.rows[0]);
-    }
-    container.insertBefore(expanded_motif, table2);
-  }
-  find_child(expanded_motif, "tvar_less").focus();
-}
-
-//
-// action_show_less
-//
-// Show less information on the motif.
-///
-function action_show_less(e) {
-  var btn;
-  var expanded_motif, container, motif, ordinal, colw, focus_target;
-  var table, tbody, tbody2, row, table_before, table_after;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  btn = this;
-  // find expanded motif
-  expanded_motif = find_parent(btn, "expanded_motif");
-  if (!expanded_motif) throw new Error("Expected expanded motif.");
-  // find the container
-  container = expanded_motif.parentNode;
-  // get data
-  motif = expanded_motif.data_motif;
-  ordinal = expanded_motif.data_ordinal;
-  colw = container.data_colw;
-  // get the table before
-  table_before = expanded_motif.previousSibling;
-  if (table_before && table_before.tagName !== "TABLE") {
-    table_before = null;
-  }
-  // get the table after
-  table_after = expanded_motif.nextSibling;
-  if (table_after && table_after.tagName !== "TABLE") {
-    table_after = null;
-  }
-  // see if there is a table below or above that we can put this in.
-  // if there is a table both below and above then add this motif and
-  // all ones below to the above table
-  motif["expanded"] = false;
-  if (table_before && table_after) {
-    tbody = table_before.tBodies[0];
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-    tbody2 = table_after.tBodies[0];
-    while (tbody2.rows.length > 0) {
-      row = tbody2.rows[0];
-      row.parentNode.removeChild(row);
-      tbody.appendChild(row);
-    }
-    container.removeChild(table_after);
-  } else if (table_before) {
-    tbody = table_before.tBodies[0];
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-  } else if (table_after) {
-    tbody = table_after.tBodies[0];
-    row = tbody.insertRow(0);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-  } else {
-    //no table above or below!
-    // make a new table
-    table = make_motifs_table(meme_alphabet, ordinal, [motif], colw, data["stop_reason"]);
-    focus_target = find_child(table.tBodies[0].rows[0].cells[5], "sym_btn");
-    container.replaceChild(table, expanded_motif);
-  }
-  focus_target.focus();
-}
-
-function action_show_outpop(e) {
-  "use strict";
-  function init() {
-    "use strict";
-    var close_btn, next_btn, prev_btn, cancel_btn, do_btn;
-    var tab1, tab2, tab3;
-    var pnl1, pnl2, pnl3;
-    var format_list;
-    var tbl_submit, inputs, i, default_prog;
-    close_btn = $("outpop_close");
-    close_btn.addEventListener("click", action_hide_outpop, false);
-    close_btn.addEventListener("keydown", action_hide_outpop, false);
-    next_btn = $("outpop_next");
-    next_btn.addEventListener("click", action_outpop_next, false);
-    next_btn.addEventListener("keydown", action_outpop_next, false);
-    prev_btn = $("outpop_prev");
-    prev_btn.addEventListener("click", action_outpop_prev, false);
-    prev_btn.addEventListener("keydown", action_outpop_prev, false);
-    cancel_btn = $("outpop_cancel");
-    cancel_btn.addEventListener("click", action_hide_outpop, false);
-    do_btn = $("outpop_do");
-    do_btn.addEventListener("click", action_outpop_submit, false);
-    tab1 = $("outpop_tab_1");
-    tab1.tabIndex = 0;
-    tab1.addEventListener("click", action_outpop_tab, false);
-    tab1.addEventListener("keydown", action_outpop_tab, false);
-    tab2 = $("outpop_tab_2");
-    tab2.tabIndex = 0;
-    tab2.addEventListener("click", action_outpop_tab, false);
-    tab2.addEventListener("keydown", action_outpop_tab, false);
-    tab3 = $("outpop_tab_3");
-    tab3.tabIndex = 0;
-    tab3.addEventListener("click", action_outpop_tab, false);
-    tab3.addEventListener("keydown", action_outpop_tab, false);
-    pnl1 = $("outpop_pnl_1");
-    pnl2 = $("outpop_pnl_2");
-    pnl3 = $("outpop_pnl_3");
-    toggle_class(tab1, "activeTab", true);
-    toggle_class(tab2, "activeTab", false);
-    toggle_class(tab3, "activeTab", false);
-    pnl1.style.display = "block";
-    pnl2.style.display = "none";
-    pnl3.style.display = "none";
-    format_list = $("text_format");
-    format_list.addEventListener("change", action_outpop_format, false);
-    // setup program selection
-    tbl_submit = $("programs");
-    // when not dna, hide the inputs for programs that require dna motifs
-    toggle_class(tbl_submit, "alphabet_dna", meme_alphabet.has_complement());//TODO FIXME alphabet_dna is a bad name for a field when allowing custom alphabets
-    // add a click listener for the radio buttons
-    inputs = tbl_submit.querySelectorAll("input[type='radio']");
-    for (i = 0; i < inputs.length; i++) {
-      inputs[i].addEventListener("click", action_outpop_program, false);
-    }
-    // ensure that a default program option is selected for DNA and Protein
-    default_prog = document.getElementById(meme_alphabet.has_complement() ? "submit_tomtom" : "submit_fimo"); //TODO FIXME Tomtom might require a more strict definition of DNA
-    default_prog.checked = true;
-    action_outpop_program.call(default_prog);
-    // disable reverse-complement when not DNA
-    $("logo_rc_option").disabled = !meme_alphabet.has_complement(); 
-    // set errorbars on when ssc is on
-    $("logo_ssc").addEventListener("change", action_outpop_ssc, false);
-  }
-  var node;
-  // store the focused element
-  action_hide_outpop.last_active = document.activeElement;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // hide the help popup
-  help_popup();
-  // on first load initilize the popup
-  if (!action_show_outpop.ready) {
-    init();
-    action_show_outpop.ready = true;
-  }
-  // load the motif logo
-  node = this;
-  do {
-    if (/\bexpanded_motif\b/.test(node.className) || node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (node === null) throw new Error("Expected node!");
-  update_outpop_motif(node.data_ordinal - 1);
-  // display the download popup
-  $("grey_out_page").style.display = "block";
-  $("download").style.display = "block";
-  $("outpop_close").focus();
-}
-
-function action_hide_outpop(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  $("download").style.display = "none";
-  $("grey_out_page").style.display = "none";
-  if (typeof action_hide_outpop.last_active !== "undefined") {
-    action_hide_outpop.last_active.focus();
-  }
-}
-
-function action_outpop_next(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif + 1);
-}
-
-function action_outpop_prev(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif - 1);
-}
-
-function action_outpop_program() {
-  "use strict";
-  var table, tr, rows, i;
-  tr = find_parent_tag(this, "TR");
-  table = find_parent_tag(tr, "TABLE");
-  rows = table.querySelectorAll("tr");
-  for (i = 0; i < rows.length; i++) {
-    toggle_class(rows[i], "selected", rows[i] === tr);
-  }
-}
-
-function action_outpop_ssc() {
-  "use strict";
-  $("logo_err").value = $("logo_ssc").value;
-}
-
-function action_outpop_submit(e) {
-  "use strict";
-  var form, input, program, motifs;
-  // find out which program is selected
-  var radios, i;
-  radios = document.getElementsByName("program");
-  program = "fimo"; // default to fimo, since it works with all alphabet types
-  for (i = 0; i < radios.length; i++) {
-    if (radios[i].checked) program = radios[i].value;
-  }
-
-  motifs = motif_minimal_meme(current_motif);
-  form = document.createElement("form");
-  form.setAttribute("method", "post");
-  form.setAttribute("action", site_url + "/tools/" + program);
-  
-  input = document.createElement("input");
-  input.setAttribute("type", "hidden");
-  input.setAttribute("name", "motifs_embed");
-  input.setAttribute("value", motifs);
-  form.appendChild(input);
-
-  document.body.appendChild(form);
-  form.submit();
-  document.body.removeChild(form);
-}
-
-function action_outpop_download_motif(e) {
-  $("text_form").submit();
-}
-
-function action_outpop_download_logo(e) {
-  "use strict";
-  $("logo_motifs").value = motif_minimal_meme(current_motif);
-  $("logo_form").submit();
-}
-
-function action_btn_rc(e) {
-  "use strict";
-  var node, tr, motif, box, logo_box, tab_st, tab_rc, rc;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  node = this;
-  do {
-    if (node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find row!?");
-  tr = node;
-  // get info
-  motif = tr.data_motif;
-  box = find_parent(this, "preview_box");
-  logo_box = find_child(box, "preview_logo_box");
-  tab_st = find_child(box, "plus");
-  tab_rc = find_child(box, "minus");
-  rc = (this === tab_rc);
-  motif["rc"] = rc;
-  toggle_class(logo_box, "show_rc_logo", rc);
-  toggle_class(tab_st, "active", !rc);
-  toggle_class(tab_rc, "active", rc);
-}
-
-function action_rc_tab(e) {
-  "use strict";
-  var box, logo_box, tab_st, tab_rc, rc;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  box = find_parent(this, "expanded_motif");
-  logo_box = find_child(box, "tvar_logo");
-  tab_st = find_child(box, "tvar_tab");
-  tab_rc = find_child(box, "tvar_tab_rc");
-  rc = (this === tab_rc);
-  box.data_motif["rc"] = rc;
-  toggle_class(logo_box, "show_rc_logo", rc);
-  toggle_class(tab_st, "activeTab", !rc);
-  toggle_class(tab_rc, "activeTab", rc);
-}
-
-function action_outpop_tab(e) {
-  "use strict";
-  var tab1, tab2, tab3, pnl1, pnl2, pnl3, do_btn;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  tab1 = $("outpop_tab_1");
-  tab2 = $("outpop_tab_2");
-  tab3 = $("outpop_tab_3");
-  pnl1 = $("outpop_pnl_1");
-  pnl2 = $("outpop_pnl_2");
-  pnl3 = $("outpop_pnl_3");
-  do_btn = $("outpop_do");
-
-  toggle_class(tab1, "activeTab", (this === tab1));
-  toggle_class(tab2, "activeTab", (this === tab2));
-  toggle_class(tab3, "activeTab", (this === tab3));
-  pnl1.style.display = ((this === tab1) ? "block" : "none");
-  pnl2.style.display = ((this === tab2) ? "block" : "none");
-  pnl3.style.display = ((this === tab3) ? "block" : "none");
-  do_btn.value = ((this === tab1) ? "Submit" : "Download");
-  do_btn.removeEventListener("click", action_outpop_submit, false);
-  do_btn.removeEventListener("click", action_outpop_download_logo, false);
-  do_btn.removeEventListener("click", action_outpop_download_motif, false);
-  if (this === tab1) {
-    do_btn.addEventListener("click", action_outpop_submit, false);
-  } else if (this === tab2) {
-    do_btn.addEventListener("click", action_outpop_download_motif, false);
-  } else {
-    do_btn.addEventListener("click", action_outpop_download_logo, false);
-  }
-}
-
-function action_seqs_filter() {
-  "use strict";
-  var block_container;
-  block_container = $("blocks");
-  if ($("rdo_all_seqs").checked) {
-    toggle_class(block_container, "hide_empty_seqs", false);
-    toggle_class(block_container, "hide_only_scan", false);
-  } else if ($("rdo_sites_and_scan").checked) {
-    toggle_class(block_container, "hide_empty_seqs", true);
-    toggle_class(block_container, "hide_only_scan", false);
-  } else if ($("rdo_sites_only").checked) {
-    toggle_class(block_container, "hide_empty_seqs", true);
-    toggle_class(block_container, "hide_only_scan", true);
-  }
-}
-
-function action_outpop_format() {
-  update_outpop_format(current_motif);
-}
-
-//
-// page_loaded
-//
-// Called when the page has loaded for the first time.
-///
-function page_loaded() {
-  post_load_setup();
-}
-
-//
-// page_loaded
-//
-// Called when a cached page is reshown.
-///
-function page_shown(e) {
-  if (e.persisted) post_load_setup();
-}
-
-//
-// page_loaded
-//
-// Called when the page is resized
-///
-function page_resized() {
-  var page, blocks_scroll;
-  update_scroll_pad();
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  blocks_scroll = $("blocks_scroll");
-  if (blocks_scroll) {
-    blocks_scroll.style.maxHeight = Math.max(page.clientHeight - 300, 300) + "px";
-  }
-}
-
-//
-// pre_load_setup
-//
-// Run before the page is displayed
-///
-function pre_load_setup() {
-  var start, hue, sat, light, divisions;
-  var i, j, motifs, motif, sites, site, sequences, sequence;
-  var max_seq_len;
-  motifs = data["motifs"];
-  sequences = data["sequence_db"]["sequences"];
-  max_seq_len = 1;
-  for (i = 0; i < sequences.length; i++) {
-    sequence = sequences[i];
-    sequence["sites"] = [];
-    if (sequence["length"] > max_seq_len) {
-      max_seq_len = sequence["length"];
-    }
-  }
-  data["sequence_db"]["max_length"] = max_seq_len;
-  // use hsl colours
-  start = 0; //red
-  sat = 100;
-  light = 50;
-  for (i = 0; i < motifs.length; i++) {
-    motif = motifs[i];
-    // give the motif a colour
-    divisions = 1 << Math.ceil(Math.log(i + 1) / Math.LN2);
-    hue = start + (360 / divisions) * ((i - (divisions >> 1)) * 2 + 1);
-    motif["colour"] = "hsl(" + hue + ", " + sat + "%, " + light + "%)";
-    // associate sites with sequences as well 
-    // to make generating the block diagram easier
-    sites = motif["sites"];
-    for (j = 0; j < sites.length; j++) {
-      site = sites[j];
-      sequence = sequences[site["seq"]];
-      // record the motif index
-      site["motif"] = i;
-      // add the site to the sequence
-      sequence["sites"].push(site);
-    }
-  }
-}
-
-//
-// post_load_setup
-//
-// Run when the page has loaded, or been reloaded.
-//
-function post_load_setup() {
-  update_scroll_pad();
-  if (data["motifs"].length > 0) {
-    make_motifs();
-    make_blocks();
-  } else {
-    $("motifs").innerHTML = "<p>No significant motifs found!</p>"; // clear content
-    $("motifs").innerHTML += "<p><b>" + data["stop_reason"] + "</b></p>";
-    $("blocks").innerHTML = "<p>No significant motifs found!</p>";
-  }
-}
-
-pre_load_setup();
-</script>
-    <style>
-/* The following is the content of meme.css */
-body { background-color:white; font-size: 12px; font-family: Verdana, Arial, Helvetica, sans-serif;}
-
-div.help {
-  display: inline-block;
-  margin: 0px;
-  padding: 0px;
-  width: 12px;
-  height: 13px;
-  cursor: pointer;
-  background-image: url();
-}
-
-div.help:hover {
-  background-image: url();
-}
-
-p.spaced { line-height: 1.8em;}
-
-span.citation { font-family: "Book Antiqua", "Palatino Linotype", serif; color: #004a4d;}
-
-p.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-td.jump { font-size: 13px; color: #ffffff; background-color: #00666a;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-a.jump { margin: 15px 0 0; font-style: normal; font-variant: small-caps;
-  font-weight: bolder; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.mainh {font-size: 1.5em; font-style: normal; margin: 15px 0 0;
-  font-variant: small-caps; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.line {border-bottom: 1px solid #CCCCCC; font-size: 1.5em; font-style: normal;
-  margin: 15px 0 0; padding-bottom: 3px; font-variant: small-caps;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-h4 {border-bottom: 1px solid #CCCCCC; font-size: 1.2em; font-style: normal;
-  margin: 10px 0 0; padding-bottom: 3px; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h5 {margin: 0px}
-
-a.help { font-size: 9px; font-style: normal; text-transform: uppercase;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-div.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-div.pad1 { margin: 10px 5px;}
-
-div.pad2 { margin: 25px 5px 5px;}
-h2.pad2 { padding: 25px 5px 5px;}
-
-div.pad3 { padding: 5px 0px 10px 30px;}
-
-div.box { border: 2px solid #CCCCCC; padding:10px; overflow: hidden;}
-
-div.bar { border-left: 7px solid #00666a; padding:5px; margin-top:25px; }
-
-div.subsection {margin:25px 0px;}
-
-img {border:0px none;}
-
-th.majorth {text-align:left;}
-th.minorth {font-weight:normal; text-align:left; width:8em; padding: 3px 0px;}
-th.actionth {font-weight:normal; text-align:left;}
-
-.explain h5 {font-size:1em; margin-left: 1em;}
-
-div.doc {margin-left: 2em; margin-bottom: 3em;}
-
-th.trainingset {
-  border-bottom: thin dashed black; 
-  font-weight:normal; 
-  padding:0px 10px;
-}
-div.pop_content {
-  position:absolute;
-  z-index:50;
-  width:300px;
-  padding: 5px;
-  background: #E4ECEC;
-  font-size: 12px;
-  font-family: Arial;
-  border-style: double;
-  border-width: 3px;
-  border-color: #AA2244;
-  display:none;
-}
-
-div.pop_content > *:first-child {
-  margin-top: 0px;
-}
-
-div.pop_content h1, div.pop_content h2, div.pop_content h3, div.pop_content h4, 
-div.pop_content h5, div.pop_content h6, div.pop_content p {
-  margin: 0px;
-}
-
-div.pop_content p + h1, div.pop_content p + h2, div.pop_content p + h3, 
-div.pop_content p + h4, div.pop_content p + h5, div.pop_content p + h6 {
-  margin-top: 5px;
-}
-
-div.pop_content p + p {
-  margin-top: 5px;
-}
-
-div.pop_content > *:last-child {
-  margin-bottom: 0px;
-}
-
-div.pop_content div.pop_close {
-  /* old definition */
-  float:right;
-  bottom: 0;
-}
-
-div.pop_content span.pop_close, div.pop_content span.pop_back {
-  display: inline-block;
-  border: 2px outset #661429;
-  background-color: #CCC;
-  padding-left: 1px;
-  padding-right: 1px;
-  padding-top: 0px;
-  padding-bottom: 0px;
-  cursor: pointer;
-  color: #AA2244; /*#661429;*/
-  font-weight: bold;
-}
-
-div.pop_content span.pop_close:active, div.pop_content span.pop_back:active {
-  border-style: inset;
-}
-
-div.pop_content span.pop_close {
-  float:right;
-  /*border: 2px outset #AA002B;*/
-  /*color: #AA2244;*/
-}
-
-div.pop_content:not(.nested) .nested_only {
-  display: none;
-}
-
-div.pop_back_sec {
-  margin-bottom: 5px;
-}
-
-div.pop_close_sec {
-  margin-top: 5px;
-}
-
-table.hide_advanced tr.advanced {
-  display: none;
-}
-span.show_more {
-  display: none;
-}
-table.hide_advanced span.show_more {
-  display: inline;
-}
-table.hide_advanced span.show_less {
-  display: none;
-}
-
-
-/*****************************************************************************
- * Program logo styling
- ****************************************************************************/
-div.prog_logo {
-  border-bottom: 0.25em solid #0f5f60;
-  height: 4.5em;
-  width: 24em;
-  display:inline-block;
-}
-div.prog_logo img {
-  float:left;
-  width: 4em;
-  border-style: none;
-  margin-right: 0.2em;
-}
-div.prog_logo h1, div.prog_logo h1:hover, div.prog_logo h1:active, div.prog_logo h1:visited {
-  margin:0;
-  padding:0;
-  font-family: Arial, Helvetica,  sans-serif;
-  font-size: 3.2em;
-  line-height: 1em;
-  vertical-align: top;
-  display: block;
-  color: #026666;
-  letter-spacing: -0.06em;
-  text-shadow: 0.04em 0.06em 0.05em #666;
-}
-div.prog_logo h2, div.prog_logo h2:hover, div.prog_logo h2:active, div.prog_logo h2:visited {
-  display: block;
-  margin:0;
-  padding:0;
-  font-family: Helvetica, sans-serif;
-  font-size: 0.9em;
-  line-height: 1em;
-  letter-spacing: -0.06em;
-  color: black;
-}
-
-div.big.prog_logo {
-  font-size: 18px;
-}
-
-</style>
-    <style>
-.block_td {
-  height:25px;
-}
-.block_container {
-  position:relative;
-  box-sizing: border-box;
-  height: 25px;
-  padding: 0px;
-  margin: 0px;
-  margin-left: 1em;
-}
-.block_label {
-  position: absolute; 
-  display: inline-block;
-  padding: 3px;
-  z-index: 4;
-  top: 6px;
-  height: 12px;
-  line-height: 12px;
-  font-size: 12px;
-  background-color: white;
-  border: 1px solid black;
-  -moz-border-radius: 12px;
-  -webkit-border-radius: 12px;
-  border-radius: 12px;
-  transform: translateX(-50%);
-}
-.block_motif {
-  position: absolute; 
-  z-index: 3;
-  top: 0px;
-  box-sizing: border-box;
-  border: 1px solid black;
-  height: 12px;
-  background-color: cyan;
-}
-.block_motif.top {
-  border-bottom-width: 0;
-}
-.block_motif.bottom {
-  border-top-width: 0;
-}
-.block_motif.scanned_site {
-  opacity: 0.3;
-}
-.block_motif.scanned_site.active {
-  opacity: 0.9;
-}
-.block_region {
-  position:absolute; 
-  z-index:6; 
-  height:25px; 
-  top:0px; 
-}
-.block_region.main {
-  z-index:8;
-}
-.block_region.scanned_site {
-  z-index:5;
-}
-.block_region.scanned_site.main {
-  z-index:7;
-}
-.block_region.top {
-  height:13px;
-}
-.block_region.bottom {
-  height:13px;
-  top:12px;
-}
-.block_rule {
-  position:absolute;
-  z-index:2;
-  width:100%;
-  height:1px;
-  top:12px;
-  left:0px;
-  background-color:gray;
-}
-.block_plus_sym {
-  position:absolute;
-  z-index:4;
-  line-height:12px;
-  top:0px;
-  left:-1em;
-}
-.block_minus_sym {
-  position:absolute;
-  z-index:4;
-  line-height:12px;
-  top:13px;
-  left:-1em;
-}
-
-.tic_major {
-  position:absolute;
-  top:0em;
-  height:0.5em;
-  width: 2px;
-  margin-left: -1px;
-  background-color: blue;
-}
-.tic_minor {
-  position:absolute;
-  top:0em;
-  height:0.2em;
-  width: 1px;
-  margin-left: -0.5px;
-  background-color: blue;
-}
-.tic_label {
-  position:absolute;
-  display: inline-block;
-  top:0.5em;
-  height: 1em;
-  color: blue;
-  transform: translateX(-50%);
-}
-
-.block_needle {
-  position:absolute;
-  z-index:4;
-  height:30px; 
-  width:1px; 
-  top:-2px; 
-  background-color:gray;
-}
-.block_needle.right {
-  height: 60px;
-}
-.block_handle {
-  position: absolute; 
-  display: inline-block;
-  z-index: 5; 
-  top: 27px; 
-  min-width: 3ex;
-  text-align: center;
-  font-size: 12px;
-  line-height: 12px;
-  transform: translateX(-50%);
-  background-color: LightGrey; 
-  border:3px outset grey;
-  cursor: pointer;
-  -webkit-user-select: none; /* Chrome/Safari */        
-  -moz-user-select: none; /* Firefox */
-  -ms-user-select: none; /* IE10+ */
-  /* Rules below not implemented in browsers yet */
-  -o-user-select: none;
-  user-select: none;
-}
-.block_handle.right {
-  top: 47px;
-}
-
-.legend_container {
-  text-align: right;
-}
-.legend_entry {
-  display: inline-block;
-  padding: 5px;
-}
-div.legend_swatch {
-  box-sizing: border-box;
-  width: 15px;
-  height: 15px;
-  border: 1px solid black;
-  background-color: cyan;
-  float: left;
-}
-div.legend_swatch input {
-  display: none;
-}
-.legend_text {
-  line-height: 15px;
-  margin-left: 20px;
-}
-</style>
-    <style>
-/* meme output specific css */
-
-div.pop_block {
-  position:absolute;
-  z-index:5;
-  padding: 5px;
-  border: 1px solid black;
-  display: inline-block;
-  background-color: white;
-}
-
-#measure_match {
-  position: absolute;
-  visibility: hidden;
-  height: auto;
-  width: auto;
-  white-space: nowrap;
-}
-
-div.template {
-  position: absolute;
-  z-index: 1;
-  left: 0;
-  top: 0;
-  visibility: hidden;
-}
-
-table.block_information {
-  margin-left: auto;
-  margin-right: auto;
-}
-
-table.block_information * th {
-  text-align: right;
-}
-
-*.hide_empty_seqs * tr.empty_seq {
-  display: none;
-}
-
-*.hide_only_scan * tr.only_scan {
-  display: none;
-}
-
-*.hide_only_scan * div.scanned_site {
-  display: none;
-}
-
-td.symaction {
-  text-align: center;
-  text-decoration: underline;
-  font-size: 20px;
-  cursor: pointer;
-}
-div.sym_btn {
-  display:inline-block;
-  text-decoration: underline;
-  cursor: pointer;
-  font-size: 20px;
-  line-height:20px; 
-  text-align: center;
-  width: 20px;
-  height: 20px;
-  color: blue;
-}
-div.sym_btn:hover {
-  color: white;
-  background-color: blue;
-}
-
-div.sym_btn.positioned {
-  position: absolute;
-  top: 0px;
-}
-
-div.actionbutton { 
-  display:inline-block;
-  cursor: pointer;
-  font-size: 18px;
-  line-height:20px; 
-  padding: 5px; 
-  margin: 10px 0; 
-  border: 1px solid black;
-}
-
-div.actionbutton:hover {
-  color:#FFF;
-  background-color:#000;
-}
-
-div.param_box {
-  display: inline-block;
-  margin-right: 20px;
-}
-
-span.param {
-  font-weight: bold;
-}
-
-div.box + div.box {
-  margin-top: 5px;
-}
-
-div.sites_outer {
-  position: relative;
-  padding-top: 20px; /* height of header */
-  display: inline-block;
-}
-
-div.sites_inner {
-  overflow-x: hidden;
-  overflow-y: auto;
-  max-height: 200px;
-}
-table.sites_tbl {
-  border-collapse: collapse;
-}
-
-div.sites_th_inner {
-  position: absolute;
-  top: 0;
-  line-height: 20px; /* height of header */
-  text-align: left;
-  padding-left: 5px;
-}
-th.nopad div.sites_th_inner {
-  padding-left: 0;
-}
-div.sites_th_hidden {
-  visibility: hidden;
-  height: 0;
-  padding: 0 10px;
-}
-th.nopad div.sites_th_hidden {
-  padding: 0;
-}
-div.sites_inner * th {
-  height: 0;
-}
-
-table.sites_tbl {
-  overflow-x: hidden;
-  overflow-y: auto;
-}
-
-.site_num {
-  text-align: right;
-}
-.site_name {
-  padding:0px 5px; 
-  text-align:left;
-}
-.site_strand {
-  padding:0px 5px; 
-  text-align:center;
-}
-.norc .site_strand, .norc .site_strand_title {
-  display: none;
-}
-.site_start {
-  padding:0px 15px; 
-  text-align: right;
-}
-.site_pvalue {
-  text-align:center; 
-  padding:0px 15px; 
-  text-align:right;
-  white-space: nowrap;
-}
-.lflank, .rflank, .match, .alpha_symbol {
-  font-weight:bold; 
-  font-size:15px; 
-  font-family: 'Courier New', Courier, monospace;
-  color:gray; 
-}
-
-.site.lflank {
-  text-align:right; 
-  padding-right:5px; 
-  color:gray;
-}
-.site.match {
-  text-align:center; 
-}
-.site.rflank {
-  text-align:left; 
-  padding-left:5px; 
-  padding-right: 20px;
-}
-
-th.stop_reason {
-  text-align: left;
-  padding-right: 10px;
-}
-
-th.motif_ordinal {
-
-}
-td.motif_ordinal {
-  text-align: right;
-  padding-right: 10px;
-}
-th.motif_logo {
-  padding-right: 10px;
-}
-td.motif_logo {
-  padding-right: 10px;
-}
-th.motif_evalue {
-  text-align:right;
-  padding-right: 10px;
-}
-td.motif_evalue {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-th.motif_nsites {
-  text-align: right;
-  padding-right: 10px;
-}
-td.motif_nsites {
-  text-align: right;
-  padding-right: 20px;
-}
-th.motif_width {
-  text-align: right;
-  padding-right: 5px;
-}
-td.motif_width {
-  text-align: right;
-  padding-right: 15px;
-}
-th.motif_more {
-  padding: 0 5px;
-}
-td.motif_more {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_submit {
-  padding: 0 5px;
-}
-td.motif_submit {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_download {
-  padding-left: 5px;
-}
-td.motif_download {
-  text-align: center;
-  padding-left: 5px;
-}
-
-
-div.tabArea {
-  font-size: 80%;
-  font-weight: bold;
-}
-
-.norc div.tabArea {
-  display: none;
-}
-
-span.tab, span.tab:visited {
-  cursor: pointer;
-  color: #888;
-  background-color: #ddd;
-  border: 2px solid #ccc;
-  padding: 2px 1em;
-  text-decoration: none;
-}
-span.tab.middle {
-  border-left-width: 0px;
-}
-div.tabArea.base span.tab {
-  border-top-width: 0px;
-}
-div.tabArea.top span.tab {
-  border-bottom-width: 0px;
-}
-
-span.tab:hover {
-  background-color: #bbb;
-  border-color: #bbb;
-  color: #666;
-}
-span.tab.activeTab, span.tab.activeTab:hover, span.tab.activeTab:visited {
-  background-color: white;
-  color: black;
-  cursor: default;
-}
-div.tabMain {
-  border: 2px solid #ccc;
-  background-color: white;
-  padding: 10px;
-}
-div.tabMain.base {
-  margin-top: 5px;
-  display: inline-block;
-  max-width: 98%;
-}
-
-div.tabMain.top {
-  margin-bottom: 5px;
-}
-
-div.tabCenter {
-  max-width: 100%;
-  overflow-x: auto;
-  height: 200px;
-  overflow-y: hidden;
-}
-
-canvas.logo_rc {
-  display:none;
-}
-.show_rc_logo > canvas {
-  display: none;
-}
-.show_rc_logo > canvas.logo_rc {
-  display: block;
-}
-
-canvas.scan_logo {
-  margin-left: 10px;
-}
-
-div.blocks_outer {
-  position: relative;
-  padding-top: 20px; /* height of header */
-}
-
-div.blocks_inner {
-  overflow-x: hidden;
-  overflow-y: auto;
-  max-height: 200px;
-}
-table.blocks_tbl {
-  border-collapse: collapse;
-  width: 100%;
-}
-
-div.blocks_th_inner {
-  position: absolute;
-  top: 0;
-  line-height: 20px; /* height of header */
-  text-align: left;
-  padding-left: 5px;
-}
-th.nopad div.blocks_th_inner {
-  padding-left: 0;
-}
-div.blocks_th_hidden {
-  visibility: hidden;
-  height: 0;
-  padding: 0 10px;
-}
-th.nopad div.blocks_th_hidden {
-  padding: 0;
-}
-div.blocks_inner * th {
-  height: 0;
-}
-
-table.blocks_tbl {
-  overflow-x: hidden;
-  overflow-y: auto;
-}
-td.block_td {
-  width: 99%;
-}
-
-*.blockdiag_num {
-  text-align: right;
-}
-
-td.blockdiag_name {
-  text-align: left;
-  padding:0px 10px; 
-}
-
-td.blockdiag_pvalue {
-  padding:0px 10px; 
-  text-align:right;
-  white-space: nowrap;
-}
-
-div.preview_btn {
-  border: 2px solid white;
-  height: 16px;
-  width: 16px;
-  font-size: 12px;
-  line-height: 16px;
-  text-align: center;
-  cursor: pointer;
-}
-div.preview_btn + div.preview_btn {
-  margin-top: 3px;
-}
-
-div.preview_btn.active {
-  border: 2px solid black;
-  cursor: default;
-}
-
-div.preview_btn:hover {
-  background-color: black;
-  color: white;
-  border-color: black;
-}
-
-div.preview_btn.active:hover {
-  background-color: white;
-  color: black;
-  border-color: black;
-}
-
-
-div.preview_btn_box {
-  position: absolute;
-  left: 0px;
-  top: 0px;
-  padding: 3px;
-}
-
-div.preview_logo_box {
-  height: 50px;
-  overflow-y: hidden;
-}
-
-div.preview_btn_box + div.preview_logo_box {
-  margin-left: 25px;
-}
-
-div.preview_box {
-  position: relative;
-}
-
-div.grey_background {
-  position:fixed; 
-  z-index: 8;
-  background-color: #000;
-  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
-  opacity: 0.5;
-  left: 0;
-  top: 0;
-  width: 100%;
-  height: 100%;
-}
-
-div.popup_wrapper {
-  position:fixed; 
-  z-index:9;
-  width:100%; 
-  height:0; 
-  top:50%; 
-  left:0;
-}
-
-div.popup {
-  width: 600px; 
-  z-index:9;
-  margin-left: auto;
-  margin-right: auto;
-  padding: 5px;
-  background-color: #FFF;
-  border-style: double;
-  border-width: 5px;
-  border-color: #00666a;
-  position:relative; 
-}
-div.close {
-  cursor: pointer;
-  border: 1px solid black; 
-  width:15px; 
-  height:15px; 
-  line-height:15px; /* this causes vertical centering */
-  text-align:center; 
-  background-color:#FFF; 
-  color:#000; 
-  font-size:15px;
-  font-family:monospace;
-}
-
-div.close:hover {
-  color:#FFF;
-  background-color:#000; 
-}
-
-div.navnum {
-  width:100%; 
-  height:20px; 
-  line-height:20px; 
-  text-align:center; 
-  font-size:medium;
-}
-
-div.navarrow {
-  font-size: 30px;
-  text-decoration:none;
-  cursor: pointer;
-  -moz-user-select: none;  
-  -webkit-user-select: none;  
-  -ms-user-select: none;
-}
-
-div.navarrow > span.inactive {
-  display: inline;
-}
-div.navarrow > span.active {
-  display: none;
-}
-
-div.navarrow:hover > span.active {
-  display: inline;
-}
-div.navarrow:hover > span.inactive {
-  display: none;
-}
-
-table.programs {
-  width: 100%;
-}
-
-table.programs tr {
-  background-color: #EFE;
-}
-
-table.programs tr.selected {
-  background-color: #262;
-  color: #FFF;
-}
-
-table.programs tr.dna_only {
-  display: none;
-}
-
-table.programs.alphabet_dna tr.dna_only {
-  display: table-row;
-}
-
-div.programs_scroll {
-  width: 100%; 
-  height: 90px; 
-  overflow-y: auto; 
-  overflow-x: hidden;
-  margin: 0 auto; 
-}
-table.inputs, table.alpha_bg_table {
-  margin-top: 20px;
-  border-collapse:collapse;
-}
-table.inputs * td, table.inputs * th, table.alpha_bg_table * td, table.alpha_bg_table * th {
-  padding-left: 15px;
-  padding-right: 15px;
-  padding-top: 1px;
-  padding-bottom: 1px;
-}
-
-table.hide_psp td.col_psp, table.hide_psp th.col_psp {
-  display: none;
-}
-
-/* program settings */
-span.mod_oops, span.mod_zoops, span.mod_anr {
-  display: none;
-}
-td.oops span.mod_oops,td.zoops span.mod_zoops, td.anr span.mod_anr  {
-  display: inline;
-}
-span.strand_none, span.strand_given, span.strand_both {
-  display: none;
-}
-td.none span.strand_none, td.given span.strand_given, td.both span.strand_both {
-  display: inline;
-}
-span.spmap_uni, span.spmap_pam {
-  display: none;
-}
-td.uni span.spmap_uni, td.pam span.spmap_pam {
-  display: inline;
-}
-span.prior_dirichlet, span.prior_dmix, span.prior_mega, span.prior_megap, span.prior_addone {
-  display: none;
-}
-td.dirichlet span.prior_dirichlet, td.dmix span.prior_dmix, td.mega span.prior_mega,
-td.megap span.prior_megap, td.addone span.prior_addone {
-  display: inline;
-}
-span.noendgaps_on, span.noendgaps_off {
-  display: none;
-}
-td.on span.noendgaps_on, td.off span.noendgaps_off {
-  display: inline;
-}
-span.substring_on, span.substring_off {
-  display: none;
-}
-td.on span.substring_on, td.off span.substring_off {
-  display: inline;
-}
-</style>
-  </head>
-  <body onload="page_loaded()" onpageshow="page_shown(event)" onresize="page_resized()">
-    <!--  -->
-    <div id="grey_out_page" class="grey_background" style="display:none;">
-    </div>
-    <!-- Help popups -->
-    <div class="pop_content" id="pop_">
-      <p>Help poup.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_ev">
-      <p>The statistical significance of the motif. MEME usually finds the most
-      statistically significant (low E-value) motifs first. It is unusual to
-      consider a motif with an E-value larger than 0.05 significant so, as an
-      additional indicator, MEME displays these partially transparent.</p> 
-      <p>The E-value of a motif is based on its log likelihood ratio, width,
-      sites, the background letter frequencies (given in the command line
-      summary), and the size of the training set.</p>
-      <p>The E-value is an estimate of the expected number of motifs with the
-      given log likelihood ratio (or higher), and with the same width and site
-      count, that one would find in a similarly sized set of random
-      sequences (sequences where each position is independent and letters are
-      chosen according to the background letter frequencies).</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_sites">
-      <p>The number of sites contributing to the construction of the motif.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_width">
-      <p>The width of the motif. Each motif describes a pattern of a fixed
-      width, as no gaps are allowed in MEME motifs.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_more">
-      <p>Click on the blue symbol below to reveal more information about this motif.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_submit_dl">
-      <p>Click on the blue symbol below to reveal options allowing you
-      to submit this motif to another MEME Suite motif analysis program, to download this
-      motif in various text formats, or to download a sequence "logo" of
-      this motif PNG or EPS format.</p>
-      <h5>Supported Programs</h5>
-      <dl>
-        <dt>Tomtom</dt>
-        <dd>Tomtom is a tool for searching for similar known motifs. 
-          [<a href="http://meme-suite.org/doc/tomtom.html?man_type=web">manual</a>]</dd>
-        <dt>MAST</dt>
-        <dd>MAST is a tool for searching biological sequence databases for 
-          sequences that contain one or more of a group of known motifs.
-          [<a href="http://meme-suite.org/doc/mast.html?man_type=web">manual</a>]</dd>
-        <dt>FIMO</dt>
-        <dd>FIMO is a tool for searching biological sequence databases for 
-          sequences that contain one or more known motifs.
-          [<a href="http://meme-suite.org/doc/fimo.html?man_type=web">manual</a>]</dd>
-        <dt>GOMO</dt>
-        <dd>GOMO is a tool for identifying possible roles (Gene Ontology 
-          terms) for DNA binding motifs.
-          [<a href="http://meme-suite.org/doc/gomo.html?man_type=web">manual</a>]</dd>
-        <dt>SpaMo</dt>
-        <dd>SpaMo is a tool for inferring possible transcription factor
-          complexes by finding motifs with enriched spacings.
-          [<a href="http://meme-suite.org/doc/spamo.html?man_type=web">manual</a>]</dd>
-      </dl>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_llr">
-      <p>The log likelihood ratio of the motif.The log likelihood ratio is the 
-      logarithm of the ratio of the probability of the occurrences of the motif
-      given the motif model (likelihood given the motif) versus their
-      probability given the background model (likelihood given the null model).
-      (Normally the background model is a 0-order Markov model using the
-      background letter frequencies, but higher order Markov models may be
-      specified via the -bfile option to MEME.).</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_ic">
-      <p>The information content of the motif in bits. It is equal to the sum
-      of the uncorrected information content, R(), in the columns of the pwm.
-      This is equal relative entropy of the motif relative to a uniform
-      background frequency model.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_re">
-      <p>The relative entropy of the motif.</p>
-
-      <p style="font-family: monospace;">re = llr / (sites * ln(2))</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_bt">
-      <p>The Bayes Threshold.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_strand">
-      <p>The strand used for the motif site.</p>
-      <dl>
-        <dt>+</dt>
-        <dd>The motif site was found in the sequence as it was supplied.</dd>
-        <dt>-</dt>
-        <dd>The motif site was found in the reverse complement of the supplied sequence.</dd>
-      </dl>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_start">
-      <p>The position in the sequence where the motif site starts. If a motif
-      started right at the begining of a sequence it would be described as
-      starting at position 1.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_pvalue">
-      <p>The probability that an equal or better site would be found in a
-      random sequence of the same length conforming to the background letter
-      frequencies.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_match">
-      <p>A motif site with the 10 flanking letters on either side.</p> 
-      <p>When the site is not on the given strand then the site
-      and both flanks are reverse complemented so they align.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_name">
-      <p>The name of the sequences as given in the FASTA file.</p>
-      <p>The number to the left of the sequence name is the ordinal
-      of the sequence.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_motif_sites">
-      <p>These are the motif sites predicted by MEME and used to build the motif.</p>
-      <p>These sites are shown in solid color and hovering the cursor
-      over a site will reveal details about the site.  Only sequences
-      that contain a motif site are shown.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_scanned_sites">
-      <p>These are the motif sites predicted by MEME plus
-      any additional sites detected using a motif scanning
-      algorithm.</p>
-      <p>These MEME sites are shown in solid color and 
-      additional scanned sites are shown in transparent color.
-      Hovering the cursor over a site will reveal details about the site.
-      Only sequences containing a predicted or scanned motif site are shown.</p>
-      <p>The scanned sites are predicted using a
-      log-odds scoring matrix constructed from the MEME sites.
-      Only scanned sites with position <i>p</i>-values less
-      than 0.0001 are shown.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_all_sequences">
-      <p>These are the same sites as shown by selecting the
-      "Motif Sites + Scanned Sites" button except that all
-      sequences, including those with no sites, are included
-      in the diagram.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_pvalue">
-      <p>This is the combined match <i>p</i>-value.</p>
-      <p>The combined match <i>p</i>-value is defined as the probability that a
-      random sequence (with the same length and conforming to the background) 
-      would have position <i>p</i>-values such that the product is smaller
-      or equal to the value calulated for the sequence under test.</p>
-      <p>The position <i>p</i>-value is defined as the probability that a
-      random sequence (with the same length and conforming to the background)
-      would have a match to the motif under test with a score greater or equal
-      to the largest found in the sequence under test.</p>
-      <p>Hovering your mouse over a motif site in the motif location 
-      block diagram will show its position <i>p</i>-value and other information
-      about the site.</p>
-       
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_location">
-      <p>This diagram shows the location of motif sites.</p>
-      <p>Each block shows the position and strength of a motif
-      site.  The height of a block gives an indication of the 
-      significance of the site as taller blocks are more significant. 
-      The height is calculated to be proportional to the negative 
-      logarithm of the <i>p</i>-value of the site, truncated at 
-      the height for a <i>p</i>-value of 1e-10.</p>
-      <p>For complementable alphabets (like DNA), sites on the 
-      positive strand are shown above the line,
-      sites on the negative strand are shown below.</p>
-      <p>Placing the cursor
-      over a motif site will reveal more information about the site
-      including its position <i>p</i>-value.  (See the help
-      for the <i>p</i>-value column for an explanation of position 
-      <i>p</i>-values.)</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_source">
-      <p>The name of the file of sequences input to MEME.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_psp_source">
-      <p>The position specific priors file used by MEME to find the motifs.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_alph">
-      <p>The alphabet used by the sequences.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_count">
-      <p>The number of sequences provided as input to MEME.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_name">
-      <p>The name of the alphabet symbol.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_alph_freq">
-      <p>The frequency of the alphabet symbol in the dataset with a pseudocount
-      so it is never zero.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_alph_bg">
-      <p>The frequency of the alphabet symbol as defined by the background model.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <!-- templates -->
-    <div id="measure_match" class="match"></div>
-    <div class="template pop_block" id="tmpl_block_info">
-      <div>
-        <span class="tvar_logo_pad lflank" style="visibility:hidden;"></span>
-        <span class="tvar_logo"></span>
-      </div>
-      <div class="block_sequence_fragment">
-        <span class="tvar_lflank lflank"></span>
-        <span class="tvar_match match"></span>
-        <span class="tvar_rflank rflank"></span>
-      </div>
-      <table class="block_information">
-        <tr><th>Motif</th><td class="tvar_motif">1</td></tr>
-        <tr><th><i>p</i>-value</th><td class="tvar_pvalue">8.23e-7</td></tr>
-        <tr><th>Start</th><td class="tvar_start">23</td></tr>
-        <tr><th>End</th><td class="tvar_end">33</td></tr>
-      </table>
-    </div>
-
-    <div class="template pop_block" id="tmpl_scan_info">
-      <h5>Scanned Site</h5>
-      <div class="tvar_logo"></div>
-      <table class="block_information">
-        <tr><th>Motif</th><td class="tvar_motif">1</td></tr>
-        <tr><th><i>p</i>-value</th><td class="tvar_pvalue">8.23e-7</td></tr>
-        <tr><th>Start</th><td class="tvar_start">23</td></tr>
-        <tr><th>End</th><td class="tvar_end">33</td></tr>
-      </table>
-    </div>
-
-    <div class="template box expanded_motif" id="tmpl_motif_expanded">
-      <div style="position: relative; min-height: 20px">
-        <div class="param_box">
-          <span class="param"><span class="tvar_ordinal"></span>.</span>
-        </div>
-        <div class="sym_btn positioned tvar_less" tabindex="0" 
-          title="Show less information.">&#8613;</div>
-        <div class="sym_btn positioned tvar_submit" tabindex="0"
-          title="Submit the motif to another MEME Suite program or download it.">&#8674;</div>
-      </div>
-      <div>
-        <div class="param_box">
-          <span class="param"><i>E</i>-value:</span>
-          <span class="tvar_evalue"></span>
-          <div class="help" data-topic="pop_ev"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Site Count:</span>
-          <span class="tvar_site_count"></span>
-          <div class="help" data-topic="pop_sites"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Width:</span>
-          <span class="tvar_width"></span>
-          <div class="help" data-topic="pop_width"></div>
-        </div>
-      </div>
-      <div class="tabMain base">
-        <div class="tabCenter tvar_logo"></div>
-      </div>
-      <div class="tabArea base">
-        <span class="tvar_tab tab" tabindex="0">Standard</span><span 
-          class="tvar_tab_rc tab middle" tabindex="0">Reverse 
-          Complement</span>
-      </div>
-      <div style="padding: 10px 0">
-        <div class="param_box">
-          <span class="param">Log Likelihood Ratio:</span>
-          <span class="tvar_llr"></span>
-          <div class="help" data-topic="pop_llr"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Information Content:</span>
-          <span class="tvar_ic"></span>
-          <div class="help" data-topic="pop_ic"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Relative Entropy:</span>
-          <span class="tvar_re"></span>
-          <div class="help" data-topic="pop_re"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Bayes Threshold:</span>
-          <span class="tvar_bt"></span>
-          <div class="help" data-topic="pop_bt"></div>
-        </div>
-      </div>
-      <div class="tvar_sites"></div>
-    </div>
-
-
-    <div class="popup_wrapper">
-      <div class="popup" style="display:none; top: -150px;" id="download">
-        <div>
-          <div style="float:right; ">
-            <div id="outpop_close" class="close" tabindex="0">x</div>
-          </div>
-          <h2 class="mainh" style="margin:0; padding:0;">Submit or Download</h2>
-          <div style="clear:both"></div>
-        </div>
-          <div style="height:100px">
-            <div style="float:right; width: 30px;">
-              <div id="outpop_prev" class="navarrow" tabindex="0">
-                <span class="inactive">&#8679;</span><span class="active">&#11014;</span>
-              </div>
-              <div id="outpop_num" class="navnum"></div>
-              <div id="outpop_next" class="navarrow" tabindex="0">
-                <span class="inactive">&#8681;</span><span class="active">&#11015;</span>
-              </div>
-            </div>
-            <div id="logo_box" style="height: 100px; margin-right: 40px;">
-              <canvas id="outpop_logo" height="100" width="580"></canvas>
-              <canvas id="outpop_logo_rc" class="logo_rc" height="100" width="580"></canvas>
-            </div>
-          </div>
-          <div>
-            <!-- tabs start -->
-            <div class="tabArea top">
-              <span id="outpop_tab_1" class="tab">Submit Motif</span><span
-                id="outpop_tab_2" class="tab middle">Download Motif</span><span 
-                id="outpop_tab_3" class="tab middle">Download Logo</span>
-            </div>
-            <div class="tabMain top">
-              <!-- Submit to another program -->
-              <div id="outpop_pnl_1">
-                <h4 class="compact">Submit to program</h4>
-                <table id="programs" class="programs">
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="tomtom" id="submit_tomtom"></td>
-                    <td><label for="submit_tomtom">Tomtom</label></td>
-                    <td><label for="submit_tomtom">Find similar motifs in
-                        published libraries or a library you supply.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="fimo" id="submit_fimo"></td>
-                    <td><label for="submit_fimo">FIMO</label></td>
-                    <td><label for="submit_fimo">Find motif occurrences in
-                        sequence data.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="mast" id="submit_mast"></td>
-                    <td><label for="submit_mast">MAST</label></td>
-                    <td><label for="submit_mast">Rank sequences by affinity to
-                        groups of motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="gomo" id="submit_gomo"></td>
-                    <td><label for="submit_gomo">GOMo</label></td>
-                    <td><label for="submit_gomo">Identify possible roles (Gene
-                        Ontology terms) for motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="spamo" id="submit_spamo"></td>
-                    <td><label for="submit_spamo">SpaMo</label></td>
-                    <td><label for="submit_spamo">Find other motifs that are
-                        enriched at specific close spacings which might imply the existance of a complex.</label></td>
-                  </tr>
-                </table>
-              </div>
-              <!-- download text format  -->
-              <div id="outpop_pnl_2">
-                <div>
-                  <label for="text_format">Format:</label>
-                  <select id="text_format">
-                    <option value="0">Count Matrix</option>
-                    <option value="1">Probability Matrix</option>
-                    <option value="2">Minimal MEME</option>
-                    <option value="3">FASTA</option>
-                    <option value="4">Raw</option>
-                  </select>
-                </div>
-                <form id="text_form" method="post" action="">
-                  <script>$("text_form").action = site_url + "/utilities/save_generated_file";</script>
-                  <input type="hidden" id="text_name" name="name" value="motif.txt">
-                  <input type="hidden" name="mime_type" value="text/plain">
-                  <textarea id="outpop_text" name="content"
-                    style="width:99%; white-space: pre; word-wrap: normal; overflow-x: scroll;" 
-                    rows="8" readonly="readonly" wrap="off"></textarea>
-                </form>
-              </div>
-              <!-- download logo format -->
-              <div id="outpop_pnl_3">
-                <form id="logo_form" method="post" action="">
-                  <script>$("logo_form").action = site_url + "/utilities/generate_logo";</script>
-                  <input type="hidden" name="program" value="MEME"/>
-                  <input type="hidden" id="logo_motifs" name="motifs" value=""/>
-                  <table>
-                    <tr>
-                      <td><label for="logo_format">Format:</label></td>
-                      <td>
-                        <select id="logo_format" name="png">
-                          <option value="1">PNG (for web)</option>
-                          <option value="0">EPS (for publication)</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_rc">Orientation:</label></td>
-                      <td>
-                        <select id="logo_rc" name="rc1">
-                          <option value="0">Normal</option>
-                          <option value="1" id="logo_rc_option">Reverse Complement</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_ssc">Small Sample Correction:</label></td>
-                      <td>
-                        <input type="hidden" id="logo_err" name="errbars" value="0"/>
-                        <select id="logo_ssc" name="ssc">
-                          <option value="0">Off</option>
-                          <option value="1">On</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_width">Width:</label></td>
-                      <td>
-                        <input type="text" id="logo_width" size="4" placeholder="default" name="width"/>&nbsp;cm
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_height">Height:</label></td>
-                      <td>
-                        <input type="text" id="logo_height" size="4" placeholder="default" name="height"/>&nbsp;cm
-                      </td>
-                    </tr>
-                  </table>
-                </form>
-              </div>
-              <!-- Buttons -->
-              <div>
-                <div style="float:left;">
-                  <input type="button" id="outpop_do" value="Submit" />
-                </div>
-                <div style="float:right;">
-                  <input id="outpop_cancel" type="button" value="Cancel" />
-                </div>
-                <div style="clear:both;"></div>
-              </div>
-            </div>
-        </div>
-      </div>
-    </div>
-
-
-
-    <!-- Page starts here -->
-    <div id="top" class="pad1">
-      <div class="prog_logo big">
-        <img src="" alt="MEME Logo">
-        <h1>MEME</h1>
-        <h2>Multiple Em for Motif Elicitation</h2>
-      </div>
-      <p>
-        For further information on how to interpret these results or to get a 
-        copy of the MEME software please access 
-        <a href="http://meme-suite.org/">http://meme-suite.org</a>. 
-      </p>
-      <p>If you use MEME in your research, please cite the following paper:<br />
-        <span class="citation">
-          Timothy L. Bailey and Charles Elkan, 
-          "Fitting a mixture model by expectation maximization to discover motifs in biopolymers", 
-          <em>Proceedings of the Second International Conference on Intelligent Systems 
-          for Molecular Biology</em>, pp. 28-36, AAAI Press, Menlo Park, California, 1994. 
-          <a href="http://meme-suite.org/doc/ismb94.pdf">[pdf]</a> 
-        </span>
-      </p>
-    </div>
-    <!-- navigation -->
-    <div class="pad2">
-      <a class="jump" href="#motifs_sec">Discovered Motifs</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#sites_sec">Motif Locations</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#inputs_sec">Inputs &amp; Settings</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#info_sec">Program information</a>
-    </div>
-    <!-- alert the user when their browser is not up to the task -->
-    <noscript><h1 style="color:red">Javascript is required to view these results!</h1></noscript>
-    <h1 id="html5_warning" style="color:red; display:none;">Your browser does not support canvas!</h1>
-    <script>
-      if (!window.HTMLCanvasElement) $("html5_warning").style.display = "block";
-    </script>
-    <h2 class="mainh pad2" id="motifs_sec">Discovered Motifs</h2>
-    <div id="motifs" class="box">
-      <p>Please wait... Loading...</p>
-      <p>If the page has fully loaded and this message does not disappear then an error may have occurred.</p>
-    </div>
-    <h2 class="mainh pad2" id="sites_sec">Motif Locations</h2>
-    <div id="blocks" class="box">
-      <p>Please wait... Loading...</p>
-      <p>If the page has fully loaded and this message does not disappear then an error may have occurred.</p>
-    </div>
-    <h2 class="mainh pad2" id="inputs_sec">Inputs &amp; Settings</h2>
-    <div class="box">
-      <h4>Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th class="col_psp">PSP Source <div class="help" data-topic="pop_psp_source"></div></th>
-          <th>Alphabet <div class="help" data-topic="pop_seq_alph"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_seq_source"></td>
-          <td id="ins_seq_psp" class="col_psp"></td>
-          <td id="ins_seq_alphabet"></td>
-          <td id="ins_seq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.sequence_db;
-        $("ins_seq_source").innerHTML = db.source;
-        $("ins_seq_alphabet").innerHTML = meme_alphabet.get_alphabet_name();
-        $("ins_seq_count").innerHTML = db.sequences.length;
-        if (db.psp) {
-          $("ins_seq_psp").innerHTML = db.psp;
-        }
-        toggle_class($("seq_info"), "hide_psp", !(db.psp));
-      }
-      </script>
-      <h4>Background</h4>
-      <span id="alpha_bg"></span>
-      <script>
-      {
-        $("alpha_bg").appendChild(make_alpha_bg_table(meme_alphabet, data.sequence_db.freqs));
-      }
-      </script>
-      <h4>Other Settings</h4>
-      <table id="tbl_settings" class="inputs hide_advanced">
-        <tr>
-          <th>Motif Site Distribution</th>
-          <td id="opt_mod">
-            <span class="mod_zoops">ZOOPS: Zero or one site per sequence</span>
-            <span class="mod_oops">OOPS: Exactly one site per sequence</span>
-            <span class="mod_anr">ANR: Any number of sites per sequence</span>
-          </td>
-        </tr>
-        <tr>
-          <th>Site Strand Handling</th>
-          <td id="opt_strand">
-            <span class="strand_none">This alphabet only has one strand</span>
-            <span class="strand_given">Sites must be on the given strand</span>
-            <span class="strand_both">Sites may be on either strand</span>
-          </td>
-        </tr>
-        <tr>
-          <th>Maximum Number of Motifs</th>
-          <td id="opt_nmotifs"></td>
-        </tr>
-        <tr>
-          <th>Motif E-value Threshold</th>
-          <td id="opt_evt"></td>
-        </tr>
-        <tr>
-          <th>Minimum Motif Width</th>
-          <td id="opt_minw"></td>
-        </tr>
-        <tr>
-          <th>Maximum Motif Width</th>
-          <td id="opt_maxw"></td>
-        </tr>
-        <tr>
-          <th>Minimum Sites per Motif</th>
-          <td id="opt_minsites"></td>
-        </tr>
-        <tr>
-          <th>Maximum Sites per Motif</th>
-          <td id="opt_maxsites"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Bias on Number of Sites</th>
-          <td id="opt_wnsites"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Sequence Prior</th>
-          <td id="opt_prior">
-            <span class="prior_dirichlet">Simple Dirichlet</span>
-            <span class="prior_dmix">Dirichlets Mix</span>
-            <span class="prior_mega">Mega-weight Dirichlets Mix</span>
-            <span class="prior_megap">Mega-weight Dirichlets Mix Plus</span>
-            <span class="prior_addone">Add One</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>Sequence Prior Strength</th>
-          <td id="opt_b"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Source</th>
-          <td id="opt_substring">
-            <span class="substring_on">From substrings in input sequences</span>
-            <span class="substring_off">From strings on command line (-cons)</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Map Type</th>
-          <td id="opt_spmap">
-            <span class="spmap_uni">Uniform</span>
-            <span class="spmap_pam">Point Accepted Mutation</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Fuzz</th>
-          <td id="opt_spfuzz"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Maximum Iterations</th>
-          <td id="opt_maxiter"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Improvement Threshold</th>
-          <td id="opt_distance"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Trim Gap Open Cost</th>
-          <td id="opt_wg"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Trim Gap Extend Cost</th>
-          <td id="opt_ws"></td>
-        </tr>
-        <tr class="advanced">
-          <th>End Gap Treatment</th>
-          <td id="opt_noendgaps">
-            <span class="noendgaps_on">No cost</span>
-            <span class="noendgaps_off">Same cost as other gaps</span>
-          </td>
-        </tr>
-        <tr>
-          <td colspan="2" style="text-align: center">
-            <a href="javascript:toggle_class(document.getElementById('tbl_settings'), 'hide_advanced')">
-              <span class="show_more">Show Advanced Settings</span>
-              <span class="show_less">Hide Advanced Settings</span>
-            </a>
-          </td>
-        </tr>
-      </table>
-      <script>
-      {
-        $("opt_mod").className = data.options.mod;
-        $("opt_strand").className = (meme_alphabet.has_complement() ? (data.options.revcomp ? "both" : "given") : "none");
-        $("opt_nmotifs").textContent = data.options.nmotifs;
-        $("opt_evt").textContent = (typeof data.options.evt === "number" ? data.options.evt : "no limit");
-        $("opt_minw").textContent = data.options.minw;
-        $("opt_maxw").textContent = data.options.maxw;
-        $("opt_minsites").textContent = data.options.minsites;
-        $("opt_maxsites").textContent = data.options.maxsites;
-        $("opt_wnsites").textContent = data.options.wnsites;
-        $("opt_spmap").className = data.options.spmap;
-        $("opt_spfuzz").textContent = data.options.spfuzz;
-        $("opt_prior").className = data.options.prior;
-        $("opt_b").textContent = data.options.b;
-        $("opt_maxiter").textContent = data.options.maxiter;
-        $("opt_distance").textContent = data.options.distance;
-        $("opt_wg").textContent = data.options.wg;
-        $("opt_ws").textContent = data.options.ws;
-        $("opt_noendgaps").className = (data.options.noendgaps ? "on" : "off");
-        $("opt_substring").className = (data.options.substring ? "on" : "off");
-      }
-      </script>
-    </div>
-    <!-- list information on this program -->
-    <div id="info_sec" class="bar">
-      <div class="subsection">
-        <h5 id="version">MEME version</h5>
-        <span id="ins_version"></span> 
-        (Release date: <span id="ins_release"></span>)<br>
-      </div>
-      <script>
-        $("ins_version").innerHTML = data["version"];
-        $("ins_release").innerHTML = data["release"];
-      </script>
-      <div class="subsection">
-        <h5 id="reference">Reference</h5>
-        <span class="citation">
-          Timothy L. Bailey and Charles Elkan, 
-          "Fitting a mixture model by expectation maximization to discover motifs in biopolymers", 
-          <em>Proceedings of the Second International Conference on Intelligent Systems 
-          for Molecular Biology</em>, pp. 28-36, AAAI Press, Menlo Park, California, 1994. 
-        </span>
-      </div>
-      <div class="subsection">
-        <h5 id="command">Command line</h5>
-        <textarea id="cmd" rows="5" style="width:100%;" readonly="readonly">
-        </textarea>
-        <script>$("cmd").value = data["cmd"].join(" ");</script>
-      </div>
-    </div>
-    
-  </body>
-</html>
--- a/test-data/meme_output_test1.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test1.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,325 +1,61 @@
 ********************************************************************************
 MEME - Motif discovery tool
-********************************************************************************
-MEME version 4.12.0 (Release date: Tue Jun 27 16:22:50 2017 -0700)
-
-For further information on how to interpret these results or to get
-a copy of the MEME software please access http://meme-suite.org .
-
-This file may be used as input to the MAST algorithm for searching
-sequence databases for matches to groups of motifs.  MAST is available
-for interactive use and downloading at http://meme-suite.org .
-********************************************************************************
-
-
-********************************************************************************
+MEME version 5.0.5 (Release date: Mon Mar 18 20:12:19 2019 -0700)
 REFERENCE
-********************************************************************************
-If you use this program in your research, please cite:
-
-Timothy L. Bailey and Charles Elkan,
-"Fitting a mixture model by expectation maximization to discover
-motifs in biopolymers", Proceedings of the Second International
-Conference on Intelligent Systems for Molecular Biology, pp. 28-36,
-AAAI Press, Menlo Park, California, 1994.
-********************************************************************************
-
-
-********************************************************************************
 TRAINING SET
-********************************************************************************
-DATAFILE= meme_input_1.fasta
+CONTROL SEQUENCES= --none--
 ALPHABET= ACDEFGHIKLMNPQRSTVWY
 Sequence name            Weight Length  Sequence name            Weight Length  
 -------------            ------ ------  -------------            ------ ------  
 chr21_19617074_19617124_ 1.0000     50  chr21_26934381_26934431_ 1.0000     50  
-chr21_28217753_28217803_ 1.0000     50  chr21_31710037_31710087_ 1.0000     50  
-chr21_31744582_31744632_ 1.0000     50  chr21_31768316_31768366_ 1.0000     50  
-chr21_31914206_31914256_ 1.0000     50  chr21_31933633_31933683_ 1.0000     50  
-chr21_31962741_31962791_ 1.0000     50  chr21_31964683_31964733_ 1.0000     50  
-chr21_31973364_31973414_ 1.0000     50  chr21_31992870_31992920_ 1.0000     50  
-chr21_32185595_32185645_ 1.0000     50  chr21_32202076_32202126_ 1.0000     50  
-chr21_32253899_32253949_ 1.0000     50  chr21_32410820_32410870_ 1.0000     50  
-chr21_36411748_36411798_ 1.0000     50  chr21_37838750_37838800_ 1.0000     50  
-chr21_45705687_45705737_ 1.0000     50  chr21_45971413_45971463_ 1.0000     50  
-chr21_45978668_45978718_ 1.0000     50  chr21_45993530_45993580_ 1.0000     50  
-chr21_46020421_46020471_ 1.0000     50  chr21_46031920_46031970_ 1.0000     50  
-chr21_46046964_46047014_ 1.0000     50  chr21_46057197_46057247_ 1.0000     50  
-chr21_46086869_46086919_ 1.0000     50  chr21_46102103_46102153_ 1.0000     50  
-chr21_47517957_47518007_ 1.0000     50  chr21_47575506_47575556_ 1.0000     50  
-********************************************************************************
-
-********************************************************************************
 COMMAND LINE SUMMARY
-********************************************************************************
-This information can also be useful in the event you wish to report a
-problem with the MEME software.
-
-command: meme meme_input_1.fasta -o meme_test1_out -nostatus -maxsize 1000000 
-
 model:  mod=         zoops    nmotifs=         1    evt=           inf
-object function=  E-value of product of p-values
+objective function:           em=       E-value of product of p-values
+                              starts=   E-value of product of p-values
 width:  minw=            8    maxw=           50
-width:  wg=             11    ws=              1    endgaps=       yes
 nsites: minsites=        2    maxsites=       30    wnsites=       0.8
 theta:  spmap=         pam    spfuzz=        120
-global: substring=     yes    branching=      no    wbranch=        no
 em:     prior=       megap    b=            7500    maxiter=        50
         distance=    1e-05
-data:   n=            1500    N=              30    shuffle=        -1
-
-sample: seed=            0    ctfrac=         -1    maxwords=       -1
+trim:   wg=             11    ws=              1    endgaps=       yes
+data:   n=            1500    N=              30
+sample: seed=            0    hsfrac=          0
+        searchsize=   1500    norand=         no    csites=       1000
 Dirichlet mixture priors file: prior30.plib
 Letter frequencies in dataset:
-A 0.294 C 0.231 D 0.000 E 0.000 F 0.000 G 0.257 H 0.000 I 0.000 K 0.000 
-L 0.000 M 0.000 N 0.000 P 0.000 Q 0.000 R 0.000 S 0.000 T 0.217 V 0.000 
-W 0.000 Y 0.000 
-Background letter frequencies (from dataset with add-one prior applied):
-A 0.291 C 0.229 D 0.001 E 0.001 F 0.001 G 0.255 H 0.001 I 0.001 K 0.001 
-L 0.001 M 0.001 N 0.001 P 0.001 Q 0.001 R 0.001 S 0.001 T 0.215 V 0.001 
-W 0.001 Y 0.001 
-********************************************************************************
-
-
-********************************************************************************
+A 0.294 C 0.231 D 0 E 0 F 0 G 0.257 H 0 I 0 K 0 
+L 0 M 0 N 0 P 0 Q 0 R 0 S 0 T 0.217 V 0 
+W 0 Y 0 
+Background letter frequencies (from file dataset with add-one prior applied):
+A 0.291 C 0.229 D 0.000658 E 0.000658 F 0.000658 G 0.255 H 0.000658 I 0.000658 K 0.000658 
+L 0.000658 M 0.000658 N 0.000658 P 0.000658 Q 0.000658 R 0.000658 S 0.000658 T 0.215 V 0.000658 
+W 0.000658 Y 0.000658 
+Background model order: 0
 MOTIF GGGGTATAAAA MEME-1	width =  11  sites =  25  llr = 239  E-value = 2.4e-011
-********************************************************************************
 --------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 Description
---------------------------------------------------------------------------------
-Simplified        A  2323:a:a8a8
-pos.-specific     C  ::3::::::::
-probability       D  :::::::::::
-matrix            E  :::::::::::
-                  F  :::::::::::
-                  G  7746::::::1
-                  H  :::::::::::
-                  I  :::::::::::
-                  K  :::::::::::
-                  L  :::::::::::
-                  M  :::::::::::
-                  N  :::::::::::
-                  P  :::::::::::
-                  Q  :::::::::::
-                  R  :::::::::::
-                  S  :::::::::::
-                  T  1:2:a:a:2::
-                  V  :::::::::::
-                  W  :::::::::::
-                  Y  :::::::::::
-
-         bits   10.6            
-                 9.5            
-                 8.5            
-                 7.4            
-Relative         6.3            
-Entropy          5.3            
-(13.8 bits)      4.2            
-                 3.2            
-                 2.1     * **   
-                 1.1 ** ********
-                 0.0 -----------
-
-Multilevel           GGGGTATAAAA
-consensus            AACA    T  
-sequence                        
-                                
-                                
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 sites sorted by position p-value
---------------------------------------------------------------------------------
 Sequence name             Start   P-value               Site  
 -------------             ----- ---------            -----------
 chr21_46046964_46047014_     13  1.06e-06 AAGGCCAGGA GGGGTATAAAA GCCTGAGAGC
-chr21_46057197_46057247_     37  3.41e-06 ACAGGCCCTG GGCATATAAAA GCC       
-chr21_45971413_45971463_     10  3.41e-06  CAGGCCCTG GGCATATAAAA GCCCCAGCAG
-chr21_31964683_31964733_     14  3.41e-06 GATTCACTGA GGCATATAAAA GGCCCTCTGC
-chr21_45993530_45993580_      8  4.00e-06    CCAAGGA GGAGTATAAAA GCCCCACAAA
-chr21_32202076_32202126_     14  5.01e-06 CCACCAGCTT GAGGTATAAAA AGCCCTGTAC
-chr21_46031920_46031970_     16  6.06e-06 ATACCCAGGG AGGGTATAAAA CCTCAGCAGC
-chr21_32410820_32410870_     22  8.67e-06 AATCACTGAG GATGTATAAAA GTCCCAGGGA
-chr21_32185595_32185645_     19  8.67e-06 CACCAGAGCT GGGATATATAA AGAAGGTTCT
-chr21_31992870_31992920_     17  8.67e-06 CACTATTGAA GATGTATAAAA TTTCATTTGC
-chr21_46020421_46020471_      3  1.21e-05         GA GACATATAAAA GCCAACATCC
-chr21_47517957_47518007_     33  1.59e-05 CCGGCGGGGC GGGGTATAAAG GGGGCGG   
-chr21_45978668_45978718_      5  1.59e-05       CAGA GGGGTATAAAG GTTCCGACCA
-chr21_31914206_31914256_     16  1.68e-05 CCCACTACTT AGAGTATAAAA TCATTCTGAG
-chr21_32253899_32253949_     20  2.03e-05 CACCAGCAAG GATATATAAAA GCTCAGGAGT
-chr21_31744582_31744632_     13  3.06e-05 CAGGTCTAAG AGCATATATAA CTTGGAGTCC
-chr21_19617074_19617124_     40  3.06e-05 CCTCGGGACG TGGGTATATAA           
-chr21_45705687_45705737_     38  3.82e-05 CGTGGTCGCG GGGGTATAACA GC        
-chr21_31768316_31768366_      1  3.82e-05          . AACGTATATAA ATGGTCCTGT
-chr21_47575506_47575556_     31  4.02e-05 GCTGCCGGTG AGCGTATAAAG GCCCTGGCG 
-chr21_26934381_26934431_     28  5.52e-05 AGTCACAAGT GAGTTATAAAA GGGTCGCACG
-chr21_31710037_31710087_     15  5.94e-05 CCCAGGTTTC TGAGTATATAA TCGCCGCACC
-chr21_36411748_36411798_     23  6.78e-05 AGTTTCAGTT GGCATCtaaaa attatataac
-chr21_31933633_31933683_      3  2.08e-04         TC AGAGTATATAT AAATGTTCCT
-chr21_31962741_31962791_     14  4.05e-04 TATAACTCAG GTTGGATAAAA TAATTTGTAC
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 block diagrams
---------------------------------------------------------------------------------
 SEQUENCE NAME            POSITION P-VALUE  MOTIF DIAGRAM
 -------------            ----------------  -------------
 chr21_46046964_46047014_          1.1e-06  12_[1]_27
-chr21_46057197_46057247_          3.4e-06  36_[1]_3
-chr21_45971413_45971463_          3.4e-06  9_[1]_30
-chr21_31964683_31964733_          3.4e-06  13_[1]_26
-chr21_45993530_45993580_            4e-06  7_[1]_32
-chr21_32202076_32202126_            5e-06  13_[1]_26
-chr21_46031920_46031970_          6.1e-06  15_[1]_24
-chr21_32410820_32410870_          8.7e-06  21_[1]_18
-chr21_32185595_32185645_          8.7e-06  18_[1]_21
-chr21_31992870_31992920_          8.7e-06  16_[1]_23
-chr21_46020421_46020471_          1.2e-05  2_[1]_37
-chr21_47517957_47518007_          1.6e-05  32_[1]_7
-chr21_45978668_45978718_          1.6e-05  4_[1]_35
-chr21_31914206_31914256_          1.7e-05  15_[1]_24
-chr21_32253899_32253949_            2e-05  19_[1]_20
-chr21_31744582_31744632_          3.1e-05  12_[1]_27
-chr21_19617074_19617124_          3.1e-05  39_[1]
-chr21_45705687_45705737_          3.8e-05  37_[1]_2
-chr21_31768316_31768366_          3.8e-05  [1]_39
-chr21_47575506_47575556_            4e-05  30_[1]_9
-chr21_26934381_26934431_          5.5e-05  27_[1]_12
-chr21_31710037_31710087_          5.9e-05  14_[1]_25
-chr21_36411748_36411798_          6.8e-05  22_[1]_17
-chr21_31933633_31933683_          0.00021  2_[1]_37
-chr21_31962741_31962791_           0.0004  13_[1]_26
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 in BLOCKS format
---------------------------------------------------------------------------------
 BL   MOTIF GGGGTATAAAA width=11 seqs=25
 chr21_46046964_46047014_ (   13) GGGGTATAAAA  1 
-chr21_46057197_46057247_ (   37) GGCATATAAAA  1 
-chr21_45971413_45971463_ (   10) GGCATATAAAA  1 
-chr21_31964683_31964733_ (   14) GGCATATAAAA  1 
-chr21_45993530_45993580_ (    8) GGAGTATAAAA  1 
-chr21_32202076_32202126_ (   14) GAGGTATAAAA  1 
-chr21_46031920_46031970_ (   16) AGGGTATAAAA  1 
-chr21_32410820_32410870_ (   22) GATGTATAAAA  1 
-chr21_32185595_32185645_ (   19) GGGATATATAA  1 
-chr21_31992870_31992920_ (   17) GATGTATAAAA  1 
-chr21_46020421_46020471_ (    3) GACATATAAAA  1 
-chr21_47517957_47518007_ (   33) GGGGTATAAAG  1 
-chr21_45978668_45978718_ (    5) GGGGTATAAAG  1 
-chr21_31914206_31914256_ (   16) AGAGTATAAAA  1 
-chr21_32253899_32253949_ (   20) GATATATAAAA  1 
-chr21_31744582_31744632_ (   13) AGCATATATAA  1 
-chr21_19617074_19617124_ (   40) TGGGTATATAA  1 
-chr21_45705687_45705737_ (   38) GGGGTATAACA  1 
-chr21_31768316_31768366_ (    1) AACGTATATAA  1 
-chr21_47575506_47575556_ (   31) AGCGTATAAAG  1 
-chr21_26934381_26934431_ (   28) GAGTTATAAAA  1 
-chr21_31710037_31710087_ (   15) TGAGTATATAA  1 
-chr21_36411748_36411798_ (   23) GGCATCTAAAA  1 
-chr21_31933633_31933683_ (    3) AGAGTATATAT  1 
-chr21_31962741_31962791_ (   14) GTTGGATAAAA  1 
-//
-
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 position-specific scoring matrix
---------------------------------------------------------------------------------
 log-odds matrix: alength= 20 w= 11 n= 1200 bayes= 5.33554 E= 2.4e-011 
    -32   -680     91     77      7    138    -20     55     64    107     11    150    142     72     87    396   -148    221   -140    -36 
-   -11   -680     89     76      7    137    -21     55     63    107     10    149    141     71     87    396   -239    220   -140    -36 
-   -79     41      4     21     -7     44    -62     42     -5     99      0     99    138     52     42    399    -46    223   -173    -68 
-    11   -677     48     47     -2    127    -43     46     27    101      3    124    138     60     62    397   -235    220   -160    -55 
-  -596   -820     12    -21    -53   -267    -74     37     16     44    -37     98     31      9     19    319    212    127   -193    -95 
-   165   -261     70    110     77   -521     -4    147     95    201     90    121    124     91    107    425   -527    314    -95      8 
-  -838   -990    -89   -149   -151   -841   -161   -117   -113    -66   -209    -68    -69   -129    -91    111    221    -55   -255   -173 
-   176   -858    -79   -103   -115   -717   -148    -95   -108    -17   -162    -61    -12    -95    -69    193   -737     52   -240   -153 
-   134   -686      0     16    -12   -553    -68     44     -8     96     -9     88    124     41     36    384     11    216   -177    -71 
-   165   -261     70    110     77   -521     -4    147     95    201     90    121    124     91    107    425   -527    314    -95      8 
-   147   -614     89    129     93   -121     12    160    113    217    108    144    144    111    125    447   -241    332    -81     22 
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 position-specific probability matrix
---------------------------------------------------------------------------------
 letter-probability matrix: alength= 20 w= 11 nsites= 25 E= 2.4e-011 
  0.240000  0.000000  0.000000  0.000000  0.000000  0.680000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.080000  0.000000  0.000000  0.000000 
- 0.280000  0.000000  0.000000  0.000000  0.000000  0.680000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.040000  0.000000  0.000000  0.000000 
- 0.160000  0.320000  0.000000  0.000000  0.000000  0.360000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.160000  0.000000  0.000000  0.000000 
- 0.320000  0.000000  0.000000  0.000000  0.000000  0.640000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.040000  0.000000  0.000000  0.000000 
- 0.000000  0.000000  0.000000  0.000000  0.000000  0.040000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.960000  0.000000  0.000000  0.000000 
- 0.960000  0.040000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000 
- 0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  1.000000  0.000000  0.000000  0.000000 
- 1.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000 
- 0.760000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.240000  0.000000  0.000000  0.000000 
- 0.960000  0.040000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000 
- 0.840000  0.000000  0.000000  0.000000  0.000000  0.120000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.000000  0.040000  0.000000  0.000000  0.000000 
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGGGTATAAAA MEME-1 regular expression
---------------------------------------------------------------------------------
 [GA][GA][GC][GA]TATA[AT]AA
---------------------------------------------------------------------------------
-
-
-
-
-Time  0.77 secs.
-
-********************************************************************************
-
-
-********************************************************************************
 SUMMARY OF MOTIFS
-********************************************************************************
-
---------------------------------------------------------------------------------
 	Combined block diagrams: non-overlapping sites with p-value < 0.0001
---------------------------------------------------------------------------------
 SEQUENCE NAME            COMBINED P-VALUE  MOTIF DIAGRAM
 -------------            ----------------  -------------
 chr21_19617074_19617124_         1.22e-03  39_[1(3.06e-05)]
-chr21_26934381_26934431_         2.21e-03  27_[1(5.52e-05)]_12
-chr21_28217753_28217803_         7.29e-01  50
-chr21_31710037_31710087_         2.37e-03  14_[1(5.94e-05)]_25
-chr21_31744582_31744632_         1.22e-03  12_[1(3.06e-05)]_27
-chr21_31768316_31768366_         1.53e-03  [1(3.82e-05)]_39
-chr21_31914206_31914256_         6.70e-04  15_[1(1.68e-05)]_24
-chr21_31933633_31933683_         1.81e-03  4_[1(4.54e-05)]_35
-chr21_31962741_31962791_         1.61e-02  50
-chr21_31964683_31964733_         1.36e-04  13_[1(3.41e-06)]_26
-chr21_31973364_31973414_         1.99e-01  50
-chr21_31992870_31992920_         3.47e-04  16_[1(8.67e-06)]_23
-chr21_32185595_32185645_         3.47e-04  18_[1(8.67e-06)]_21
-chr21_32202076_32202126_         2.01e-04  13_[1(5.01e-06)]_26
-chr21_32253899_32253949_         8.11e-04  19_[1(2.03e-05)]_20
-chr21_32410820_32410870_         3.47e-04  21_[1(8.67e-06)]_18
-chr21_36411748_36411798_         2.71e-03  22_[1(6.78e-05)]_17
-chr21_37838750_37838800_         8.23e-02  50
-chr21_45705687_45705737_         1.53e-03  37_[1(3.82e-05)]_2
-chr21_45971413_45971463_         1.36e-04  9_[1(3.41e-06)]_30
-chr21_45978668_45978718_         6.37e-04  4_[1(1.59e-05)]_35
-chr21_45993530_45993580_         1.60e-04  7_[1(4.00e-06)]_32
-chr21_46020421_46020471_         4.83e-04  2_[1(1.21e-05)]_37
-chr21_46031920_46031970_         2.43e-04  15_[1(6.06e-06)]_24
-chr21_46046964_46047014_         4.26e-05  12_[1(1.06e-06)]_27
-chr21_46057197_46057247_         1.36e-04  36_[1(3.41e-06)]_3
-chr21_46086869_46086919_         4.30e-02  50
-chr21_46102103_46102153_         4.30e-02  50
-chr21_47517957_47518007_         6.37e-04  32_[1(1.59e-05)]_7
-chr21_47575506_47575556_         1.61e-03  30_[1(4.02e-05)]_9
---------------------------------------------------------------------------------
-
-********************************************************************************
-
-
-********************************************************************************
 Stopped because requested number of motifs (1) found.
-********************************************************************************
-
-CPU: ThinkPad-T450s
-
-********************************************************************************
--- a/test-data/meme_output_test1.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test1.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -10,136 +10,29 @@
 <!ATTLIST MEME 
   version CDATA #REQUIRED
   release CDATA #REQUIRED
->
 <!-- Training-set elements -->
 <!ELEMENT training_set (alphabet, ambigs, sequence*, letter_frequencies)>
-<!ATTLIST training_set datafile CDATA #REQUIRED length CDATA #REQUIRED>
-<!ELEMENT alphabet (letter*)>
-<!ATTLIST alphabet name CDATA #REQUIRED>
-<!ELEMENT ambigs (letter*)>
-<!ELEMENT letter EMPTY>
-<!ATTLIST letter id ID #REQUIRED>
-<!ATTLIST letter symbol CDATA #REQUIRED>
-<!ATTLIST letter equals CDATA #IMPLIED>
-<!ATTLIST letter aliases CDATA #IMPLIED>
-<!ATTLIST letter complement CDATA #IMPLIED>
-<!ATTLIST letter name CDATA #IMPLIED>
-<!ATTLIST letter colour CDATA #IMPLIED>
-<!ELEMENT sequence EMPTY>
-<!ATTLIST sequence id ID #REQUIRED
                    name CDATA #REQUIRED
                    length CDATA #REQUIRED
                    weight CDATA #REQUIRED
->
 <!ELEMENT letter_frequencies (alphabet_array)>
-
 <!-- Model elements -->
 <!ELEMENT model (
   command_line,
   host,
   type,
   nmotifs,
-  evalue_threshold,
-  object_function,
-  spfun,
-  min_width,
-  max_width,
-  wg,
-  ws,
-  endgaps,
-  minsites,
-  maxsites,
-  wnsites,
-  spmap,
-  spfuzz,
-  prior,
-  beta,
-  maxiter,
-  distance,
-  num_sequences,
-  num_positions,
-  seed,
-  hsfrac,
-  maxwords,
-  maxsize,
-  csites,
-  strands,
-  priors_file,
-  reason_for_stopping,
-  back_order,
-  background_frequencies
 )>
 <!ELEMENT command_line (#PCDATA)*>
 <!ELEMENT host (#PCDATA)*>
 <!ELEMENT type (#PCDATA)*>
 <!ELEMENT nmotifs (#PCDATA)*>
-<!ELEMENT evalue_threshold (#PCDATA)*>
-<!ELEMENT object_function (#PCDATA)*>
-<!ELEMENT spfun (#PCDATA)*>
-<!ELEMENT min_width (#PCDATA)*>
-<!ELEMENT max_width (#PCDATA)*>
-<!ELEMENT wg (#PCDATA)*>
-<!ELEMENT ws (#PCDATA)*>
-<!ELEMENT endgaps (#PCDATA)*>
-<!ELEMENT minsites (#PCDATA)*>
-<!ELEMENT maxsites (#PCDATA)*>
-<!ELEMENT wnsites (#PCDATA)*>
-<!ELEMENT spmap (#PCDATA)*>
-<!ELEMENT spfuzz (#PCDATA)*>
-<!ELEMENT prior (#PCDATA)*>
-<!ELEMENT beta (#PCDATA)*>
-<!ELEMENT maxiter (#PCDATA)*>
-<!ELEMENT distance (#PCDATA)*>
-<!ELEMENT num_sequences (#PCDATA)*>
-<!ELEMENT num_positions (#PCDATA)*>
-<!ELEMENT seed (#PCDATA)*>
-<!ELEMENT hsfrac (#PCDATA)*>
-<!ELEMENT maxwords (#PCDATA)*>
-<!ELEMENT maxsites (#PCDATA)*>
-<!ELEMENT csites (#PCDATA)*>
-<!ELEMENT strands (#PCDATA)*>
-<!ELEMENT priors_file (#PCDATA)*>
-<!ELEMENT reason_for_stopping (#PCDATA)*>
-<!ELEMENT back_order (#PCDATA)*>
-<!ELEMENT background_frequencies (alphabet_array)>
-<!ATTLIST background_frequencies source CDATA #REQUIRED>
-
-<!-- Motif elements -->
-<!ELEMENT motifs (motif*)>
-<!ELEMENT motif (scores, probabilities, regular_expression?, contributing_sites)>
-<!ATTLIST motif id ID #REQUIRED
-                name CDATA #REQUIRED
-                alt CDATA ""
-                width CDATA #REQUIRED
-                sites CDATA #REQUIRED
-                llr CDATA #REQUIRED
-                ic CDATA #REQUIRED
-                re CDATA #REQUIRED
-                bayes_threshold CDATA #REQUIRED
-                e_value CDATA #REQUIRED
-                elapsed_time CDATA #REQUIRED
-                url CDATA ""
->
-<!ELEMENT scores (alphabet_matrix)>
-<!ELEMENT probabilities (alphabet_matrix)>
-<!ELEMENT regular_expression (#PCDATA)*>
-
-<!-- Contributing site elements -->
-<!-- Contributing sites are motif occurences found during the motif discovery phase -->
-<!ELEMENT contributing_sites (contributing_site*)>
-<!ELEMENT contributing_site (left_flank, site, right_flank)>
-<!ATTLIST contributing_site sequence_id IDREF #REQUIRED
-                          position CDATA #REQUIRED
-                          strand (plus|minus|none) 'none'
-                          pvalue CDATA #REQUIRED
->
 <!-- The left_flank contains the sequence for 10 bases to the left of the motif start -->
 <!ELEMENT left_flank (#PCDATA)>
 <!-- The site contains the sequence for the motif instance -->
 <!ELEMENT site (letter_ref*)>
 <!-- The right_flank contains the sequence for 10 bases to the right of the motif end -->
 <!ELEMENT right_flank (#PCDATA)>
-
 <!-- Scanned site elements -->
 <!-- Scanned sites are motif occurences found during the sequence scan phase -->
 <!ELEMENT scanned_sites_summary (scanned_sites*)>
@@ -153,7 +46,6 @@
                         strand (plus|minus|none) 'none'
                         position CDATA #REQUIRED
                         pvalue CDATA #REQUIRED>
-
 <!-- Utility elements -->
 <!-- A reference to a letter in the alphabet -->
 <!ELEMENT letter_ref EMPTY>
@@ -162,643 +54,44 @@
 <!ELEMENT alphabet_array (value*)>
 <!ELEMENT value (#PCDATA)>
 <!ATTLIST value letter_id IDREF #REQUIRED>
-
 <!-- A alphabet_matrix contains one alphabet_array for each position in a motif -->
 <!ELEMENT alphabet_matrix (alphabet_array*)>
-
 ]>
 <!-- Begin document body -->
-<MEME version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
-<training_set datafile="meme_input_1.fasta" length="30">
+<MEME version="5.0.5" release="Mon Mar 18 20:12:19 2019 -0700">
 <alphabet name="Protein" like="protein">
 <letter id="A" symbol="A" name="Alanine" colour="0000CC"/>
-<letter id="C" symbol="C" name="Cysteine" colour="0000CC"/>
-<letter id="D" symbol="D" name="Aspartic acid" colour="FF00FF"/>
-<letter id="E" symbol="E" name="Glutamic acid" colour="FF00FF"/>
-<letter id="F" symbol="F" name="Phenylalanine" colour="0000CC"/>
-<letter id="G" symbol="G" name="Glycine" colour="FFB300"/>
-<letter id="H" symbol="H" name="Histidine" colour="FFCCCC"/>
-<letter id="I" symbol="I" name="Isoleucine" colour="0000CC"/>
-<letter id="K" symbol="K" name="Lysine" colour="CC0000"/>
-<letter id="L" symbol="L" name="Leucine" colour="0000CC"/>
-<letter id="M" symbol="M" name="Methionine" colour="0000CC"/>
-<letter id="N" symbol="N" name="Asparagine" colour="008000"/>
-<letter id="P" symbol="P" name="Proline" colour="FFFF00"/>
-<letter id="Q" symbol="Q" name="Glutamine" colour="008000"/>
-<letter id="R" symbol="R" name="Arginine" colour="CC0000"/>
-<letter id="S" symbol="S" name="Serine" colour="008000"/>
-<letter id="T" symbol="T" name="Threonine" colour="008000"/>
-<letter id="V" symbol="V" name="Valine" colour="0000CC"/>
-<letter id="W" symbol="W" name="Tryptophan" colour="0000CC"/>
-<letter id="Y" symbol="Y" name="Tyrosine" colour="33E6CC"/>
-<letter id="X" symbol="X" aliases="*." equals="ACDEFGHIKLMNPQRSTVWY" name="Any amino acid"/>
-<letter id="B" symbol="B" equals="DN" name="Asparagine or Aspartic acid"/>
-<letter id="Z" symbol="Z" equals="EQ" name="Glutamine or Glutamic acid"/>
-<letter id="J" symbol="J" equals="IL" name="Leucine or Isoleucine"/>
 </alphabet>
 <sequence id="sequence_0" name="chr21_19617074_19617124_+" length="50" weight="1.000000" />
-<sequence id="sequence_1" name="chr21_26934381_26934431_+" length="50" weight="1.000000" />
-<sequence id="sequence_2" name="chr21_28217753_28217803_-" length="50" weight="1.000000" />
-<sequence id="sequence_3" name="chr21_31710037_31710087_-" length="50" weight="1.000000" />
-<sequence id="sequence_4" name="chr21_31744582_31744632_-" length="50" weight="1.000000" />
-<sequence id="sequence_5" name="chr21_31768316_31768366_+" length="50" weight="1.000000" />
-<sequence id="sequence_6" name="chr21_31914206_31914256_-" length="50" weight="1.000000" />
-<sequence id="sequence_7" name="chr21_31933633_31933683_-" length="50" weight="1.000000" />
-<sequence id="sequence_8" name="chr21_31962741_31962791_-" length="50" weight="1.000000" />
-<sequence id="sequence_9" name="chr21_31964683_31964733_+" length="50" weight="1.000000" />
-<sequence id="sequence_10" name="chr21_31973364_31973414_+" length="50" weight="1.000000" />
-<sequence id="sequence_11" name="chr21_31992870_31992920_+" length="50" weight="1.000000" />
-<sequence id="sequence_12" name="chr21_32185595_32185645_-" length="50" weight="1.000000" />
-<sequence id="sequence_13" name="chr21_32202076_32202126_-" length="50" weight="1.000000" />
-<sequence id="sequence_14" name="chr21_32253899_32253949_-" length="50" weight="1.000000" />
-<sequence id="sequence_15" name="chr21_32410820_32410870_-" length="50" weight="1.000000" />
-<sequence id="sequence_16" name="chr21_36411748_36411798_-" length="50" weight="1.000000" />
-<sequence id="sequence_17" name="chr21_37838750_37838800_-" length="50" weight="1.000000" />
-<sequence id="sequence_18" name="chr21_45705687_45705737_+" length="50" weight="1.000000" />
-<sequence id="sequence_19" name="chr21_45971413_45971463_-" length="50" weight="1.000000" />
-<sequence id="sequence_20" name="chr21_45978668_45978718_-" length="50" weight="1.000000" />
-<sequence id="sequence_21" name="chr21_45993530_45993580_+" length="50" weight="1.000000" />
-<sequence id="sequence_22" name="chr21_46020421_46020471_+" length="50" weight="1.000000" />
-<sequence id="sequence_23" name="chr21_46031920_46031970_+" length="50" weight="1.000000" />
-<sequence id="sequence_24" name="chr21_46046964_46047014_+" length="50" weight="1.000000" />
-<sequence id="sequence_25" name="chr21_46057197_46057247_+" length="50" weight="1.000000" />
-<sequence id="sequence_26" name="chr21_46086869_46086919_-" length="50" weight="1.000000" />
-<sequence id="sequence_27" name="chr21_46102103_46102153_-" length="50" weight="1.000000" />
-<sequence id="sequence_28" name="chr21_47517957_47518007_+" length="50" weight="1.000000" />
-<sequence id="sequence_29" name="chr21_47575506_47575556_-" length="50" weight="1.000000" />
 <letter_frequencies>
 <alphabet_array>
 <value letter_id="A">0.294</value>
-<value letter_id="C">0.231</value>
-<value letter_id="D">0.000</value>
-<value letter_id="E">0.000</value>
-<value letter_id="F">0.000</value>
-<value letter_id="G">0.257</value>
-<value letter_id="H">0.000</value>
-<value letter_id="I">0.000</value>
-<value letter_id="K">0.000</value>
-<value letter_id="L">0.000</value>
-<value letter_id="M">0.000</value>
-<value letter_id="N">0.000</value>
-<value letter_id="P">0.000</value>
-<value letter_id="Q">0.000</value>
-<value letter_id="R">0.000</value>
-<value letter_id="S">0.000</value>
-<value letter_id="T">0.217</value>
-<value letter_id="V">0.000</value>
-<value letter_id="W">0.000</value>
-<value letter_id="Y">0.000</value>
-</alphabet_array>
 </letter_frequencies>
 </training_set>
 <model>
-<command_line>meme meme_input_1.fasta -o meme_test1_out -nostatus -maxsize 1000000 </command_line>
-<host>ThinkPad-T450s</host>
-<type>zoops</type>
-<nmotifs>1</nmotifs>
-<evalue_threshold>inf</evalue_threshold>
-<object_function>E-value of product of p-values</object_function>
-<use_llr>0</use_llr>
-<min_width>8</min_width>
-<max_width>50</max_width>
-<wg>11</wg>
-<ws>1</ws>
-<endgaps>yes</endgaps>
-<substring>yes</substring>
-<minsites>2</minsites>
-<maxsites>30</maxsites>
-<wnsites>0.8</wnsites>
-<spmap>pam</spmap>
-<spfuzz>120</spfuzz>
-<prior>megap</prior>
-<beta>7500</beta>
-<maxiter>50</maxiter>
-<distance>1e-05</distance>
-<num_sequences>30</num_sequences>
-<num_positions>1500</num_positions>
-<seed>0</seed>
-<ctfrac>-1</ctfrac>
-<maxwords>-1</maxwords>
-<strands>none</strands>
-<priors_file>prior30.plib</priors_file>
-<reason_for_stopping>Stopped because requested number of motifs (1) found.</reason_for_stopping>
-<background_frequencies source="dataset with add-one prior applied">
-<alphabet_array>
-<value letter_id="A">0.291</value>
-<value letter_id="C">0.229</value>
-<value letter_id="D">0.001</value>
-<value letter_id="E">0.001</value>
-<value letter_id="F">0.001</value>
-<value letter_id="G">0.255</value>
-<value letter_id="H">0.001</value>
-<value letter_id="I">0.001</value>
-<value letter_id="K">0.001</value>
-<value letter_id="L">0.001</value>
-<value letter_id="M">0.001</value>
-<value letter_id="N">0.001</value>
-<value letter_id="P">0.001</value>
-<value letter_id="Q">0.001</value>
-<value letter_id="R">0.001</value>
-<value letter_id="S">0.001</value>
-<value letter_id="T">0.215</value>
-<value letter_id="V">0.001</value>
-<value letter_id="W">0.001</value>
-<value letter_id="Y">0.001</value>
-</alphabet_array>
-</background_frequencies>
-</model>
-<motifs>
-<motif id="motif_1" name="GGGGTATAAAA" alt="MEME-1" width="11" sites="25" ic="40.0" re="13.8" llr="239" e_value="2.4e-011" bayes_threshold="5.33554" elapsed_time="0.772000">
 <scores>
 <alphabet_matrix>
-<alphabet_array>
 <value letter_id="A">-32</value>
-<value letter_id="C">-680</value>
-<value letter_id="D">91</value>
-<value letter_id="E">77</value>
-<value letter_id="F">7</value>
-<value letter_id="G">138</value>
-<value letter_id="H">-20</value>
-<value letter_id="I">55</value>
-<value letter_id="K">64</value>
-<value letter_id="L">107</value>
-<value letter_id="M">11</value>
-<value letter_id="N">150</value>
-<value letter_id="P">142</value>
-<value letter_id="Q">72</value>
-<value letter_id="R">87</value>
-<value letter_id="S">396</value>
-<value letter_id="T">-148</value>
-<value letter_id="V">221</value>
-<value letter_id="W">-140</value>
-<value letter_id="Y">-36</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">-11</value>
-<value letter_id="C">-680</value>
-<value letter_id="D">89</value>
-<value letter_id="E">76</value>
-<value letter_id="F">7</value>
-<value letter_id="G">137</value>
-<value letter_id="H">-21</value>
-<value letter_id="I">55</value>
-<value letter_id="K">63</value>
-<value letter_id="L">107</value>
-<value letter_id="M">10</value>
-<value letter_id="N">149</value>
-<value letter_id="P">141</value>
-<value letter_id="Q">71</value>
-<value letter_id="R">87</value>
-<value letter_id="S">396</value>
-<value letter_id="T">-239</value>
-<value letter_id="V">220</value>
-<value letter_id="W">-140</value>
-<value letter_id="Y">-36</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">-79</value>
-<value letter_id="C">41</value>
-<value letter_id="D">4</value>
-<value letter_id="E">21</value>
-<value letter_id="F">-7</value>
-<value letter_id="G">44</value>
-<value letter_id="H">-62</value>
-<value letter_id="I">42</value>
-<value letter_id="K">-5</value>
-<value letter_id="L">99</value>
-<value letter_id="M">0</value>
-<value letter_id="N">99</value>
-<value letter_id="P">138</value>
-<value letter_id="Q">52</value>
-<value letter_id="R">42</value>
-<value letter_id="S">399</value>
-<value letter_id="T">-46</value>
-<value letter_id="V">223</value>
-<value letter_id="W">-173</value>
-<value letter_id="Y">-68</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">11</value>
-<value letter_id="C">-677</value>
-<value letter_id="D">48</value>
-<value letter_id="E">47</value>
-<value letter_id="F">-2</value>
-<value letter_id="G">127</value>
-<value letter_id="H">-43</value>
-<value letter_id="I">46</value>
-<value letter_id="K">27</value>
-<value letter_id="L">101</value>
-<value letter_id="M">3</value>
-<value letter_id="N">124</value>
-<value letter_id="P">138</value>
-<value letter_id="Q">60</value>
-<value letter_id="R">62</value>
-<value letter_id="S">397</value>
-<value letter_id="T">-235</value>
-<value letter_id="V">220</value>
-<value letter_id="W">-160</value>
-<value letter_id="Y">-55</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">-596</value>
-<value letter_id="C">-820</value>
-<value letter_id="D">12</value>
-<value letter_id="E">-21</value>
-<value letter_id="F">-53</value>
-<value letter_id="G">-267</value>
-<value letter_id="H">-74</value>
-<value letter_id="I">37</value>
-<value letter_id="K">16</value>
-<value letter_id="L">44</value>
-<value letter_id="M">-37</value>
-<value letter_id="N">98</value>
-<value letter_id="P">31</value>
-<value letter_id="Q">9</value>
-<value letter_id="R">19</value>
-<value letter_id="S">319</value>
-<value letter_id="T">212</value>
-<value letter_id="V">127</value>
-<value letter_id="W">-193</value>
-<value letter_id="Y">-95</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">165</value>
-<value letter_id="C">-261</value>
-<value letter_id="D">70</value>
-<value letter_id="E">110</value>
-<value letter_id="F">77</value>
-<value letter_id="G">-521</value>
-<value letter_id="H">-4</value>
-<value letter_id="I">147</value>
-<value letter_id="K">95</value>
-<value letter_id="L">201</value>
-<value letter_id="M">90</value>
-<value letter_id="N">121</value>
-<value letter_id="P">124</value>
-<value letter_id="Q">91</value>
-<value letter_id="R">107</value>
-<value letter_id="S">425</value>
-<value letter_id="T">-527</value>
-<value letter_id="V">314</value>
-<value letter_id="W">-95</value>
-<value letter_id="Y">8</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">-838</value>
-<value letter_id="C">-990</value>
-<value letter_id="D">-89</value>
-<value letter_id="E">-149</value>
-<value letter_id="F">-151</value>
-<value letter_id="G">-841</value>
-<value letter_id="H">-161</value>
-<value letter_id="I">-117</value>
-<value letter_id="K">-113</value>
-<value letter_id="L">-66</value>
-<value letter_id="M">-209</value>
-<value letter_id="N">-68</value>
-<value letter_id="P">-69</value>
-<value letter_id="Q">-129</value>
-<value letter_id="R">-91</value>
-<value letter_id="S">111</value>
-<value letter_id="T">221</value>
-<value letter_id="V">-55</value>
-<value letter_id="W">-255</value>
-<value letter_id="Y">-173</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">176</value>
-<value letter_id="C">-858</value>
-<value letter_id="D">-79</value>
-<value letter_id="E">-103</value>
-<value letter_id="F">-115</value>
-<value letter_id="G">-717</value>
-<value letter_id="H">-148</value>
-<value letter_id="I">-95</value>
-<value letter_id="K">-108</value>
-<value letter_id="L">-17</value>
-<value letter_id="M">-162</value>
-<value letter_id="N">-61</value>
-<value letter_id="P">-12</value>
-<value letter_id="Q">-95</value>
-<value letter_id="R">-69</value>
-<value letter_id="S">193</value>
-<value letter_id="T">-737</value>
-<value letter_id="V">52</value>
-<value letter_id="W">-240</value>
-<value letter_id="Y">-153</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">134</value>
-<value letter_id="C">-686</value>
-<value letter_id="D">0</value>
-<value letter_id="E">16</value>
-<value letter_id="F">-12</value>
-<value letter_id="G">-553</value>
-<value letter_id="H">-68</value>
-<value letter_id="I">44</value>
-<value letter_id="K">-8</value>
-<value letter_id="L">96</value>
-<value letter_id="M">-9</value>
-<value letter_id="N">88</value>
-<value letter_id="P">124</value>
-<value letter_id="Q">41</value>
-<value letter_id="R">36</value>
-<value letter_id="S">384</value>
-<value letter_id="T">11</value>
-<value letter_id="V">216</value>
-<value letter_id="W">-177</value>
-<value letter_id="Y">-71</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">165</value>
-<value letter_id="C">-261</value>
-<value letter_id="D">70</value>
-<value letter_id="E">110</value>
-<value letter_id="F">77</value>
-<value letter_id="G">-521</value>
-<value letter_id="H">-4</value>
-<value letter_id="I">147</value>
-<value letter_id="K">95</value>
-<value letter_id="L">201</value>
-<value letter_id="M">90</value>
-<value letter_id="N">121</value>
-<value letter_id="P">124</value>
-<value letter_id="Q">91</value>
-<value letter_id="R">107</value>
-<value letter_id="S">425</value>
-<value letter_id="T">-527</value>
-<value letter_id="V">314</value>
-<value letter_id="W">-95</value>
-<value letter_id="Y">8</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">147</value>
-<value letter_id="C">-614</value>
-<value letter_id="D">89</value>
-<value letter_id="E">129</value>
-<value letter_id="F">93</value>
-<value letter_id="G">-121</value>
-<value letter_id="H">12</value>
-<value letter_id="I">160</value>
-<value letter_id="K">113</value>
-<value letter_id="L">217</value>
-<value letter_id="M">108</value>
-<value letter_id="N">144</value>
-<value letter_id="P">144</value>
-<value letter_id="Q">111</value>
-<value letter_id="R">125</value>
-<value letter_id="S">447</value>
-<value letter_id="T">-241</value>
-<value letter_id="V">332</value>
-<value letter_id="W">-81</value>
-<value letter_id="Y">22</value>
-</alphabet_array>
-</alphabet_matrix>
-</scores>
-<probabilities>
-<alphabet_matrix>
-<alphabet_array>
 <value letter_id="A">0.240000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.680000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.080000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.280000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.680000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.040000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.160000</value>
-<value letter_id="C">0.320000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.360000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.160000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.320000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.640000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.040000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.000000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.040000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.960000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.960000</value>
-<value letter_id="C">0.040000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.000000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.000000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">1.000000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">1.000000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.000000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.760000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.240000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.960000</value>
-<value letter_id="C">0.040000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.000000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.840000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="D">0.000000</value>
-<value letter_id="E">0.000000</value>
-<value letter_id="F">0.000000</value>
-<value letter_id="G">0.120000</value>
-<value letter_id="H">0.000000</value>
-<value letter_id="I">0.000000</value>
-<value letter_id="K">0.000000</value>
-<value letter_id="L">0.000000</value>
-<value letter_id="M">0.000000</value>
-<value letter_id="N">0.000000</value>
-<value letter_id="P">0.000000</value>
-<value letter_id="Q">0.000000</value>
-<value letter_id="R">0.000000</value>
-<value letter_id="S">0.000000</value>
-<value letter_id="T">0.040000</value>
-<value letter_id="V">0.000000</value>
-<value letter_id="W">0.000000</value>
-<value letter_id="Y">0.000000</value>
-</alphabet_array>
 </alphabet_matrix>
 </probabilities>
 <regular_expression>
@@ -809,484 +102,17 @@
 <left_flank>AAGGCCAGGA</left_flank>
 <site>
 <letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
 </site>
 <right_flank>GCCTGAGAGC</right_flank>
 </contributing_site>
 <contributing_site sequence_id="sequence_25" position="36" strand="none" pvalue="3.41e-06" >
 <left_flank>ACAGGCCCTG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
 <right_flank>GCC</right_flank>
 </contributing_site>
 <contributing_site sequence_id="sequence_19" position="9" strand="none" pvalue="3.41e-06" >
 <left_flank>CAGGCCCTG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
 <right_flank>GCCCCAGCAG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_9" position="13" strand="none" pvalue="3.41e-06" >
-<left_flank>GATTCACTGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GGCCCTCTGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_21" position="7" strand="none" pvalue="4.00e-06" >
-<left_flank>CCAAGGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCCCCACAAA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_13" position="13" strand="none" pvalue="5.01e-06" >
-<left_flank>CCACCAGCTT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>AGCCCTGTAC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_23" position="15" strand="none" pvalue="6.06e-06" >
-<left_flank>ATACCCAGGG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>CCTCAGCAGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_15" position="21" strand="none" pvalue="8.67e-06" >
-<left_flank>AATCACTGAG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GTCCCAGGGA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_12" position="18" strand="none" pvalue="8.67e-06" >
-<left_flank>CACCAGAGCT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>AGAAGGTTCT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_11" position="16" strand="none" pvalue="8.67e-06" >
-<left_flank>CACTATTGAA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TTTCATTTGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_22" position="2" strand="none" pvalue="1.21e-05" >
-<left_flank>GA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCCAACATCC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_28" position="32" strand="none" pvalue="1.59e-05" >
-<left_flank>CCGGCGGGGC</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GGGGCGG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_20" position="4" strand="none" pvalue="1.59e-05" >
-<left_flank>CAGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GTTCCGACCA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_6" position="15" strand="none" pvalue="1.68e-05" >
-<left_flank>CCCACTACTT</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TCATTCTGAG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_14" position="19" strand="none" pvalue="2.03e-05" >
-<left_flank>CACCAGCAAG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCTCAGGAGT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_4" position="12" strand="none" pvalue="3.06e-05" >
-<left_flank>CAGGTCTAAG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>CTTGGAGTCC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_0" position="39" strand="none" pvalue="3.06e-05" >
-<left_flank>CCTCGGGACG</left_flank>
-<site>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank></right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_18" position="37" strand="none" pvalue="3.82e-05" >
-<left_flank>CGTGGTCGCG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_5" position="0" strand="none" pvalue="3.82e-05" >
-<left_flank></left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>ATGGTCCTGT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_29" position="30" strand="none" pvalue="4.02e-05" >
-<left_flank>GCTGCCGGTG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GCCCTGGCG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_1" position="27" strand="none" pvalue="5.52e-05" >
-<left_flank>AGTCACAAGT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GGGTCGCACG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_3" position="14" strand="none" pvalue="5.94e-05" >
-<left_flank>CCCAGGTTTC</left_flank>
-<site>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TCGCCGCACC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_16" position="22" strand="none" pvalue="6.78e-05" >
-<left_flank>AGTTTCAGTT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>attatataac</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_7" position="2" strand="none" pvalue="2.08e-04" >
-<left_flank>TC</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-</site>
-<right_flank>AAATGTTCCT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_8" position="13" strand="none" pvalue="4.05e-04" >
-<left_flank>TATAACTCAG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TAATTTGTAC</right_flank>
-</contributing_site>
-</contributing_sites>
-</motif>
-</motifs>
-<scanned_sites_summary p_thresh="0.0001">
-<scanned_sites sequence_id="sequence_0" pvalue="1.22e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="39" pvalue="3.06e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_1" pvalue="2.21e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="27" pvalue="5.52e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_2" pvalue="7.29e-01" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_3" pvalue="2.37e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="14" pvalue="5.94e-05"/>
-</scanned_sites>
 <scanned_sites sequence_id="sequence_4" pvalue="1.22e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="12" pvalue="3.06e-05"/>
-</scanned_sites>
 <scanned_sites sequence_id="sequence_5" pvalue="1.53e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="0" pvalue="3.82e-05"/>
-</scanned_sites>
 <scanned_sites sequence_id="sequence_6" pvalue="6.70e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="15" pvalue="1.68e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_7" pvalue="1.81e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="4" pvalue="4.54e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_8" pvalue="1.61e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_9" pvalue="1.36e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="13" pvalue="3.41e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_10" pvalue="1.99e-01" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_11" pvalue="3.47e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="16" pvalue="8.67e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_12" pvalue="3.47e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="18" pvalue="8.67e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_13" pvalue="2.01e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="13" pvalue="5.01e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_14" pvalue="8.11e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="19" pvalue="2.03e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_15" pvalue="3.47e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="21" pvalue="8.67e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_16" pvalue="2.71e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="22" pvalue="6.78e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_17" pvalue="8.23e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_18" pvalue="1.53e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="37" pvalue="3.82e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_19" pvalue="1.36e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="9" pvalue="3.41e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_20" pvalue="6.37e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="4" pvalue="1.59e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_21" pvalue="1.60e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="7" pvalue="4.00e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_22" pvalue="4.83e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="2" pvalue="1.21e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_23" pvalue="2.43e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="15" pvalue="6.06e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_24" pvalue="4.26e-05" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="12" pvalue="1.06e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_25" pvalue="1.36e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="36" pvalue="3.41e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_26" pvalue="4.30e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_27" pvalue="4.30e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_28" pvalue="6.37e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="32" pvalue="1.59e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_29" pvalue="1.61e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="none" position="30" pvalue="4.02e-05"/>
-</scanned_sites>
-</scanned_sites_summary>
 </MEME>
--- a/test-data/meme_output_test2.html	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test2.html	Wed Dec 11 18:05:15 2019 -0500
@@ -7,7931 +7,21 @@
       // @JSON_VAR data
       var data = {
         "program": "MEME",
-        "version": "4.12.0",
-        "release": "Tue Jun 27 16:22:50 2017 -0700",
+        "version": "5.0.5",
+        "release": "Mon Mar 18 20:12:19 2019 -0700",
         "stop_reason": "Stopped because requested number of motifs (1) found.",
         "cmd": [
-          "meme", "meme_input_1.fasta", "-o", "meme_test2_out", "-nostatus",
-          "-maxsize", "1000000", "-sf", "Galaxy_FASTA_Input", "-dna", "-mod",
-          "zoops", "-nmotifs", "1", "-wnsites", "0.8", "-minw", "8", "-maxw",
-          "50", "-wg", "11", "-ws", "1", "-maxiter", "50", "-distance",
-          "0.001", "-prior", "dirichlet", "-b", "0.01", "-plib",
-          "prior30.plib", "-spmap", "uni", "-spfuzz", "0.5"
+          "meme",
+          "-o",
+          "-nostatus", "-maxsize", "1000000", "-sf", "Galaxy_FASTA_Input",
+          "-dna", "-mod", "zoops", "-nmotifs", "1", "-wnsites", "0.8",
+          "-minw", "8", "-maxw", "50", "-wg", "11", "-ws", "1", "-maxiter",
+          "50", "-distance", "0.001", "-prior", "dirichlet", "-b", "0.01",
+          "-plib",
+          "-spmap", "uni", "-spfuzz", "0.5"
         ],
-        "options": {
-          "mod": "zoops",
-          "revcomp": false,
-          "nmotifs": 1,
-          "minw": 8,
-          "maxw": 50,
-          "minsites": 2,
-          "maxsites": 30,
-          "wnsites": 0.8,
-          "spmap": "uni",
-          "spfuzz": 0.5,
-          "maxwords": -1,
-          "prior": "dirichlet",
-          "b": 0.01,
-          "maxiter": 50,
-          "distance": 0.001,
-          "wg": 11,
-          "ws": 1,
-          "noendgaps": false,
-          "substring": true
-        },
-        "alphabet": {
-          "name": "DNA",
-          "like": "dna",
-          "ncore": 4,
-          "symbols": [
-            {
-              "symbol": "A",
-              "name": "Adenine",
-              "colour": "CC0000",
-              "complement": "T"
-            }, {
-              "symbol": "C",
-              "name": "Cytosine",
-              "colour": "0000CC",
-              "complement": "G"
-            }, {
-              "symbol": "G",
-              "name": "Guanine",
-              "colour": "FFB300",
-              "complement": "C"
-            }, {
-              "symbol": "T",
-              "aliases": "U",
-              "name": "Thymine",
-              "colour": "008000",
-              "complement": "A"
-            }, {
-              "symbol": "N",
-              "aliases": "X.",
-              "name": "Any base",
-              "equals": "ACGT"
-            }, {
-              "symbol": "V",
-              "name": "Not T",
-              "equals": "ACG"
-            }, {
-              "symbol": "H",
-              "name": "Not G",
-              "equals": "ACT"
-            }, {
-              "symbol": "D",
-              "name": "Not C",
-              "equals": "AGT"
-            }, {
-              "symbol": "B",
-              "name": "Not A",
-              "equals": "CGT"
-            }, {
-              "symbol": "M",
-              "name": "Amino",
-              "equals": "AC"
-            }, {
-              "symbol": "R",
-              "name": "Purine",
-              "equals": "AG"
-            }, {
-              "symbol": "W",
-              "name": "Weak",
-              "equals": "AT"
-            }, {
-              "symbol": "S",
-              "name": "Strong",
-              "equals": "CG"
-            }, {
-              "symbol": "Y",
-              "name": "Pyrimidine",
-              "equals": "CT"
-            }, {
-              "symbol": "K",
-              "name": "Keto",
-              "equals": "GT"
-            }
-          ]
-        },
-        "background": {
-          "freqs": [0.294, 0.231, 0.257, 0.217]
-        },
-        "sequence_db": {
-          "source": "Galaxy_FASTA_Input",
-          "psp_source": "prior30.plib",
-          "freqs": [0.294, 0.231, 0.257, 0.217],
-          "sequences": [
-            {
-              "name": "chr21_19617074_19617124_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_26934381_26934431_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_28217753_28217803_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31710037_31710087_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31744582_31744632_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31768316_31768366_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31914206_31914256_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31933633_31933683_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31962741_31962791_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31964683_31964733_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31973364_31973414_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_31992870_31992920_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32185595_32185645_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32202076_32202126_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32253899_32253949_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_32410820_32410870_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_36411748_36411798_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_37838750_37838800_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45705687_45705737_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45971413_45971463_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45978668_45978718_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_45993530_45993580_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46020421_46020471_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46031920_46031970_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46046964_46047014_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46057197_46057247_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46086869_46086919_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_46102103_46102153_-",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_47517957_47518007_+",
-              "length": 50,
-              "weight": 1.000000
-            }, {
-              "name": "chr21_47575506_47575556_-",
-              "length": 50,
-              "weight": 1.000000
-            }
-          ]
-        },
         "motifs": [
-          {
-            "db": 0,
-            "id": "GGSRTATAAAA",
-            "alt": "MEME-1",
-            "len": 11,
-            "nsites": 30,
-            "evalue": "5.1e-040",
-            "ic": 13.0,
-            "re": 12.2,
-            "llr": 254,
-            "bt": 5.2854,
-            "time": 0.376000,
-            "psm": [
-              [-14, -179, 114, -112], [3, -1155, 137, -270], 
-              [-114, 20, 86, -71], [3, -279, 122, -170], 
-              [-1155, -1155, -295, 215], [156, -179, -1155, -170], 
-              [-1155, -1155, -1155, 220], [172, -279, -1155, -1155], 
-              [125, -1155, -1155, 46], [167, -179, -1155, -1155], 
-              [144, -1155, -63, -270]
-            ],
-            "pwm": [
-              [0.266667, 0.066667, 0.566667, 0.100000], 
-              [0.300000, 0.000000, 0.666667, 0.033333], 
-              [0.133333, 0.266667, 0.466667, 0.133333], 
-              [0.300000, 0.033333, 0.600000, 0.066667], 
-              [0.000000, 0.000000, 0.033333, 0.966667], 
-              [0.866667, 0.066667, 0.000000, 0.066667], 
-              [0.000000, 0.000000, 0.000000, 1.000000], 
-              [0.966667, 0.033333, 0.000000, 0.000000], 
-              [0.700000, 0.000000, 0.000000, 0.300000], 
-              [0.933333, 0.066667, 0.000000, 0.000000], 
-              [0.800000, 0.000000, 0.166667, 0.033333]
-            ],
-            "sites": [
-              {
-                "seq": 24,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 4.51e-07,
-                "lflank": "AAGGCCAGGA",
-                "match": "GGGGTATAAAA",
-                "rflank": "GCCTGAGAGC"
-              }, {
-                "seq": 23,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 2.22e-06,
-                "lflank": "ATACCCAGGG",
-                "match": "AGGGTATAAAA",
-                "rflank": "CCTCAGCAGC"
-              }, {
-                "seq": 13,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 2.74e-06,
-                "lflank": "CCACCAGCTT",
-                "match": "GAGGTATAAAA",
-                "rflank": "AGCCCTGTAC"
-              }, {
-                "seq": 25,
-                "pos": 36,
-                "rc": false,
-                "pvalue": 4.86e-06,
-                "lflank": "ACAGGCCCTG",
-                "match": "GGCATATAAAA",
-                "rflank": "GCC"
-              }, {
-                "seq": 21,
-                "pos": 7,
-                "rc": false,
-                "pvalue": 4.86e-06,
-                "lflank": "CCAAGGA",
-                "match": "GGAGTATAAAA",
-                "rflank": "GCCCCACAAA"
-              }, {
-                "seq": 19,
-                "pos": 9,
-                "rc": false,
-                "pvalue": 4.86e-06,
-                "lflank": "CAGGCCCTG",
-                "match": "GGCATATAAAA",
-                "rflank": "GCCCCAGCAG"
-              }, {
-                "seq": 9,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 4.86e-06,
-                "lflank": "GATTCACTGA",
-                "match": "GGCATATAAAA",
-                "rflank": "GGCCCTCTGC"
-              }, {
-                "seq": 28,
-                "pos": 32,
-                "rc": false,
-                "pvalue": 6.48e-06,
-                "lflank": "CCGGCGGGGC",
-                "match": "GGGGTATAAAG",
-                "rflank": "GGGGCGG"
-              }, {
-                "seq": 20,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 6.48e-06,
-                "lflank": "CAGA",
-                "match": "GGGGTATAAAG",
-                "rflank": "GTTCCGACCA"
-              }, {
-                "seq": 12,
-                "pos": 18,
-                "rc": false,
-                "pvalue": 6.48e-06,
-                "lflank": "CACCAGAGCT",
-                "match": "GGGATATATAA",
-                "rflank": "AGAAGGTTCT"
-              }, {
-                "seq": 15,
-                "pos": 21,
-                "rc": false,
-                "pvalue": 1.38e-05,
-                "lflank": "AATCACTGAG",
-                "match": "GATGTATAAAA",
-                "rflank": "GTCCCAGGGA"
-              }, {
-                "seq": 11,
-                "pos": 16,
-                "rc": false,
-                "pvalue": 1.38e-05,
-                "lflank": "CACTATTGAA",
-                "match": "GATGTATAAAA",
-                "rflank": "TTTCATTTGC"
-              }, {
-                "seq": 0,
-                "pos": 39,
-                "rc": false,
-                "pvalue": 1.41e-05,
-                "lflank": "CCTCGGGACG",
-                "match": "TGGGTATATAA",
-                "rflank": ""
-              }, {
-                "seq": 6,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 1.61e-05,
-                "lflank": "CCCACTACTT",
-                "match": "AGAGTATAAAA",
-                "rflank": "TCATTCTGAG"
-              }, {
-                "seq": 22,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 1.95e-05,
-                "lflank": "GA",
-                "match": "GACATATAAAA",
-                "rflank": "GCCAACATCC"
-              }, {
-                "seq": 14,
-                "pos": 17,
-                "rc": false,
-                "pvalue": 1.95e-05,
-                "lflank": "CCCACCAGCA",
-                "match": "AGGATATATAA",
-                "rflank": "AAGCTCAGGA"
-              }, {
-                "seq": 18,
-                "pos": 37,
-                "rc": false,
-                "pvalue": 2.16e-05,
-                "lflank": "CGTGGTCGCG",
-                "match": "GGGGTATAACA",
-                "rflank": "GC"
-              }, {
-                "seq": 29,
-                "pos": 30,
-                "rc": false,
-                "pvalue": 3.04e-05,
-                "lflank": "GCTGCCGGTG",
-                "match": "AGCGTATAAAG",
-                "rflank": "GCCCTGGCG"
-              }, {
-                "seq": 4,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 3.04e-05,
-                "lflank": "CAGGTCTAAG",
-                "match": "AGCATATATAA",
-                "rflank": "CTTGGAGTCC"
-              }, {
-                "seq": 5,
-                "pos": 0,
-                "rc": false,
-                "pvalue": 3.67e-05,
-                "lflank": "",
-                "match": "AACGTATATAA",
-                "rflank": "ATGGTCCTGT"
-              }, {
-                "seq": 1,
-                "pos": 27,
-                "rc": false,
-                "pvalue": 3.93e-05,
-                "lflank": "AGTCACAAGT",
-                "match": "GAGTTATAAAA",
-                "rflank": "GGGTCGCACG"
-              }, {
-                "seq": 7,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 5.65e-05,
-                "lflank": "TCAG",
-                "match": "AGTATATATAA",
-                "rflank": "ATGTTCCTGT"
-              }, {
-                "seq": 3,
-                "pos": 14,
-                "rc": false,
-                "pvalue": 6.24e-05,
-                "lflank": "CCCAGGTTTC",
-                "match": "TGAGTATATAA",
-                "rflank": "TCGCCGCACC"
-              }, {
-                "seq": 16,
-                "pos": 22,
-                "rc": false,
-                "pvalue": 7.15e-05,
-                "lflank": "AGTTTCAGTT",
-                "match": "GGCATCTAAAA",
-                "rflank": "attatataac"
-              }, {
-                "seq": 27,
-                "pos": 36,
-                "rc": false,
-                "pvalue": 1.39e-04,
-                "lflank": "TGCCTGGGTC",
-                "match": "CAGGTATAAAG",
-                "rflank": "GCT"
-              }, {
-                "seq": 26,
-                "pos": 37,
-                "rc": false,
-                "pvalue": 1.39e-04,
-                "lflank": "TGCCTGGGCC",
-                "match": "CAGGTATAAAG",
-                "rflank": "GC"
-              }, {
-                "seq": 17,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 4.81e-04,
-                "lflank": "ga",
-                "match": "TGGTTTTATAA",
-                "rflank": "ggggcctcac"
-              }, {
-                "seq": 8,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 8.57e-04,
-                "lflank": "TATAACTCAG",
-                "match": "GTTGGATAAAA",
-                "rflank": "TAATTTGTAC"
-              }, {
-                "seq": 10,
-                "pos": 7,
-                "rc": false,
-                "pvalue": 1.47e-03,
-                "lflank": "aaactta",
-                "match": "AAACTCTATAA",
-                "rflank": "acttaaaact"
-              }, {
-                "seq": 2,
-                "pos": 26,
-                "rc": false,
-                "pvalue": 2.64e-03,
-                "lflank": "GGTGGGGGTG",
-                "match": "GGGGTTTCACT",
-                "rflank": "GGTCCACTAT"
-              }
-            ]
-          }
-        ],
-        "scan": [
-          {
-            "pvalue": 5.63e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 39,
-                "rc": false,
-                "pvalue": 1.41e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.57e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 27,
-                "rc": false,
-                "pvalue": 3.93e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.00e-01,
-            "sites": []
-          }, {
-            "pvalue": 2.49e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 14,
-                "rc": false,
-                "pvalue": 6.24e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.22e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 3.04e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.47e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 0,
-                "rc": false,
-                "pvalue": 3.67e-05
-              }
-            ]
-          }, {
-            "pvalue": 6.45e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 1.61e-05
-              }
-            ]
-          }, {
-            "pvalue": 2.26e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 5.65e-05
-              }
-            ]
-          }, {
-            "pvalue": 3.37e-02,
-            "sites": []
-          }, {
-            "pvalue": 1.95e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 4.86e-06
-              }
-            ]
-          }, {
-            "pvalue": 5.73e-02,
-            "sites": []
-          }, {
-            "pvalue": 5.52e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 16,
-                "rc": false,
-                "pvalue": 1.38e-05
-              }
-            ]
-          }, {
-            "pvalue": 2.59e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 18,
-                "rc": false,
-                "pvalue": 6.48e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.10e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 13,
-                "rc": false,
-                "pvalue": 2.74e-06
-              }
-            ]
-          }, {
-            "pvalue": 7.78e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 17,
-                "rc": false,
-                "pvalue": 1.95e-05
-              }
-            ]
-          }, {
-            "pvalue": 5.52e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 21,
-                "rc": false,
-                "pvalue": 1.38e-05
-              }
-            ]
-          }, {
-            "pvalue": 2.85e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 22,
-                "rc": false,
-                "pvalue": 7.15e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.90e-02,
-            "sites": []
-          }, {
-            "pvalue": 8.63e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 37,
-                "rc": false,
-                "pvalue": 2.16e-05
-              }
-            ]
-          }, {
-            "pvalue": 1.95e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 9,
-                "rc": false,
-                "pvalue": 4.86e-06
-              }
-            ]
-          }, {
-            "pvalue": 2.59e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 4,
-                "rc": false,
-                "pvalue": 6.48e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.95e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 7,
-                "rc": false,
-                "pvalue": 4.86e-06
-              }
-            ]
-          }, {
-            "pvalue": 7.78e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 2,
-                "rc": false,
-                "pvalue": 1.95e-05
-              }
-            ]
-          }, {
-            "pvalue": 8.89e-05,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 15,
-                "rc": false,
-                "pvalue": 2.22e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.80e-05,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 12,
-                "rc": false,
-                "pvalue": 4.51e-07
-              }
-            ]
-          }, {
-            "pvalue": 1.95e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 36,
-                "rc": false,
-                "pvalue": 4.86e-06
-              }
-            ]
-          }, {
-            "pvalue": 5.54e-03,
-            "sites": []
-          }, {
-            "pvalue": 5.54e-03,
-            "sites": []
-          }, {
-            "pvalue": 2.59e-04,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 32,
-                "rc": false,
-                "pvalue": 6.48e-06
-              }
-            ]
-          }, {
-            "pvalue": 1.22e-03,
-            "sites": [
-              {
-                "motif": 0,
-                "pos": 30,
-                "rc": false,
-                "pvalue": 3.04e-05
-              }
-            ]
-          }
         ]
       };
     </script>
-    <script>
 var site_url = "http://meme-suite.org";
-</script>
-    <script>
-
-/*
- * $
- *
- * Shorthand function for getElementById
- */
-function $(el) {
-  return document.getElementById(el);
-}
-
-
-/*
- * See http://stackoverflow.com/a/5450113/66387
- * Does string multiplication like the perl x operator.
- */
-function string_mult(pattern, count) {
-    if (count < 1) return '';
-    var result = '';
-    while (count > 1) {
-        if (count & 1) result += pattern;
-        count >>= 1, pattern += pattern;
-    }
-    return result + pattern;
-}
-
-/*
- * See http://stackoverflow.com/questions/814613/how-to-read-get-data-from-a-url-using-javascript
- * Slightly modified with information from
- * https://developer.mozilla.org/en/DOM/window.location
- */
-function parse_params() {
-  "use strict";
-  var search, queryStart, queryEnd, query, params, nvPairs, i, nv, n, v;
-  search = window.location.search;
-  queryStart = search.indexOf("?") + 1;
-  queryEnd   = search.indexOf("#") + 1 || search.length + 1;
-  query      = search.slice(queryStart, queryEnd - 1);
-
-  if (query === search || query === "") return {};
-
-  params  = {};
-  nvPairs = query.replace(/\+/g, " ").split("&");
-
-  for (i = 0; i < nvPairs.length; i++) {
-    nv = nvPairs[i].split("=");
-    n  = decodeURIComponent(nv[0]);
-    v  = decodeURIComponent(nv[1]);
-    // allow a name to be used multiple times
-    // storing each value in the array
-    if (!(n in params)) {
-      params[n] = [];
-    }
-    params[n].push(nv.length === 2 ? v : null);
-  }
-  return params;
-}
-
-/*
- * coords
- *
- * Calculates the x and y offset of an element.
- * From http://www.quirksmode.org/js/findpos.html
- * with alterations to take into account scrolling regions
- */
-function coords(elem) {
-  var myX = myY = 0;
-  if (elem.getBoundingClientRect) {
-    var rect;
-    rect = elem.getBoundingClientRect();
-    myX = rect.left + ((typeof window.pageXOffset !== "undefined") ?
-        window.pageXOffset : document.body.scrollLeft);
-    myY = rect.top + ((typeof window.pageYOffset !== "undefined") ?
-        window.pageYOffset : document.body.scrollTop);
-  } else {
-    // this fall back doesn't properly handle absolutely positioned elements
-    // inside a scrollable box
-    var node;
-    if (elem.offsetParent) {
-      // subtract all scrolling
-      node = elem;
-      do {
-        myX -= node.scrollLeft ? node.scrollLeft : 0;
-        myY -= node.scrollTop ? node.scrollTop : 0;
-      } while (node = node.parentNode);
-      // this will include the page scrolling (which is unwanted) so add it back on
-      myX += (typeof window.pageXOffset !== "undefined") ? window.pageXOffset : document.body.scrollLeft;
-      myY += (typeof window.pageYOffset !== "undefined") ? window.pageYOffset : document.body.scrollTop;
-      // sum up offsets
-      node = elem;
-      do {
-        myX += node.offsetLeft;
-        myY += node.offsetTop;
-      } while (node = node.offsetParent);
-    }
-  }
-  return [myX, myY];
-}
-
-/*
- * position_popup
- *
- * Positions a popup relative to an anchor element.
- *
- * The avaliable positions are:
- * 0 - Centered below the anchor.
- */
-function position_popup(anchor, popup, position) {
-  "use strict";
-  var a_x, a_y, a_w, a_h, p_x, p_y, p_w, p_h;
-  var a_xy, spacer, margin, scrollbar, page_w;
-  // define constants
-  spacer = 5;
-  margin = 15;
-  scrollbar = 15;
-  // define the positions and widths
-  a_xy = coords(anchor);
-  a_x = a_xy[0];
-  a_y = a_xy[1];
-  a_w = anchor.offsetWidth;
-  a_h = anchor.offsetHeight;
-  p_w = popup.offsetWidth;
-  p_h = popup.offsetHeight;
-  page_w = null;
-  if (window.innerWidth) {
-    page_w = window.innerWidth;
-  } else if (document.body) {
-    page_w = document.body.clientWidth;
-  }
-  // check the position type is defined
-  if (typeof position !== "number") {
-    position = 0;
-  }
-  // calculate the popup position
-  switch (position) {
-    case 1:
-      p_x = a_x + a_w + spacer;
-      p_y = a_y + (a_h / 2) - (p_h / 2);
-      break;
-    case 0:
-    default:
-      p_x = a_x + (a_w / 2) - (p_w / 2);
-      p_y = a_y + a_h + spacer;
-      break;
-  }
-  // constrain the popup position
-  if (p_x < margin) {
-    p_x = margin;
-  } else if (page_w != null && (p_x + p_w) > (page_w - margin - scrollbar)) {
-    p_x = page_w - margin - scrollbar - p_w;
-  }
-  if (p_y < margin) {
-    p_y = margin;
-  }
-  // position the popup
-  popup.style.left = p_x + "px";
-  popup.style.top = p_y + "px";
-}
-
-function lookup_help_popup(popup_id) {
-  var _body, pop, info;
-  pop = document.getElementById(popup_id);
-  if (pop == null) {
-    _body = document.getElementsByTagName("body")[0];
-    pop = document.createElement("div");
-    pop.className = "pop_content";
-    pop.id = popup_id;
-    pop.style.backgroundColor = "#FFC";
-    pop.style.borderColor = "black";
-    info = document.createElement("p");
-    info.style.fontWeight = "bold";
-    info.appendChild(document.createTextNode("Error: No popup for topic \"" + popup_id + "\"."));
-    pop.appendChild(info);
-    // this might cause problems with the menu, but as this only happens
-    // when something is already wrong I don't think that's too much of a problem
-    _body.insertBefore(pop, _body.firstChild);
-  }
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-autobtns")) {
-    if (!/\bauto_buttons\b/.test(pop.className)) {
-      pop.className += " auto_buttons";
-      var back_btn_sec = document.createElement("div");
-      back_btn_sec.className = "nested_only pop_back_sec";
-      var back_btn = document.createElement("span");
-      back_btn.className = "pop_back";
-      back_btn.appendChild(document.createTextNode("<< back"));
-      back_btn.addEventListener("click", function(e) {
-        help_return();
-      }, false);
-      back_btn_sec.appendChild(back_btn);
-      pop.insertBefore(back_btn_sec, pop.firstChild);
-      var close_btn_sec = document.createElement("div");
-      close_btn_sec.className = "pop_close_sec";
-      var close_btn = document.createElement("span");
-      close_btn.className = "pop_close";
-      close_btn.appendChild(document.createTextNode("close"));
-      close_btn.addEventListener("click", function(e) {
-        help_popup();
-      }, false);
-      close_btn_sec.appendChild(close_btn);
-      pop.appendChild(close_btn_sec);
-    }
-  }
-  return pop;
-}
-
-/*
- * help_popup
- *
- * Moves around help pop-ups so they appear
- * below an activator.
- */
-function help_popup(activator, popup_id) {
-  "use strict";
-  var pop;
-  // set default values
-  if (typeof help_popup.popup === "undefined") {
-    help_popup.popup = [];
-  }
-  if (typeof help_popup.activator === "undefined") {
-    help_popup.activator = null;
-  }
-  var last_pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (typeof(activator) == "undefined") { // no activator so hide
-    if (last_pop != null) {
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-    }
-    return;
-  }
-  pop = lookup_help_popup(popup_id);
-  if (pop == last_pop) {
-    if (activator == help_popup.activator) {
-      //hide popup (as we've already shown it for the current help button)
-      last_pop.style.display = 'none';
-      help_popup.popup = [];
-      return; // toggling complete!
-    }
-  } else if (last_pop != null) {
-    //activating different popup so hide current one
-    last_pop.style.display = 'none';
-  }
-  help_popup.popup = [pop];
-  help_popup.activator = activator;
-  toggle_class(pop, "nested", false);
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = 'block';
-  position_popup(activator, pop);
-}
-
-/*
- * help_refine
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_refine(popup_id) {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not refine a help popup when one is not shown!");
-  }
-  var pop = lookup_help_popup(popup_id);
-  var last_pop = help_popup.popup[help_popup.popup.length - 1];
-  if (pop == last_pop) return; // slightly odd, but no real cause for alarm
-  help_popup.popup.push(pop);
-  toggle_class(pop, "nested", true);
-  last_pop.style.display = "none";
-  //must make the popup visible to measure it or it has zero width
-  pop.style.display = "block";
-  position_popup(help_popup.activator, pop);
-}
-
-/*
- * help_return
- * 
- * Intended for links within a help popup. Stores a stack of state so
- * you can go back.
- */
-function help_return() {
-  if (help_popup.popup == null || help_popup.popup.length == 0 || help_popup.activator == null) {
-    throw new Error("Can not return to a earlier help popup when one is not shown!");
-  }
-  var last_pop = help_popup.popup.pop();
-  last_pop.style.display = "none";
-  var pop = (help_popup.popup.length > 0 ? help_popup.popup[help_popup.popup.length - 1] : null);
-  if (pop != null) {
-    toggle_class(pop, "nested", help_popup.popup.length > 1);
-    pop.style.display = "block";
-    position_popup(help_popup.activator, pop);
-  } else {
-    help_popup.activator = null;
-  }
-}
-
-/*
- * update_scroll_pad
- *
- * Creates padding at the bottom of the page to allow
- * scrolling of anything into view.
- */
-function update_scroll_pad() {
-  var page, pad;
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  pad = $("scrollpad");
-  if (pad === null) {
-    pad = document.createElement("div");
-    pad.id = 'scrollpad';
-    document.getElementsByTagName('body')[0].appendChild(pad);
-  }
-  pad.style.height = Math.abs(page.clientHeight - 100) + "px";
-}
-
-function substitute_classes(node, remove, add) {
-  "use strict";
-  var list, all, i, cls, classes;
-  list = node.className.split(/\s+/);
-  all = {};
-  for (i = 0; i < list.length; i++) {
-    if (list[i].length > 0) all[list[i]] = true;
-  }
-  for (i = 0; i < remove.length; i++) {
-    if (all.hasOwnProperty(remove[i])) {
-      delete all[remove[i]];
-    }
-  }
-  for (i = 0; i < add.length; i++) {
-    all[add[i]] = true;
-  }
-  classes = "";
-  for (cls in all) {
-    classes += cls + " ";
-  }
-  node.className = classes;
-}
-
-/*
- * toggle_class
- *
- * Adds or removes a class from the node. If the parameter 'enabled' is not 
- * passed then the existence of the class will be toggled, otherwise it will be
- * included if enabled is true.
- */
-function toggle_class(node, cls, enabled) {
-  var classes = node.className;
-  var list = classes.replace(/^\s+/, '').replace(/\s+$/, '').split(/\s+/);
-  var found = false;
-  for (var i = 0; i < list.length; i++) {
-    if (list[i] == cls) {
-      list.splice(i, 1);
-      i--;
-      found = true;
-    }
-  }
-  if (typeof enabled == "undefined") {
-    if (!found) list.push(cls);
-  } else {
-    if (enabled) list.push(cls);
-  }
-  node.className = list.join(" ");
-}
-
-/*
- * find_child
- *
- * Searches child nodes in depth first order and returns the first it finds
- * with the className specified.
- * TODO replace with querySelector
- */
-function find_child(node, className) {
-  var pattern;
-  if (node == null || typeof node !== "object") {
-    return null;
-  }
-  if (typeof className === "string") {
-    pattern = new RegExp("\\b" + className + "\\b");
-  } else {
-    pattern = className;
-  }
-  if (node.nodeType == Node.ELEMENT_NODE && 
-      pattern.test(node.className)) {
-    return node;
-  } else {
-    var result = null;
-    for (var i = 0; i < node.childNodes.length; i++) {
-      result = find_child(node.childNodes[i], pattern);
-      if (result != null) break;
-    }
-    return result;
-  }
-}
-
-/*
- * find_parent
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the className specified.
- */
-function find_parent(node, className) {
-  var pattern;
-  pattern = new RegExp("\\b" + className + "\\b");
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && 
-        pattern.test(node.className)) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * find_parent_tag
- *
- * Searches parent nodes outwards from the node and returns the first it finds
- * with the tag name specified. HTML tags should be specified in upper case.
- */
-function find_parent_tag(node, tag_name) {
-  do {
-    if (node.nodeType == Node.ELEMENT_NODE && node.tagName == tag_name) {
-      return node;
-    }
-  } while (node = node.parentNode);
-  return null;
-}
-
-/*
- * __toggle_help
- *
- * Uses the 'topic' property of the this object to
- * toggle display of a help topic.
- *
- * This function is not intended to be called directly.
- */
-function __toggle_help(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-
-  help_popup(this, this.getAttribute("data-topic"));
-}
-
-function setup_help_button(button) {
-  "use strict";
-  var topic;
-  if (button.hasAttribute("data-topic")) {
-    topic = button.getAttribute("data-topic");
-    if (document.getElementById(topic) != null) {
-      button.tabIndex = "0"; // make keyboard selectable
-      button.addEventListener("click", function() {
-        help_popup(button, topic);
-      }, false);
-      button.addEventListener("keydown", function(e) {
-        // toggle only on Enter or Spacebar, let other keys do their thing
-        if (e.keyCode !== 13 && e.keyCode !== 32) return;
-        // stop a submit or something like that
-        e.preventDefault();
-        help_popup(button, topic);
-      }, false);
-    } else {
-      button.style.visibility = "hidden";
-    }
-  }
-  button.className += " active";
-}
-
-/*
- * help_button
- *
- * Makes a help button for the passed topic.
- */
-function help_button(topic) {
-  var btn = document.createElement("div");
-  btn.className = "help";
-  btn.setAttribute("data-topic", topic);
-  setup_help_button(btn);
-  return btn;
-}
-
-/*
- * prepare_download
- *
- * Sets the attributes of a link to setup a file download using the given content.
- * If no link is provided then create one and click it.
- */
-function prepare_download(content, mimetype, filename, link) {
-  "use strict";
-  // if no link is provided then create one and click it
-  var click_link = false;
-  if (!link) {
-    link = document.createElement("a");
-    click_link = true;
-  }
-  try {
-    // Use a BLOB to convert the text into a data URL.
-    // We could do this manually with a base 64 conversion.
-    // This will only be supported on modern browsers,
-    // hence the try block.
-    var blob = new Blob([content], {type: mimetype});
-    var reader = new FileReader();
-    reader.onloadend = function() {
-      // If we're lucky the browser will also support the download
-      // attribute which will let us suggest a file name to save the link.
-      // Otherwise it is likely that the filename will be unintelligible. 
-      link.setAttribute("download", filename);
-      link.href = reader.result;
-      if (click_link) {
-        // must add the link to click it
-        document.body.appendChild(link);
-        link.click();
-        document.body.removeChild(link);
-      }
-    }
-    reader.readAsDataURL(blob);
-  } catch (error) {
-    if (console && console.log) console.log(error);
-    // probably an old browser
-    link.href = "";
-    link.visible = false;
-  }
-}
-
-/*
- * add_cell
- *
- * Add a cell to the table row.
- */
-function add_cell(row, node, cls, click_action) {
-  var cell = row.insertCell(row.cells.length);
-  if (node) cell.appendChild(node);
-  if (cls && cls !== "") cell.className = cls;
-  if (click_action) cell.addEventListener("click", click_action, false);
-}
-
-/*
- * add_header_cell
- *
- * Add a header cell to the table row.
- */
-function add_header_cell(row, node, help_topic, cls, colspan) {
-  var th = document.createElement("th");
-  if (node) th.appendChild(node);
-  if (help_topic && help_topic !== "") th.appendChild(help_button(help_topic));
-  if (cls && cls !== "") th.className = cls;
-  if (typeof colspan == "number" && colspan > 1) th.colSpan = colspan;
-  row.appendChild(th);
-}
-
-/*
- * add_text_cell
- *
- * Add a text cell to the table row.
- */
-function add_text_cell(row, text, cls, action) {
-  var node = null;
-  if (typeof(text) != 'undefined') node = document.createTextNode(text);
-  add_cell(row, node, cls, action);
-}
-
-/*
- * add_text_header_cell
- *
- * Add a text header cell to the table row.
- */
-function add_text_header_cell(row, text, help_topic, cls, action, colspan) {
-  var node = null;
-  if (typeof(text) != 'undefined') {
-    var nbsp = (help_topic ? "\u00A0" : "");
-    var str = "" + text;
-    var parts = str.split(/\n/);
-    if (parts.length === 1) {
-      if (action) {
-        node = document.createElement("span");
-        node.appendChild(document.createTextNode(str + nbsp));
-      } else {
-        node = document.createTextNode(str + nbsp);
-      }
-    } else {
-      node = document.createElement("span");
-      for (var i = 0; i < parts.length; i++) {
-        if (i !== 0) {
-          node.appendChild(document.createElement("br"));
-        }
-        node.appendChild(document.createTextNode(parts[i]));
-      }
-    }
-    if (action) {
-      node.addEventListener("click", action, false);
-      node.style.cursor = "pointer";
-    }
-  }
-  add_header_cell(row, node, help_topic, cls, colspan);
-}
-
-function setup_help() {
-  "use strict";
-  var help_buttons, i;
-  help_buttons = document.querySelectorAll(".help:not(.active)");
-  for (i = 0; i < help_buttons.length; i++) {
-    setup_help_button(help_buttons[i]);
-  }
-}
-
-function setup_scrollpad() {
-  "use strict";
-  if (document.getElementsByTagName('body')[0].hasAttribute("data-scrollpad") && document.getElementById("scrollpad") == null) {
-    window.addEventListener("resize", update_scroll_pad, false);
-    update_scroll_pad();
-  }
-}
-
-// anon function to avoid polluting global scope
-(function() {
-  "use strict";
-  window.addEventListener("load", function load(evt) {
-    window.removeEventListener("load", load, false);
-    setup_help();
-    setup_scrollpad();
-  }, false);
-})();
-
-/*
- *  make_link
- *
- *  Creates a text node and if a URL is specified it surrounds it with a link.
- *  If the URL doesn't begin with "http://" it automatically adds it, as
- *  relative links don't make much sense in this context.
- */
-function make_link(text, url) {
-  var textNode = null;
-  var link = null;
-  if (typeof text !== "undefined" && text !== null) textNode = document.createTextNode(text);
-  if (typeof url === "string") {
-    if (url.indexOf("//") == -1) {
-      url = "http://" + url;
-    }
-    link = document.createElement('a');
-    link.href = url;
-    if (textNode) link.appendChild(textNode);
-    return link;
-  }
-  return textNode;
-}
-</script>
-    <script>
-      // 
-      // return true if any part of the passed element is visible in the viewport
-      //
-      function element_in_viewport(elem) {
-        var rect;
-        try {
-          rect = elem.getBoundingClientRect();
-        } catch (e) {
-          return false;
-        }
-        return (
-            rect.top < (window.innerHeight || document.body.clientHeight) &&
-            rect.bottom > 0 &&
-            rect.left < (window.innerWidth || document.body.clientWidth) &&
-            rect.right > 0
-            );
-      }
-
-      //
-      // Functions to delay a drawing task until it is required or it would not lag the display to do so
-      //
-
-      // a list of items still to be drawn
-      var drawable_list = [];
-      // the delay between drawing objects that are not currently visible
-      var draw_delay = 1;
-      // the delay after a user interaction
-      var user_delay = 300;
-      // the delay after a user has stopped scrolling and is viewing the stuff drawn on the current page
-      var stop_delay = 300;
-      // the timer handle; allows resetting of the timer after user interactions
-      var draw_timer = null;
-
-      //
-      // Drawable
-      //
-      // elem - a page element which defines the position on the page that drawing is to be done
-      // task - an object with the method run which takes care of painting the object
-      //
-      var Drawable = function(elem, task) {
-        this.elem = elem;
-        this.task = task;
-      }
-
-      //
-      // Drawable.is_visible
-      //
-      // Determines if the element is visible in the viewport
-      //
-      Drawable.prototype.is_visible = function() {
-        return element_in_viewport(this.elem);
-      }
-
-      //
-      // Drawable.run
-      //
-      // Run the task held by the drawable
-      Drawable.prototype.run = function() {
-        if (this.task) this.task.run();
-        this.task = null;
-      }
-
-      //
-      // Drawable.run
-      //
-      // Run the task iff visible
-      // returns true if the task ran or has already run
-      Drawable.prototype.run_visible = function() {
-        if (this.task) {
-          if (element_in_viewport(this.elem)) {
-            this.task.run();
-            this.task = null;
-            return true;
-          }
-          return false;
-        } else {
-          return true;
-        }
-      }
-
-      //
-      // draw_on_screen
-      //
-      // Checks each drawable object and draws those on screen.
-      //
-      function draw_on_screen() {
-        var found = false;
-        for (var i = 0; i < drawable_list.length; i++) {
-          if (drawable_list[i].run_visible()) {
-            drawable_list.splice(i--, 1);
-            found = true;
-          }
-        }
-        return found;
-      }
-
-      //
-      // process_draw_tasks
-      //
-      // Called on a delay to process the next avaliable
-      // draw task.
-      //
-      function process_draw_tasks() {
-        var delay = draw_delay;
-        draw_timer = null;
-        if (drawable_list.length == 0) return; //no more tasks
-        if (draw_on_screen()) {
-          delay = stop_delay; //give the user a chance to scroll
-        } else {
-          //get next task
-          var drawable = drawable_list.shift();
-          drawable.task.run();
-        }
-        //allow UI updates between tasks
-        draw_timer = window.setTimeout("process_draw_tasks()", delay);
-      }
-
-      //
-      // delayed_process_draw_tasks
-      //
-      // Call process_draw_tasks after a short delay.
-      // The delay serves to group multiple redundant events.       
-      // Should be set as event handler for onscroll and onresize.
-      //
-      function delayed_process_draw_tasks() {
-        //reset the timer
-        if (drawable_list.length > 0) { 
-          if (draw_timer != null) clearTimeout(draw_timer);
-          draw_timer = window.setTimeout("process_draw_tasks()", user_delay);
-        }
-      }
-
-      //
-      // add_draw_task
-      //
-      // Add a drawing task to be called immediately if it is
-      // visible, or to be called on a delay to reduce stuttering
-      // effect on the web browser.
-      function add_draw_task(elem, task) {
-        drawable = new Drawable(elem, task);
-        if (drawable.is_visible()) {
-          task.run();
-        } else {
-          drawable_list.push(drawable);
-          //reset timer
-          if (draw_timer != null) clearTimeout(draw_timer);
-          draw_timer = window.setTimeout("process_draw_tasks()", user_delay);
-        }
-      }
-
-</script>
-    <script>
-//======================================================================
-// start Alphabet object
-//======================================================================
-var Alphabet = function(alphabet, background) {
-  "use strict";
-  var i, j, sym, aliases, complement, comp_e_sym, ambigs, generate_background;
-  generate_background = (background == null);
-  if (generate_background) {
-    background = [];
-    for (i = 0; i < alphabet.ncore; i++) background[i] = 1.0 / alphabet.ncore;
-  } else if (alphabet.ncore != background.length) {
-    throw new Error("The background length does not match the alphabet length.");
-  }
-  this.name = alphabet.name;
-  this.like = (alphabet.like != null ? alphabet.like.toUpperCase() : null);
-  this.ncore = alphabet.ncore;
-  this.symbols = alphabet.symbols;
-  this.background = background;
-  this.genbg = generate_background;
-  this.encode = {};
-  this.encode2core = {};
-  this.complement = {};
-  // check if all symbols are same case
-  var seen_uc = false;
-  var seen_lc = false;
-  var check_case = function (syms) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        if (sym >= 'a' && sym <= 'z') seen_lc = true;
-        else if (sym >= 'A' && sym <= 'Z') seen_uc = true;
-      }
-    }
-  };
-  for (i = 0; i < this.symbols.length; i++) {
-    check_case(this.symbols[i].symbol);
-    check_case(this.symbols[i].aliases);
-  }
-  // now map symbols to indexes
-  var update_array = function(array, syms, index) {
-    var s, sym;
-    if (typeof syms === "string") {
-      for (s = 0; s < syms.length; s++) {
-        sym = syms.charAt(s);
-        array[sym] = index;
-        // when only a single case is used, then encode as case insensitive
-        if (seen_uc != seen_lc) {
-          if (sym >= 'a' && sym <= 'z') {
-            array[sym.toUpperCase()] = index;
-          } else if (sym >= 'A' && sym <= 'Z') {
-            array[sym.toLowerCase()] = index;
-          }
-        }
-      }
-    }
-  }
-  // map core symbols to index
-  for (i = 0; i < this.ncore; i++) {
-    update_array(this.encode2core, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode2core, this.symbols[i].aliases, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-  }
-  // map ambigous symbols to index
-  ambigs = {};
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    update_array(this.encode, this.symbols[i].symbol, i);
-    update_array(this.encode, this.symbols[i].aliases, i);
-    ambigs[this.symbols[i].equals] = i;
-  }
-  // determine complements
-  for (i = 0; i < this.ncore; i++) {
-    complement = this.symbols[i].complement;
-    if (typeof complement === "string") {
-      this.complement[i] = this.encode2core[complement];
-    }
-  }
-  next_symbol:
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    complement = "";
-    for (j = 0; j < this.symbols[i].equals.length; j++) {
-      comp_e_sym = this.complement[this.encode2core[this.symbols[i].equals.charAt(j)]];
-      if (typeof comp_e_sym !== "number") continue next_symbol;
-      complement += this.symbols[comp_e_sym].symbol;
-    }
-    complement = complement.split("").sort().join("");
-    if (typeof ambigs[complement] === "number") {
-      this.complement[i] = ambigs[complement];
-    }
-  }
-  // determine case insensitivity
-  this.case_insensitive = true;
-  if (seen_uc == seen_lc) {
-    // when there is a mixture of cases it probably won't
-    // be case insensitive but we still need to check
-    loop:
-    for (i = 0; i < this.symbols.length; i++) {
-      sym = this.symbols[i].symbol;
-      if (sym >= 'A' && sym <= 'Z') {
-        if (this.encode[sym.toLowerCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      } else if (sym >= 'a' && sym <= 'z') {
-        if (this.encode[sym.toUpperCase()] != i) {
-          this.case_insensitive = false;
-          break loop;
-        }
-      }
-      aliases = this.symbols[i].aliases;
-      if (aliases != null) {
-        for (j = 0; j < aliases.length; j++) {
-          sym = aliases.charAt(j);
-          if (sym >= 'A' && sym <= 'Z') {
-            if (this.encode[sym.toLowerCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          } else if (sym >= 'a' && sym <= 'z') {
-            if (this.encode[sym.toUpperCase()] != i) {
-              this.case_insensitive = false;
-              break loop;
-            }
-          }
-        }
-      }
-    }
-  }
-  // normalise aliases to remove the prime symbol and eliminate
-  // the alternate cases when the alphabet is case insensitive
-  var seen, out;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym = this.symbols[i].symbol;
-    aliases = this.symbols[i].aliases;
-    if (typeof aliases != "string") aliases = "";
-    seen = {};
-    out = [];
-    if (this.case_insensitive) {
-      sym = sym.toUpperCase();
-      aliases = aliases.toUpperCase();
-    }
-    seen[sym] = true;
-    for (j = 0; j < aliases.length; j++) {
-      if (!seen[aliases.charAt(j)]) {
-        seen[aliases.charAt(j)] = true;
-        out.push(aliases.charAt(j));
-      }
-    }
-    this.symbols[i].aliases = out.sort().join("");
-  }
-};
-// return the name of the alphabet
-Alphabet.prototype.get_alphabet_name = function() {
-  return this.name;
-};
-// return if the alphabet can be complemented
-Alphabet.prototype.has_complement = function() {
-  return (typeof this.symbols[0].complement === "string");
-};
-// return true if an uppercase letter has the same meaning as the lowercase form
-Alphabet.prototype.is_case_insensitive = function() {
-  return this.case_insensitive;
-};
-// return the information content of an alphabet letter
-Alphabet.prototype.get_ic = function() {
-  return Math.log(this.ncore) / Math.LN2;
-};
-// return the count of the core alphabet symbols
-Alphabet.prototype.get_size_core = function() {
-  return this.ncore;
-};
-// return the count of all alphabet symbols
-Alphabet.prototype.get_size_full = function() {
-  return this.symbols.length;
-};
-// return the symbol for the given alphabet index
-Alphabet.prototype.get_symbol = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  return this.symbols[alph_index].symbol;
-};
-// return the aliases for the given alphabet index
-Alphabet.prototype.get_aliases = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  var sym_obj = this.symbols[alph_index];
-  return (sym_obj.aliases != null ? sym_obj.aliases : "");
-};
-// return the name for the given alphabet index
-Alphabet.prototype.get_name = function(alph_index) {
-  "use strict";
-  var sym;
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("Alphabet index out of bounds");
-  }
-  sym = this.symbols[alph_index];
-  return (typeof sym.name === "string" ? sym.name : sym.symbol);
-};
-// return the alphabet it is like or null
-Alphabet.prototype.get_like = function() {
-  "use strict";
-  return this.like;
-};
-// return the index of the complement for the given alphabet index
-Alphabet.prototype.get_complement = function(alph_index) {
-  var comp_e_sym = this.complement[alph_index];
-  if (typeof comp_e_sym === "number") {
-    return comp_e_sym;
-  } else {
-    return -1;
-  }
-};
-// return a string containing the core symbols
-Alphabet.prototype.get_symbols = function() {
-  "use strict";
-  var i, core_symbols;
-  core_symbols = "";
-  for (i = 0; i < this.ncore; i++) {
-    core_symbols += this.symbols[i].symbol;
-  }
-  return core_symbols;
-};
-// return if the background was not a uniform generated background
-Alphabet.prototype.has_bg = function() {
-  "use strict";
-  return !this.genbg;
-};
-// get the background frequency for the index
-Alphabet.prototype.get_bg_freq = function(alph_index) {
-  "use strict";
-  var freq, i, symbols;
-  if (alph_index >= 0) {
-    if (alph_index < this.ncore) {
-      return this.background[alph_index];
-    } else if (alph_index < this.symbols.length) {
-      freq = 0;
-      symbols = this.symbols[alph_index].equals;
-      for (i = 0; i < symbols.length; i++) {
-        freq += this.background[this.encode2core[symbols.charAt(i)]];
-      }
-      return freq;
-    } 
-  }
-  throw new Error("The alphabet index is out of range.");
-};
-// get the colour of the index
-Alphabet.prototype.get_colour = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return "black";
-  }
-  return "#" + this.symbols[alph_index].colour;
-};
-// get the rgb componets of the colour at the index
-Alphabet.prototype.get_rgb = function(alph_index) {
-  "use strict";
-  if (alph_index < 0 || alph_index >= this.symbols.length) {
-    throw new Error("BAD_ALPHABET_INDEX");
-  }
-  if (typeof this.symbols[alph_index].colour != "string") {
-    return {"red": 0, "green": 0, "blue": 0};
-  }
-  var colour = this.symbols[alph_index].colour;
-  var red = parseInt(colour.substr(0, 2), 16) / 255;
-  var green = parseInt(colour.substr(2, 2), 16) / 255;
-  var blue = parseInt(colour.substr(4, 2), 16) / 255;
-  return {"red": red, "green": green, "blue": blue};
-};
-// convert a symbol into the index
-Alphabet.prototype.get_index = function(letter) {
-  "use strict";
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    return -1;
-  }
-  return alph_index;
-};
-// convert a symbol into the list of core indexes that it equals
-Alphabet.prototype.get_indexes = function(letter) {
-  "use strict";
-  var alph_index, comprise_str, i, comprise_list;
-  alph_index = this.encode[letter];
-  if (typeof alph_index === "undefined") {
-    throw new Error("Unknown letter");
-  }
-  comprise_str = this.symbols[alph_index].equals;
-  comprise_list = [];
-  if (typeof comprise_str == "string") {
-    for (i = 0; i < comprise_str.length; i++) {
-      comprise_list.push(this.encode2core[comprise_str.charAt(i)]);
-    }
-  } else {
-    comprise_list.push(alph_index);
-  }
-  return comprise_list;
-};
-// check if a symbol is the primary way of representing the symbol in the alphabet
-Alphabet.prototype.is_prime_symbol = function(letter) {
-  var alph_index;
-  alph_index = this.encode[letter];
-  if (alph_index == null) return false;
-  if (this.is_case_insensitive()) {
-    return (this.symbols[alph_index].symbol.toUpperCase() == letter.toUpperCase());
-  } else {
-    return (this.symbols[alph_index].symbol == letter);
-  }
-};
-// compare 2 alphabets
-Alphabet.prototype.equals = function(other) {
-  "use strict";
-  var i, sym1, sym2;
-  // first check that it's actually an alphabet object
-  if (!(typeof other === "object" && other != null && other instanceof Alphabet)) {
-    return false;
-  }
-  // second shortcircuit if it's the same object
-  if (this === other) return true;
-  // compare
-  if (this.name !== other.name) return false;
-  if (this.ncore !== other.ncore) return false;
-  if (this.symbols.length !== other.symbols.length) return false;
-  for (i = 0; i < this.symbols.length; i++) {
-    sym1 = this.symbols[i];
-    sym2 = other.symbols[i];
-    if (sym1.symbol !== sym2.symbol) return false;
-    if (sym1.aliases !== sym2.aliases) return false;
-    if (sym1.name !== sym2.name) return false;
-    if (typeof sym1.colour !== typeof sym2.colour || 
-        (typeof sym1.colour === "string" && typeof sym2.colour === "string" &&
-         parseInt(sym1.colour, 16) != parseInt(sym2.colour, 16))) {
-      return false;
-    }
-    if (sym1.complement !== sym2.complement) return false;
-    if (sym1.equals !== sym2.equals) return false;
-  }
-  return true;
-};
-Alphabet.prototype.check_core_subset = function(super_alph) {
-  var complement_same = true;
-  var seen_set = {};
-  var sub_i, sub_symbol, super_i, super_symbol;
-  for (sub_i = 0; sub_i < this.ncore; sub_i++) {
-    sub_symbol = this.symbols[sub_i];
-    super_i = super_alph.encode[sub_symbol.symbol]; 
-    if (super_i == null) return 0;
-    super_symbol = super_alph.symbols[super_i];
-    if (seen_set[super_i]) return 0;
-    seen_set[super_i] = true;
-    // check complement
-    if (sub_symbol.complement != null && super_symbol.complement != null) {
-      if (super_alph.encode[sub_symbol.complement] != super_alph.encode[super_symbol.complement]) {
-        complement_same = false;
-      }
-    } else if (sub_symbol.complement != null || super_symbol.complement != null) {
-      complement_same = false;
-    }
-  }
-  return (complement_same ? 1 : -1);
-};
-// convert a sequence to its reverse complement
-Alphabet.prototype.invcomp_seq = function(seq) {
-  "use strict";
-  var syms, i, e_sym, comp_e_sym;
-  if (!this.has_complement()) throw new Error("Alphabet must be complementable");
-  syms = seq.split("");
-  for (i = 0; i < syms.length; i++) {
-    e_sym = this.encode[syms[i]];
-    if (typeof e_sym === "undefined") {
-      e_sym = this.ncore; // wildcard
-    }
-    comp_e_sym = this.complement[e_sym];
-    if (typeof comp_e_sym === "undefined") {
-      comp_e_sym = e_sym; // not complementable
-    }
-    syms[i] = this.symbols[comp_e_sym].symbol;
-  }
-  return syms.reverse().join("");
-};
-// convert the alphabet to the text version
-Alphabet.prototype.as_text = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  function symbol_as_text(sym) {
-    var out;
-    out = sym.symbol;
-    if (typeof sym.name === "string" && sym.name != sym.symbol) {
-      out += " " + name_as_text(sym.name);
-    }
-    if (typeof sym.colour === "string") {
-      out += " " + sym.colour;
-    }
-    return out;
-  }
-  var out, i, j, c, sym;
-  out = "";
-  // output core symbols with 2 way complements
-  for (i = 0; i < this.ncore; i++) {
-    c = this.complement[i];
-    if (typeof c === "number" && i < c && this.complement[c] === i) {
-      out += symbol_as_text(this.symbols[i]) + " ~ " + symbol_as_text(this.symbols[c]) + "\n";  
-    }
-  }
-  // output core symbols with no complement
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.complement[i] === "undefined") {
-      out += symbol_as_text(this.symbols[i]) + "\n";
-    }
-  }
-  // output ambiguous symbols that have comprising characters
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    if (this.symbols[i].equals.length == 0) break;
-    out += symbol_as_text(this.symbols[i]) + " = " + this.symbols[i].equals + "\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].equals + "\n";
-      }
-    }
-  }
-  // output aliases of core symbols
-  for (i = 0; i < this.ncore; i++) {
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " = " + this.symbols[i].symbol + "\n";
-      }
-    }
-  }
-  // output gap symbols
-  i = this.symbols.length - 1;
-  if (this.symbols[i].equals.length == 0) {
-    out += symbol_as_text(this.symbols[i]) + " =\n";
-    if (typeof this.symbols[i].aliases === "string") {
-      for (j = 0; j < this.symbols[i].aliases.length; j++) {
-        if (this.symbols[i].aliases.charAt(j) == this.symbols[i].symbol) continue;
-        out += this.symbols[i].aliases.charAt(j) + " =\n";
-      }
-    }
-  }
-  return out;
-};
-// output the alphabet as it appears in minimal MEME format
-Alphabet.prototype.as_meme = function() {
-  "use strict";
-  function name_as_text(name) {
-    var i, c, out;
-    out = "\"";
-    for (i = 0; i < name.length; i++) {
-      c = name.charAt(i);
-      if (c == "\"") {
-        out += "\\\"";
-      } else if (c == "/") {
-        out += "\\/";
-      } else if (c == "\\") {
-        out += "\\\\";
-      } else {
-        out += c;
-      }
-    }
-    out += "\"";
-    return out;
-  }
-  if (this.equals(AlphStd.DNA)) {
-    return "ALPHABET= ACGT\n";
-  } else if (this.equals(AlphStd.PROTEIN)) {
-    return "ALPHABET= ACDEFGHIKLMNPQRSTVWY\n";
-  } else {
-    return "ALPHABET" + 
-      (this.name != null ? " " + name_as_text(this.name) : "") + 
-      (this.like != null ? " " + this.like + "-LIKE" : "") + "\n" +
-      this.as_text() + "END ALPHABET\n";
-  }
-};
-
-// Returns a table showing all the letters in the alphabet
-Alphabet.prototype.as_table = function() {
-  "use strict";
-  var i, j, row, th, td, aliases, equals, sym;
-  var table = document.createElement("table");
-  // create the core symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  if (this.has_complement()) {
-    th.appendChild(document.createTextNode("Complement"));
-  }
-  row.appendChild(th);
-  // list the core symbols
-  for (i = 0; i < this.ncore; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].complement != null) {
-      td.style.color = this.get_colour(this.get_index(this.symbols[i].complement));
-      td.appendChild(document.createTextNode(this.symbols[i].complement));
-    }
-    row.appendChild(td);
-  }
-  // create the ambiguous symbol header
-  row = table.insertRow(table.rows.length);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Symbol(s)"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Name"));
-  row.appendChild(th);
-  th = document.createElement("th");
-  th.appendChild(document.createTextNode("Matches"));
-  row.appendChild(th);
-  // list the ambiguous symbols
-  for (i = this.ncore; i < this.symbols.length; i++) {
-    row = table.insertRow(table.rows.length);
-    td = document.createElement("td");
-    if (this.symbols[i].colour != null) {
-      td.style.color = '#' + this.symbols[i].colour;
-    }
-    td.appendChild(document.createTextNode(this.symbols[i].symbol));
-    aliases = this.get_aliases(i);
-    if (aliases.length > 0) {
-      td.appendChild(document.createTextNode(' ' + aliases.split('').join(' ')));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    if (this.symbols[i].name != null) {
-      td.appendChild(document.createTextNode(this.symbols[i].name));
-    }
-    row.appendChild(td);
-    td = document.createElement("td");
-    equals = this.symbols[i].equals.split('');
-    for (j = 0; j < equals.length; j++) {
-      if (j != 0) td.appendChild(document.createTextNode(' '));
-      sym = document.createElement("span");
-      sym.style.color = this.get_colour(this.get_index(equals[j]));
-      sym.appendChild(document.createTextNode(equals[j]));
-      td.appendChild(sym);
-    }
-    row.appendChild(td);
-  }
-  return table;
-};
-
-// returns a dictionary of the colours for EPS
-Alphabet.prototype._as_eps_dict = function() {
-  "use strict";
-  var i, sym, rgb;
-  var out = "/fullColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = this.get_rgb(i);
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  out += "/mutedColourDict <<\n";
-  for (i = 0; i < this.ncore; i++) {
-    sym = this.get_symbol(i);
-    sym = sym.replace(/\\/g, "\\\\");
-    sym = sym.replace(/\(/g, "\\(");
-    sym = sym.replace(/\)/g, "\\)");
-    rgb = Alphabet.lighten_colour(this.get_rgb(i));
-    out += " (" + sym + ") [" + rgb.red.toFixed(4) + " " + rgb.green.toFixed(4) + " " + rgb.blue.toFixed(4) + "]\n";
-  }
-  out += ">> def\n";
-  return out;
-};
-
-// return the alphabet name or a list of primary symbols
-Alphabet.prototype.toString = function() {
-  "use strict";
-  if (this.name != null) {
-    return this.name;
-  } else {
-    return this.get_symbols();
-  }
-};
-
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-// Helper functions
-//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-// Convert a colour specified in RGB colourspace values into LAB colourspace
-Alphabet.rgb2lab = function(rgb) {
-  "use strict";
-  var xyzHelper, labHelper;
-  // XYZ helper
-  xyzHelper = function(value) {
-    if (value > 0.0445) {
-      value = (value + 0.055) / 1.055;
-      value = Math.pow(value, 2.4);
-    } else {
-      value /= 12.92;
-    }
-    value *= 100;
-    return value;
-  };
-  // lab helper
-  labHelper = function(value) {
-    if (value > 0.008856) {
-      value = Math.pow(value, 1.0 / 3.0);
-    } else {
-      value = (7.787 * value) + (16.0 / 116.0);
-    }
-    return value;
-  };
-  // convert into XYZ colourspace
-  var c1, c2, c3;
-  if (typeof rgb == "number") {
-    c1 = xyzHelper(((rgb >> 16) & 0xFF) / 255.0);
-    c2 = xyzHelper(((rgb >> 8) & 0xFF) / 255.0);
-    c3 = xyzHelper((rgb & 0xFF) / 255.0);
-  } else {
-    c1 = xyzHelper(rgb.red);
-    c2 = xyzHelper(rgb.green);
-    c3 = xyzHelper(rgb.blue);
-  }
-  var x = (c1 * 0.4124) + (c2 * 0.3576) + (c3 * 0.1805);
-  var y = (c1 * 0.2126) + (c2 * 0.7152) + (c3 * 0.0722);
-  var z = (c1 * 0.0193) + (c2 * 0.1192) + (c3 * 0.9505);
-  // convert into Lab colourspace
-  c1 = labHelper(x / 95.047);
-  c2 = labHelper(y / 100.0);
-  c3 = labHelper(z / 108.883);
-  var l = (116.0 * c2) - 16;
-  var a = 500.0 * (c1 - c2);
-  var b = 200.0 * (c2 - c3);
-  return {"l": l, "a": a, "b": b};
-};
-
-// Convert a colour specified in HSV colourspace into RGB colourspace
-Alphabet.hsv2rgb = function(hue, sat, value, output_object) {
-  // achromatic (grey)
-  var r = value;
-  var g = value;
-  var b = value;
-  if (sat != 0) {
-    var h = hue / 60.0;
-    var i = Math.floor(h);
-    var f = h - i;
-    var p = value * (1.0 - sat);
-    var q = value * (1.0 - (sat * f));
-    var t = value * (1.0 - (sat * (1.0 - f)));
-    if (i == 0) {
-      r = value;
-      g = t;
-      b = p;
-    } else if (i == 1) {
-      r = q;
-      g = value;
-      b = p;
-    } else if (i == 2) {
-      r = p;
-      g = value;
-      b = t;
-    } else if (i == 3) {
-      r = p;
-      g = q;
-      b = value;
-    } else if (i == 4) {
-      r = t;
-      g = p;
-      b = value;
-    } else {
-      r = value;
-      g = p;
-      b = q;
-    }
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-// Calculate a distance score between two colours in LAB colourspace
-Alphabet.lab_dist = function(lab1, lab2) {
-  var c1 = Math.sqrt((lab1.l * lab1.l) + (lab1.a * lab1.a));
-  var c2 = Math.sqrt((lab2.l * lab2.l) + (lab2.a * lab2.a));
-  var dc = c1 - c2;
-  var dl = lab1.l - lab2.l;
-  var da = lab1.a - lab2.a;
-  var db = lab1.b - lab2.b;
-  // we don't want NaN due to rounding errors so fudge things a bit...
-  var dh = 0;
-  var dh_squared = (da * da) + (db * db) - (dc * dc);
-  if (dh_squared > 0) {
-    dh = Math.sqrt(dh_squared);
-  }
-  var first = dl;
-  var second = dc / (1.0 + (0.045 * c1));
-  var third = dh / (1.0 + (0.015 * c1));
-  return Math.sqrt((first * first) + (second * second) + (third * third));
-};
-
-// convert an RGB value into a HSL value
-Alphabet.rgb2hsl = function(rgb) {
-  "use strict";
-  var min, max, delta, h, s, l, r, g, b;
-  if (typeof rgb == "number") {
-    r = ((rgb >> 16) & 0xFF) / 255.0;
-    g = ((rgb >> 8) & 0xFF) / 255.0;
-    b = (rgb & 0xFF) / 255.0;
-  } else {
-    r = rgb.red;
-    g = rgb.green;
-    b = rgb.blue;
-  }
-  min = Math.min(r, g, b);
-  max = Math.max(r, g, b);
-  delta = max - min;
-  l = min + (delta / 2);
-  if (max == min) {
-    h = 0; // achromatic (grayscale)
-    s = 0;
-  } else {
-    if (l > 0.5) {
-      s = delta / (2 - max - min);
-    } else {
-      s = delta / (max + min);
-    }
-    if (max == r) {
-      h = (g - b) / delta;
-      if (g < b) h += 6;
-    } else if (max == g) {
-      h = ((b - r) / delta) + 2;
-    } else {
-      h = ((r - g) / delta) + 4;
-    }
-    h /= 6;
-  }
-  return {"h": h, "s": s, "l": l};
-};
-
-// convert a HSL value into an RGB value
-Alphabet.hsl2rgb = function(hsl, output_object) {
-  "use strict";
-  function _hue(p, q, t) {
-    "use strict";
-    if (t < 0) t += 1;
-    else if (t > 1) t -= 1;
-    if (t < (1.0 / 6.0)) {
-      return p + ((q - p) * 6.0 * t);
-    } else if (t < 0.5) {
-      return q;
-    } else if (t < (2.0 / 3.0)) {
-      return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-    } else {
-      return p;
-    }
-  }
-  var r, g, b, p, q;
-  if (hsl.s == 0) {
-    // achromatic (grayscale)
-    r = hsl.l;
-    g = hsl.l;
-    b = hsl.l;
-  } else {
-    if (hsl.l < 0.5) {
-      q = hsl.l * (1 + hsl.s);
-    } else {
-      q = hsl.l + hsl.s - (hsl.l * hsl.s);
-    }
-    p = (2 * hsl.l) - q;
-    r = _hue(p, q, hsl.h + (1.0 / 3.0));
-    g = _hue(p, q, hsl.h);
-    b = _hue(p, q, hsl.h - (1.0 / 3.0));
-  }
-  if (output_object) {
-    return {"red": r, "green": g, "blue": b};
-  } else {
-    return (Math.floor(r * 255) << 15) | (Math.floor(g * 255) << 8) | (Math.floor(b * 255));
-  }
-};
-
-Alphabet.lighten_colour = function(rgb) {
-  "use strict";
-  var hsl = Alphabet.rgb2hsl(rgb);
-  hsl.l += (1.0 - hsl.l) * 2 / 3;
-  return Alphabet.hsl2rgb(hsl, typeof rgb != "number");
-};
-
-//======================================================================
-// end Alphabet object
-//======================================================================
-
-//======================================================================
-// start StandardAlphabet object
-//======================================================================
-
-// an extension of the alphabet object to support some additional fields 
-// only present in standard alphabets.
-var StandardAlphabet = function(enum_code, enum_name, alphabet_data) {
-  Alphabet.apply(this, [alphabet_data]);
-  this.enum_code = enum_code;
-  this.enum_name = enum_name;
-};
-StandardAlphabet.prototype = Alphabet.prototype;
-StandardAlphabet.prototype.constructor = StandardAlphabet;
-
-// A unique code for this standard alphabet.
-// This code will be a power of 2 to enable creation of bitsets for
-// a selection of standard alphabets.
-StandardAlphabet.prototype.get_code = function() {
-  return this.enum_code;
-};
-
-// A unique name for this standard alphabet.
-// this name will be all upper case and the same as the property that
-// refers to this alphabet in the AlphStd collection.
-StandardAlphabet.prototype.get_enum = function() {
-  return this.enum_name;
-};
-
-//======================================================================
-// end StandardAlphabet object
-//======================================================================
-
-// A collection of standard alphabets.
-var AlphStd = {
-  RNA: new StandardAlphabet(1, "RNA", {
-    "name": "RNA",
-    "like": "RNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300"},
-      {"symbol": "U", "name": "Uracil", "colour": "008000",
-        "aliases": "T"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGU", "aliases": "X."},
-      {"symbol": "V", "name": "Not U", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACU"},
-      {"symbol": "D", "name": "Not C", "equals": "AGU"},
-      {"symbol": "B", "name": "Not A", "equals": "CGU"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AU"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CU"},
-      {"symbol": "K", "name": "Keto", "equals": "GU"}
-    ]
-  }), 
-  DNA: new StandardAlphabet(2, "DNA", {
-    "name": "DNA",
-    "like": "DNA",
-    "ncore": 4,
-    "symbols": [
-      {"symbol": "A", "name": "Adenine", "colour": "CC0000", "complement": "T"},
-      {"symbol": "C", "name": "Cytosine", "colour": "0000CC", "complement": "G"},
-      {"symbol": "G", "name": "Guanine", "colour": "FFB300", "complement": "C"},
-      {"symbol": "T", "name": "Thymine", "colour": "008000", "complement": "A",
-        "aliases": "U"},
-      {"symbol": "N", "name": "Any base", "equals": "ACGT", "aliases": "X."},
-      {"symbol": "V", "name": "Not T", "equals": "ACG"},
-      {"symbol": "H", "name": "Not G", "equals": "ACT"},
-      {"symbol": "D", "name": "Not C", "equals": "AGT"},
-      {"symbol": "B", "name": "Not A", "equals": "CGT"},
-      {"symbol": "M", "name": "Amino", "equals": "AC"},
-      {"symbol": "R", "name": "Purine", "equals": "AG"},
-      {"symbol": "W", "name": "Weak", "equals": "AT"}, 
-      {"symbol": "S", "name": "Strong", "equals": "CG"},
-      {"symbol": "Y", "name": "Pyrimidine", "equals": "CT"},
-      {"symbol": "K", "name": "Keto", "equals": "GT"}
-    ]
-  }), 
-  PROTEIN: new StandardAlphabet(4, "PROTEIN", {
-    "name": "Protein",
-    "like": "PROTEIN",
-    "ncore": 20,
-    "symbols": [
-      {"symbol": "A", "name": "Alanine", "colour": "0000CC"},
-      {"symbol": "C", "name": "Cysteine", "colour": "0000CC"},
-      {"symbol": "D", "name": "Aspartic acid", "colour": "FF00FF"},
-      {"symbol": "E", "name": "Glutamic acid", "colour": "FF00FF"},
-      {"symbol": "F", "name": "Phenylalanine", "colour": "0000CC"},
-      {"symbol": "G", "name": "Glycine", "colour": "FFB300"},
-      {"symbol": "H", "name": "Histidine", "colour": "FFCCCC"},
-      {"symbol": "I", "name": "Isoleucine", "colour": "0000CC"},
-      {"symbol": "K", "name": "Lysine", "colour": "CC0000"},
-      {"symbol": "L", "name": "Leucine", "colour": "0000CC"},
-      {"symbol": "M", "name": "Methionine", "colour": "0000CC"},
-      {"symbol": "N", "name": "Asparagine", "colour": "008000"},
-      {"symbol": "P", "name": "Proline", "colour": "FFFF00"},
-      {"symbol": "Q", "name": "Glutamine", "colour": "008000"},
-      {"symbol": "R", "name": "Arginine", "colour": "CC0000"},
-      {"symbol": "S", "name": "Serine", "colour": "008000"},
-      {"symbol": "T", "name": "Threonine", "colour": "008000"},
-      {"symbol": "V", "name": "Valine", "colour": "0000CC"},
-      {"symbol": "W", "name": "Tryptophan", "colour": "0000CC"},
-      {"symbol": "Y", "name": "Tyrosine", "colour": "33E6CC"},
-      {"symbol": "X", "name": "Any amino acid", "equals": "ACDEFGHIKLMNPQRSTVWY", "aliases": "*."},
-      {"symbol": "B", "name": "Asparagine or Aspartic acid", "equals": "DN"}, 
-      {"symbol": "Z", "name": "Glutamine or Glutamic acid", "equals": "EQ"}, 
-      {"symbol": "J", "name": "Leucine or Isoleucine", "equals": "IL"}
-    ]
-  })
-};
-
-//======================================================================
-// start Symbol object
-//======================================================================
-var Symbol = function(alph_index, scale, alphabet) {
-  "use strict";
-  //variable prototype
-  this.symbol = alphabet.get_symbol(alph_index);
-  this.scale = scale;
-  this.colour = alphabet.get_colour(alph_index);
-};
-
-Symbol.prototype.get_symbol = function() {
-  "use strict";
-  return this.symbol;
-};
-
-Symbol.prototype.get_scale = function() {
-  "use strict";
-  return this.scale;
-};
-
-Symbol.prototype.get_colour = function() {
-  "use strict";
-  return this.colour;
-};
-
-Symbol.prototype.toString = function() {
-  "use strict";
-  return this.symbol + " " + (Math.round(this.scale*1000)/10) + "%";
-};
-
-function compare_symbol(sym1, sym2) {
-  "use strict";
-  if (sym1.get_scale() < sym2.get_scale()) {
-    return -1;
-  } else if (sym1.get_scale() > sym2.get_scale()) {
-    return 1;
-  } else {
-    return 0;
-  }
-}
-//======================================================================
-// end Symbol object
-//======================================================================
-
-//======================================================================
-// start Pspm object
-//======================================================================
-var Pspm = function(matrix, name, ltrim, rtrim, nsites, evalue, pssm, alt) {
-  "use strict";
-  var row, col, data, row_sum, delta, evalue_re;
-  if (typeof name !== "string") {
-    name = "";
-  }
-  this.name = name;
-  //construct
-  if (matrix instanceof Pspm) {
-    // copy constructor
-    this.alph_length = matrix.alph_length;
-    this.motif_length = matrix.motif_length;
-    this.name = matrix.name;
-    this.alt = matrix.alt;
-    this.nsites = matrix.nsites;
-    this.evalue = matrix.evalue;
-    this.ltrim = matrix.ltrim;
-    this.rtrim = matrix.rtrim;
-    this.pspm = [];
-    for (row = 0; row < matrix.motif_length; row++) {
-      this.pspm[row] = [];
-      for (col = 0; col < matrix.alph_length; col++) {
-        this.pspm[row][col] = matrix.pspm[row][col];
-      }
-    }
-    if (matrix.pssm != null) {
-      this.pssm = [];
-      for (row = 0; row < matrix.motif_length; row++) {
-        this.pspm[row] = [];
-        for (col = 0; col < matrix.alph_length; col++) {
-          this.pssm[row][col] = matrix.pssm[row][col];
-        }
-      }
-    }
-  } else {
-    // check parameters
-    if (ltrim == null) {
-      ltrim = 0;
-    } else if (typeof ltrim !== "number" || ltrim % 1 !== 0 || ltrim < 0) {
-      throw new Error("ltrim must be a non-negative integer, got: " + ltrim);
-    }
-    if (rtrim == null) {
-      rtrim = 0;
-    } else if (typeof rtrim !== "number" || rtrim % 1 !== 0 || rtrim < 0) {
-      throw new Error("rtrim must be a non-negative integer, got: " + rtrim);
-    }
-    if (nsites != null) {
-      if (typeof nsites !== "number" || nsites < 0) {
-        throw new Error("nsites must be a positive number, got: " + nsites);
-      } else if (nsites == 0) {
-        nsites = null;
-      }
-    }
-    if (evalue != null) {
-      if (typeof evalue === "number") {
-        if (evalue < 0) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else if (typeof evalue === "string") {
-        evalue_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-        if (!evalue_re.test(evalue)) {
-          throw new Error("evalue must be a non-negative number, got: " + evalue);
-        }
-      } else {
-        throw new Error("evalue must be a non-negative number, got: " + evalue);
-      }
-    }
-    // set properties
-    this.name = name;
-    this.alt = alt;
-    this.nsites = nsites;
-    this.evalue = evalue;
-    this.ltrim = ltrim;
-    this.rtrim = rtrim;
-    if (typeof matrix === "string") {
-      // string constructor
-      data = parse_pspm_string(matrix);
-      this.alph_length = data["alph_length"];
-      this.motif_length = data["motif_length"];
-      this.pspm = data["pspm"];
-      if (this.evalue == null) {
-        if (data["evalue"] != null) {
-          this.evalue = data["evalue"];
-        } else {
-          this.evalue = 0;
-        }
-      }
-      if (this.nsites == null) {
-        if (typeof data["nsites"] === "number") {
-          this.nsites = data["nsites"];
-        } else {
-          this.nsites = 20;
-        }
-      }
-    } else {
-      // assume pspm is a nested array
-      this.motif_length = matrix.length;
-      this.alph_length = (matrix.length > 0 ? matrix[0].length : 0);
-      if (this.nsites == null) {
-        this.nsites = 20;
-      }
-      if (this.evalue == null) {
-        this.evalue = 0;
-      }
-      this.pspm = [];
-      // copy pspm and check
-      for (row = 0; row < this.motif_length; row++) {
-        if (this.alph_length != matrix[row].length) {
-          throw new Error("COLUMN_MISMATCH");
-        }
-        this.pspm[row] = [];
-        row_sum = 0;
-        for (col = 0; col < this.alph_length; col++) {
-          this.pspm[row][col] = matrix[row][col];
-          row_sum += this.pspm[row][col];
-        }
-        delta = 0.1;
-        if (isNaN(row_sum) || (row_sum > 1 && (row_sum - 1) > delta) || 
-            (row_sum < 1 && (1 - row_sum) > delta)) {
-          throw new Error("INVALID_SUM");
-        }
-      }
-      // copy pssm
-      if (pssm != null) {
-        this.pssm = [];
-        for (row = 0; row < this.motif_length; row++) {
-          this.pssm[row] = [];
-          for (col = 0; col < this.alph_length; col++) {
-            this.pssm[row][col] = pssm[row][col];
-          }
-        }
-      }
-    }
-  }
-};
-
-Pspm.prototype.copy = function() {
-  "use strict";
-  return new Pspm(this);
-};
-
-Pspm.prototype.reverse = function() {
-  "use strict";
-  var x, y, temp, temp_trim;
-  //reverse
-  x = 0;
-  y = this.motif_length-1;
-  while (x < y) {
-    temp = this.pspm[x];
-    this.pspm[x] = this.pspm[y];
-    this.pspm[y] = temp;
-    x++;
-    y--;
-  }
-  // reverse pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //reverse
-    x = 0;
-    y = this.motif_length-1;
-    while (x < y) {
-      temp = this.pssm[x];
-      this.pspm[x] = this.pssm[y];
-      this.pssm[y] = temp;
-      x++;
-      y--;
-    }
-  }
-  //swap triming
-  temp_trim = this.ltrim;
-  this.ltrim = this.rtrim;
-  this.rtrim = temp_trim;
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.reverse_complement = function(alphabet) {
-  "use strict";
-  var x, y, temp, i, row, c, temp_trim;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  if (!alphabet.has_complement()) {
-    throw new Error("The specified alphabet can not be complemented.");
-  }
-  // reverse motif
-  this.reverse();
-  //complement
-  for (x = 0; x < this.motif_length; x++) {
-    row = this.pspm[x];
-    for (i = 0; i < row.length; i++) {
-      c = alphabet.get_complement(i);
-      if (c < i) continue;
-      temp = row[i];
-      row[i] = row[c];
-      row[c] = temp;
-    }
-  }
-  // complement pssm (if defined)
-  if (typeof this.pssm !== "undefined") {
-    //complement
-    for (x = 0; x < this.motif_length; x++) {
-      row = this.pssm[x];
-      for (i = 0; i < row.length; i++) {
-        c = alphabet.get_complement(i);
-        if (c < i) continue;
-        temp = row[i];
-        row[i] = row[c];
-        row[c] = temp;
-      }
-    }
-  }
-  return this; //allow function chaining...
-};
-
-Pspm.prototype.get_stack = function(position, alphabet, ssc) {
-  "use strict";
-  var row, stack_ic, alphabet_ic, stack, i, sym;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size of the pspm.");
-  }
-  row = this.pspm[position];
-  stack_ic = this.get_stack_ic(position, alphabet);
-  if (ssc) stack_ic -= this.get_error(alphabet);
-  alphabet_ic = alphabet.get_ic();
-  stack = [];
-  for (i = 0; i < this.alph_length; i++) {
-    sym = new Symbol(i, row[i]*stack_ic/alphabet_ic, alphabet);
-    if (sym.get_scale() <= 0) {
-      continue;
-    }
-    stack.push(sym);
-  }
-  stack.sort(compare_symbol);
-  return stack;
-};
-
-Pspm.prototype.get_stack_ic = function(position, alphabet) {
-  "use strict";
-  var row, H, i;
-  if (this.alph_length != alphabet.get_size_core()) {
-    throw new Error("The alphabet size does not match the size fo the pspm.");
-  }
-  row = this.pspm[position];
-  H = 0;
-  for (i = 0; i < this.alph_length; i++) {
-    if (row[i] === 0) {
-      continue;
-    }
-    H -= (row[i] * (Math.log(row[i]) / Math.LN2));
-  }
-  return alphabet.get_ic() - H;
-};
-
-Pspm.prototype.get_error = function(alphabet) {
-  "use strict";
-  if (this.nsites === 0) {
-    return 0;
-  }
-  return (alphabet.get_size_core()-1) / (2 * Math.LN2 * this.nsites);
-};
-
-Pspm.prototype.get_motif_length = function() {
-  "use strict";
-  return this.motif_length;
-};
-
-Pspm.prototype.get_alph_length = function() {
-  "use strict";
-  return this.alph_length;
-};
-
-Pspm.prototype.get_left_trim = function() {
-  "use strict";
-  return this.ltrim;
-};
-
-Pspm.prototype.get_right_trim = function() {
-  "use strict";
-  return this.rtrim;
-};
-
-Pspm.prototype.as_best_match = function(alphabet) {
-  "use strict";
-  var match, odds, best_odds, best_index;
-  var i, j;
-  match = "";
-  for (i = 0; i < this.motif_length; i++) {
-    best_index = 0;
-    best_odds = this.pspm[i][0] / alphabet.get_bg_freq(0);
-    for (j = 1; j < this.alph_length; j++) {
-      odds = this.pspm[i][j] / alphabet.get_bg_freq(j);
-      if (odds > best_odds) {
-        best_odds = odds;
-        best_index = j;
-      }
-    }
-    match += alphabet.get_symbol(best_index);
-  }
-  return match;
-};
-
-Pspm.prototype.as_count_matrix = function() {
-  "use strict";
-  var count, count_text, text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      count = Math.round(this.nsites * this.pspm[i][j]);
-      count_text = "" + count;
-      // pad up to length of 4
-      if (count_text.length < 4) {
-        text += (new Array(5 - count_text.length)).join(" ") + count_text;
-      } else {
-        text += count_text;
-      }
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_probability_matrix = function() {
-  "use strict";
-  var text;
-  var i, j;
-  text = "";
-  for (i = 0; i < this.motif_length; i++) {
-    if (i !== 0) {
-      text += "\n";
-    }
-    for (j = 0; j < this.alph_length; j++) {
-      if (j !== 0) {
-        text += " ";
-      }
-      text += this.pspm[i][j].toFixed(6);
-    }
-  }
-  return text; 
-};
-
-Pspm.prototype.as_score_matrix = function(alphabet, pseudo) {
-  "use strict";
-  var me, score, out, row, col, score_text;
-  me = this;
-  if (typeof this.pssm === "undefined") {
-    if (!(typeof alphabet === "object" && alphabet != null && alphabet instanceof Alphabet)) {
-      throw new Error("The alphabet is required to generate the pssm.");
-    }
-    if (typeof pseudo === "undefined") {
-      pseudo = 0.01;
-    } else if (typeof pseudo !== "number" || pseudo < 0) {
-      throw new Error("Expected positive number for pseudocount");
-    }
-    score = function(row, col) {
-      "use strict";
-      var p, bg, p2;
-      p = me.pspm[row][col];
-      bg = alphabet.get_bg_freq(col);
-      p2 = (p * me.nsites + bg * pseudo) / (me.nsites + pseudo);
-      return (p2 > 0 ? Math.round((Math.log(p2 / bg) / Math.LN2) * 100) : -10000);
-    };
-  } else {
-    score = function(row, col) {
-      "use strict";
-      return me.pssm[row][col];
-    };
-  }
-  out = "";
-  for (row = 0; row < this.motif_length; row++) {
-    for (col = 0; col < this.alph_length; col++) {
-      if (col !== 0) {
-        out += " ";
-      }
-      score_text = "" + score(row, col);
-      // pad out to 6 characters
-      if (score_text.length < 6) {
-        out += (new Array(7 - score_text.length)).join(" ") + score_text;
-      } else {
-        out += score_text;
-      }
-    }
-    out += "\n";
-  }
-  return out;
-}
-
-Pspm.prototype.as_pspm = function() {
-  "use strict";
-  return "letter-probability matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + " nsites= " + this.nsites + 
-      " E= " + (typeof this.evalue === "number" ? 
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_probability_matrix();
-};
-
-Pspm.prototype.as_pssm = function(alphabet, pseudo) {
-  "use strict";
-  return "log-odds matrix: alength= " + this.alph_length + 
-      " w= " + this.motif_length + 
-      " E= " + (typeof this.evalue == "number" ?
-          this.evalue.toExponential() : this.evalue) + "\n" +
-      this.as_score_matrix(alphabet, pseudo);
-};
-
-Pspm.prototype.as_meme = function(options) {
-  var with_header, with_pspm, with_pssm, version, alphabet, bg_source, pseudocount, strands;
-  var out, alen, i;
-  // get the options
-  if (typeof options !== "object" || options === null) {
-    options = {};
-  }
-  with_header = (typeof options["with_header"] === "boolean" ? options["with_header"] : false);
-  with_pspm = (typeof options["with_pspm"] === "boolean" ? options["with_pspm"] : false);
-  with_pssm = (typeof options["with_pssm"] === "boolean" ? options["with_pssm"] : false);
-  if (!with_pspm && !with_pssm) with_pspm = true;
-  if (with_header) {
-    if (typeof options["version"] === "string" && /^\d+(?:\.\d+){0,2}$/.test(options["version"])) {
-      version = options["version"];
-    } else if (typeof options["version"] === "number") {
-      version = options["version"].toFixed(0);
-    } else {
-      version = "4";
-    }
-    if (typeof options["strands"] === "number" && options["strands"] === 1) {
-      strands = 1;
-    } else {
-      strands = 2;
-    }
-    if (typeof options["bg_source"] === "string") {
-      bg_source = options["bg_source"];
-    } else {
-      bg_source = "unknown source";
-    }
-    if (typeof options["alphabet"] === "object" && options["alphabet"] != null
-        && options["alphabet"] instanceof Alphabet) {
-      alphabet = options["alphabet"];
-    } else {
-      throw new Error("The alphabet is required to generate the header.");
-    }
-  }
-  // now create the output
-  out = "";
-  if (with_header) {
-    out = "MEME version " + version + "\n\n";
-    out += alphabet.as_meme() + "\n";
-    if (alphabet.has_complement()) { // assume DNA has both strands unless otherwise specified
-      out += "strands: " + (strands === 1 ? "+" : "+ -") + "\n\n";
-    }
-    out += "Background letter frequencies (from " + bg_source + "):\n";
-    alen = alphabet.get_size_core();
-    for (i = 0; i < alen; i++) {
-      if (i !== 0) {
-        if (i % 9 === 0) { // maximum of nine entries per line
-          out += "\n";
-        } else {
-          out += " ";
-        }
-      }
-      out += alphabet.get_symbol(i) + " " + alphabet.get_bg_freq(i).toFixed(3);
-    }
-  }
-  out += "\n\n";
-  out += "MOTIF " + this.name + (this.alt == null ? "" : " " + this.alt);
-  if (with_pssm) {
-    out += "\n\n";
-    out += this.as_pssm(options["alphabet"], options["pseudocount"]);
-  }
-  if (with_pspm) {
-    out += "\n\n";
-    out += this.as_pspm();
-  }
-  return out;
-}
-
-Pspm.prototype.toString = function() {
-  "use strict";
-  var str, i, row;
-  str = "";
-  for (i = 0; i < this.pspm.length; i++) {
-    row = this.pspm[i];
-    str += row.join("\t") + "\n";
-  }
-  return str;
-};
-
-function parse_pspm_properties(str) {
-  "use strict";
-  var parts, i, eqpos, before, after, properties, prop, num, num_re;
-  num_re = /^((?:[+]?[0-9]*\.?[0-9]+(?:[eE][-+]?[0-9]+)?)|inf)$/;
-  parts = trim(str).split(/\s+/);
-  // split up words containing =
-  for (i = 0; i < parts.length;) {
-    eqpos = parts[i].indexOf("=");
-    if (eqpos != -1) {
-      before = parts[i].substr(0, eqpos);
-      after = parts[i].substr(eqpos+1);
-      if (before.length > 0 && after.length > 0) {
-        parts.splice(i, 1, before, "=", after);
-        i += 3;
-      } else if (before.length > 0) {
-        parts.splice(i, 1, before, "=");
-        i += 2;
-      } else if (after.length > 0) {
-        parts.splice(i, 1, "=", after);
-        i += 2;
-      } else {
-        parts.splice(i, 1, "=");
-        i++;
-      }
-    } else {
-      i++;
-    }
-  }
-  properties = {};
-  for (i = 0; i < parts.length; i += 3) {
-    if (parts.length - i < 3) {
-      throw new Error("Expected PSPM property was incomplete. "+
-          "Remaing parts are: " + parts.slice(i).join(" "));
-    }
-    if (parts[i+1] !== "=") {
-      throw new Error("Expected '=' in PSPM property between key and " +
-          "value but got " + parts[i+1]); 
-    }
-    prop = parts[i].toLowerCase();
-    num = parts[i+2];
-    if (!num_re.test(num)) {
-      throw new Error("Expected numeric value for PSPM property '" + 
-          prop + "' but got '" + num + "'");
-    }
-    properties[prop] = num;
-  }
-  return properties;
-}
-
-function parse_pspm_string(pspm_string) {
-  "use strict";
-  var header_re, lines, first_line, line_num, col_num, alph_length, 
-      motif_length, nsites, evalue, pspm, i, line, match, props, parts,
-      j, prob;
-  header_re = /^letter-probability\s+matrix:(.*)$/i;
-  lines = pspm_string.split(/\n/);
-  first_line = true;
-  line_num = 0;
-  col_num = 0;
-  alph_length;
-  motif_length;
-  nsites;
-  evalue;
-  pspm = [];
-  for (i = 0; i < lines.length; i++) {
-    line = trim(lines[i]);
-    if (line.length === 0) { 
-      continue;
-    }
-    // check the first line for a header though allow matrices without it
-    if (first_line) {
-      first_line = false;
-      match = header_re.exec(line);
-      if (match !== null) {
-        props = parse_pspm_properties(match[1]);
-        if (props.hasOwnProperty("alength")) {
-          alph_length = parseFloat(props["alength"]);
-          if (alph_length != 4 && alph_length != 20) {
-            throw new Error("PSPM property alength should be 4 or 20" +
-                " but got " + alph_length);
-          }
-        }
-        if (props.hasOwnProperty("w")) {
-          motif_length = parseFloat(props["w"]);
-          if (motif_length % 1 !== 0 || motif_length < 1) {
-            throw new Error("PSPM property w should be an integer larger " +
-                "than zero but got " + motif_length);
-          }
-        }
-        if (props.hasOwnProperty("nsites")) {
-          nsites = parseFloat(props["nsites"]);
-          if (nsites <= 0) {
-            throw new Error("PSPM property nsites should be larger than " +
-                "zero but got " + nsites);
-          }
-        }
-        if (props.hasOwnProperty("e")) {
-          evalue = props["e"];
-          if (evalue < 0) {
-            throw new Error("PSPM property evalue should be " +
-                "non-negative but got " + evalue);
-          }
-        }
-        continue;
-      }
-    }
-    pspm[line_num] = [];
-    col_num = 0;
-    parts = line.split(/\s+/);
-    for (j = 0; j < parts.length; j++) {
-      prob = parseFloat(parts[j]);
-      if (prob != parts[j] || prob < 0 || prob > 1) {
-        throw new Error("Expected probability but got '" + parts[j] + "'"); 
-      }
-      pspm[line_num][col_num] = prob;
-      col_num++;
-    }
-    line_num++;
-  }
-  if (typeof motif_length === "number") {
-    if (pspm.length != motif_length) {
-      throw new Error("Expected PSPM to have a motif length of " + 
-          motif_length + " but it was actually " + pspm.length);
-    }
-  } else {
-    motif_length = pspm.length;
-  }
-  if (typeof alph_length !== "number") {
-    alph_length = pspm[0].length;
-    if (alph_length != 4 && alph_length != 20) {
-      throw new Error("Expected length of first row in the PSPM to be " +
-          "either 4 or 20 but got " + alph_length);
-    }
-  }
-  for (i = 0; i < pspm.length; i++) {
-    if (pspm[i].length != alph_length) {
-      throw new Error("Expected PSPM row " + i + " to have a length of " + 
-          alph_length + " but the length was " + pspm[i].length);
-    }
-  }
-  return {"pspm": pspm, "motif_length": motif_length, 
-    "alph_length": alph_length, "nsites": nsites, "evalue": evalue};
-}
-//======================================================================
-// end Pspm object
-//======================================================================
-
-//======================================================================
-// start Logo object
-//======================================================================
-
-var Logo = function(alphabet, options) {
-  "use strict";
-  this.alphabet = alphabet;
-  this.fine_text = "";
-  this.x_axis = 1;
-  this.y_axis = true;
-  this.xlate_nsyms = 1;
-  this.xlate_start = null;
-  this.xlate_end = null;
-  this.pspm_list = [];
-  this.pspm_column = [];
-  this.rows = 0;
-  this.columns = 0;
-  if (typeof options === "string") {
-    // the old method signature had fine_text here so we support that
-    this.fine_text = options;
-  } else if (typeof options === "object" && options != null) {
-    this.fine_text = (typeof options.fine_text === "string" ? options.fine_text : "");
-    this.x_axis = (typeof options.x_axis === "boolean" ? (options.x_axis ? 1 : 0) : 1);
-    if (options.x_axis_hidden != null && options.x_axis_hidden) this.x_axis = -1;
-    this.y_axis = (typeof options.y_axis === "boolean" ? options.y_axis : true);
-    this.xlate_nsyms = (typeof options.xlate_nsyms === "number" ? options.xlate_nsyms : this.xlate_nsyms);
-    this.xlate_start = (typeof options.xlate_start === "number" ? options.xlate_start : this.xlate_start);
-    this.xlate_end = (typeof options.xlate_end === "number" ? options.xlate_end : this.xlate_end);
-  }
-};
-
-Logo.prototype.add_pspm = function(pspm, column) {
-  "use strict";
-  var col;
-  if (typeof column === "undefined") {
-    column = 0;
-  } else if (column < 0) {
-    throw new Error("Column index out of bounds.");
-  }
-  this.pspm_list[this.rows] = pspm;
-  this.pspm_column[this.rows] = column;
-  this.rows++;
-  col = column + pspm.get_motif_length();
-  if (col > this.columns) {
-    this.columns = col;
-  }
-};
-
-Logo.prototype.get_columns = function() {
-  "use strict";
-  return this.columns;
-};
-
-Logo.prototype.get_xlate_nsyms = function() {
-  "use strict";
-  return this.xlate_nsyms;
-};
-
-Logo.prototype.get_xlate_start = function() {
-  "use strict";
-  return (this.xlate_start != null ? this.xlate_start : 0);
-};
-
-Logo.prototype.get_xlate_end = function() {
-  "use strict";
-  return (this.xlate_end != null ? this.xlate_end : this.columns * this.xlate_nsyms);
-};
-
-Logo.prototype.get_xlate_columns = function() {
-  "use strict";
-  return this.get_xlate_end() - this.get_xlate_start();
-};
-
-Logo.prototype.get_rows = function() {
-  "use strict";
-  return this.rows;
-};
-
-Logo.prototype.get_pspm = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_list[row_index];
-};
-
-Logo.prototype.get_offset = function(row_index) {
-  "use strict";
-  if (row_index < 0 || row_index >= this.rows) {
-    throw new Error("INDEX_OUT_OF_BOUNDS");
-  }
-  return this.pspm_column[row_index];
-};
-
-Logo.prototype._as_eps_data = function(ssc, errbars) {
-  var i, j, pos, stack_pos, pspm, stack, sym, out;
-  out = "";
-  for (i = 0; i < this.rows; i++) {
-    out += "\nStartLine\n";
-    // Indent
-    for (j = 0; j < this.pspm_column[i]; j++) {
-      out += "() startstack\nendstack\n\n";
-    }
-    pspm = this.pspm_list[i];
-    if (pspm.get_left_trim() > 0) {
-      out += "MuteColour\nDrawTrimEdge\n" + pspm.get_left_trim() + " DrawTrimBg\n";
-    }
-    for (pos = 0; pos < pspm.get_motif_length(); pos++) {
-      if (pos != 0 && pos == pspm.get_left_trim()) { // enable full colour
-        out += "DrawTrimEdge\nRestoreColour\n";
-      } else if (pos == (pspm.get_motif_length() - pspm.get_right_trim())) {
-        out += "MuteColour\n" + pspm.get_right_trim() + " DrawTrimBg\n";
-      }
-      out += "(" + (pos + 1) + ") startstack\n";
-      stack = pspm.get_stack(pos, this.alphabet, ssc);
-      for (stack_pos = 0; stack_pos < stack.length; stack_pos++) {
-        sym = stack[stack_pos];
-        out += " " + (sym.get_scale() * this.alphabet.get_ic()) + " (" + sym.get_symbol() + ") numchar\n";
-      }
-      if (errbars) {
-        out += " " + pspm.get_error(this.alphabet) + " Ibeam\n";
-      }
-      out += "endstack\n\n";
-    }
-    if (pspm.get_right_trim() > 0 || pspm.get_left_trim() == pspm.get_motif_length()) {
-      out += "RestoreColour\n";
-    }
-    out += "EndLine\n";
-  }
-  return out;
-};
-
-Logo.prototype.as_eps = function(options) {
-  "use strict";
-  if (this.xlate_nsyms != 1) throw new Error("Unsupported setting xlate_nsyms for EPS");
-  if (this.xlate_start != null) throw new Error("Unsupported setting xlate_start for EPS");
-  if (this.xlate_end != null) throw new Error("Unsupported setting xlate_end for EPS");
-
-  var LOGOHEIGHT = 7.5; // default height of line in cm
-  var cm2pts, height, width, now, ssc, errbars;
-  if (typeof options === "undefined") {
-    options = {};
-  }
-  cm2pts = 72 / 2.54;
-  if (typeof options.logo_height == "number") {
-    height = options.logo_height;
-  } else {
-    height = LOGOHEIGHT * this.rows;
-  }
-  if (typeof options.logo_width == "number") {
-    width = options.logo_width;
-  } else {
-    width = this.columns + 2;
-  }
-  now = new Date();
-  ssc = (typeof options.ssc == "boolean" ? options.ssc : false);
-  errbars = (typeof options.show_error_bar == "boolean" ? options.show_error_bar : ssc);
-  var values = {
-    "LOGOHEIGHT": height,
-    "LOGOWIDTH": width,
-    "BOUNDINGHEIGHT": Math.round(height * cm2pts),
-    "BOUNDINGWIDTH": Math.round(width * cm2pts),
-    "LOGOLINEHEIGHT": (height / this.rows),
-    "CHARSPERLINE": this.columns,
-    "BARBITS": this.alphabet.get_ic(),
-    "LOGOTYPE": (this.alphabet.has_complement() ? "NA" : "AA"),
-    "CREATIONDATE": now.getDate() + "." + (now.getMonth() + 1) + "." + now.getFullYear() + " " + now.getHours() + ":" + now.getMinutes() + ":" + now.getSeconds(),
-    "ERRORBARFRACTION": (typeof options.error_bar_fraction == "number" ? options.error_bar_fraction : 1.0),
-    "TICBITS": (typeof options.ticbits == "number" ? options.ticbits : 1.0),
-    "TITLE": (typeof options.title == "string" ? options.title : ""),
-    "FINEPRINT": (typeof options.fineprint == "string" ? options.fineprint : this.fine_text),
-    "XAXISLABEL": (typeof options.xaxislabel == "string" ? options.xaxislabel : ""),
-    "YAXISLABEL": (typeof options.yaxislabel == "string" ? options.yaxislabel : "bits"),
-    "SSC": ssc,
-    "YAXIS": (typeof options.show_y_axis == "boolean" ? options.show_y_axis : this.y_axis),
-    "SHOWENDS": (typeof options.show_ends == "boolean" ? options.show_ends : false),
-    "ERRBAR": errbars,
-    "OUTLINE": (typeof options.show_outline == "boolean" ? options.show_outline : false),
-    "NUMBERING": (typeof options.show_numbering == "boolean" ? options.show_numbering : this.x_axis != 0),
-    "SHOWINGBOX": (typeof options.show_box == "boolean" ? options.show_box : false),
-    "CREATOR": (typeof options.creator == "string" ? options.creator : "motif_logo.js"),
-    "FONTSIZE": (typeof options.label_font_size == "number" ? options.label_font_size : 12),
-    "TITLEFONTSIZE": (typeof options.title_font_size == "number" ? options.title_font_size : 12),
-    "SMALLFONTSIZE": (typeof options.small_font_size == "number" ? options.small_font_size : 6),
-    "TOPMARGIN" : (typeof options.top_margin == "number" ? options.top_margin : 0.9),
-    "BOTTOMMARGIN": (typeof options.bottom_margin == "number" ? options.bottom_margin : 0.9),
-    "COLORDICT": this.alphabet._as_eps_dict(),
-    "DATA": this._as_eps_data(ssc, errbars)
-  };
-  // now this requires that the script containing the template has been imported!
-  return motif_logo_template(values);
-};
-
-//======================================================================
-// end Logo object
-//======================================================================
-
-// calculate the exact size (in pixels) of an object drawn on the
-// canvas assuming that the background of the canvas is transparent.
-function canvas_bounds(ctx, cwidth, cheight) {
-  "use strict";
-  var data, r, c, top_line, bottom_line, left_line, right_line, 
-      txt_width, txt_height;
-
-  // extract the image data
-  data = ctx.getImageData(0, 0, cwidth, cheight).data;
-
-  // set initial values
-  top_line = -1; bottom_line = -1; left_line = -1; right_line = -1;
-  txt_width = 0; txt_height = 0;
-
-  // Find the top-most line with a non-transparent pixel
-  for (r = 0; r < cheight; r++) {
-    for (c = 0; c < cwidth; c++) {
-      if (data[r * cwidth * 4 + c * 4 + 3]) {
-        top_line = r;
-        break;
-      }
-    }
-    if (top_line != -1) {
-      break;
-    }
-  }
-  
-  // Only bother looking if we found at least one set pixel... 
-  if (top_line != -1) {
-
-    //find the last line with a non-transparent pixel
-    for (r = cheight-1; r >= top_line; r--) {
-      for(c = 0; c < cwidth; c++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          bottom_line = r;
-          break;
-        }
-      }
-      if (bottom_line != -1) {
-        break;
-      }
-    }
-    // calculate height
-    txt_height = bottom_line - top_line + 1;
-
-    // Find the left-most line with a non-transparent pixel
-    for (c = 0; c < cwidth; c++) {
-      for (r = top_line; r <= bottom_line; r++) {
-        if (data[r * cwidth * 4 + c * 4 + 3]) {
-          left_line = c;
-          break;
-        }
-      }
-      if (left_line != -1) {
-        break;
-      }
-    }
-
-    //find the right most line with a non-transparent pixel
-    for (c = cwidth-1; c >= left_line; c--) {
-      for(r = top_line; r <= bottom_line; r++) {
-        if(data[r * cwidth * 4 + c * 4 + 3]) {
-          right_line = c;
-          break;
-        }
-      }
-      if (right_line != -1) {
-        break;
-      }
-    }
-    txt_width = right_line - left_line + 1;
-  }
-
-  //return the bounds
-  return {bound_top: top_line, bound_bottom: bottom_line, 
-    bound_left: left_line, bound_right: right_line, width: txt_width, 
-    height: txt_height};
-}
-
-//======================================================================
-// start RasterizedAlphabet
-//======================================================================
-
-// Rasterize Alphabet
-// 1) Measure width of text at default font for all symbols in alphabet
-// 2) sort in width ascending
-// 3) Drop the top and bottom 10% (designed to ignore outliers like 'W' and 'I')
-// 4) Calculate the average as the maximum scaling factor (designed to stop I becoming a rectangular blob).
-// 5) Assume scale of zero would result in width of zero, interpolate scale required to make perfect width font
-// 6) Draw text onto temp canvas at calculated scale
-// 7) Find bounds of drawn text
-// 8) Paint on to another canvas at the desired height (but only scaling width to fit if larger).
-var RasterizedAlphabet = function(alphabet, logo_scale, font, width) {
-  "use strict";
-  var default_size, safety_pad, canvas, ctx, middle, baseline, widths, sizes,
-      i, sym, size, tenpercent, avg_width, scale, 
-      target_width, target_height;
-  //variable prototypes
-  this.alphabet = alphabet;
-  this.scale = logo_scale;
-  this.sym_cache = {};
-  this.stack_num_cache = [];
-  this.scale_num_cache = [];
-  // size of canvas
-  default_size = 60; // size of measuring canvas
-  safety_pad = 20; // pixels to pad around so we don't miss the edges
-  // create a canvas to do our measuring
-  canvas = document.createElement("canvas");
-  if (!canvas.getContext) throw new Error("No canvas support");
-  canvas.width = default_size + 2 * safety_pad;
-  canvas.height = default_size + 2 * safety_pad;
-  middle = Math.round(canvas.width / 2);
-  baseline = Math.round(canvas.height - safety_pad);
-  ctx = canvas.getContext('2d');
-  if (!supports_text(ctx)) throw new Error("Canvas does not support text");
-  ctx.font = font;
-  ctx.textAlign = "center";
-  ctx.translate(middle, baseline);
-  // list of widths
-  widths = [];
-  sizes = [];
-  //now measure each letter in the alphabet
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    // reset the canvas
-    ctx.clearRect(0, 0, canvas.width, canvas.height);
-    ctx.fillStyle = alphabet.get_colour(i);
-    // draw the test text
-    ctx.fillText(alphabet.get_symbol(i), 0, 0);
-    //measure
-    size = canvas_bounds(ctx, canvas.width, canvas.height);
-    if (size.width === 0) throw new Error("Invisible symbol!");
-    widths.push(size.width);
-    sizes[i] = size;
-  }
-  //sort the widths
-  widths.sort(function(a,b) {return a - b;});
-  //drop 10% of the items off each end
-  tenpercent = Math.floor(widths.length / 10);
-  for (i = 0; i < tenpercent; ++i) {
-    widths.pop();
-    widths.shift();
-  }
-  //calculate average width
-  avg_width = 0;
-  for (i = 0; i < widths.length; ++i) {
-    avg_width += widths[i];
-  }
-  avg_width /= widths.length;
-  // calculate the target width
-  target_width = width * this.scale * 2;
-  // calculate scales
-  for (i = 0; i < alphabet.get_size_core(); ++i) {
-    sym = alphabet.get_symbol(i);
-    size = sizes[i];
-    // calculate scale
-    scale = target_width / Math.max(avg_width, size.width);
-    // estimate scaled height
-    target_height = size.height * scale;
-    // create an appropriately sized canvas
-    canvas = document.createElement("canvas");
-    canvas.width = target_width;
-    canvas.height = target_height + safety_pad * 2;
-    // calculate the middle
-    middle = Math.round(canvas.width / 2);
-    // calculate the baseline
-    baseline = Math.round(canvas.height - safety_pad);
-    // get the context and prepare to draw the rasterized text
-    ctx = canvas.getContext('2d');
-    ctx.font = font;
-    ctx.fillStyle = alphabet.get_colour(i);
-    ctx.textAlign = "center";
-    ctx.translate(middle, baseline);
-    ctx.save();
-    ctx.scale(scale, scale);
-    // draw the text
-    ctx.fillText(sym, 0, 0);
-    ctx.restore();
-    this.sym_cache[sym] = {"image": canvas, "size": canvas_bounds(ctx, canvas.width, canvas.height)};
-  }
-};
-
-RasterizedAlphabet.prototype.get_alphabet = function() {
-  return this.alphabet;
-};
-
-RasterizedAlphabet.prototype.get_scale = function() {
-  return this.scale;
-};
-
-RasterizedAlphabet.prototype.draw_stack_sym = function(ctx, letter, dx, dy, dWidth, dHeight) {
-  "use strict";
-  var entry, image, size;
-  entry = this.sym_cache[letter];
-  image = entry.image;
-  size = entry.size;
-  ctx.drawImage(image, 0, size.bound_top -1, image.width, size.height+1, dx, dy, dWidth, dHeight);
-};
-
-RasterizedAlphabet.prototype.draw_stack_num = function(ctx, font, stack_width, index) {
-  var image, image_ctx, text_length;
-  if (index >= this.stack_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.save();
-    image_ctx.font = font;
-    text_length = image_ctx.measureText("" + (index + 1)).width;
-    image_ctx.restore();
-    // resize the canvas to fit
-    image.width = Math.ceil(stack_width);
-    image.height = Math.ceil(text_length);
-    // draw the text
-    image_ctx = image.getContext('2d');
-    image_ctx.translate(Math.round(stack_width / 2), 0);
-    image_ctx.font = font;
-    image_ctx.textBaseline = "middle";
-    image_ctx.textAlign = "right";
-    image_ctx.rotate(-(Math.PI / 2));
-    image_ctx.fillText("" + (index + 1), 0, 0);
-    this.stack_num_cache[index] = image;
-  } else {
-    image = this.stack_num_cache[index];
-  }
-  ctx.drawImage(image, 0, 0);
-}
-
-RasterizedAlphabet.prototype.draw_scale_num = function(ctx, font, num) {
-  var image, image_ctx, text_size, m_length;
-  if (num >= this.scale_num_cache.length) {
-    image = document.createElement("canvas");
-    // measure the text
-    image_ctx = image.getContext('2d');
-    image_ctx.font = font;
-    text_size = image_ctx.measureText("" + num);
-    if (text_size.actualBoundingBoxAscent && text_size.actualBoundingBoxDesent) {
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(text_size.actualBoundingBoxAscent + text_size.actualBoundingBoxDesent);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.fillText("" + num, image.width, text_size.actualBoundingBoxAscent);
-    } else {
-      // measure width of 'm' to approximate height, we double it later anyway
-      m_length = image_ctx.measureText("m").width;
-      // resize the canvas to fit
-      image.width = Math.ceil(text_size.width);
-      image.height = Math.ceil(2 * m_length);
-      // draw the text
-      image_ctx = image.getContext('2d');
-      image_ctx.font = font;
-      image_ctx.textAlign = "right";
-      image_ctx.textBaseline = "middle";
-      image_ctx.fillText("" + num, image.width, m_length);
-    }
-    this.scale_num_cache[num] = image;
-  } else {
-    image = this.scale_num_cache[num];
-  }
-  ctx.drawImage(image, -image.width, -Math.round(image.height / 2))
-}
-
-//======================================================================
-// end RasterizedAlphabet
-//======================================================================
-
-//======================================================================
-// start LogoMetrics object
-//======================================================================
-
-var LogoMetrics = function(ctx, logo_columns, logo_rows, has_names, has_finetext, x_axis, y_axis) {
-  "use strict";
-  var i, row_height;
-  //variable prototypes
-  this.pad_top = (has_names ? 5 : 0);
-  this.pad_left = (y_axis ? 10 : 0);
-  this.pad_right = (has_finetext ? 15 : 0);
-  this.pad_bottom = 0;
-  this.pad_middle = 20;
-  this.name_height = 14;
-  this.name_font = "bold " + this.name_height + "px Times, sans-serif";
-  this.name_spacer = 0;
-  this.y_axis = y_axis;
-  this.y_label = "bits";
-  this.y_label_height = 12;
-  this.y_label_font = "bold " + this.y_label_height + "px Helvetica, sans-serif";
-  this.y_label_spacer = 3;
-  this.y_num_height = 12;
-  this.y_num_width = 0;
-  this.y_num_font = "bold " + this.y_num_height + "px Helvetica, sans-serif";
-  this.y_tic_width = 5;
-  this.stack_pad_left = 0;
-  this.stack_font = "bold 25px Helvetica, sans-serif";
-  this.stack_height = 90;
-  this.stack_width = 26;
-  this.stacks_pad_right = 5;
-  this.x_axis = x_axis;
-  this.x_num_above = 2;
-  this.x_num_height = 12;
-  this.x_num_width = 0;
-  this.x_num_font = "bold " + this.x_num_height + "px Helvetica, sans-serif";
-  this.fine_txt_height = 6;
-  this.fine_txt_above = 2;
-  this.fine_txt_font = "normal " + this.fine_txt_height + "px Helvetica, sans-serif";
-  this.letter_metrics = new Array();
-  this.summed_width = 0;
-  this.summed_height = 0;
-  //calculate the width of the y axis numbers
-  ctx.font = this.y_num_font;
-  for (i = 0; i <= 2; i++) {
-    this.y_num_width = Math.max(this.y_num_width, ctx.measureText("" + i).width);
-  }
-  //calculate the width of the x axis numbers (but they are rotated so it becomes height)
-  if (x_axis == 1) {
-    ctx.font = this.x_num_font;
-    for (i = 1; i <= logo_columns; i++) {
-      this.x_num_width = Math.max(this.x_num_width, ctx.measureText("" + i).width);
-    }
-  } else if (x_axis == 0) {
-    this.x_num_height = 4;
-    this.x_num_width = 4;
-  } else {
-    this.x_num_height = 0;
-    this.x_num_width = 0;
-  }
-  
-  //calculate how much vertical space we want to draw this
-  //first we add the padding at the top and bottom since that's always there
-  this.summed_height += this.pad_top + this.pad_bottom;
-  //all except the last row have the same amount of space allocated to them
-  if (logo_rows > 1) {
-    row_height = this.stack_height + this.pad_middle;
-    if (has_names) {
-      row_height += this.name_height;
-      //the label is allowed to overlap into the spacer
-      row_height += Math.max(this.y_num_height/2, this.name_spacer); 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    } else {
-      row_height += this.y_num_height/2; 
-      //the label is allowed to overlap the space used by the other label
-      row_height += Math.max(this.y_num_height/2, this.x_num_height + this.x_num_above); 
-    }
-    this.summed_height += row_height * (logo_rows - 1);
-  }
-  //the last row has the name and fine text below it but no padding
-  this.summed_height += this.stack_height + (this.y_axis ? this.y_num_height/2 : 0);
-
-  var fine_txt_total = (has_finetext ? this.fine_txt_height + this.fine_txt_above : 0);
-  if (has_names) {
-    this.summed_height += fine_txt_total + this.name_height;
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + this.name_spacer);
-  } else {
-    this.summed_height += Math.max((this.y_axis ? this.y_num_height/2 : 0), 
-        this.x_num_height + this.x_num_above + fine_txt_total);
-  }
-
-  //calculate how much horizontal space we want to draw this
-  //first add the padding at the left and right since that's always there
-  this.summed_width += this.pad_left + this.pad_right;
-  if (this.y_axis) {
-    //add on the space for the y-axis label
-    this.summed_width += this.y_label_height + this.y_label_spacer;
-    //add on the space for the y-axis
-    this.summed_width += this.y_num_width + this.y_tic_width;
-  }
-  //add on the space for the stacks
-  this.summed_width += (this.stack_pad_left + this.stack_width) * logo_columns;
-  //add on the padding after the stacks (an offset from the fine text)
-  this.summed_width += this.stacks_pad_right;
-
-};
-
-//======================================================================
-// end LogoMetrics object
-//======================================================================
-
-//found this trick at http://talideon.com/weblog/2005/02/detecting-broken-images-js.cfm
-function image_ok(img) {
-  "use strict";
-  // During the onload event, IE correctly identifies any images that
-  // weren't downloaded as not complete. Others should too. Gecko-based
-  // browsers act like NS4 in that they report this incorrectly.
-  if (!img.complete) {
-    return false;
-  }
-  // However, they do have two very useful properties: naturalWidth and
-  // naturalHeight. These give the true size of the image. If it failed
-  // to load, either of these should be zero.
-  if (typeof img.naturalWidth !== "undefined" && img.naturalWidth === 0) {
-    return false;
-  }
-  // No other way of checking: assume it's ok.
-  return true;
-}
-  
-function supports_text(ctx) {
-  "use strict";
-  if (!ctx.fillText) {
-    return false;
-  }
-  if (!ctx.measureText) {
-    return false;
-  }
-  return true;
-}
-
-//draws the scale, returns the width
-function draw_scale(ctx, metrics, alphabet_ic, raster) {
-  "use strict";
-  var tic_height, i;
-  tic_height = metrics.stack_height / alphabet_ic;
-  ctx.save();
-  ctx.translate(metrics.y_label_height, metrics.y_num_height/2);
-  //draw the axis label
-  ctx.save();
-  ctx.font = metrics.y_label_font;
-  ctx.translate(0, metrics.stack_height/2);
-  ctx.rotate(-(Math.PI / 2));
-  ctx.textAlign = "center";
-  ctx.fillText("bits", 0, 0);
-  ctx.restore();
-
-  ctx.translate(metrics.y_label_spacer + metrics.y_num_width, 0);
-
-  //draw the axis tics
-  ctx.save();
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i <= alphabet_ic; i++) {
-    //draw the number
-    ctx.save();
-    ctx.translate(-1, 0);
-    raster.draw_scale_num(ctx, metrics.y_num_font, i);
-    ctx.restore();
-    //draw the tic
-    ctx.fillRect(0, -1, metrics.y_tic_width, 2);
-    //prepare for next tic
-    ctx.translate(0, -tic_height);
-  }
-  ctx.restore();
-
-  ctx.fillRect(metrics.y_tic_width - 2, 0, 2, metrics.stack_height)
-
-  ctx.restore();
-}
-
-function draw_stack_num(ctx, metrics, row_index, raster) {
-  "use strict";
-  ctx.save();
-  ctx.translate(0, Math.round(metrics.stack_height + metrics.x_num_above));
-  if (metrics.x_axis == 1) {
-    raster.draw_stack_num(ctx, metrics.x_num_font, metrics.stack_width, row_index);
-  } else if (metrics.x_axis == 0) {
-    // draw dots instead of the numbers (good for small logos)
-    ctx.beginPath();
-    var radius = Math.round(metrics.x_num_height / 2);
-    ctx.arc(Math.round(metrics.stack_width / 2), radius, radius, 0, 2 * Math.PI, false);
-    ctx.fill();
-  }
-  ctx.restore();
-}
-
-function draw_stack(ctx, metrics, symbols, raster) {
-  "use strict";
-  var preferred_pad, sym_min, i, sym, sym_height, pad;
-  preferred_pad = 0;
-  sym_min = 5;
-
-  ctx.save();//1
-  ctx.translate(0, metrics.stack_height);
-  for (i = 0; i < symbols.length; i++) {
-    sym = symbols[i];
-    sym_height = metrics.stack_height * sym.get_scale();
-    
-    pad = preferred_pad;
-    if (sym_height - pad < sym_min) {
-      pad = Math.min(pad, Math.max(0, sym_height - sym_min));
-    }
-    sym_height -= pad;
-
-    //translate to the correct position
-    ctx.translate(0, -(pad/2 + sym_height));
-
-    //draw
-    raster.draw_stack_sym(ctx, sym.get_symbol(), 0, 0, metrics.stack_width, sym_height);
-    //translate past the padding
-    ctx.translate(0, -(pad/2));
-  }
-  ctx.restore();//1
-}
-
-function draw_dashed_line(ctx, pattern, start, x1, y1, x2, y2) {
-  "use strict";
-  var x, y, len, i, dx, dy, tlen, theta, mulx, muly, lx, ly;
-  dx = x2 - x1;
-  dy = y2 - y1;
-  tlen = Math.pow(dx*dx + dy*dy, 0.5);
-  theta = Math.atan2(dy,dx);
-  mulx = Math.cos(theta);
-  muly = Math.sin(theta);
-  lx = [];
-  ly = [];
-  for (i = 0; i < pattern; ++i) {
-    lx.push(pattern[i] * mulx);
-    ly.push(pattern[i] * muly);
-  }
-  i = start;
-  x = x1;
-  y = y1;
-  len = 0;
-  ctx.beginPath();
-  while (len + pattern[i] < tlen) {
-    ctx.moveTo(x, y);
-    x += lx[i];
-    y += ly[i];
-    ctx.lineTo(x, y);
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-    x += lx[i];
-    y += ly[i];
-    len += pattern[i];
-    i = (i + 1) % pattern.length;
-  }
-  if (len < tlen) {
-    ctx.moveTo(x, y);
-    x += mulx * (tlen - len);
-    y += muly * (tlen - len);
-    ctx.lineTo(x, y);
-  }
-  ctx.stroke();
-}
-
-function draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider) {
-  "use strict";
-  var left_size = left_end - left_start;
-  var right_size = right_end - right_start;
-  var line_x;
-
-  ctx.save();//s8
-  ctx.fillStyle = "rgb(240, 240, 240)";
-  if (left_size > 0) {
-    ctx.fillRect(left_start * metrics.stack_width, 0, left_size * metrics.stack_width, metrics.stack_height);
-  }
-  if (right_size > 0) {
-    ctx.fillRect(right_start * metrics.stack_width, 0, right_size * metrics.stack_width, metrics.stack_height);
-  }
-  ctx.fillStyle = "rgb(51, 51, 51)";
-  if (left_size > 0 && left_divider) {
-    line_x = (left_end * metrics.stack_width) - 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  if (right_size > 0 && right_divider) {
-    line_x = (right_start * metrics.stack_width) + 0.5;
-    draw_dashed_line(ctx, [3], 0, line_x, 0, line_x, metrics.stack_height);
-  }
-  ctx.restore();//s8
-}
-
-function size_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var draw_name, draw_finetext, metrics;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  if (canvas.width !== 0 && canvas.height !== 0) {
-    return;
-  }
-  metrics = new LogoMetrics(canvas.getContext('2d'), 
-      logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      canvas.width = metrics.summed_width * (canvas.height / metrics.summed_height);
-    } else if (canvas.height === 0) {
-      canvas.height = metrics.summed_height * (canvas.width / metrics.summed_width);
-    }
-  }
-}
-
-function draw_logo_on_canvas(logo, canvas, show_names, scale) {
-  "use strict";
-  var i, draw_name, draw_finetext, ctx, metrics, raster, pspm_i, pspm, 
-      offset, col_index, motif_position, ssc;
-  ssc = false;
-  draw_name = (typeof show_names === "boolean" ? show_names : (logo.get_rows() > 1));
-  draw_finetext = (logo.fine_text.length > 0);
-  ctx = canvas.getContext('2d');
-  //assume that the user wants the canvas scaled equally so calculate what the best width for this image should be
-  metrics = new LogoMetrics(ctx, logo.get_xlate_columns(), logo.get_rows(), draw_name, draw_finetext, logo.x_axis, logo.y_axis);
-  if (typeof scale == "number") {
-    //resize the canvas to fit the scaled logo
-    canvas.width = metrics.summed_width * scale;
-    canvas.height = metrics.summed_height * scale;
-  } else {
-    if (canvas.width === 0 && canvas.height === 0) {
-      scale = 1;
-      canvas.width = metrics.summed_width;
-      canvas.height = metrics.summed_height;
-    } else if (canvas.width === 0) {
-      scale = canvas.height / metrics.summed_height;
-      canvas.width = metrics.summed_width * scale;
-    } else if (canvas.height === 0) {
-      scale = canvas.width / metrics.summed_width;
-      canvas.height = metrics.summed_height * scale;
-    } else {
-      scale = Math.min(canvas.width / metrics.summed_width, canvas.height / metrics.summed_height);
-    }
-  }
-  // cache the raster based on the assumption that we will be drawing a lot
-  // of logos the same size and alphabet
-  if (typeof draw_logo_on_canvas.raster_cache === "undefined") {
-    draw_logo_on_canvas.raster_cache = [];
-  }
-  for (i = 0; i < draw_logo_on_canvas.raster_cache.length; i++) {
-    raster = draw_logo_on_canvas.raster_cache[i];
-    if (raster.get_alphabet().equals(logo.alphabet) &&
-        Math.abs(raster.get_scale() - scale) < 0.1) break;
-    raster = null;
-  }
-  if (raster == null) {
-    raster = new RasterizedAlphabet(logo.alphabet, scale, metrics.stack_font, metrics.stack_width);
-    draw_logo_on_canvas.raster_cache.push(raster);
-  }
-  ctx = canvas.getContext('2d');
-  ctx.save();//s1
-  ctx.scale(scale, scale);
-  ctx.save();//s2
-  ctx.save();//s7
-  //create margin
-  ctx.translate(Math.round(metrics.pad_left), Math.round(metrics.pad_top));
-  for (pspm_i = 0; pspm_i < logo.get_rows(); ++pspm_i) {
-    pspm = logo.get_pspm(pspm_i);
-    offset = logo.get_offset(pspm_i);
-    //optionally draw name if this isn't the last row or is the only row 
-    if (draw_name && (logo.get_rows() == 1 || pspm_i != (logo.get_rows()-1))) {
-      ctx.save();//s4
-      ctx.translate(Math.round(metrics.summed_width/2), Math.round(metrics.name_height));
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s4
-      ctx.translate(0, Math.round(metrics.name_height + 
-          Math.min(0, metrics.name_spacer - metrics.y_num_height/2)));
-    }
-    //draw scale
-    if (logo.y_axis) draw_scale(ctx, metrics, logo.alphabet.get_ic(), raster);
-    ctx.save();//s5
-    //translate across past the scale
-    if (logo.y_axis) {
-      ctx.translate(Math.round(metrics.y_label_height + metrics.y_label_spacer + 
-        metrics.y_num_width + metrics.y_tic_width), Math.round(metrics.y_num_height / 2));
-    }
-    //draw the trimming background
-    if (pspm.get_left_trim() > 0 || pspm.get_right_trim() > 0) {
-      var left_start = offset * logo.get_xlate_nsyms();
-      var left_end = (offset + pspm.get_left_trim()) * logo.get_xlate_nsyms();
-      var left_divider = true;
-      if (left_end < logo.get_xlate_start() || left_start > logo.get_xlate_end()) {
-        // no overlap
-        left_start = 0;
-        left_end = 0;
-        left_divider = false;
-      } else {
-        if (left_start < logo.get_xlate_start()) {
-          left_start = logo.get_xlate_start();
-        }
-        if (left_end > logo.get_xlate_end()) {
-          left_end = logo.get_xlate_end();
-          left_divider = false;
-        }
-        left_start -= logo.get_xlate_start();
-        left_end -= logo.get_xlate_start();
-        if (left_end < left_start) {
-          left_start = 0;
-          left_end = 0;
-          left_divider = false;
-        }
-      }
-      var right_end = (offset + pspm.get_motif_length()) * logo.get_xlate_nsyms();
-      //var right_start = right_end - (pspm.get_left_trim() * logo.get_xlate_nsyms());
-      var right_start = right_end - (pspm.get_right_trim() * logo.get_xlate_nsyms());
-      var right_divider = true;
-      if (right_end < logo.get_xlate_start() || right_start > logo.get_xlate_end()) {
-        // no overlap
-        right_start = 0;
-        right_end = 0;
-        right_divider = false;
-      } else {
-        if (right_start < logo.get_xlate_start()) {
-          right_start = logo.get_xlate_start();
-          right_divider = false;
-        }
-        if (right_end > logo.get_xlate_end()) {
-          right_end = logo.get_xlate_end();
-        }
-        right_start -= logo.get_xlate_start();
-        right_end -= logo.get_xlate_start();
-        if (right_end < right_start) {
-          right_start = 0;
-          right_end = 0;
-          right_divider = false;
-        }
-      }
-      draw_trim_background(ctx, metrics, left_start, left_end, left_divider, right_start, right_end, right_divider);
-    }
-    //draw letters
-    var xlate_col;
-    for (xlate_col = logo.get_xlate_start(); xlate_col < logo.get_xlate_end(); xlate_col++) {
-      ctx.translate(metrics.stack_pad_left,0);
-      col_index = Math.floor(xlate_col / logo.get_xlate_nsyms());
-      if (xlate_col % logo.get_xlate_nsyms() == 0) {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          motif_position = col_index - offset;
-          draw_stack_num(ctx, metrics, motif_position, raster);
-          draw_stack(ctx, metrics, pspm.get_stack(motif_position, logo.alphabet, ssc), raster);
-        }
-      } else {
-        if (col_index >= offset && col_index < (offset + pspm.get_motif_length())) {
-          ctx.save();// s5.1
-          ctx.translate(0, Math.round(metrics.stack_height));
-          // TODO draw a dot or dash or something to indicate continuity of the motif
-          ctx.restore(); //s5.1
-        }
-      }
-      ctx.translate(Math.round(metrics.stack_width), 0);
-    }
-    ctx.restore();//s5
-    ////optionally draw name if this is the last row but isn't the only row 
-    if (draw_name && (logo.get_rows() != 1 && pspm_i == (logo.get_rows()-1))) {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width + metrics.name_spacer));
-
-      ctx.save();//s6
-      ctx.translate(metrics.summed_width/2, metrics.name_height);
-      ctx.font = metrics.name_font;
-      ctx.textAlign = "center";
-      ctx.fillText(pspm.name, 0, 0);
-      ctx.restore();//s6
-      ctx.translate(0, metrics.name_height);
-    } else {
-      //translate vertically past the stack and axis's        
-      ctx.translate(0, metrics.y_num_height/2 + metrics.stack_height + 
-          Math.max(metrics.y_num_height/2, metrics.x_num_above + metrics.x_num_width));
-    }
-    //if not the last row then add middle padding
-    if (pspm_i != (logo.get_rows() -1)) {
-      ctx.translate(0, metrics.pad_middle);
-    }
-  }
-  ctx.restore();//s7
-  if (logo.fine_text.length > 0) {
-    ctx.translate(metrics.summed_width - metrics.pad_right, metrics.summed_height - metrics.pad_bottom);
-    ctx.font = metrics.fine_txt_font;
-    ctx.textAlign = "right";
-    ctx.fillText(logo.fine_text, 0,0);
-  }
-  ctx.restore();//s2
-  ctx.restore();//s1
-}
-
-function create_canvas(c_width, c_height, c_id, c_title, c_display) {
-  "use strict";
-  var canvas = document.createElement("canvas");
-  //check for canvas support before attempting anything
-  if (!canvas.getContext) {
-    return null;
-  }
-  var ctx = canvas.getContext('2d');
-  //check for html5 text drawing support
-  if (!supports_text(ctx)) {
-    return null;
-  }
-  //size the canvas
-  canvas.width = c_width;
-  canvas.height = c_height;
-  canvas.id = c_id;
-  canvas.title = c_title;
-  canvas.style.display = c_display;
-  return canvas;
-}
-
-function logo_1(alphabet, fine_text, pspm) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  logo.add_pspm(pspm);
-  return logo;
-}
-
-function logo_2(alphabet, fine_text, target, query, query_offset) {
-  "use strict";
-  var logo = new Logo(alphabet, fine_text);
-  if (query_offset < 0) {
-    logo.add_pspm(target, -query_offset);
-    logo.add_pspm(query);
-  } else {
-    logo.add_pspm(target);
-    logo.add_pspm(query, query_offset);
-  }      
-  return logo;
-}
-
-/*
- * Specifies an alternate source for an image.
- * If the image with the image_id specified has
- * not loaded then a generated logo will be used 
- * to replace it.
- *
- * Note that the image must either have dimensions
- * or a scale must be set.
- */
-function alternate_logo(logo, image_id, scale) {
-  "use strict";
-  var image = document.getElementById(image_id);
-  if (!image) {
-    alert("Can't find specified image id (" +  image_id + ")");
-    return;
-  }
-  //if the image has loaded then there is no reason to use the canvas
-  if (image_ok(image)) {
-    return;
-  }
-  //the image has failed to load so replace it with a canvas if we can.
-  var canvas = create_canvas(image.width, image.height, image_id, image.title, image.style.display);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the image with the canvas
-  image.parentNode.replaceChild(canvas, image);
-}
-
-/*
- * Specifes that the element with the specified id
- * should be replaced with a generated logo.
- */
-function replace_logo(logo, replace_id, scale, title_txt, display_style) {
-  "use strict";
-  var element = document.getElementById(replace_id);
-  if (!replace_id) {
-    alert("Can't find specified id (" + replace_id + ")");
-    return;
-  }
-  //found the element!
-  var canvas = create_canvas(50, 120, replace_id, title_txt, display_style);
-  if (canvas === null) {
-    return;
-  }
-  //draw the logo on the canvas
-  draw_logo_on_canvas(logo, canvas, null, scale);
-  //replace the element with the canvas
-  element.parentNode.replaceChild(canvas, element);
-}
-
-/*
- * Fast string trimming implementation found at
- * http://blog.stevenlevithan.com/archives/faster-trim-javascript
- *
- * Note that regex is good at removing leading space but
- * bad at removing trailing space as it has to first go through
- * the whole string.
- */
-function trim (str) {
-  "use strict";
-  var ws, i;
-  str = str.replace(/^\s\s*/, '');
-  ws = /\s/; i = str.length;
-  while (ws.test(str.charAt(--i)));
-  return str.slice(0, i + 1);
-}
-</script>
-    <script>
-
-// PRIVATE GLOBAL (uhoh)
-var _block_colour_lookup = {};
-
-function block_colour(index) {
-  function hsl2rgb(hue, saturation, lightness) {
-    "use strict";
-    function _hue(p, q, t) {
-      "use strict";
-      if (t < 0) t += 1;
-      else if (t > 1) t -= 1;
-      if (t < (1.0 / 6.0)) {
-        return p + ((q - p) * 6.0 * t);
-      } else if (t < 0.5) {
-        return q;
-      } else if (t < (2.0 / 3.0)) {
-        return p + ((q - p) * ((2.0 / 3.0) - t) * 6.0);
-      } else {
-        return p;
-      }
-    }
-    function _pad_hex(value) {
-      var hex = Math.round(value * 255).toString(16);
-      if (hex.length < 2) hex = "0" + hex;
-      return hex;
-    }
-    var r, g, b, p, q;
-    if (saturation == 0) {
-      // achromatic (grayscale)
-      r = lightness;
-      g = lightness;
-      b = lightness;
-    } else {
-      if (lightness < 0.5) {
-        q = lightness * (1 + saturation);
-      } else {
-        q = lightness + saturation - (lightness * saturation);
-      }
-      p = (2 * lightness) - q;
-      r = _hue(p, q, hue + (1.0 / 3.0));
-      g = _hue(p, q, hue);
-      b = _hue(p, q, hue - (1.0 / 3.0));
-    }
-    return "#" + _pad_hex(r) + _pad_hex(g) + _pad_hex(b);
-  }
-  if (typeof index !== "number" || index % 1 !== 0 || index < 0) return "#000000";
-  // check for override
-  if (_block_colour_lookup[index] == null) {
-    var start = 0; //red
-    var sat = 100;
-    var light = 50;
-    var divisions = 1 << Math.ceil(Math.log(index + 1) / Math.LN2);
-    hue = start + (360 / divisions) * ((index - (divisions >> 1)) * 2 + 1);
-    // colour input fields only support values in the form #RRGGBB
-    _block_colour_lookup[index] = hsl2rgb(hue / 360, sat / 100, light / 100);
-  }
-  return _block_colour_lookup[index];
-}
-
-function set_block_colour(index, new_colour) {
-  _block_colour_lookup[index] = new_colour;
-  var blocks = document.querySelectorAll("div.block_motif[data-colour-index=\"" + index + "\"]");
-  var i;
-  for (i = 0; i < blocks.length; i++) {
-    blocks[i].style.backgroundColor = new_colour;
-  }
-  var swatches = document.querySelectorAll("div.legend_swatch[data-colour-index=\"" + index + "\"]");
-  var picker;
-  for (i = 0; i < swatches.length; i++) {
-    swatches[i].style.backgroundColor = new_colour;
-    picker = swatches[i].querySelector("input[type=\"color\"]");
-    if (picker != null) picker.value = new_colour;
-  }
-}
-
-function make_block_legend_entry(motif_name, motif_colour_index) {
-  if (typeof make_block_legend_entry.has_colour_picker !== "boolean") {
-    // test if colour picker is supported, based off Modernizer
-    // see http://stackoverflow.com/a/7787648/66387
-    make_block_legend_entry.has_colour_picker = (function() {
-      var doc_ele = document.documentElement;
-      // We first check to see if the type we give it sticks..
-      var input_ele = document.createElement('input');
-      input_ele.setAttribute('type', 'color');
-      var value_ok = input_ele.type !== 'text';
-      if (value_ok) {
-        // If the type does, we feed it a textual value, which shouldn't be valid.
-        // If the value doesn't stick, we know there's input sanitization which infers a custom UI
-        var smile = ':)';
-        input_ele.value = smile;
-        input_ele.style.cssText = 'position:absolute;visibility:hidden;';
-        // chuck into DOM and force reflow for Opera bug in 11.00
-        // github.com/Modernizr/Modernizr/issues#issue/159
-        doc_ele.appendChild(input_ele);
-        doc_ele.offsetWidth;
-        value_ok = input_ele.value != smile;
-        doc_ele.removeChild(input_ele);
-      }
-      return value_ok;
-    })();
-  }
-  var entry = document.createElement("div");
-  entry.className = "legend_entry";
-  var swatch;
-  swatch = document.createElement("div");
-  swatch.className = "legend_swatch";
-  swatch.setAttribute("data-colour-index", motif_colour_index);
-  swatch.style.backgroundColor = block_colour(motif_colour_index);
-  if (make_block_legend_entry.has_colour_picker) {
-    var picker = document.createElement("input");
-    picker.type = "color";
-    picker.value = block_colour(motif_colour_index);
-    picker.addEventListener("change", function(e) {
-      set_block_colour(motif_colour_index, picker.value);
-    }, false);
-    swatch.addEventListener("click", function(e) {
-      picker.click();
-    }, false);
-    swatch.appendChild(picker);
-  }
-  entry.appendChild(swatch);
-  var name = document.createElement("div");
-  name.className = "legend_text";
-  name.appendChild(document.createTextNode(motif_name));
-  entry.appendChild(name);
-  return entry;
-}
-
-function make_block_ruler(max_len) {
-  var container = document.createElement("div");
-  container.className = "block_container";
-  var step;
-  if (max_len < 50) {
-    step = 1;
-  } else if (max_len < 100) {
-    step = 2;
-  } else if (max_len < 200) {
-    step = 4;
-  } else if (max_len < 500) {
-    step = 10;
-  } else if (max_len < 1000) {
-    step = 20;
-  } else if (max_len < 2000) {
-    step = 40;
-  } else if (max_len < 5000) {
-    step = 100;
-  } else if (max_len < 10000) {
-    step = 200;
-  } else if (max_len < 20000) {
-    step = 400;
-  } else {
-    step = Math.floor(max_len / 20000) * 400;
-  }
-  var peroid;
-  if (max_len < 10) {
-    peroid = 1;
-  } else if (max_len < 20) {
-    peroid = 2;
-  } else {
-    peroid = 5;
-  }
-  var i, cycle, offset, tic, label;
-  for (i = 0, cycle = 0; i < max_len; i += step, cycle = (cycle + 1) % peroid) {
-    offset = "" + ((i / max_len) * 100) + "%";
-    tic = document.createElement("div");
-    tic.style.left = offset;
-    tic.className = (cycle == 0 ? "tic_major" : "tic_minor");
-    container.appendChild(tic);
-    if (cycle == 0) {
-      label = document.createElement("div");
-      label.className = "tic_label";
-      label.style.left = offset;
-      label.appendChild(document.createTextNode(i));
-      container.appendChild(label);
-    }
-  }
-  return container;
-}
-
-function _calculate_block_needle_drag_pos(e, data) {
-  var mouse;
-  e = e || window.event;
-  if (e.pageX || ev.pageY) {
-    mouse = {"x": e.pageX, "y": e.pageY};
-  } else {
-    mouse = {
-      x:e.clientX + document.body.scrollLeft - document.body.clientLeft, 
-      y:e.clientY + document.body.scrollTop  - document.body.clientTop 
-    };
-  }
-  var cont = data.container;
-  var dragable_length = cont.clientWidth - 
-    (cont.style.paddingLeft ? cont.style.paddingLeft : 0) -
-    (cont.style.paddingRight ? cont.style.paddingRight : 0);
-  //I believe that the offset parent is the body
-  //otherwise I would need to make this recursive
-  //maybe clientLeft would work, but the explanation of
-  //it is hard to understand and it apparently doesn't work
-  //in firefox 2.
-  var diff = mouse.x - cont.offsetLeft;
-  if (diff < 0) diff = 0;
-  if (diff > dragable_length) diff = dragable_length;
-  var pos = Math.round(diff / dragable_length * data.max);
-  if (pos > data.len) pos = data.len;
-  return pos;
-}
-
-function _update_block_needle_drag(e, data, done) {
-  "use strict";
-  var pos = _calculate_block_needle_drag_pos(e, data);
-  // read the needle positions
-  var left = parseInt(data.llabel.textContent, 10) - data.off - 1;
-  var right = parseInt(data.rlabel.textContent, 10) - data.off;
-  // validate needle positions
-  if (left >= data.len) left = data.len - 1;
-  if (left < 0) left = 0;
-  if (right > data.len) right = data.len;
-  if (right <= left) right = left + 1;
-  // calculate the new needle positions
-  if (data.moveboth) {
-    var size = right - left;
-    if (data.isleft) {
-      if ((pos + size) > data.len) pos = data.len - size;
-      left = pos;
-      right = pos + size;
-    } else {
-      if ((pos - size) < 0) pos = size;
-      left = pos - size;
-      right = pos;
-    }
-  } else {
-    if (data.isleft) {
-      if (pos >= right) pos = right - 1;
-      left = pos;
-    } else {
-      if (pos <= left) pos = left + 1;
-      right = pos;
-    }
-  }
-  // update the needle positions
-  data.lneedle.style.left = "" + (left / data.max * 100) + "%";
-  data.llabel.textContent = "" + (left + data.off + 1);
-  data.rneedle.style.left = "" + (right / data.max * 100) + "%";
-  data.rlabel.textContent = "" + (right + data.off);
-  data.handler(left, right, done);
-}
-
-function _make_block_needle_drag_start_handler(isleft, data) {
-  return function (e) {
-    data.isleft = isleft;
-    data.moveboth = !(e.shiftKey);
-    document.addEventListener("mousemove", data.drag_during, false);
-    document.addEventListener("mouseup", data.drag_end, false);
-  };
-}
-
-function _make_block_needle_drag_end_handler(data) {
-  return function (e) {
-    document.removeEventListener("mousemove", data.drag_during, false);
-    document.removeEventListener("mouseup", data.drag_end, false);
-    _update_block_needle_drag(e, data, true);
-  };
-}
-
-function _make_block_needle_drag_during_handler(data) {
-  return function (e) {
-    _update_block_needle_drag(e, data, false);
-  };
-}
-
-// private function used by make_block_container
-function _make_block_needle(isleft, value, data) {
-  var vbar = document.createElement('div');
-  vbar.className = "block_needle " + (isleft ? "left" : "right");
-  vbar.style.left = "" + (value / data.max * 100)+ "%";
-  var label = document.createElement('div');
-  label.className = "block_handle " + (isleft ? "left" : "right");
-  // The needles sit between the sequence positions, so the left one sits at the
-  // start and the right at the end. This is why 1 is added to the displayed
-  // value for a left handle as the user doesn't need to know about this detail
-  label.textContent = "" + (isleft ? value + data.off + 1 : value + data.off);
-  label.unselectable = "on"; // so IE and Opera don't select the text, others are done in css
-  label.title = "Drag to move the displayed range. Hold shift and drag to change " + (isleft ? "lower" : "upper") + " bound of the range.";
-  vbar.appendChild(label);
-  if (isleft) {
-    data.lneedle = vbar;
-    data.llabel = label;
-  } else {
-    data.rneedle = vbar;
-    data.rlabel = label;
-  }
-  label.addEventListener("mousedown", _make_block_needle_drag_start_handler(isleft, data), false);
-  return vbar;
-}
-
-function make_block_container(is_stranded, has_both_strands, max_len, show_len, offset, range_handler) {
-  offset = (offset != null ? offset : 0);
-  // make the container for the block diagram
-  var container = document.createElement("div");
-  container.className = "block_container";
-  container.setAttribute("data-max", max_len);
-  container.setAttribute("data-off", offset);
-  if (is_stranded) {
-    var plus = document.createElement("div");
-    plus.appendChild(document.createTextNode("+"));
-    plus.className = "block_plus_sym";
-    container.appendChild(plus);
-    if (has_both_strands) {
-      var minus = document.createElement("div");
-      minus.appendChild(document.createTextNode("-"));
-      minus.className = "block_minus_sym";
-      container.appendChild(minus);
-    }
-  }
-  var rule = document.createElement("div");
-  rule.className = "block_rule";
-  rule.style.width = ((show_len / max_len) * 100) + "%";
-  container.appendChild(rule);
-  if (range_handler != null) {
-    var range_data = {
-      "max": max_len,
-      "len": show_len,
-      "off": offset,
-      "handler": range_handler,
-      "container": container,
-      "lneedle": null, "llabel": null,
-      "rneedle": null, "rlabel": null,
-      "isleft": false, "moveboth" : false
-    };
-    range_data.drag_during = _make_block_needle_drag_during_handler(range_data);
-    range_data.drag_end = _make_block_needle_drag_end_handler(range_data);
-    container.appendChild(_make_block_needle(false, 1, range_data)); // add right first so z-index works
-    container.appendChild(_make_block_needle(true, 0, range_data));
-  }
-  return container;
-}
-
-function make_block_label(container, max_len, pos, length, message) {
-  "use strict";
-  var label = document.createElement("div");
-  label.className = "block_label";
-  label.style.left = (((pos + (length / 2)) / max_len) * 100) + "%";
-  label.appendChild(document.createTextNode(message));
-  container.appendChild(label);
-}
-
-function make_block(container, max_len,
-    site_pos, site_len, site_pvalue, site_rc, site_colour_index, site_secondary) {
-  "use strict";
-  var block_height, block, block_region1, block_region2;
-  var max_block_height = 12;
-  var max_pvalue = 1e-10;
-  // calculate the height of the block
-  block_height = (site_pvalue < max_pvalue ? max_block_height : 
-      (Math.log(site_pvalue) / Math.log(max_pvalue)) * max_block_height);
-  if (block_height < 1) block_height = 1;
-  // create a block to represent the motif
-  block = document.createElement("div");
-  block.className = "block_motif" + (site_secondary ? " scanned_site" : "") + (site_rc ? " bottom" : " top");
-  block.style.left = ((site_pos / max_len) * 100) + "%";
-  block.style.top = (!site_rc ? max_block_height - block_height : 
-      max_block_height + 1) + "px";
-  block.style.width = ((site_len / max_len) * 100) + "%";
-  block.style.height = block_height + "px";
-  block.style.backgroundColor = block_colour(site_colour_index);
-  block.setAttribute("data-colour-index", site_colour_index);
-  // add to container
-  container.appendChild(block);
-  var activator = function (e) {
-    toggle_class(block, "active", true);
-    var new_e = new e.constructor(e.type, e);
-    block.dispatchEvent(new_e);
-  };
-  var deactivator = function (e) {
-    toggle_class(block, "active", false);
-    var new_e = new e.constructor(e.type, e);
-    block.dispatchEvent(new_e);
-  }
-  // create a larger region to detect mouseover for the block
-  block_region1 = document.createElement("div");
-  block_region1.className = "block_region top" + 
-    (site_secondary ? " scanned_site" : "") + (site_rc ? "" : " main");
-  block_region1.style.left = block.style.left;
-  block_region1.style.width = block.style.width;
-  block_region1.addEventListener('mouseover', activator, false);
-  block_region1.addEventListener('mouseout', deactivator, false);
-  container.appendChild(block_region1);
-  block_region2 = document.createElement("div");
-  block_region2.className = "block_region bottom" + 
-    (site_secondary ? " scanned_site" : "") + (site_rc ? " main" : "");
-  block_region2.style.left = block.style.left;
-  block_region2.style.width = block.style.width;
-  block_region2.addEventListener('mouseover', activator, false);
-  block_region2.addEventListener('mouseout', deactivator, false);
-  container.appendChild(block_region2);
-  return block;
-}
-
-function set_block_needle_positions(containingNode, start, end) {
-  var container, lneedle, llabel, rneedle, rlabel, max, off, left, right;
-  container = (/\bblock_container\b/.test(containingNode.className) ? containingNode : containingNode.querySelector(".block_container"));
-  max = parseInt(container.getAttribute("data-max"), 10);
-  off = parseInt(container.getAttribute("data-off"), 10);
-  left = start - off;
-  right = end - off;
-  lneedle = containingNode.querySelector(".block_needle.left");
-  llabel = lneedle.querySelector(".block_handle.left");
-  rneedle = containingNode.querySelector(".block_needle.right");
-  rlabel = rneedle.querySelector(".block_handle.right");
-  // update the needle positions
-  lneedle.style.left = "" + (left / max * 100) + "%";
-  llabel.textContent = "" + (left + off + 1);
-  rneedle.style.left = "" + (right / max * 100) + "%";
-  rlabel.textContent = "" + (right + off);
-}
-
-function get_block_needle_positions(containingNode) {
-  var container, llabel, rlabel, max, off, left, right;
-  container = (/\bblock_container\b/.test(containingNode.className) ? containingNode : containingNode.querySelector(".block_container"));
-  max = parseInt(container.getAttribute("data-max"), 10);
-  off = parseInt(container.getAttribute("data-off"), 10);
-  llabel = containingNode.querySelector(".block_needle.left > .block_handle.left");
-  rlabel = containingNode.querySelector(".block_needle.right > .block_handle.right");
-  left = parseInt(llabel.textContent, 10) - off - 1;
-  right = parseInt(rlabel.textContent, 10) - off;
-  return {"start": left + off, "end": right + off};
-}
-</script>
-    <script>
-function make_alpha_bg_table(alph, freqs) {
-  function colour_symbol(index) {
-    var span = document.createElement("span");
-    span.appendChild(document.createTextNode(alph.get_symbol(index)));
-    span.style.color = alph.get_colour(index);
-    span.className = "alpha_symbol";
-    return span;
-  }
-  var table, thead, tbody, row, th, span, i;
-  // create table
-  table = document.createElement("table");
-  table.className = "alpha_bg_table";
-  // create header
-  thead = document.createElement("thead");
-  table.appendChild(thead);
-  row = thead.insertRow(thead.rows.length);
-  if (alph.has_complement()) {
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-  } else {
-    add_text_header_cell(row, "");
-    add_text_header_cell(row, "Name", "pop_alph_name");
-    if (freqs != null) add_text_header_cell(row, "Freq.", "pop_alph_freq");
-    if (alph.has_bg()) add_text_header_cell(row, "Bg.", "pop_alph_bg");
-  }
-  // add alphabet entries
-  tbody = document.createElement("tbody");
-  table.appendChild(tbody);
-  if (alph.has_complement()) {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      var c = alph.get_complement(i);
-      if (i > c) continue;
-      row = tbody.insertRow(tbody.rows.length);
-      add_text_cell(row, alph.get_name(i));
-      if (freqs != null) add_text_cell(row, "" + freqs[i].toFixed(3));
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(i).toFixed(3));
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, "~");
-      add_cell(row, colour_symbol(c)); 
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(c).toFixed(3));
-      if (freqs != null) add_text_cell(row, "" + freqs[c].toFixed(3));
-      add_text_cell(row, alph.get_name(c));
-    }
-  } else {
-    for (i = 0; i < alph.get_size_core(); i++) {
-      row = tbody.insertRow(tbody.rows.length);
-      add_cell(row, colour_symbol(i)); 
-      add_text_cell(row, alph.get_name(i));
-      if (freqs != null) add_text_cell(row, "" + freqs[i].toFixed(3));
-      if (alph.has_bg()) add_text_cell(row, "" + alph.get_bg_freq(i).toFixed(3));
-    }
-  }
-  return table;
-}
-
-</script>
-    <script>
-var current_motif = 0;
-var meme_alphabet = new Alphabet(data.alphabet, data.background.freqs);
-
-var DelayLogoTask = function(logo, canvas) {
-  this.logo = logo;
-  this.canvas = canvas;
-};
-
-DelayLogoTask.prototype.run = function () {
-  draw_logo_on_canvas(this.logo, this.canvas, false);
-};
-
-function motif_pspm(index) {
-  var motif, pwm, psm, name, ltrim, rtrim, nsites, evalue;
-  // get motif
-  motif = data["motifs"][index];
-  // get motif paramters
-  pwm = motif["pwm"]; 
-  psm = motif["psm"];
-  name = "" + (index + 1); ltrim = 0; rtrim = 0; 
-  nsites = motif["nsites"]; evalue = motif["evalue"];
-  // make pspm
-  return new Pspm(pwm, name, ltrim, rtrim, nsites, evalue, psm);
-}
-
-function motif_count_matrix(index) {
-  return motif_pspm(index).as_count_matrix();
-}
-
-function motif_prob_matrix(index) {
-  return motif_pspm(index).as_probability_matrix();
-}
-
-function motif_minimal_meme(index) {
-  return motif_pspm(index).as_meme({
-    "with_header": true, 
-    "with_pspm": true,
-    "with_pssm": true,
-    "version": data["version"],
-    "alphabet": meme_alphabet,
-    "strands": (meme_alphabet.has_complement() && data.options.revcomp ? 2 : 1)
-  });
-}
-
-function motif_fasta(index) {
-  "use strict";
-  var motif, sites, site, seq, sequences, sequence, i, num, counter, out;
-  counter = {};
-  sequences = data["sequence_db"]["sequences"];
-  motif = data["motifs"][index];
-  sites = motif["sites"];
-  out = "";
-  for (i = 0; i < sites.length; i++) {
-    site = sites[i];
-    seq = site["seq"];
-    sequence = sequences[seq];
-    counter[seq] = (num = counter[seq]) ? (++num) : (num = 1); // inc counter
-    if (i !== 0) {out += "\n";}
-    out += ">" + sequence["name"] + "_site_" + num + " offset= " + site["pos"] + 
-      (site["rc"] ? " RC\n" : "\n");
-    out += site["match"];
-  }
-  return out;
-}
-
-function motif_raw(index) {
-  "use strict";
-  var sites, i, out;
-  sites = data["motifs"][index]["sites"];
-  out = "";
-  for (i = 0; i < sites.length; i++) {
-    if (i !== 0) {out += "\n";}
-    out += sites[i]["match"];
-  }
-  return out;
-}
-
-function clone_template(template) {
-  "use strict";
-  var node, help_btns, i, button;
-  node = $(template).cloneNode(true);
-  toggle_class(node, "template", false);
-  node.id = "";
-  help_btns = node.querySelectorAll(".help");
-  for (i = 0; i < help_btns.length; i++) {
-    button = help_btns[i];
-    if (button.hasAttribute("data-topic")) {
-      button.tabIndex = "0";
-      button.addEventListener("click", __toggle_help, false);
-      button.addEventListener("keydown", __toggle_help, false);
-    }
-  }
-  return node;
-}
-
-function set_tvar(template, tvar, value) {
-  var node;
-  node = find_child(template, tvar);
-  if (node === null) {
-    throw new Error("Template does not contain variable " + tvar);
-  }
-  node.innerHTML = "";
-  if (typeof value !== "object") {
-    node.appendChild(document.createTextNode(value));
-  } else {
-    node.appendChild(value);
-  }
-}
-
-function make_logo(alphabet, pspm, rc, offset, className) {
-  if (rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, "");
-  logo.add_pspm(pspm, offset);
-  var canvas = document.createElement('canvas');
-  canvas.height = 50;
-  canvas.width = 0;
-  canvas.className = className;
-  size_logo_on_canvas(logo, canvas, false);
-  add_draw_task(canvas, new DelayLogoTask(logo, canvas));
-  return canvas;
-}
-
-function make_small_logo(alphabet, pspm, options) {
-  if (typeof options === "undefined") options = {};
-  if (options.rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, {x_axis: false, y_axis: false});
-  logo.add_pspm(pspm, (typeof options.offset === "number" ? options.offset : 0));
-  var canvas = document.createElement('canvas');
-  if (typeof options.className === "string") canvas.className = options.className;
-  if (typeof options.width === "number" && options.width > 0) {
-    canvas.height = 0;
-    canvas.width = options.width;
-    draw_logo_on_canvas(logo, canvas, false);
-  } else {
-    draw_logo_on_canvas(logo, canvas, false, 1/3);
-  }
-  return canvas;
-}
-
-function make_large_logo(alphabet, pspm, rc, offset, className) {
-  if (rc) pspm = pspm.copy().reverse_complement(alphabet);
-  var logo = new Logo(alphabet, "");
-  logo.add_pspm(pspm, offset);
-  var canvas = document.createElement('canvas');
-  canvas.height = 200;
-  canvas.width = 0;
-  canvas.className = className;
-  size_logo_on_canvas(logo, canvas, false);
-  add_draw_task(canvas, new DelayLogoTask(logo, canvas));
-  return canvas;
-}
-
-function make_sym_btn(symbol, title, action) {
-  var box;
-  box = document.createElement("div");
-  box.tabIndex = 0;
-  box.className = "sym_btn";
-  box.appendChild(document.createTextNode(symbol));
-  box.title = title;
-  box.addEventListener('click', action, false);
-  box.addEventListener('keydown', action, false);
-  return box;
-}
-
-function make_seq(alphabet, seq) {
-  var i, j, letter, lbox, sbox;
-  sbox = document.createElement("span");
-  for (i = 0; i < seq.length; i = j) {
-    letter = seq.charAt(i);
-    for (j = i+1; j < seq.length; j++) {
-      if (seq.charAt(j) !== letter) {
-        break;
-      }
-    }
-    lbox = document.createElement("span");
-    lbox.style.color = alphabet.get_colour(alphabet.get_index(letter));
-    lbox.appendChild(document.createTextNode(seq.substring(i, j)));
-    sbox.appendChild(lbox);
-  }
-  return sbox;
-}
-
-//
-// make_pv_text
-//
-// Returns the string p-value, with the p italicised.
-///
-function make_pv_text() {
-  var pv_text = document.createElement("span");
-  var pv_italic_text = document.createElement("span");
-  pv_italic_text.appendChild(document.createTextNode("p"));
-  pv_italic_text.style.fontStyle = "italic";
-  pv_text.appendChild(pv_italic_text);
-  pv_text.appendChild(document.createTextNode("-value"));
-  return pv_text;
-}
-
-function append_site_entries(tbody, motif, site_index, count) {
-  "use strict";
-  var i, end;
-  var sites, site, sequences, sequence;
-  var rbody;
-  if (typeof count !== "number") {
-    count = 20;
-  }
-  sequences = data["sequence_db"]["sequences"];
-  sites = motif["sites"];
-  end = Math.min(site_index + count, sites.length);
-  for (i = site_index; i < end; i++) {
-    site = sites[i];
-    sequence = sequences[site["seq"]];
-
-    rbody = tbody.insertRow(tbody.rows.length);
-    add_text_cell(rbody, "" + (site["seq"] + 1) + ".", "site_num");
-    add_text_cell(rbody, sequence["name"], "site_name");
-    add_text_cell(rbody, site["rc"] ? "-" : "+", "site_strand");
-    add_text_cell(rbody, site["pos"] + 1, "site_start");
-    add_text_cell(rbody, site["pvalue"].toExponential(2), "site_pvalue");
-    add_text_cell(rbody, site["lflank"], "site lflank");
-    add_cell(rbody, make_seq(meme_alphabet, site["match"]), "site match");
-    add_text_cell(rbody, site["rflank"], "site rflank");
-  }
-  return i;
-}
-
-function make_site_entries() {
-  "use strict";
-  var region;
-  region = this;
-  if (region.data_site_index >= region.data_motif["sites"].length) {
-    // all sites created
-    region.removeEventListener('scroll', make_site_entries, false);
-    return;
-  }
-  // if there's still 100 pixels to scroll than don't do anything yet
-  if (region.scrollHeight - (region.scrollTop + region.offsetHeight) > 100) {
-    return;
-  }
-
-  region.data_site_index = append_site_entries(
-      find_child(region, "sites_tbl").tBodies[0], 
-      region.data_motif, region.data_site_index, 20
-    ); 
-}
-
-function make_sites(motif) {
-  "use strict";
-  function add_site_header(row, title, nopad, help_topic, tag_class) {
-    var div, divcp, th;
-    th = document.createElement("th");
-    div = document.createElement("div");
-    div.className = "sites_th_inner";
-    if (typeof title !== "object") {
-      title = document.createTextNode("" + title);
-    }
-    div.appendChild(title);
-    if (help_topic) {
-      div.appendChild(document.createTextNode("\xA0"));
-      div.appendChild(help_button(help_topic));
-    }
-    divcp = div.cloneNode(true);
-    divcp.className = "sites_th_hidden";
-    th.appendChild(div);
-    th.appendChild(divcp);
-    if (nopad) {
-      th.className = "nopad";
-    }
-    if (tag_class) {
-      th.className += " " + tag_class;
-    }
-    row.appendChild(th);
-  }
-  var outer_tbl, inner_tbl, tbl, thead, tbody, rhead;
-
-  outer_tbl = document.createElement("div");
-  outer_tbl.className = "sites_outer";
-
-  inner_tbl = document.createElement("div");
-  inner_tbl.className = "sites_inner";
-  outer_tbl.appendChild(inner_tbl);
-
-  tbl = document.createElement("table");
-  tbl.className = "sites_tbl";
-  inner_tbl.appendChild(tbl);
-
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-
-  rhead = thead.insertRow(thead.rows.length);
-  add_site_header(rhead, "", true);
-  add_site_header(rhead, "Name", false, "pop_seq_name");
-  add_site_header(rhead, "Strand", false, "pop_site_strand", "site_strand_title");
-  add_site_header(rhead, "Start", false, "pop_site_start");
-  add_site_header(rhead, make_pv_text(), false, "pop_site_pvalue");
-  add_site_header(rhead, "", false);
-  add_site_header(rhead, "Sites", true, "pop_site_match");
-  add_site_header(rhead, "", false);
-
-  inner_tbl.data_motif = motif;
-  inner_tbl.data_site_index = append_site_entries(tbody, motif, 0, 20);
-  if (inner_tbl.data_site_index < motif["sites"].length) {
-    inner_tbl.addEventListener('scroll', make_site_entries, false);
-  }
-  return outer_tbl;
-}
-
-function make_motif_table_entry(row, alphabet, ordinal, motif, colw) {
-  "use strict";
-  function ev_sig(evalue_str) {
-    "use strict";
-    var ev_re, match, sig, exp, num;
-    ev_re = /^(.*)e(.*)$/;
-    if (match = ev_re.exec(evalue_str)) {
-      sig = parseFloat(match[1]);
-      exp = parseInt(match[2]);
-      if (exp >= 0) {
-        return false;
-      } else if (exp <= -3) {
-        return true;
-      } else {
-        return sig * Math.pow(10, exp) <= 0.05;
-      }
-    }
-    return true;
-  }
-  function make_preview(alphabet, motif) {
-    "use strict";
-    var pspm, preview, preview_rc;
-    var box, btn_box, logo_box, btn_plus, btn_minus;
-    if (motif["preview_logo"]) {
-      preview = motif["preview_logo"];
-      preview_rc = motif["preview_logo_rc"];
-    } else {
-      pspm = new Pspm(motif["pwm"]);
-      preview = make_logo(alphabet, pspm);
-      motif["preview_logo"] = preview;
-      if (alphabet.has_complement()) {
-        preview_rc = make_logo(alphabet, pspm, true, 0, "logo_rc");
-        motif["preview_logo_rc"] = preview_rc;
-      }
-    }
-    if (preview_rc) {
-      btn_plus = document.createElement("div");
-      btn_plus.appendChild(document.createTextNode("+"));
-      btn_plus.className = "preview_btn plus";
-      btn_plus.tabIndex = "0";
-      btn_plus.addEventListener("click", action_btn_rc, false);
-      btn_plus.addEventListener("keydown", action_btn_rc, false);
-      btn_minus = document.createElement("div");
-      btn_minus.appendChild(document.createTextNode("-"));
-      btn_minus.className = "preview_btn minus";
-      btn_minus.tabIndex = "0";
-      btn_minus.addEventListener("click", action_btn_rc, false);
-      btn_minus.addEventListener("keydown", action_btn_rc, false);
-      btn_box = document.createElement("div");
-      btn_box.className = "preview_btn_box";
-      btn_box.appendChild(btn_plus);
-      btn_box.appendChild(btn_minus);
-    }
-    logo_box = document.createElement("div");
-    logo_box.className = "preview_logo_box";
-    logo_box.appendChild(preview);
-    if (preview_rc) logo_box.appendChild(preview_rc);
-    box = document.createElement("div");
-    box.className = "preview_box";
-    if (preview_rc) box.appendChild(btn_box);
-    box.appendChild(logo_box);
-    if (preview_rc) {
-      if (motif["rc"]) {
-        btn_minus.className += " active";
-        logo_box.className += " show_rc_logo";
-      } else {
-        btn_plus.className += " active";
-      }
-    }
-    return box;
-  }
-  var pspm, preview, preview_rc, c;
-  row.data_motif = motif;
-  row.data_ordinal = ordinal;
-  if (!ev_sig(motif["evalue"])) {
-    row.style.opacity = 0.4;
-  }
-  add_text_cell(row, "" + ordinal + ".", "motif_ordinal");
-  add_cell(row, make_preview(alphabet, motif), "motif_logo");
-  add_text_cell(row, motif["evalue"], "motif_evalue");
-  add_text_cell(row, motif["nsites"], "motif_nsites");
-  add_text_cell(row, motif["len"], "motif_width");
-  add_cell(row, make_sym_btn("\u21A7", "Show more information.", 
-        action_show_more), "motif_more");
-  add_cell(row, 
-      make_sym_btn("\u21E2", 
-        "Submit the motif to another MEME Suite program or download it.",
-        action_show_outpop), 
-      "motif_submit");
-  if (colw) {
-    for (c = 0; c < row.cells.length; c++) {
-      row.cells[c].style.minWidth = colw[c] + "px";
-    }
-  }
-}
-
-function make_motifs_table(alphabet, start_ordinal, motifs, colw, stop_reason) {
-  var i, j;
-  var tbl, thead, tbody, tfoot, row, preview;
-  var motif, pspm;
-
-  tbl = document.createElement("table");
-  
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-  tfoot = document.createElement("tfoot");
-  tbl.appendChild(tfoot);
-
-  row = thead.insertRow(thead.rows.length);
-  add_text_header_cell(row, "", "", "motif_ordinal");
-  add_text_header_cell(row, "Logo", "", "motif_logo");
-  add_text_header_cell(row, "E-value", "pop_ev", "motif_evalue");
-  add_text_header_cell(row, "Sites", "pop_sites", "motif_nsites");
-  add_text_header_cell(row, "Width", "pop_width", "motif_width");
-  add_text_header_cell(row, "More", "pop_more", "motif_more");
-  add_text_header_cell(row, "Submit/Download", "pop_submit_dl", "motif_submit");
-
-  for (i = 0; i < motifs.length; i++) {
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, alphabet, start_ordinal + i, motifs[i], colw);
-  }
-
-  row = tfoot.insertRow(tfoot.rows.length);
-  add_text_header_cell(row, stop_reason, "", "stop_reason", "", 6);
-
-  return tbl;
-}
-
-function make_expanded_motif(alphabet, ordinal, motif, less_x, submit_x) {
-  "use strict";
-  var box, pspm, logo_box, large_logo, large_logo_rc, tab_logo, tab_logo_rc;
-  var btn, offset, norc;
-
-  box = clone_template("tmpl_motif_expanded");
-  box.data_motif = motif;
-  box.data_ordinal = ordinal;
-
-  pspm = new Pspm(motif["pwm"]);
-  if (typeof motif["rc"] !== "boolean") {
-    motif["rc"] = false;
-  }
-  if (motif["large_logo"]) {
-    large_logo = motif["large_logo"];
-    large_logo_rc = motif["large_logo_rc"];
-  } else {
-    large_logo = make_large_logo(alphabet, pspm, false, 0);
-    motif["large_logo"] = large_logo;
-    if (alphabet.has_complement()) {
-      large_logo_rc = make_large_logo(alphabet, pspm, true, 0, "logo_rc");
-      motif["large_logo_rc"] = large_logo_rc;
-    }
-  }
-  norc = (large_logo_rc == null);
-  toggle_class(box, "norc", norc);
-
-  logo_box = find_child(box, "tvar_logo");
-  logo_box.appendChild(large_logo);
-  if (large_logo_rc) logo_box.appendChild(large_logo_rc);
-  toggle_class(logo_box, "show_rc_logo", motif["rc"]);
-
-  tab_logo = find_child(box, "tvar_tab");
-  tab_logo_rc = find_child(box, "tvar_tab_rc");
-
-  toggle_class(tab_logo, "activeTab", !motif["rc"]);
-  toggle_class(tab_logo_rc, "activeTab", motif["rc"]);
-
-  tab_logo.addEventListener('click', action_rc_tab, false);
-  tab_logo.addEventListener('keydown', action_rc_tab, false);
-  tab_logo_rc.addEventListener('click', action_rc_tab, false);
-  tab_logo_rc.addEventListener('keydown', action_rc_tab, false);
-
-  set_tvar(box, "tvar_ordinal", ordinal); 
-  set_tvar(box, "tvar_evalue", motif["evalue"]);
-  set_tvar(box, "tvar_width", motif["len"]);
-  set_tvar(box, "tvar_site_count", motif["nsites"]);
-  set_tvar(box, "tvar_llr", motif["llr"]);
-  set_tvar(box, "tvar_ic", motif["ic"]);
-  set_tvar(box, "tvar_re", motif["re"]);
-  set_tvar(box, "tvar_bt", motif["bt"]);
-  set_tvar(box, "tvar_sites", make_sites(motif));
-
-  offset = 32; // 1* 5px padding + 2 * 10px padding + 2 * 2px border + 3px ??
-
-  btn = find_child(box, "tvar_less");
-  btn.style.left = (less_x - offset) + "px";
-  btn.addEventListener('click', action_show_less, false);
-  btn.addEventListener('keydown', action_show_less, false);
-  btn = find_child(box, "tvar_submit");
-  btn.style.left = (submit_x - offset) + "px";
-  btn.addEventListener('click', action_show_outpop, false);
-  btn.addEventListener('keydown', action_show_outpop, false);
-  return box;
-}
-
-
-//
-//
-///
-function make_motifs() {
-  "use strict";
-  function pixel_value(str_in) {
-    "use strict";
-    var px_re, match;
-    px_re = /^(\d+)px$/;
-    if (match = px_re.exec(str_in)) {
-      return parseInt(match[1], 10);
-    }
-    return 0;
-  }
-  var container, tbl;
-  var colw, r, row, c, cell, cell_style, pad_left, pad_right;
-
-  // make the motifs table
-  container = $("motifs");
-  container.innerHTML = ""; // clear content
-
-  tbl = make_motifs_table(meme_alphabet, 1, data["motifs"], colw, data["stop_reason"]);
-  container.appendChild(tbl);
-
-  // measure table column widths
-  colw = [];
-  row = tbl.tBodies[0].rows[0];
-  for (c = 0; c < row.cells.length; c++) {
-    var padLeft, padRight;
-    cell = row.cells[c];
-    cell_style = window.getComputedStyle(cell, null);
-    pad_left = pixel_value(cell_style.getPropertyValue("padding-left"));
-    pad_right = pixel_value(cell_style.getPropertyValue("padding-right"));
-    colw[c] = cell.clientWidth - pad_left - pad_right;
-    if (typeof colw[c] !== "number" || colw[c] < 0) {
-      colw[c] = 1;
-    }
-  }
-
-  // set minimum table column widths on each row so later when we remove rows it still aligns
-  for (r = 0; r < tbl.tBodies[0].rows.length; r++) {
-    row = tbl.tBodies[0].rows[r];
-    for (c = 0; c < row.cells.length; c++) {
-      row.cells[c].style.minWidth = colw[c] + "px";
-    }
-  }
-
-  // store the table column widths so we can create rows latter with the same minimums
-  container.data_colw = colw;
-
-  // calculate the x offset for the buttons
-  row = tbl.tBodies[0].rows[0];
-  container.data_more_x = coords(find_child(find_child(row, "motif_more"), "sym_btn"))[0];
-  container.data_submit_x = coords(find_child(find_child(row, "motif_submit"), "sym_btn"))[0];
-
-  draw_on_screen();
-}
-
-function make_meme_block(container, max_seq_len, is_scan, site) {
-  "use strict";
-  var motif = data.motifs[site.motif];
-  var block = make_block(container, max_seq_len, site.pos, motif.len,
-      site.pvalue, site.rc, site.motif, is_scan);
-  var handler = (is_scan ?
-      make_scan_popup(site, motif, block) :
-      make_block_popup(site, motif, block));
-  block.addEventListener("mouseover", handler, false);
-  block.addEventListener("mouseout", handler, false);
-}
-
-function append_blocks_entries(tbody, seq_index, count) {
-  "use strict";
-  var i, end, j;
-  var max_pvalue, max_block_height, max_seq_len, sequences;
-  var sequence, sites, scans, scan;
-  var container, plus, minus, rule, row;
-  // define some constants
-  max_seq_len = data.sequence_db.max_length;
-  // determine how many to load
-  end = Math.min(seq_index + count, data.sequence_db.sequences.length);
-  for (i = seq_index; i < end; i++) {
-    // get the sequence
-    sequence = data.sequence_db.sequences[i];
-    // make the containers for the block diagram
-    container = make_block_container(meme_alphabet.has_complement(),
-        data.options.revcomp, max_seq_len, sequence.length);
-    // create blocks for the motif sites
-    sites = sequence["sites"];
-    for (j = 0; j < sites.length; j++)
-      make_meme_block(container, max_seq_len, false, sites[j]);
-    // create blocks for the scanned sites
-    scan = data.scan[i];
-    for (j = 0; j < scan.sites.length; j++)
-      make_meme_block(container, max_seq_len, true, scan.sites[j]);
-    // create a row for the sequence
-    row = tbody.insertRow(tbody.rows.length);
-    toggle_class(row, "empty_seq", sites.length == 0 && scan.sites.length == 0);
-    toggle_class(row, "only_scan", sites.length == 0 && scan.sites.length > 0);
-    add_text_cell(row, (i + 1) + ".", "blockdiag_num");
-    add_text_cell(row, sequence["name"], "blockdiag_name");
-    add_text_cell(row, scan["pvalue"].toExponential(2), "blockdiag_pvalue");
-    add_cell(row, container, "block_td"); 
-  }
-  return end;
-}
-
-function make_blocks_entries() {
-  "use strict";
-  var region;
-  region = this;
-  if (region.data_blocks_index >= data["sequence_db"]["sequences"].length) {
-    // all sites created
-    region.removeEventListener('scroll', make_blocks_entries, false);
-    return;
-  }
-  // if there's still 100 pixels to scroll than don't do anything yet
-  if (region.scrollHeight - (region.scrollTop + region.offsetHeight) > 100) {
-    return;
-  }
-
-  region.data_blocks_index = append_blocks_entries(
-      find_child(region, "blocks_tbl").tBodies[0], 
-      region.data_blocks_index, 20
-    ); 
-}
-
-function make_blocks() {
-  "use strict";
-  function add_seqs_filter(container, id, checked, label_text, help_topic) {
-    "use strict";
-    var label, radio;
-    radio = document.createElement("input");
-    radio.type = "radio";
-    radio.name = "seqs_display";
-    radio.id = id;
-    radio.checked = checked;
-    radio.addEventListener('click', action_seqs_filter, false);
-    label = document.createElement("label");
-    label.appendChild(document.createTextNode(label_text));
-    label.htmlFor = id;
-    container.appendChild(radio);
-    container.appendChild(label);
-    if (help_topic) {
-      container.appendChild(document.createTextNode("\xA0"));
-      container.appendChild(help_button(help_topic));
-    }
-  }
-  function add_blocks_header(row, title, nopad, help_topic) {
-    "use strict";
-    var div, divcp, th;
-    th = document.createElement("th");
-    div = document.createElement("div");
-    div.className = "blocks_th_inner";
-    if (typeof title !== "object") {
-      title = document.createTextNode("" + title);
-    }
-    div.appendChild(title);
-    if (help_topic) {
-      div.appendChild(document.createTextNode("\xA0"));
-      div.appendChild(help_button(help_topic));
-    }
-    divcp = div.cloneNode(true);
-    divcp.className = "blocks_th_hidden";
-    th.appendChild(div);
-    th.appendChild(divcp);
-    if (nopad) {
-      th.className = "nopad";
-    }
-    row.appendChild(th);
-  }
-  var container;
-  var page, view_height, outer_tbl, inner_tbl, tbl, thead, tbody, rhead;
-  var in_view, i, seq_count;
-  
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  view_height = Math.max(page.clientHeight - 300, 300);
-
-  container = $("blocks");
-  toggle_class(container, "hide_empty_seqs", true);
-  toggle_class(container, "hide_only_scan", true);
-  container.innerHTML = "";
-  add_seqs_filter(container, "rdo_sites_only", true, "Only Motif Sites", "pop_motif_sites");
-  add_seqs_filter(container, "rdo_sites_and_scan", false, "Motif Sites+Scanned Sites", "pop_scanned_sites");
-  add_seqs_filter(container, "rdo_all_seqs", false, "All Sequences", "pop_all_sequences");
-
-  outer_tbl = document.createElement("div");
-  outer_tbl.className = "blocks_outer";
-
-  inner_tbl = document.createElement("div");
-  inner_tbl.id = "blocks_scroll";
-  inner_tbl.className = "blocks_inner";
-  inner_tbl.style.maxHeight = view_height + "px";
-  outer_tbl.appendChild(inner_tbl);
-
-  tbl = document.createElement("table");
-  tbl.className = "blocks_tbl";
-  inner_tbl.appendChild(tbl);
-
-  thead = document.createElement("thead");
-  tbl.appendChild(thead);
-  tbody = document.createElement("tbody");
-  tbl.appendChild(tbody);
-
-  rhead = thead.insertRow(thead.rows.length);
-  add_blocks_header(rhead, "", true);
-  add_blocks_header(rhead, "Name", false, "pop_seq_name");
-  add_blocks_header(rhead, make_pv_text(), false, "pop_seq_pvalue");
-  add_blocks_header(rhead, "Motif Location", false, "pop_motif_location");
-
-  container.appendChild(outer_tbl);
-
-  
-  seq_count = data["sequence_db"]["sequences"].length;
-  in_view = Math.max(Math.ceil(view_height / 25), 1);
-  i = append_blocks_entries(tbody, 0, in_view);
-
-  while (i < seq_count && inner_tbl.scrollHeight - (inner_tbl.scrollTop + inner_tbl.offsetHeight) < 400) {
-    i = append_blocks_entries(tbody, i, 20);
-  }
-  inner_tbl.data_blocks_index = i;
-  if (i < seq_count) {
-    inner_tbl.addEventListener('scroll', make_blocks_entries, false);
-  }
-}
-
-function make_scan_popup(site, motif) {
-  return function (e) {
-    "use strict";
-    var pop, xy, padding, edge_padding, pop_left, pop_top, page_width;
-    var lflank, match, rflank, pspm;
-    if (!e) var e = window.event;
-    pop = make_scan_popup.pop;
-    if (e.type === "mouseover") {
-      if (pop) return;
-      pop = clone_template("tmpl_scan_info");
-      pspm = new Pspm(motif.pwm);
-      if (site.rc) pspm.reverse_complement(meme_alphabet);
-      set_tvar(pop, "tvar_logo", make_small_logo(meme_alphabet, pspm, {"className": "scan_logo"}));
-      set_tvar(pop, "tvar_motif", motif.id);
-      set_tvar(pop, "tvar_pvalue", site.pvalue.toExponential(2));
-      set_tvar(pop, "tvar_start", site.pos + 1);
-      set_tvar(pop, "tvar_end", site.pos + motif.len);
-
-      document.body.appendChild(pop);
-      position_popup(this, pop);
-      make_scan_popup.pop = pop;
-    } else if (e.type === "mouseout") {
-      if (pop) {
-        pop.parentNode.removeChild(pop);
-        make_scan_popup.pop = null;
-      }
-    }
-  };
-}
-
-function make_block_popup(site, motif, block) {
-  return function (e) {
-    "use strict";
-    var pop;
-    var lflank, match, rflank, pspm, ruler, match_seq, match_width;
-    if (!e) var e = window.event;
-    pop = make_block_popup.pop;
-    if (e.type === "mouseover") {
-      if (pop) return;
-      pop = clone_template("tmpl_block_info");
-      pspm = new Pspm(motif.pwm);
-      if (site.rc) { // must be dna
-        pspm.reverse_complement(meme_alphabet);
-        lflank = meme_alphabet.invcomp_seq(site.rflank);
-        match = meme_alphabet.invcomp_seq(site.match);
-        rflank = meme_alphabet.invcomp_seq(site.lflank);
-      } else {
-        lflank = site.lflank;
-        match = site.match;
-        rflank = site.rflank;
-      }
-      ruler = document.getElementById("measure_match");
-      match_seq = make_seq(meme_alphabet, match);
-      ruler.innerHTML = "";
-      ruler.appendChild(match_seq);
-      match_width = ruler.clientWidth;
-      ruler.removeChild(match_seq);
-      set_tvar(pop, "tvar_lflank", lflank);
-      set_tvar(pop, "tvar_match", match_seq);
-      set_tvar(pop, "tvar_rflank", rflank);
-      set_tvar(pop, "tvar_logo_pad", lflank);
-      set_tvar(pop, "tvar_logo", make_small_logo(meme_alphabet, pspm, {"width": match_width}));
-      set_tvar(pop, "tvar_motif", motif.id);
-      set_tvar(pop, "tvar_pvalue", site.pvalue.toExponential(2));
-      set_tvar(pop, "tvar_start", site.pos + 1);
-      set_tvar(pop, "tvar_end", site.pos + motif.len);
-
-      document.body.appendChild(pop);
-      position_popup(block, pop);
-      make_block_popup.pop = pop;
-    } else if (e.type === "mouseout") {
-      if (pop) {
-        pop.parentNode.removeChild(pop);
-        make_block_popup.pop = null;
-      }
-    }
-  };
-}
-
-function update_outpop_format(index) {
-  switch(parseInt($("text_format").value)) {
-    case 0: // count matrix
-      $("outpop_text").value = motif_count_matrix(index);
-      $("text_name").value = "motif_" + (index + 1) + "_counts.txt";
-      break;
-    case 1: // prob matrix
-      $("outpop_text").value = motif_prob_matrix(index);
-      $("text_name").value = "motif_" + (index + 1) + "_freqs.txt";
-      break;
-    case 2: // minimal meme
-      $("outpop_text").value = motif_minimal_meme(index);
-      $("text_name").value = "motif_" + (index + 1) + ".txt";
-      break;
-    case 3: // fasta
-      $("outpop_text").value = motif_fasta(index);
-      $("text_name").value = "motif_" + (index + 1) + "_fasta.txt";
-      break;
-    case 4: // raw
-      $("outpop_text").value = motif_raw(index);
-      $("text_name").value = "motif_" + (index + 1) + "_raw.txt";
-      break;
-    default:
-      throw new Error("Unknown motif format");
-  }
-}
-
-function update_outpop_motif(index) {
-  "use strict";
-  var motifs, motif, pspm, logo, canvas, num;
-  motifs = data["motifs"];
-  if (index < 0 || index >= motifs.length) {return;}
-  current_motif = index;
-  motif = motifs[index];
-  pspm = new Pspm(motif["pwm"]);
-  logo = new Logo(meme_alphabet, "");
-  logo.add_pspm(pspm, 0);
-  canvas = $("outpop_logo");
-  canvas.width = canvas.width; // clear canvas
-  draw_logo_on_canvas(logo, canvas, false);
-  if (meme_alphabet.has_complement()) {
-    pspm.reverse_complement(meme_alphabet);
-    logo = new Logo(meme_alphabet, "");
-    canvas = $("outpop_logo_rc");
-    canvas.width = canvas.width; // clear canvas
-    draw_logo_on_canvas(logo, canvas, false);
-  }
-  num = $("outpop_num");
-  num.innerHTML = "";
-  num.appendChild(document.createTextNode("" + (index + 1)));
-  update_outpop_format(index);
-}
-
-//
-// action_show_more
-//
-// Show more information on the motif.
-///
-function action_show_more(e) {
-  var node, tr, tbody, table, container, motif, ordinal;
-  var expanded_motif;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // find the row that contains the cell
-  node = this;
-  do {
-    if (node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find row!?");
-  tr = node;
-  // get info
-  motif = tr.data_motif;
-  ordinal = tr.data_ordinal;
-  // find tbody
-  do {
-    if (node.tagName === "TBODY") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find tbody!?");
-  tbody = node;
-  // find table
-  do {
-    if (node.tagName === "TABLE") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find table!?");
-  table = node;
-  // find container
-  container = node.parentNode;
-  // make a expanded motif
-  motif["expanded"] = true;
-  expanded_motif = make_expanded_motif(meme_alphabet, ordinal, motif, 
-      container.data_more_x, container.data_submit_x);
-  // now determine how to place it
-  if (tbody.rows.length === 1) {
-    // only us in the table so the table can be replaced
-    container.replaceChild(expanded_motif, table);
-  } else if (tbody.rows[0] === tr) {
-    // first row, so remove and insert an expanded motif before
-    table.deleteRow(tr.rowIndex);
-    container.insertBefore(expanded_motif, table);
-  } else if (tbody.rows[tbody.rows.length -1] === tr) {
-    // last row, so remove and insert an expanded motif after
-    table.deleteRow(tr.rowIndex);
-    container.insertBefore(expanded_motif, table.nextSibling);
-  } else {
-    var table2, tbody2;
-    table2 = table.cloneNode(false);
-    table2.appendChild(table.tHead.cloneNode(true));
-    tbody2 = table.tBodies[0].cloneNode(false);
-    table2.appendChild(tbody2);
-    container.insertBefore(table2, table.nextSibling);
-    for (i = tbody.rows.length - 1; i >= 0; i--) {
-      row = tbody.rows[i];
-      row.parentNode.removeChild(row);
-      if (row === tr) {
-        break;
-      }
-      tbody2.insertBefore(row, tbody2.rows[0]);
-    }
-    container.insertBefore(expanded_motif, table2);
-  }
-  find_child(expanded_motif, "tvar_less").focus();
-}
-
-//
-// action_show_less
-//
-// Show less information on the motif.
-///
-function action_show_less(e) {
-  var btn;
-  var expanded_motif, container, motif, ordinal, colw, focus_target;
-  var table, tbody, tbody2, row, table_before, table_after;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  btn = this;
-  // find expanded motif
-  expanded_motif = find_parent(btn, "expanded_motif");
-  if (!expanded_motif) throw new Error("Expected expanded motif.");
-  // find the container
-  container = expanded_motif.parentNode;
-  // get data
-  motif = expanded_motif.data_motif;
-  ordinal = expanded_motif.data_ordinal;
-  colw = container.data_colw;
-  // get the table before
-  table_before = expanded_motif.previousSibling;
-  if (table_before && table_before.tagName !== "TABLE") {
-    table_before = null;
-  }
-  // get the table after
-  table_after = expanded_motif.nextSibling;
-  if (table_after && table_after.tagName !== "TABLE") {
-    table_after = null;
-  }
-  // see if there is a table below or above that we can put this in.
-  // if there is a table both below and above then add this motif and
-  // all ones below to the above table
-  motif["expanded"] = false;
-  if (table_before && table_after) {
-    tbody = table_before.tBodies[0];
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-    tbody2 = table_after.tBodies[0];
-    while (tbody2.rows.length > 0) {
-      row = tbody2.rows[0];
-      row.parentNode.removeChild(row);
-      tbody.appendChild(row);
-    }
-    container.removeChild(table_after);
-  } else if (table_before) {
-    tbody = table_before.tBodies[0];
-    row = tbody.insertRow(tbody.rows.length);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-  } else if (table_after) {
-    tbody = table_after.tBodies[0];
-    row = tbody.insertRow(0);
-    make_motif_table_entry(row, meme_alphabet, ordinal, motif, colw);
-    focus_target = find_child(row.cells[5], "sym_btn");
-    container.removeChild(expanded_motif);
-  } else {
-    //no table above or below!
-    // make a new table
-    table = make_motifs_table(meme_alphabet, ordinal, [motif], colw, data["stop_reason"]);
-    focus_target = find_child(table.tBodies[0].rows[0].cells[5], "sym_btn");
-    container.replaceChild(table, expanded_motif);
-  }
-  focus_target.focus();
-}
-
-function action_show_outpop(e) {
-  "use strict";
-  function init() {
-    "use strict";
-    var close_btn, next_btn, prev_btn, cancel_btn, do_btn;
-    var tab1, tab2, tab3;
-    var pnl1, pnl2, pnl3;
-    var format_list;
-    var tbl_submit, inputs, i, default_prog;
-    close_btn = $("outpop_close");
-    close_btn.addEventListener("click", action_hide_outpop, false);
-    close_btn.addEventListener("keydown", action_hide_outpop, false);
-    next_btn = $("outpop_next");
-    next_btn.addEventListener("click", action_outpop_next, false);
-    next_btn.addEventListener("keydown", action_outpop_next, false);
-    prev_btn = $("outpop_prev");
-    prev_btn.addEventListener("click", action_outpop_prev, false);
-    prev_btn.addEventListener("keydown", action_outpop_prev, false);
-    cancel_btn = $("outpop_cancel");
-    cancel_btn.addEventListener("click", action_hide_outpop, false);
-    do_btn = $("outpop_do");
-    do_btn.addEventListener("click", action_outpop_submit, false);
-    tab1 = $("outpop_tab_1");
-    tab1.tabIndex = 0;
-    tab1.addEventListener("click", action_outpop_tab, false);
-    tab1.addEventListener("keydown", action_outpop_tab, false);
-    tab2 = $("outpop_tab_2");
-    tab2.tabIndex = 0;
-    tab2.addEventListener("click", action_outpop_tab, false);
-    tab2.addEventListener("keydown", action_outpop_tab, false);
-    tab3 = $("outpop_tab_3");
-    tab3.tabIndex = 0;
-    tab3.addEventListener("click", action_outpop_tab, false);
-    tab3.addEventListener("keydown", action_outpop_tab, false);
-    pnl1 = $("outpop_pnl_1");
-    pnl2 = $("outpop_pnl_2");
-    pnl3 = $("outpop_pnl_3");
-    toggle_class(tab1, "activeTab", true);
-    toggle_class(tab2, "activeTab", false);
-    toggle_class(tab3, "activeTab", false);
-    pnl1.style.display = "block";
-    pnl2.style.display = "none";
-    pnl3.style.display = "none";
-    format_list = $("text_format");
-    format_list.addEventListener("change", action_outpop_format, false);
-    // setup program selection
-    tbl_submit = $("programs");
-    // when not dna, hide the inputs for programs that require dna motifs
-    toggle_class(tbl_submit, "alphabet_dna", meme_alphabet.has_complement());//TODO FIXME alphabet_dna is a bad name for a field when allowing custom alphabets
-    // add a click listener for the radio buttons
-    inputs = tbl_submit.querySelectorAll("input[type='radio']");
-    for (i = 0; i < inputs.length; i++) {
-      inputs[i].addEventListener("click", action_outpop_program, false);
-    }
-    // ensure that a default program option is selected for DNA and Protein
-    default_prog = document.getElementById(meme_alphabet.has_complement() ? "submit_tomtom" : "submit_fimo"); //TODO FIXME Tomtom might require a more strict definition of DNA
-    default_prog.checked = true;
-    action_outpop_program.call(default_prog);
-    // disable reverse-complement when not DNA
-    $("logo_rc_option").disabled = !meme_alphabet.has_complement(); 
-    // set errorbars on when ssc is on
-    $("logo_ssc").addEventListener("change", action_outpop_ssc, false);
-  }
-  var node;
-  // store the focused element
-  action_hide_outpop.last_active = document.activeElement;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  // hide the help popup
-  help_popup();
-  // on first load initilize the popup
-  if (!action_show_outpop.ready) {
-    init();
-    action_show_outpop.ready = true;
-  }
-  // load the motif logo
-  node = this;
-  do {
-    if (/\bexpanded_motif\b/.test(node.className) || node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (node === null) throw new Error("Expected node!");
-  update_outpop_motif(node.data_ordinal - 1);
-  // display the download popup
-  $("grey_out_page").style.display = "block";
-  $("download").style.display = "block";
-  $("outpop_close").focus();
-}
-
-function action_hide_outpop(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  $("download").style.display = "none";
-  $("grey_out_page").style.display = "none";
-  if (typeof action_hide_outpop.last_active !== "undefined") {
-    action_hide_outpop.last_active.focus();
-  }
-}
-
-function action_outpop_next(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif + 1);
-}
-
-function action_outpop_prev(e) {
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  update_outpop_motif(current_motif - 1);
-}
-
-function action_outpop_program() {
-  "use strict";
-  var table, tr, rows, i;
-  tr = find_parent_tag(this, "TR");
-  table = find_parent_tag(tr, "TABLE");
-  rows = table.querySelectorAll("tr");
-  for (i = 0; i < rows.length; i++) {
-    toggle_class(rows[i], "selected", rows[i] === tr);
-  }
-}
-
-function action_outpop_ssc() {
-  "use strict";
-  $("logo_err").value = $("logo_ssc").value;
-}
-
-function action_outpop_submit(e) {
-  "use strict";
-  var form, input, program, motifs;
-  // find out which program is selected
-  var radios, i;
-  radios = document.getElementsByName("program");
-  program = "fimo"; // default to fimo, since it works with all alphabet types
-  for (i = 0; i < radios.length; i++) {
-    if (radios[i].checked) program = radios[i].value;
-  }
-
-  motifs = motif_minimal_meme(current_motif);
-  form = document.createElement("form");
-  form.setAttribute("method", "post");
-  form.setAttribute("action", site_url + "/tools/" + program);
-  
-  input = document.createElement("input");
-  input.setAttribute("type", "hidden");
-  input.setAttribute("name", "motifs_embed");
-  input.setAttribute("value", motifs);
-  form.appendChild(input);
-
-  document.body.appendChild(form);
-  form.submit();
-  document.body.removeChild(form);
-}
-
-function action_outpop_download_motif(e) {
-  $("text_form").submit();
-}
-
-function action_outpop_download_logo(e) {
-  "use strict";
-  $("logo_motifs").value = motif_minimal_meme(current_motif);
-  $("logo_form").submit();
-}
-
-function action_btn_rc(e) {
-  "use strict";
-  var node, tr, motif, box, logo_box, tab_st, tab_rc, rc;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  node = this;
-  do {
-    if (node.tagName === "TR") break;
-  } while (node = node.parentNode);
-  if (!node) throw new Error("Expected to find row!?");
-  tr = node;
-  // get info
-  motif = tr.data_motif;
-  box = find_parent(this, "preview_box");
-  logo_box = find_child(box, "preview_logo_box");
-  tab_st = find_child(box, "plus");
-  tab_rc = find_child(box, "minus");
-  rc = (this === tab_rc);
-  motif["rc"] = rc;
-  toggle_class(logo_box, "show_rc_logo", rc);
-  toggle_class(tab_st, "active", !rc);
-  toggle_class(tab_rc, "active", rc);
-}
-
-function action_rc_tab(e) {
-  "use strict";
-  var box, logo_box, tab_st, tab_rc, rc;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  box = find_parent(this, "expanded_motif");
-  logo_box = find_child(box, "tvar_logo");
-  tab_st = find_child(box, "tvar_tab");
-  tab_rc = find_child(box, "tvar_tab_rc");
-  rc = (this === tab_rc);
-  box.data_motif["rc"] = rc;
-  toggle_class(logo_box, "show_rc_logo", rc);
-  toggle_class(tab_st, "activeTab", !rc);
-  toggle_class(tab_rc, "activeTab", rc);
-}
-
-function action_outpop_tab(e) {
-  "use strict";
-  var tab1, tab2, tab3, pnl1, pnl2, pnl3, do_btn;
-  if (!e) e = window.event;
-  if (e.type === "keydown") {
-    if (e.keyCode !== 13 && e.keyCode !== 32) {
-      return;
-    }
-    // stop a submit or something like that
-    e.preventDefault();
-  }
-  tab1 = $("outpop_tab_1");
-  tab2 = $("outpop_tab_2");
-  tab3 = $("outpop_tab_3");
-  pnl1 = $("outpop_pnl_1");
-  pnl2 = $("outpop_pnl_2");
-  pnl3 = $("outpop_pnl_3");
-  do_btn = $("outpop_do");
-
-  toggle_class(tab1, "activeTab", (this === tab1));
-  toggle_class(tab2, "activeTab", (this === tab2));
-  toggle_class(tab3, "activeTab", (this === tab3));
-  pnl1.style.display = ((this === tab1) ? "block" : "none");
-  pnl2.style.display = ((this === tab2) ? "block" : "none");
-  pnl3.style.display = ((this === tab3) ? "block" : "none");
-  do_btn.value = ((this === tab1) ? "Submit" : "Download");
-  do_btn.removeEventListener("click", action_outpop_submit, false);
-  do_btn.removeEventListener("click", action_outpop_download_logo, false);
-  do_btn.removeEventListener("click", action_outpop_download_motif, false);
-  if (this === tab1) {
-    do_btn.addEventListener("click", action_outpop_submit, false);
-  } else if (this === tab2) {
-    do_btn.addEventListener("click", action_outpop_download_motif, false);
-  } else {
-    do_btn.addEventListener("click", action_outpop_download_logo, false);
-  }
-}
-
-function action_seqs_filter() {
-  "use strict";
-  var block_container;
-  block_container = $("blocks");
-  if ($("rdo_all_seqs").checked) {
-    toggle_class(block_container, "hide_empty_seqs", false);
-    toggle_class(block_container, "hide_only_scan", false);
-  } else if ($("rdo_sites_and_scan").checked) {
-    toggle_class(block_container, "hide_empty_seqs", true);
-    toggle_class(block_container, "hide_only_scan", false);
-  } else if ($("rdo_sites_only").checked) {
-    toggle_class(block_container, "hide_empty_seqs", true);
-    toggle_class(block_container, "hide_only_scan", true);
-  }
-}
-
-function action_outpop_format() {
-  update_outpop_format(current_motif);
-}
-
-//
-// page_loaded
-//
-// Called when the page has loaded for the first time.
-///
-function page_loaded() {
-  post_load_setup();
-}
-
-//
-// page_loaded
-//
-// Called when a cached page is reshown.
-///
-function page_shown(e) {
-  if (e.persisted) post_load_setup();
-}
-
-//
-// page_loaded
-//
-// Called when the page is resized
-///
-function page_resized() {
-  var page, blocks_scroll;
-  update_scroll_pad();
-  page = (document.compatMode === "CSS1Compat") ? document.documentElement : document.body;
-  blocks_scroll = $("blocks_scroll");
-  if (blocks_scroll) {
-    blocks_scroll.style.maxHeight = Math.max(page.clientHeight - 300, 300) + "px";
-  }
-}
-
-//
-// pre_load_setup
-//
-// Run before the page is displayed
-///
-function pre_load_setup() {
-  var start, hue, sat, light, divisions;
-  var i, j, motifs, motif, sites, site, sequences, sequence;
-  var max_seq_len;
-  motifs = data["motifs"];
-  sequences = data["sequence_db"]["sequences"];
-  max_seq_len = 1;
-  for (i = 0; i < sequences.length; i++) {
-    sequence = sequences[i];
-    sequence["sites"] = [];
-    if (sequence["length"] > max_seq_len) {
-      max_seq_len = sequence["length"];
-    }
-  }
-  data["sequence_db"]["max_length"] = max_seq_len;
-  // use hsl colours
-  start = 0; //red
-  sat = 100;
-  light = 50;
-  for (i = 0; i < motifs.length; i++) {
-    motif = motifs[i];
-    // give the motif a colour
-    divisions = 1 << Math.ceil(Math.log(i + 1) / Math.LN2);
-    hue = start + (360 / divisions) * ((i - (divisions >> 1)) * 2 + 1);
-    motif["colour"] = "hsl(" + hue + ", " + sat + "%, " + light + "%)";
-    // associate sites with sequences as well 
-    // to make generating the block diagram easier
-    sites = motif["sites"];
-    for (j = 0; j < sites.length; j++) {
-      site = sites[j];
-      sequence = sequences[site["seq"]];
-      // record the motif index
-      site["motif"] = i;
-      // add the site to the sequence
-      sequence["sites"].push(site);
-    }
-  }
-}
-
-//
-// post_load_setup
-//
-// Run when the page has loaded, or been reloaded.
-//
-function post_load_setup() {
-  update_scroll_pad();
-  if (data["motifs"].length > 0) {
-    make_motifs();
-    make_blocks();
-  } else {
-    $("motifs").innerHTML = "<p>No significant motifs found!</p>"; // clear content
-    $("motifs").innerHTML += "<p><b>" + data["stop_reason"] + "</b></p>";
-    $("blocks").innerHTML = "<p>No significant motifs found!</p>";
-  }
-}
-
-pre_load_setup();
-</script>
-    <style>
-/* The following is the content of meme.css */
-body { background-color:white; font-size: 12px; font-family: Verdana, Arial, Helvetica, sans-serif;}
-
-div.help {
-  display: inline-block;
-  margin: 0px;
-  padding: 0px;
-  width: 12px;
-  height: 13px;
-  cursor: pointer;
-  background-image: url();
-}
-
-div.help:hover {
-  background-image: url();
-}
-
-p.spaced { line-height: 1.8em;}
-
-span.citation { font-family: "Book Antiqua", "Palatino Linotype", serif; color: #004a4d;}
-
-p.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-td.jump { font-size: 13px; color: #ffffff; background-color: #00666a;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-a.jump { margin: 15px 0 0; font-style: normal; font-variant: small-caps;
-  font-weight: bolder; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.mainh {font-size: 1.5em; font-style: normal; margin: 15px 0 0;
-  font-variant: small-caps; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h2.line {border-bottom: 1px solid #CCCCCC; font-size: 1.5em; font-style: normal;
-  margin: 15px 0 0; padding-bottom: 3px; font-variant: small-caps;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-h4 {border-bottom: 1px solid #CCCCCC; font-size: 1.2em; font-style: normal;
-  margin: 10px 0 0; padding-bottom: 3px; font-family: Georgia, "Times New Roman", Times, serif;}
-
-h5 {margin: 0px}
-
-a.help { font-size: 9px; font-style: normal; text-transform: uppercase;
-  font-family: Georgia, "Times New Roman", Times, serif;}
-
-div.pad { padding-left: 30px; padding-top: 5px; padding-bottom: 10px;}
-
-div.pad1 { margin: 10px 5px;}
-
-div.pad2 { margin: 25px 5px 5px;}
-h2.pad2 { padding: 25px 5px 5px;}
-
-div.pad3 { padding: 5px 0px 10px 30px;}
-
-div.box { border: 2px solid #CCCCCC; padding:10px; overflow: hidden;}
-
-div.bar { border-left: 7px solid #00666a; padding:5px; margin-top:25px; }
-
-div.subsection {margin:25px 0px;}
-
-img {border:0px none;}
-
-th.majorth {text-align:left;}
-th.minorth {font-weight:normal; text-align:left; width:8em; padding: 3px 0px;}
-th.actionth {font-weight:normal; text-align:left;}
-
-.explain h5 {font-size:1em; margin-left: 1em;}
-
-div.doc {margin-left: 2em; margin-bottom: 3em;}
-
-th.trainingset {
-  border-bottom: thin dashed black; 
-  font-weight:normal; 
-  padding:0px 10px;
-}
-div.pop_content {
-  position:absolute;
-  z-index:50;
-  width:300px;
-  padding: 5px;
-  background: #E4ECEC;
-  font-size: 12px;
-  font-family: Arial;
-  border-style: double;
-  border-width: 3px;
-  border-color: #AA2244;
-  display:none;
-}
-
-div.pop_content > *:first-child {
-  margin-top: 0px;
-}
-
-div.pop_content h1, div.pop_content h2, div.pop_content h3, div.pop_content h4, 
-div.pop_content h5, div.pop_content h6, div.pop_content p {
-  margin: 0px;
-}
-
-div.pop_content p + h1, div.pop_content p + h2, div.pop_content p + h3, 
-div.pop_content p + h4, div.pop_content p + h5, div.pop_content p + h6 {
-  margin-top: 5px;
-}
-
-div.pop_content p + p {
-  margin-top: 5px;
-}
-
-div.pop_content > *:last-child {
-  margin-bottom: 0px;
-}
-
-div.pop_content div.pop_close {
-  /* old definition */
-  float:right;
-  bottom: 0;
-}
-
-div.pop_content span.pop_close, div.pop_content span.pop_back {
-  display: inline-block;
-  border: 2px outset #661429;
-  background-color: #CCC;
-  padding-left: 1px;
-  padding-right: 1px;
-  padding-top: 0px;
-  padding-bottom: 0px;
-  cursor: pointer;
-  color: #AA2244; /*#661429;*/
-  font-weight: bold;
-}
-
-div.pop_content span.pop_close:active, div.pop_content span.pop_back:active {
-  border-style: inset;
-}
-
-div.pop_content span.pop_close {
-  float:right;
-  /*border: 2px outset #AA002B;*/
-  /*color: #AA2244;*/
-}
-
-div.pop_content:not(.nested) .nested_only {
-  display: none;
-}
-
-div.pop_back_sec {
-  margin-bottom: 5px;
-}
-
-div.pop_close_sec {
-  margin-top: 5px;
-}
-
-table.hide_advanced tr.advanced {
-  display: none;
-}
-span.show_more {
-  display: none;
-}
-table.hide_advanced span.show_more {
-  display: inline;
-}
-table.hide_advanced span.show_less {
-  display: none;
-}
-
-
-/*****************************************************************************
- * Program logo styling
- ****************************************************************************/
-div.prog_logo {
-  border-bottom: 0.25em solid #0f5f60;
-  height: 4.5em;
-  width: 24em;
-  display:inline-block;
-}
-div.prog_logo img {
-  float:left;
-  width: 4em;
-  border-style: none;
-  margin-right: 0.2em;
-}
-div.prog_logo h1, div.prog_logo h1:hover, div.prog_logo h1:active, div.prog_logo h1:visited {
-  margin:0;
-  padding:0;
-  font-family: Arial, Helvetica,  sans-serif;
-  font-size: 3.2em;
-  line-height: 1em;
-  vertical-align: top;
-  display: block;
-  color: #026666;
-  letter-spacing: -0.06em;
-  text-shadow: 0.04em 0.06em 0.05em #666;
-}
-div.prog_logo h2, div.prog_logo h2:hover, div.prog_logo h2:active, div.prog_logo h2:visited {
-  display: block;
-  margin:0;
-  padding:0;
-  font-family: Helvetica, sans-serif;
-  font-size: 0.9em;
-  line-height: 1em;
-  letter-spacing: -0.06em;
-  color: black;
-}
-
-div.big.prog_logo {
-  font-size: 18px;
-}
-
-</style>
-    <style>
-.block_td {
-  height:25px;
-}
-.block_container {
-  position:relative;
-  box-sizing: border-box;
-  height: 25px;
-  padding: 0px;
-  margin: 0px;
-  margin-left: 1em;
-}
-.block_label {
-  position: absolute; 
-  display: inline-block;
-  padding: 3px;
-  z-index: 4;
-  top: 6px;
-  height: 12px;
-  line-height: 12px;
-  font-size: 12px;
-  background-color: white;
-  border: 1px solid black;
-  -moz-border-radius: 12px;
-  -webkit-border-radius: 12px;
-  border-radius: 12px;
-  transform: translateX(-50%);
-}
-.block_motif {
-  position: absolute; 
-  z-index: 3;
-  top: 0px;
-  box-sizing: border-box;
-  border: 1px solid black;
-  height: 12px;
-  background-color: cyan;
-}
-.block_motif.top {
-  border-bottom-width: 0;
-}
-.block_motif.bottom {
-  border-top-width: 0;
-}
-.block_motif.scanned_site {
-  opacity: 0.3;
-}
-.block_motif.scanned_site.active {
-  opacity: 0.9;
-}
-.block_region {
-  position:absolute; 
-  z-index:6; 
-  height:25px; 
-  top:0px; 
-}
-.block_region.main {
-  z-index:8;
-}
-.block_region.scanned_site {
-  z-index:5;
-}
-.block_region.scanned_site.main {
-  z-index:7;
-}
-.block_region.top {
-  height:13px;
-}
-.block_region.bottom {
-  height:13px;
-  top:12px;
-}
-.block_rule {
-  position:absolute;
-  z-index:2;
-  width:100%;
-  height:1px;
-  top:12px;
-  left:0px;
-  background-color:gray;
-}
-.block_plus_sym {
-  position:absolute;
-  z-index:4;
-  line-height:12px;
-  top:0px;
-  left:-1em;
-}
-.block_minus_sym {
-  position:absolute;
-  z-index:4;
-  line-height:12px;
-  top:13px;
-  left:-1em;
-}
-
-.tic_major {
-  position:absolute;
-  top:0em;
-  height:0.5em;
-  width: 2px;
-  margin-left: -1px;
-  background-color: blue;
-}
-.tic_minor {
-  position:absolute;
-  top:0em;
-  height:0.2em;
-  width: 1px;
-  margin-left: -0.5px;
-  background-color: blue;
-}
-.tic_label {
-  position:absolute;
-  display: inline-block;
-  top:0.5em;
-  height: 1em;
-  color: blue;
-  transform: translateX(-50%);
-}
-
-.block_needle {
-  position:absolute;
-  z-index:4;
-  height:30px; 
-  width:1px; 
-  top:-2px; 
-  background-color:gray;
-}
-.block_needle.right {
-  height: 60px;
-}
-.block_handle {
-  position: absolute; 
-  display: inline-block;
-  z-index: 5; 
-  top: 27px; 
-  min-width: 3ex;
-  text-align: center;
-  font-size: 12px;
-  line-height: 12px;
-  transform: translateX(-50%);
-  background-color: LightGrey; 
-  border:3px outset grey;
-  cursor: pointer;
-  -webkit-user-select: none; /* Chrome/Safari */        
-  -moz-user-select: none; /* Firefox */
-  -ms-user-select: none; /* IE10+ */
-  /* Rules below not implemented in browsers yet */
-  -o-user-select: none;
-  user-select: none;
-}
-.block_handle.right {
-  top: 47px;
-}
-
-.legend_container {
-  text-align: right;
-}
-.legend_entry {
-  display: inline-block;
-  padding: 5px;
-}
-div.legend_swatch {
-  box-sizing: border-box;
-  width: 15px;
-  height: 15px;
-  border: 1px solid black;
-  background-color: cyan;
-  float: left;
-}
-div.legend_swatch input {
-  display: none;
-}
-.legend_text {
-  line-height: 15px;
-  margin-left: 20px;
-}
-</style>
-    <style>
-/* meme output specific css */
-
-div.pop_block {
-  position:absolute;
-  z-index:5;
-  padding: 5px;
-  border: 1px solid black;
-  display: inline-block;
-  background-color: white;
-}
-
-#measure_match {
-  position: absolute;
-  visibility: hidden;
-  height: auto;
-  width: auto;
-  white-space: nowrap;
-}
-
-div.template {
-  position: absolute;
-  z-index: 1;
-  left: 0;
-  top: 0;
-  visibility: hidden;
-}
-
-table.block_information {
-  margin-left: auto;
-  margin-right: auto;
-}
-
-table.block_information * th {
-  text-align: right;
-}
-
-*.hide_empty_seqs * tr.empty_seq {
-  display: none;
-}
-
-*.hide_only_scan * tr.only_scan {
-  display: none;
-}
-
-*.hide_only_scan * div.scanned_site {
-  display: none;
-}
-
-td.symaction {
-  text-align: center;
-  text-decoration: underline;
-  font-size: 20px;
-  cursor: pointer;
-}
-div.sym_btn {
-  display:inline-block;
-  text-decoration: underline;
-  cursor: pointer;
-  font-size: 20px;
-  line-height:20px; 
-  text-align: center;
-  width: 20px;
-  height: 20px;
-  color: blue;
-}
-div.sym_btn:hover {
-  color: white;
-  background-color: blue;
-}
-
-div.sym_btn.positioned {
-  position: absolute;
-  top: 0px;
-}
-
-div.actionbutton { 
-  display:inline-block;
-  cursor: pointer;
-  font-size: 18px;
-  line-height:20px; 
-  padding: 5px; 
-  margin: 10px 0; 
-  border: 1px solid black;
-}
-
-div.actionbutton:hover {
-  color:#FFF;
-  background-color:#000;
-}
-
-div.param_box {
-  display: inline-block;
-  margin-right: 20px;
-}
-
-span.param {
-  font-weight: bold;
-}
-
-div.box + div.box {
-  margin-top: 5px;
-}
-
-div.sites_outer {
-  position: relative;
-  padding-top: 20px; /* height of header */
-  display: inline-block;
-}
-
-div.sites_inner {
-  overflow-x: hidden;
-  overflow-y: auto;
-  max-height: 200px;
-}
-table.sites_tbl {
-  border-collapse: collapse;
-}
-
-div.sites_th_inner {
-  position: absolute;
-  top: 0;
-  line-height: 20px; /* height of header */
-  text-align: left;
-  padding-left: 5px;
-}
-th.nopad div.sites_th_inner {
-  padding-left: 0;
-}
-div.sites_th_hidden {
-  visibility: hidden;
-  height: 0;
-  padding: 0 10px;
-}
-th.nopad div.sites_th_hidden {
-  padding: 0;
-}
-div.sites_inner * th {
-  height: 0;
-}
-
-table.sites_tbl {
-  overflow-x: hidden;
-  overflow-y: auto;
-}
-
-.site_num {
-  text-align: right;
-}
-.site_name {
-  padding:0px 5px; 
-  text-align:left;
-}
-.site_strand {
-  padding:0px 5px; 
-  text-align:center;
-}
-.norc .site_strand, .norc .site_strand_title {
-  display: none;
-}
-.site_start {
-  padding:0px 15px; 
-  text-align: right;
-}
-.site_pvalue {
-  text-align:center; 
-  padding:0px 15px; 
-  text-align:right;
-  white-space: nowrap;
-}
-.lflank, .rflank, .match, .alpha_symbol {
-  font-weight:bold; 
-  font-size:15px; 
-  font-family: 'Courier New', Courier, monospace;
-  color:gray; 
-}
-
-.site.lflank {
-  text-align:right; 
-  padding-right:5px; 
-  color:gray;
-}
-.site.match {
-  text-align:center; 
-}
-.site.rflank {
-  text-align:left; 
-  padding-left:5px; 
-  padding-right: 20px;
-}
-
-th.stop_reason {
-  text-align: left;
-  padding-right: 10px;
-}
-
-th.motif_ordinal {
-
-}
-td.motif_ordinal {
-  text-align: right;
-  padding-right: 10px;
-}
-th.motif_logo {
-  padding-right: 10px;
-}
-td.motif_logo {
-  padding-right: 10px;
-}
-th.motif_evalue {
-  text-align:right;
-  padding-right: 10px;
-}
-td.motif_evalue {
-  text-align: right;
-  white-space: nowrap;
-  padding-right: 20px;
-}
-th.motif_nsites {
-  text-align: right;
-  padding-right: 10px;
-}
-td.motif_nsites {
-  text-align: right;
-  padding-right: 20px;
-}
-th.motif_width {
-  text-align: right;
-  padding-right: 5px;
-}
-td.motif_width {
-  text-align: right;
-  padding-right: 15px;
-}
-th.motif_more {
-  padding: 0 5px;
-}
-td.motif_more {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_submit {
-  padding: 0 5px;
-}
-td.motif_submit {
-  text-align: center;
-  padding: 0 5px;
-}
-th.motif_download {
-  padding-left: 5px;
-}
-td.motif_download {
-  text-align: center;
-  padding-left: 5px;
-}
-
-
-div.tabArea {
-  font-size: 80%;
-  font-weight: bold;
-}
-
-.norc div.tabArea {
-  display: none;
-}
-
-span.tab, span.tab:visited {
-  cursor: pointer;
-  color: #888;
-  background-color: #ddd;
-  border: 2px solid #ccc;
-  padding: 2px 1em;
-  text-decoration: none;
-}
-span.tab.middle {
-  border-left-width: 0px;
-}
-div.tabArea.base span.tab {
-  border-top-width: 0px;
-}
-div.tabArea.top span.tab {
-  border-bottom-width: 0px;
-}
-
-span.tab:hover {
-  background-color: #bbb;
-  border-color: #bbb;
-  color: #666;
-}
-span.tab.activeTab, span.tab.activeTab:hover, span.tab.activeTab:visited {
-  background-color: white;
-  color: black;
-  cursor: default;
-}
-div.tabMain {
-  border: 2px solid #ccc;
-  background-color: white;
-  padding: 10px;
-}
-div.tabMain.base {
-  margin-top: 5px;
-  display: inline-block;
-  max-width: 98%;
-}
-
-div.tabMain.top {
-  margin-bottom: 5px;
-}
-
-div.tabCenter {
-  max-width: 100%;
-  overflow-x: auto;
-  height: 200px;
-  overflow-y: hidden;
-}
-
-canvas.logo_rc {
-  display:none;
-}
-.show_rc_logo > canvas {
-  display: none;
-}
-.show_rc_logo > canvas.logo_rc {
-  display: block;
-}
-
-canvas.scan_logo {
-  margin-left: 10px;
-}
-
-div.blocks_outer {
-  position: relative;
-  padding-top: 20px; /* height of header */
-}
-
-div.blocks_inner {
-  overflow-x: hidden;
-  overflow-y: auto;
-  max-height: 200px;
-}
-table.blocks_tbl {
-  border-collapse: collapse;
-  width: 100%;
-}
-
-div.blocks_th_inner {
-  position: absolute;
-  top: 0;
-  line-height: 20px; /* height of header */
-  text-align: left;
-  padding-left: 5px;
-}
-th.nopad div.blocks_th_inner {
-  padding-left: 0;
-}
-div.blocks_th_hidden {
-  visibility: hidden;
-  height: 0;
-  padding: 0 10px;
-}
-th.nopad div.blocks_th_hidden {
-  padding: 0;
-}
-div.blocks_inner * th {
-  height: 0;
-}
-
-table.blocks_tbl {
-  overflow-x: hidden;
-  overflow-y: auto;
-}
-td.block_td {
-  width: 99%;
-}
-
-*.blockdiag_num {
-  text-align: right;
-}
-
-td.blockdiag_name {
-  text-align: left;
-  padding:0px 10px; 
-}
-
-td.blockdiag_pvalue {
-  padding:0px 10px; 
-  text-align:right;
-  white-space: nowrap;
-}
-
-div.preview_btn {
-  border: 2px solid white;
-  height: 16px;
-  width: 16px;
-  font-size: 12px;
-  line-height: 16px;
-  text-align: center;
-  cursor: pointer;
-}
-div.preview_btn + div.preview_btn {
-  margin-top: 3px;
-}
-
-div.preview_btn.active {
-  border: 2px solid black;
-  cursor: default;
-}
-
-div.preview_btn:hover {
-  background-color: black;
-  color: white;
-  border-color: black;
-}
-
-div.preview_btn.active:hover {
-  background-color: white;
-  color: black;
-  border-color: black;
-}
-
-
-div.preview_btn_box {
-  position: absolute;
-  left: 0px;
-  top: 0px;
-  padding: 3px;
-}
-
-div.preview_logo_box {
-  height: 50px;
-  overflow-y: hidden;
-}
-
-div.preview_btn_box + div.preview_logo_box {
-  margin-left: 25px;
-}
-
-div.preview_box {
-  position: relative;
-}
-
-div.grey_background {
-  position:fixed; 
-  z-index: 8;
-  background-color: #000;
-  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
-  opacity: 0.5;
-  left: 0;
-  top: 0;
-  width: 100%;
-  height: 100%;
-}
-
-div.popup_wrapper {
-  position:fixed; 
-  z-index:9;
-  width:100%; 
-  height:0; 
-  top:50%; 
-  left:0;
-}
-
-div.popup {
-  width: 600px; 
-  z-index:9;
-  margin-left: auto;
-  margin-right: auto;
-  padding: 5px;
-  background-color: #FFF;
-  border-style: double;
-  border-width: 5px;
-  border-color: #00666a;
-  position:relative; 
-}
-div.close {
-  cursor: pointer;
-  border: 1px solid black; 
-  width:15px; 
-  height:15px; 
-  line-height:15px; /* this causes vertical centering */
-  text-align:center; 
-  background-color:#FFF; 
-  color:#000; 
-  font-size:15px;
-  font-family:monospace;
-}
-
-div.close:hover {
-  color:#FFF;
-  background-color:#000; 
-}
-
-div.navnum {
-  width:100%; 
-  height:20px; 
-  line-height:20px; 
-  text-align:center; 
-  font-size:medium;
-}
-
-div.navarrow {
-  font-size: 30px;
-  text-decoration:none;
-  cursor: pointer;
-  -moz-user-select: none;  
-  -webkit-user-select: none;  
-  -ms-user-select: none;
-}
-
-div.navarrow > span.inactive {
-  display: inline;
-}
-div.navarrow > span.active {
-  display: none;
-}
-
-div.navarrow:hover > span.active {
-  display: inline;
-}
-div.navarrow:hover > span.inactive {
-  display: none;
-}
-
-table.programs {
-  width: 100%;
-}
-
-table.programs tr {
-  background-color: #EFE;
-}
-
-table.programs tr.selected {
-  background-color: #262;
-  color: #FFF;
-}
-
-table.programs tr.dna_only {
-  display: none;
-}
-
-table.programs.alphabet_dna tr.dna_only {
-  display: table-row;
-}
-
-div.programs_scroll {
-  width: 100%; 
-  height: 90px; 
-  overflow-y: auto; 
-  overflow-x: hidden;
-  margin: 0 auto; 
-}
-table.inputs, table.alpha_bg_table {
-  margin-top: 20px;
-  border-collapse:collapse;
-}
-table.inputs * td, table.inputs * th, table.alpha_bg_table * td, table.alpha_bg_table * th {
-  padding-left: 15px;
-  padding-right: 15px;
-  padding-top: 1px;
-  padding-bottom: 1px;
-}
-
-table.hide_psp td.col_psp, table.hide_psp th.col_psp {
-  display: none;
-}
-
-/* program settings */
-span.mod_oops, span.mod_zoops, span.mod_anr {
-  display: none;
-}
-td.oops span.mod_oops,td.zoops span.mod_zoops, td.anr span.mod_anr  {
-  display: inline;
-}
-span.strand_none, span.strand_given, span.strand_both {
-  display: none;
-}
-td.none span.strand_none, td.given span.strand_given, td.both span.strand_both {
-  display: inline;
-}
-span.spmap_uni, span.spmap_pam {
-  display: none;
-}
-td.uni span.spmap_uni, td.pam span.spmap_pam {
-  display: inline;
-}
-span.prior_dirichlet, span.prior_dmix, span.prior_mega, span.prior_megap, span.prior_addone {
-  display: none;
-}
-td.dirichlet span.prior_dirichlet, td.dmix span.prior_dmix, td.mega span.prior_mega,
-td.megap span.prior_megap, td.addone span.prior_addone {
-  display: inline;
-}
-span.noendgaps_on, span.noendgaps_off {
-  display: none;
-}
-td.on span.noendgaps_on, td.off span.noendgaps_off {
-  display: inline;
-}
-span.substring_on, span.substring_off {
-  display: none;
-}
-td.on span.substring_on, td.off span.substring_off {
-  display: inline;
-}
-</style>
-  </head>
-  <body onload="page_loaded()" onpageshow="page_shown(event)" onresize="page_resized()">
-    <!--  -->
-    <div id="grey_out_page" class="grey_background" style="display:none;">
-    </div>
-    <!-- Help popups -->
-    <div class="pop_content" id="pop_">
-      <p>Help poup.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_ev">
-      <p>The statistical significance of the motif. MEME usually finds the most
-      statistically significant (low E-value) motifs first. It is unusual to
-      consider a motif with an E-value larger than 0.05 significant so, as an
-      additional indicator, MEME displays these partially transparent.</p> 
-      <p>The E-value of a motif is based on its log likelihood ratio, width,
-      sites, the background letter frequencies (given in the command line
-      summary), and the size of the training set.</p>
-      <p>The E-value is an estimate of the expected number of motifs with the
-      given log likelihood ratio (or higher), and with the same width and site
-      count, that one would find in a similarly sized set of random
-      sequences (sequences where each position is independent and letters are
-      chosen according to the background letter frequencies).</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_sites">
-      <p>The number of sites contributing to the construction of the motif.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_width">
-      <p>The width of the motif. Each motif describes a pattern of a fixed
-      width, as no gaps are allowed in MEME motifs.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_more">
-      <p>Click on the blue symbol below to reveal more information about this motif.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_submit_dl">
-      <p>Click on the blue symbol below to reveal options allowing you
-      to submit this motif to another MEME Suite motif analysis program, to download this
-      motif in various text formats, or to download a sequence "logo" of
-      this motif PNG or EPS format.</p>
-      <h5>Supported Programs</h5>
-      <dl>
-        <dt>Tomtom</dt>
-        <dd>Tomtom is a tool for searching for similar known motifs. 
-          [<a href="http://meme-suite.org/doc/tomtom.html?man_type=web">manual</a>]</dd>
-        <dt>MAST</dt>
-        <dd>MAST is a tool for searching biological sequence databases for 
-          sequences that contain one or more of a group of known motifs.
-          [<a href="http://meme-suite.org/doc/mast.html?man_type=web">manual</a>]</dd>
-        <dt>FIMO</dt>
-        <dd>FIMO is a tool for searching biological sequence databases for 
-          sequences that contain one or more known motifs.
-          [<a href="http://meme-suite.org/doc/fimo.html?man_type=web">manual</a>]</dd>
-        <dt>GOMO</dt>
-        <dd>GOMO is a tool for identifying possible roles (Gene Ontology 
-          terms) for DNA binding motifs.
-          [<a href="http://meme-suite.org/doc/gomo.html?man_type=web">manual</a>]</dd>
-        <dt>SpaMo</dt>
-        <dd>SpaMo is a tool for inferring possible transcription factor
-          complexes by finding motifs with enriched spacings.
-          [<a href="http://meme-suite.org/doc/spamo.html?man_type=web">manual</a>]</dd>
-      </dl>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_llr">
-      <p>The log likelihood ratio of the motif.The log likelihood ratio is the 
-      logarithm of the ratio of the probability of the occurrences of the motif
-      given the motif model (likelihood given the motif) versus their
-      probability given the background model (likelihood given the null model).
-      (Normally the background model is a 0-order Markov model using the
-      background letter frequencies, but higher order Markov models may be
-      specified via the -bfile option to MEME.).</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_ic">
-      <p>The information content of the motif in bits. It is equal to the sum
-      of the uncorrected information content, R(), in the columns of the pwm.
-      This is equal relative entropy of the motif relative to a uniform
-      background frequency model.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_re">
-      <p>The relative entropy of the motif.</p>
-
-      <p style="font-family: monospace;">re = llr / (sites * ln(2))</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_bt">
-      <p>The Bayes Threshold.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_strand">
-      <p>The strand used for the motif site.</p>
-      <dl>
-        <dt>+</dt>
-        <dd>The motif site was found in the sequence as it was supplied.</dd>
-        <dt>-</dt>
-        <dd>The motif site was found in the reverse complement of the supplied sequence.</dd>
-      </dl>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_start">
-      <p>The position in the sequence where the motif site starts. If a motif
-      started right at the begining of a sequence it would be described as
-      starting at position 1.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_pvalue">
-      <p>The probability that an equal or better site would be found in a
-      random sequence of the same length conforming to the background letter
-      frequencies.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_site_match">
-      <p>A motif site with the 10 flanking letters on either side.</p> 
-      <p>When the site is not on the given strand then the site
-      and both flanks are reverse complemented so they align.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_name">
-      <p>The name of the sequences as given in the FASTA file.</p>
-      <p>The number to the left of the sequence name is the ordinal
-      of the sequence.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_motif_sites">
-      <p>These are the motif sites predicted by MEME and used to build the motif.</p>
-      <p>These sites are shown in solid color and hovering the cursor
-      over a site will reveal details about the site.  Only sequences
-      that contain a motif site are shown.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_scanned_sites">
-      <p>These are the motif sites predicted by MEME plus
-      any additional sites detected using a motif scanning
-      algorithm.</p>
-      <p>These MEME sites are shown in solid color and 
-      additional scanned sites are shown in transparent color.
-      Hovering the cursor over a site will reveal details about the site.
-      Only sequences containing a predicted or scanned motif site are shown.</p>
-      <p>The scanned sites are predicted using a
-      log-odds scoring matrix constructed from the MEME sites.
-      Only scanned sites with position <i>p</i>-values less
-      than 0.0001 are shown.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_all_sequences">
-      <p>These are the same sites as shown by selecting the
-      "Motif Sites + Scanned Sites" button except that all
-      sequences, including those with no sites, are included
-      in the diagram.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_pvalue">
-      <p>This is the combined match <i>p</i>-value.</p>
-      <p>The combined match <i>p</i>-value is defined as the probability that a
-      random sequence (with the same length and conforming to the background) 
-      would have position <i>p</i>-values such that the product is smaller
-      or equal to the value calulated for the sequence under test.</p>
-      <p>The position <i>p</i>-value is defined as the probability that a
-      random sequence (with the same length and conforming to the background)
-      would have a match to the motif under test with a score greater or equal
-      to the largest found in the sequence under test.</p>
-      <p>Hovering your mouse over a motif site in the motif location 
-      block diagram will show its position <i>p</i>-value and other information
-      about the site.</p>
-       
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_motif_location">
-      <p>This diagram shows the location of motif sites.</p>
-      <p>Each block shows the position and strength of a motif
-      site.  The height of a block gives an indication of the 
-      significance of the site as taller blocks are more significant. 
-      The height is calculated to be proportional to the negative 
-      logarithm of the <i>p</i>-value of the site, truncated at 
-      the height for a <i>p</i>-value of 1e-10.</p>
-      <p>For complementable alphabets (like DNA), sites on the 
-      positive strand are shown above the line,
-      sites on the negative strand are shown below.</p>
-      <p>Placing the cursor
-      over a motif site will reveal more information about the site
-      including its position <i>p</i>-value.  (See the help
-      for the <i>p</i>-value column for an explanation of position 
-      <i>p</i>-values.)</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_seq_source">
-      <p>The name of the file of sequences input to MEME.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_psp_source">
-      <p>The position specific priors file used by MEME to find the motifs.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_alph">
-      <p>The alphabet used by the sequences.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_seq_count">
-      <p>The number of sequences provided as input to MEME.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <div class="pop_content" id="pop_alph_name">
-      <p>The name of the alphabet symbol.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_alph_freq">
-      <p>The frequency of the alphabet symbol in the dataset with a pseudocount
-      so it is never zero.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-    <div class="pop_content" id="pop_alph_bg">
-      <p>The frequency of the alphabet symbol as defined by the background model.</p>
-      <div style="float:right; bottom:0px;">[ 
-        <a href="javascript:help_popup()">close</a> ]</div>
-    </div>
-
-    <!-- templates -->
-    <div id="measure_match" class="match"></div>
-    <div class="template pop_block" id="tmpl_block_info">
-      <div>
-        <span class="tvar_logo_pad lflank" style="visibility:hidden;"></span>
-        <span class="tvar_logo"></span>
-      </div>
-      <div class="block_sequence_fragment">
-        <span class="tvar_lflank lflank"></span>
-        <span class="tvar_match match"></span>
-        <span class="tvar_rflank rflank"></span>
-      </div>
-      <table class="block_information">
-        <tr><th>Motif</th><td class="tvar_motif">1</td></tr>
-        <tr><th><i>p</i>-value</th><td class="tvar_pvalue">8.23e-7</td></tr>
-        <tr><th>Start</th><td class="tvar_start">23</td></tr>
-        <tr><th>End</th><td class="tvar_end">33</td></tr>
-      </table>
-    </div>
-
-    <div class="template pop_block" id="tmpl_scan_info">
-      <h5>Scanned Site</h5>
-      <div class="tvar_logo"></div>
-      <table class="block_information">
-        <tr><th>Motif</th><td class="tvar_motif">1</td></tr>
-        <tr><th><i>p</i>-value</th><td class="tvar_pvalue">8.23e-7</td></tr>
-        <tr><th>Start</th><td class="tvar_start">23</td></tr>
-        <tr><th>End</th><td class="tvar_end">33</td></tr>
-      </table>
-    </div>
-
-    <div class="template box expanded_motif" id="tmpl_motif_expanded">
-      <div style="position: relative; min-height: 20px">
-        <div class="param_box">
-          <span class="param"><span class="tvar_ordinal"></span>.</span>
-        </div>
-        <div class="sym_btn positioned tvar_less" tabindex="0" 
-          title="Show less information.">&#8613;</div>
-        <div class="sym_btn positioned tvar_submit" tabindex="0"
-          title="Submit the motif to another MEME Suite program or download it.">&#8674;</div>
-      </div>
-      <div>
-        <div class="param_box">
-          <span class="param"><i>E</i>-value:</span>
-          <span class="tvar_evalue"></span>
-          <div class="help" data-topic="pop_ev"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Site Count:</span>
-          <span class="tvar_site_count"></span>
-          <div class="help" data-topic="pop_sites"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Width:</span>
-          <span class="tvar_width"></span>
-          <div class="help" data-topic="pop_width"></div>
-        </div>
-      </div>
-      <div class="tabMain base">
-        <div class="tabCenter tvar_logo"></div>
-      </div>
-      <div class="tabArea base">
-        <span class="tvar_tab tab" tabindex="0">Standard</span><span 
-          class="tvar_tab_rc tab middle" tabindex="0">Reverse 
-          Complement</span>
-      </div>
-      <div style="padding: 10px 0">
-        <div class="param_box">
-          <span class="param">Log Likelihood Ratio:</span>
-          <span class="tvar_llr"></span>
-          <div class="help" data-topic="pop_llr"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Information Content:</span>
-          <span class="tvar_ic"></span>
-          <div class="help" data-topic="pop_ic"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Relative Entropy:</span>
-          <span class="tvar_re"></span>
-          <div class="help" data-topic="pop_re"></div>
-        </div>
-        <div class="param_box">
-          <span class="param">Bayes Threshold:</span>
-          <span class="tvar_bt"></span>
-          <div class="help" data-topic="pop_bt"></div>
-        </div>
-      </div>
-      <div class="tvar_sites"></div>
-    </div>
-
-
-    <div class="popup_wrapper">
-      <div class="popup" style="display:none; top: -150px;" id="download">
-        <div>
-          <div style="float:right; ">
-            <div id="outpop_close" class="close" tabindex="0">x</div>
-          </div>
-          <h2 class="mainh" style="margin:0; padding:0;">Submit or Download</h2>
-          <div style="clear:both"></div>
-        </div>
-          <div style="height:100px">
-            <div style="float:right; width: 30px;">
-              <div id="outpop_prev" class="navarrow" tabindex="0">
-                <span class="inactive">&#8679;</span><span class="active">&#11014;</span>
-              </div>
-              <div id="outpop_num" class="navnum"></div>
-              <div id="outpop_next" class="navarrow" tabindex="0">
-                <span class="inactive">&#8681;</span><span class="active">&#11015;</span>
-              </div>
-            </div>
-            <div id="logo_box" style="height: 100px; margin-right: 40px;">
-              <canvas id="outpop_logo" height="100" width="580"></canvas>
-              <canvas id="outpop_logo_rc" class="logo_rc" height="100" width="580"></canvas>
-            </div>
-          </div>
-          <div>
-            <!-- tabs start -->
-            <div class="tabArea top">
-              <span id="outpop_tab_1" class="tab">Submit Motif</span><span
-                id="outpop_tab_2" class="tab middle">Download Motif</span><span 
-                id="outpop_tab_3" class="tab middle">Download Logo</span>
-            </div>
-            <div class="tabMain top">
-              <!-- Submit to another program -->
-              <div id="outpop_pnl_1">
-                <h4 class="compact">Submit to program</h4>
-                <table id="programs" class="programs">
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="tomtom" id="submit_tomtom"></td>
-                    <td><label for="submit_tomtom">Tomtom</label></td>
-                    <td><label for="submit_tomtom">Find similar motifs in
-                        published libraries or a library you supply.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="fimo" id="submit_fimo"></td>
-                    <td><label for="submit_fimo">FIMO</label></td>
-                    <td><label for="submit_fimo">Find motif occurrences in
-                        sequence data.</label></td>
-                  </tr>
-                  <tr>
-                    <td><input type="radio" name="program" value="mast" id="submit_mast"></td>
-                    <td><label for="submit_mast">MAST</label></td>
-                    <td><label for="submit_mast">Rank sequences by affinity to
-                        groups of motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="gomo" id="submit_gomo"></td>
-                    <td><label for="submit_gomo">GOMo</label></td>
-                    <td><label for="submit_gomo">Identify possible roles (Gene
-                        Ontology terms) for motifs.</label></td>
-                  </tr>
-                  <tr class="dna_only">
-                    <td><input type="radio" name="program" value="spamo" id="submit_spamo"></td>
-                    <td><label for="submit_spamo">SpaMo</label></td>
-                    <td><label for="submit_spamo">Find other motifs that are
-                        enriched at specific close spacings which might imply the existance of a complex.</label></td>
-                  </tr>
-                </table>
-              </div>
-              <!-- download text format  -->
-              <div id="outpop_pnl_2">
-                <div>
-                  <label for="text_format">Format:</label>
-                  <select id="text_format">
-                    <option value="0">Count Matrix</option>
-                    <option value="1">Probability Matrix</option>
-                    <option value="2">Minimal MEME</option>
-                    <option value="3">FASTA</option>
-                    <option value="4">Raw</option>
-                  </select>
-                </div>
-                <form id="text_form" method="post" action="">
-                  <script>$("text_form").action = site_url + "/utilities/save_generated_file";</script>
-                  <input type="hidden" id="text_name" name="name" value="motif.txt">
-                  <input type="hidden" name="mime_type" value="text/plain">
-                  <textarea id="outpop_text" name="content"
-                    style="width:99%; white-space: pre; word-wrap: normal; overflow-x: scroll;" 
-                    rows="8" readonly="readonly" wrap="off"></textarea>
-                </form>
-              </div>
-              <!-- download logo format -->
-              <div id="outpop_pnl_3">
-                <form id="logo_form" method="post" action="">
-                  <script>$("logo_form").action = site_url + "/utilities/generate_logo";</script>
-                  <input type="hidden" name="program" value="MEME"/>
-                  <input type="hidden" id="logo_motifs" name="motifs" value=""/>
-                  <table>
-                    <tr>
-                      <td><label for="logo_format">Format:</label></td>
-                      <td>
-                        <select id="logo_format" name="png">
-                          <option value="1">PNG (for web)</option>
-                          <option value="0">EPS (for publication)</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_rc">Orientation:</label></td>
-                      <td>
-                        <select id="logo_rc" name="rc1">
-                          <option value="0">Normal</option>
-                          <option value="1" id="logo_rc_option">Reverse Complement</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_ssc">Small Sample Correction:</label></td>
-                      <td>
-                        <input type="hidden" id="logo_err" name="errbars" value="0"/>
-                        <select id="logo_ssc" name="ssc">
-                          <option value="0">Off</option>
-                          <option value="1">On</option>
-                        </select>
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_width">Width:</label></td>
-                      <td>
-                        <input type="text" id="logo_width" size="4" placeholder="default" name="width"/>&nbsp;cm
-                      </td>
-                    </tr>
-                    <tr>
-                      <td><label for="logo_height">Height:</label></td>
-                      <td>
-                        <input type="text" id="logo_height" size="4" placeholder="default" name="height"/>&nbsp;cm
-                      </td>
-                    </tr>
-                  </table>
-                </form>
-              </div>
-              <!-- Buttons -->
-              <div>
-                <div style="float:left;">
-                  <input type="button" id="outpop_do" value="Submit" />
-                </div>
-                <div style="float:right;">
-                  <input id="outpop_cancel" type="button" value="Cancel" />
-                </div>
-                <div style="clear:both;"></div>
-              </div>
-            </div>
-        </div>
-      </div>
-    </div>
-
-
-
-    <!-- Page starts here -->
-    <div id="top" class="pad1">
-      <div class="prog_logo big">
-        <img src="" alt="MEME Logo">
-        <h1>MEME</h1>
-        <h2>Multiple Em for Motif Elicitation</h2>
-      </div>
-      <p>
-        For further information on how to interpret these results or to get a 
-        copy of the MEME software please access 
-        <a href="http://meme-suite.org/">http://meme-suite.org</a>. 
-      </p>
-      <p>If you use MEME in your research, please cite the following paper:<br />
-        <span class="citation">
-          Timothy L. Bailey and Charles Elkan, 
-          "Fitting a mixture model by expectation maximization to discover motifs in biopolymers", 
-          <em>Proceedings of the Second International Conference on Intelligent Systems 
-          for Molecular Biology</em>, pp. 28-36, AAAI Press, Menlo Park, California, 1994. 
-          <a href="http://meme-suite.org/doc/ismb94.pdf">[pdf]</a> 
-        </span>
-      </p>
-    </div>
-    <!-- navigation -->
-    <div class="pad2">
-      <a class="jump" href="#motifs_sec">Discovered Motifs</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#sites_sec">Motif Locations</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#inputs_sec">Inputs &amp; Settings</a>
-      &nbsp;&nbsp;|&nbsp;&nbsp;
-      <a class="jump" href="#info_sec">Program information</a>
-    </div>
-    <!-- alert the user when their browser is not up to the task -->
-    <noscript><h1 style="color:red">Javascript is required to view these results!</h1></noscript>
-    <h1 id="html5_warning" style="color:red; display:none;">Your browser does not support canvas!</h1>
-    <script>
-      if (!window.HTMLCanvasElement) $("html5_warning").style.display = "block";
-    </script>
-    <h2 class="mainh pad2" id="motifs_sec">Discovered Motifs</h2>
-    <div id="motifs" class="box">
-      <p>Please wait... Loading...</p>
-      <p>If the page has fully loaded and this message does not disappear then an error may have occurred.</p>
-    </div>
-    <h2 class="mainh pad2" id="sites_sec">Motif Locations</h2>
-    <div id="blocks" class="box">
-      <p>Please wait... Loading...</p>
-      <p>If the page has fully loaded and this message does not disappear then an error may have occurred.</p>
-    </div>
-    <h2 class="mainh pad2" id="inputs_sec">Inputs &amp; Settings</h2>
-    <div class="box">
-      <h4>Sequences</h4>
-      <table id="seq_info" class="inputs">
-        <tr><th>Source <div class="help" data-topic="pop_seq_source"></div></th>
-          <th class="col_psp">PSP Source <div class="help" data-topic="pop_psp_source"></div></th>
-          <th>Alphabet <div class="help" data-topic="pop_seq_alph"></div></th>
-          <th>Sequence Count <div class="help" data-topic="pop_seq_count"></div></th>
-        </tr>
-        <tr>
-          <td id="ins_seq_source"></td>
-          <td id="ins_seq_psp" class="col_psp"></td>
-          <td id="ins_seq_alphabet"></td>
-          <td id="ins_seq_count"></td>
-        </tr>
-      </table>
-      <script>
-      {
-        var db = data.sequence_db;
-        $("ins_seq_source").innerHTML = db.source;
-        $("ins_seq_alphabet").innerHTML = meme_alphabet.get_alphabet_name();
-        $("ins_seq_count").innerHTML = db.sequences.length;
-        if (db.psp) {
-          $("ins_seq_psp").innerHTML = db.psp;
-        }
-        toggle_class($("seq_info"), "hide_psp", !(db.psp));
-      }
-      </script>
-      <h4>Background</h4>
-      <span id="alpha_bg"></span>
-      <script>
-      {
-        $("alpha_bg").appendChild(make_alpha_bg_table(meme_alphabet, data.sequence_db.freqs));
-      }
-      </script>
-      <h4>Other Settings</h4>
-      <table id="tbl_settings" class="inputs hide_advanced">
-        <tr>
-          <th>Motif Site Distribution</th>
-          <td id="opt_mod">
-            <span class="mod_zoops">ZOOPS: Zero or one site per sequence</span>
-            <span class="mod_oops">OOPS: Exactly one site per sequence</span>
-            <span class="mod_anr">ANR: Any number of sites per sequence</span>
-          </td>
-        </tr>
-        <tr>
-          <th>Site Strand Handling</th>
-          <td id="opt_strand">
-            <span class="strand_none">This alphabet only has one strand</span>
-            <span class="strand_given">Sites must be on the given strand</span>
-            <span class="strand_both">Sites may be on either strand</span>
-          </td>
-        </tr>
-        <tr>
-          <th>Maximum Number of Motifs</th>
-          <td id="opt_nmotifs"></td>
-        </tr>
-        <tr>
-          <th>Motif E-value Threshold</th>
-          <td id="opt_evt"></td>
-        </tr>
-        <tr>
-          <th>Minimum Motif Width</th>
-          <td id="opt_minw"></td>
-        </tr>
-        <tr>
-          <th>Maximum Motif Width</th>
-          <td id="opt_maxw"></td>
-        </tr>
-        <tr>
-          <th>Minimum Sites per Motif</th>
-          <td id="opt_minsites"></td>
-        </tr>
-        <tr>
-          <th>Maximum Sites per Motif</th>
-          <td id="opt_maxsites"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Bias on Number of Sites</th>
-          <td id="opt_wnsites"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Sequence Prior</th>
-          <td id="opt_prior">
-            <span class="prior_dirichlet">Simple Dirichlet</span>
-            <span class="prior_dmix">Dirichlets Mix</span>
-            <span class="prior_mega">Mega-weight Dirichlets Mix</span>
-            <span class="prior_megap">Mega-weight Dirichlets Mix Plus</span>
-            <span class="prior_addone">Add One</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>Sequence Prior Strength</th>
-          <td id="opt_b"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Source</th>
-          <td id="opt_substring">
-            <span class="substring_on">From substrings in input sequences</span>
-            <span class="substring_off">From strings on command line (-cons)</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Map Type</th>
-          <td id="opt_spmap">
-            <span class="spmap_uni">Uniform</span>
-            <span class="spmap_pam">Point Accepted Mutation</span>
-          </td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Starting Point Fuzz</th>
-          <td id="opt_spfuzz"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Maximum Iterations</th>
-          <td id="opt_maxiter"></td>
-        </tr>
-        <tr class="advanced">
-          <th>EM Improvement Threshold</th>
-          <td id="opt_distance"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Trim Gap Open Cost</th>
-          <td id="opt_wg"></td>
-        </tr>
-        <tr class="advanced">
-          <th>Trim Gap Extend Cost</th>
-          <td id="opt_ws"></td>
-        </tr>
-        <tr class="advanced">
-          <th>End Gap Treatment</th>
-          <td id="opt_noendgaps">
-            <span class="noendgaps_on">No cost</span>
-            <span class="noendgaps_off">Same cost as other gaps</span>
-          </td>
-        </tr>
-        <tr>
-          <td colspan="2" style="text-align: center">
-            <a href="javascript:toggle_class(document.getElementById('tbl_settings'), 'hide_advanced')">
-              <span class="show_more">Show Advanced Settings</span>
-              <span class="show_less">Hide Advanced Settings</span>
-            </a>
-          </td>
-        </tr>
-      </table>
-      <script>
-      {
-        $("opt_mod").className = data.options.mod;
-        $("opt_strand").className = (meme_alphabet.has_complement() ? (data.options.revcomp ? "both" : "given") : "none");
-        $("opt_nmotifs").textContent = data.options.nmotifs;
-        $("opt_evt").textContent = (typeof data.options.evt === "number" ? data.options.evt : "no limit");
-        $("opt_minw").textContent = data.options.minw;
-        $("opt_maxw").textContent = data.options.maxw;
-        $("opt_minsites").textContent = data.options.minsites;
-        $("opt_maxsites").textContent = data.options.maxsites;
-        $("opt_wnsites").textContent = data.options.wnsites;
-        $("opt_spmap").className = data.options.spmap;
-        $("opt_spfuzz").textContent = data.options.spfuzz;
-        $("opt_prior").className = data.options.prior;
-        $("opt_b").textContent = data.options.b;
-        $("opt_maxiter").textContent = data.options.maxiter;
-        $("opt_distance").textContent = data.options.distance;
-        $("opt_wg").textContent = data.options.wg;
-        $("opt_ws").textContent = data.options.ws;
-        $("opt_noendgaps").className = (data.options.noendgaps ? "on" : "off");
-        $("opt_substring").className = (data.options.substring ? "on" : "off");
-      }
-      </script>
-    </div>
-    <!-- list information on this program -->
-    <div id="info_sec" class="bar">
-      <div class="subsection">
-        <h5 id="version">MEME version</h5>
-        <span id="ins_version"></span> 
-        (Release date: <span id="ins_release"></span>)<br>
-      </div>
-      <script>
-        $("ins_version").innerHTML = data["version"];
-        $("ins_release").innerHTML = data["release"];
-      </script>
-      <div class="subsection">
-        <h5 id="reference">Reference</h5>
-        <span class="citation">
-          Timothy L. Bailey and Charles Elkan, 
-          "Fitting a mixture model by expectation maximization to discover motifs in biopolymers", 
-          <em>Proceedings of the Second International Conference on Intelligent Systems 
-          for Molecular Biology</em>, pp. 28-36, AAAI Press, Menlo Park, California, 1994. 
-        </span>
-      </div>
-      <div class="subsection">
-        <h5 id="command">Command line</h5>
-        <textarea id="cmd" rows="5" style="width:100%;" readonly="readonly">
-        </textarea>
-        <script>$("cmd").value = data["cmd"].join(" ");</script>
-      </div>
-    </div>
-    
-  </body>
-</html>
--- a/test-data/meme_output_test2.txt	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test2.txt	Wed Dec 11 18:05:15 2019 -0500
@@ -1,88 +1,36 @@
 ********************************************************************************
 MEME - Motif discovery tool
-********************************************************************************
-MEME version 4.12.0 (Release date: Tue Jun 27 16:22:50 2017 -0700)
-
-For further information on how to interpret these results or to get
-a copy of the MEME software please access http://meme-suite.org .
-
-This file may be used as input to the MAST algorithm for searching
-sequence databases for matches to groups of motifs.  MAST is available
-for interactive use and downloading at http://meme-suite.org .
-********************************************************************************
-
-
-********************************************************************************
+MEME version 5.0.5 (Release date: Mon Mar 18 20:12:19 2019 -0700)
 REFERENCE
-********************************************************************************
-If you use this program in your research, please cite:
-
-Timothy L. Bailey and Charles Elkan,
-"Fitting a mixture model by expectation maximization to discover
-motifs in biopolymers", Proceedings of the Second International
-Conference on Intelligent Systems for Molecular Biology, pp. 28-36,
-AAAI Press, Menlo Park, California, 1994.
-********************************************************************************
-
-
-********************************************************************************
 TRAINING SET
-********************************************************************************
-DATAFILE= Galaxy_FASTA_Input
+PRIMARY SEQUENCES= Galaxy_FASTA_Input
+CONTROL SEQUENCES= --none--
 ALPHABET= ACGT
 Sequence name            Weight Length  Sequence name            Weight Length  
 -------------            ------ ------  -------------            ------ ------  
 chr21_19617074_19617124_ 1.0000     50  chr21_26934381_26934431_ 1.0000     50  
-chr21_28217753_28217803_ 1.0000     50  chr21_31710037_31710087_ 1.0000     50  
-chr21_31744582_31744632_ 1.0000     50  chr21_31768316_31768366_ 1.0000     50  
-chr21_31914206_31914256_ 1.0000     50  chr21_31933633_31933683_ 1.0000     50  
-chr21_31962741_31962791_ 1.0000     50  chr21_31964683_31964733_ 1.0000     50  
-chr21_31973364_31973414_ 1.0000     50  chr21_31992870_31992920_ 1.0000     50  
-chr21_32185595_32185645_ 1.0000     50  chr21_32202076_32202126_ 1.0000     50  
-chr21_32253899_32253949_ 1.0000     50  chr21_32410820_32410870_ 1.0000     50  
-chr21_36411748_36411798_ 1.0000     50  chr21_37838750_37838800_ 1.0000     50  
-chr21_45705687_45705737_ 1.0000     50  chr21_45971413_45971463_ 1.0000     50  
-chr21_45978668_45978718_ 1.0000     50  chr21_45993530_45993580_ 1.0000     50  
-chr21_46020421_46020471_ 1.0000     50  chr21_46031920_46031970_ 1.0000     50  
-chr21_46046964_46047014_ 1.0000     50  chr21_46057197_46057247_ 1.0000     50  
-chr21_46086869_46086919_ 1.0000     50  chr21_46102103_46102153_ 1.0000     50  
-chr21_47517957_47518007_ 1.0000     50  chr21_47575506_47575556_ 1.0000     50  
-********************************************************************************
-
-********************************************************************************
 COMMAND LINE SUMMARY
-********************************************************************************
-This information can also be useful in the event you wish to report a
-problem with the MEME software.
-
-command: meme meme_input_1.fasta -o meme_test2_out -nostatus -maxsize 1000000 -sf Galaxy_FASTA_Input -dna -mod zoops -nmotifs 1 -wnsites 0.8 -minw 8 -maxw 50 -wg 11 -ws 1 -maxiter 50 -distance 0.001 -prior dirichlet -b 0.01 -plib prior30.plib -spmap uni -spfuzz 0.5 
-
 model:  mod=         zoops    nmotifs=         1    evt=           inf
-object function=  E-value of product of p-values
+objective function:           em=       E-value of product of p-values
+                              starts=   E-value of product of p-values
+strands: +
 width:  minw=            8    maxw=           50
-width:  wg=             11    ws=              1    endgaps=       yes
 nsites: minsites=        2    maxsites=       30    wnsites=       0.8
 theta:  spmap=         uni    spfuzz=        0.5
-global: substring=     yes    branching=      no    wbranch=        no
 em:     prior=   dirichlet    b=            0.01    maxiter=        50
         distance=    0.001
-data:   n=            1500    N=              30    shuffle=        -1
-strands: +
-sample: seed=            0    ctfrac=         -1    maxwords=       -1
-Dirichlet mixture priors file: prior30.plib
+trim:   wg=             11    ws=              1    endgaps=       yes
+data:   n=            1500    N=              30
+sample: seed=            0    hsfrac=          0
+        searchsize=   1500    norand=         no    csites=       1000
+Dirichlet mixture priors file:
 Letter frequencies in dataset:
 A 0.294 C 0.231 G 0.257 T 0.217 
-Background letter frequencies (from dataset with add-one prior applied):
+Background letter frequencies (from file dataset with add-one prior applied):
 A 0.294 C 0.231 G 0.257 T 0.217 
-********************************************************************************
-
-
-********************************************************************************
+Background model order: 0
 MOTIF GGSRTATAAAA MEME-1	width =  11  sites =  30  llr = 254  E-value = 5.1e-040
-********************************************************************************
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 Description
---------------------------------------------------------------------------------
 Simplified        A  3313:9:a798
 pos.-specific     C  1:3::1:::1:
 probability       G  6756::::::2
@@ -103,124 +51,17 @@
 Multilevel           GGGGTATAAAA
 consensus            AACA    T  
 sequence                        
-                                
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 sites sorted by position p-value
---------------------------------------------------------------------------------
 Sequence name             Start   P-value               Site  
--------------             ----- ---------            -----------
 chr21_46046964_46047014_     13  4.51e-07 AAGGCCAGGA GGGGTATAAAA GCCTGAGAGC
-chr21_46031920_46031970_     16  2.22e-06 ATACCCAGGG AGGGTATAAAA CCTCAGCAGC
-chr21_32202076_32202126_     14  2.74e-06 CCACCAGCTT GAGGTATAAAA AGCCCTGTAC
-chr21_46057197_46057247_     37  4.86e-06 ACAGGCCCTG GGCATATAAAA GCC       
-chr21_45993530_45993580_      8  4.86e-06    CCAAGGA GGAGTATAAAA GCCCCACAAA
-chr21_45971413_45971463_     10  4.86e-06  CAGGCCCTG GGCATATAAAA GCCCCAGCAG
-chr21_31964683_31964733_     14  4.86e-06 GATTCACTGA GGCATATAAAA GGCCCTCTGC
-chr21_47517957_47518007_     33  6.48e-06 CCGGCGGGGC GGGGTATAAAG GGGGCGG   
-chr21_45978668_45978718_      5  6.48e-06       CAGA GGGGTATAAAG GTTCCGACCA
-chr21_32185595_32185645_     19  6.48e-06 CACCAGAGCT GGGATATATAA AGAAGGTTCT
-chr21_32410820_32410870_     22  1.38e-05 AATCACTGAG GATGTATAAAA GTCCCAGGGA
-chr21_31992870_31992920_     17  1.38e-05 CACTATTGAA GATGTATAAAA TTTCATTTGC
-chr21_19617074_19617124_     40  1.41e-05 CCTCGGGACG TGGGTATATAA           
-chr21_31914206_31914256_     16  1.61e-05 CCCACTACTT AGAGTATAAAA TCATTCTGAG
-chr21_46020421_46020471_      3  1.95e-05         GA GACATATAAAA GCCAACATCC
-chr21_32253899_32253949_     18  1.95e-05 CCCACCAGCA AGGATATATAA AAGCTCAGGA
-chr21_45705687_45705737_     38  2.16e-05 CGTGGTCGCG GGGGTATAACA GC        
-chr21_47575506_47575556_     31  3.04e-05 GCTGCCGGTG AGCGTATAAAG GCCCTGGCG 
-chr21_31744582_31744632_     13  3.04e-05 CAGGTCTAAG AGCATATATAA CTTGGAGTCC
-chr21_31768316_31768366_      1  3.67e-05          . AACGTATATAA ATGGTCCTGT
-chr21_26934381_26934431_     28  3.93e-05 AGTCACAAGT GAGTTATAAAA GGGTCGCACG
-chr21_31933633_31933683_      5  5.65e-05       TCAG AGTATATATAA ATGTTCCTGT
-chr21_31710037_31710087_     15  6.24e-05 CCCAGGTTTC TGAGTATATAA TCGCCGCACC
-chr21_36411748_36411798_     23  7.15e-05 AGTTTCAGTT GGCATCtaaaa attatataac
-chr21_46102103_46102153_     37  1.39e-04 TGCCTGGGTC CAGGTATAAAG GCT       
-chr21_46086869_46086919_     38  1.39e-04 TGCCTGGGCC CAGGTATAAAG GC        
-chr21_37838750_37838800_      3  4.81e-04         ga tggttttataa ggggcctcac
-chr21_31962741_31962791_     14  8.57e-04 TATAACTCAG GTTGGATAAAA TAATTTGTAC
-chr21_31973364_31973414_      8  1.47e-03    aaactta aaactctataa acttaaaact
-chr21_28217753_28217803_     27  2.64e-03 GGTGGGGGTG GGGGTTTCACT GGTCCACTAT
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 block diagrams
---------------------------------------------------------------------------------
 SEQUENCE NAME            POSITION P-VALUE  MOTIF DIAGRAM
 -------------            ----------------  -------------
 chr21_46046964_46047014_          4.5e-07  12_[+1]_27
-chr21_46031920_46031970_          2.2e-06  15_[+1]_24
-chr21_32202076_32202126_          2.7e-06  13_[+1]_26
-chr21_46057197_46057247_          4.9e-06  36_[+1]_3
-chr21_45993530_45993580_          4.9e-06  7_[+1]_32
-chr21_45971413_45971463_          4.9e-06  9_[+1]_30
-chr21_31964683_31964733_          4.9e-06  13_[+1]_26
-chr21_47517957_47518007_          6.5e-06  32_[+1]_7
-chr21_45978668_45978718_          6.5e-06  4_[+1]_35
-chr21_32185595_32185645_          6.5e-06  18_[+1]_21
-chr21_32410820_32410870_          1.4e-05  21_[+1]_18
-chr21_31992870_31992920_          1.4e-05  16_[+1]_23
-chr21_19617074_19617124_          1.4e-05  39_[+1]
-chr21_31914206_31914256_          1.6e-05  15_[+1]_24
-chr21_46020421_46020471_          1.9e-05  2_[+1]_37
-chr21_32253899_32253949_          1.9e-05  17_[+1]_22
-chr21_45705687_45705737_          2.2e-05  37_[+1]_2
-chr21_47575506_47575556_            3e-05  30_[+1]_9
-chr21_31744582_31744632_            3e-05  12_[+1]_27
-chr21_31768316_31768366_          3.7e-05  [+1]_39
-chr21_26934381_26934431_          3.9e-05  27_[+1]_12
-chr21_31933633_31933683_          5.6e-05  4_[+1]_35
-chr21_31710037_31710087_          6.2e-05  14_[+1]_25
-chr21_36411748_36411798_          7.1e-05  22_[+1]_17
-chr21_46102103_46102153_          0.00014  36_[+1]_3
-chr21_46086869_46086919_          0.00014  37_[+1]_2
-chr21_37838750_37838800_          0.00048  2_[+1]_37
-chr21_31962741_31962791_          0.00086  13_[+1]_26
-chr21_31973364_31973414_           0.0015  7_[+1]_32
-chr21_28217753_28217803_           0.0026  26_[+1]_13
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 in BLOCKS format
---------------------------------------------------------------------------------
 BL   MOTIF GGSRTATAAAA width=11 seqs=30
 chr21_46046964_46047014_ (   13) GGGGTATAAAA  1 
-chr21_46031920_46031970_ (   16) AGGGTATAAAA  1 
-chr21_32202076_32202126_ (   14) GAGGTATAAAA  1 
-chr21_46057197_46057247_ (   37) GGCATATAAAA  1 
-chr21_45993530_45993580_ (    8) GGAGTATAAAA  1 
-chr21_45971413_45971463_ (   10) GGCATATAAAA  1 
-chr21_31964683_31964733_ (   14) GGCATATAAAA  1 
-chr21_47517957_47518007_ (   33) GGGGTATAAAG  1 
-chr21_45978668_45978718_ (    5) GGGGTATAAAG  1 
-chr21_32185595_32185645_ (   19) GGGATATATAA  1 
-chr21_32410820_32410870_ (   22) GATGTATAAAA  1 
-chr21_31992870_31992920_ (   17) GATGTATAAAA  1 
-chr21_19617074_19617124_ (   40) TGGGTATATAA  1 
-chr21_31914206_31914256_ (   16) AGAGTATAAAA  1 
-chr21_46020421_46020471_ (    3) GACATATAAAA  1 
-chr21_32253899_32253949_ (   18) AGGATATATAA  1 
-chr21_45705687_45705737_ (   38) GGGGTATAACA  1 
-chr21_47575506_47575556_ (   31) AGCGTATAAAG  1 
-chr21_31744582_31744632_ (   13) AGCATATATAA  1 
-chr21_31768316_31768366_ (    1) AACGTATATAA  1 
-chr21_26934381_26934431_ (   28) GAGTTATAAAA  1 
-chr21_31933633_31933683_ (    5) AGTATATATAA  1 
-chr21_31710037_31710087_ (   15) TGAGTATATAA  1 
-chr21_36411748_36411798_ (   23) GGCATCTAAAA  1 
-chr21_46102103_46102153_ (   37) CAGGTATAAAG  1 
-chr21_46086869_46086919_ (   38) CAGGTATAAAG  1 
-chr21_37838750_37838800_ (    3) TGGTTTTATAA  1 
-chr21_31962741_31962791_ (   14) GTTGGATAAAA  1 
-chr21_31973364_31973414_ (    8) AAACTCTATAA  1 
-chr21_28217753_28217803_ (   27) GGGGTTTCACT  1 
-//
-
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 position-specific scoring matrix
---------------------------------------------------------------------------------
 log-odds matrix: alength= 4 w= 11 n= 1200 bayes= 5.2854 E= 5.1e-040 
    -14   -179    114   -112 
      3  -1155    137   -270 
@@ -233,87 +74,13 @@
    125  -1155  -1155     46 
    167   -179  -1155  -1155 
    144  -1155    -63   -270 
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 position-specific probability matrix
---------------------------------------------------------------------------------
 letter-probability matrix: alength= 4 w= 11 nsites= 30 E= 5.1e-040 
  0.266667  0.066667  0.566667  0.100000 
- 0.300000  0.000000  0.666667  0.033333 
- 0.133333  0.266667  0.466667  0.133333 
- 0.300000  0.033333  0.600000  0.066667 
- 0.000000  0.000000  0.033333  0.966667 
- 0.866667  0.066667  0.000000  0.066667 
- 0.000000  0.000000  0.000000  1.000000 
- 0.966667  0.033333  0.000000  0.000000 
- 0.700000  0.000000  0.000000  0.300000 
- 0.933333  0.066667  0.000000  0.000000 
- 0.800000  0.000000  0.166667  0.033333 
---------------------------------------------------------------------------------
-
---------------------------------------------------------------------------------
 	Motif GGSRTATAAAA MEME-1 regular expression
---------------------------------------------------------------------------------
 [GA][GA][GC][GA]TATA[AT]AA
---------------------------------------------------------------------------------
-
-
-
-
-Time  0.38 secs.
-
-********************************************************************************
-
-
-********************************************************************************
 SUMMARY OF MOTIFS
-********************************************************************************
-
---------------------------------------------------------------------------------
 	Combined block diagrams: non-overlapping sites with p-value < 0.0001
---------------------------------------------------------------------------------
 SEQUENCE NAME            COMBINED P-VALUE  MOTIF DIAGRAM
--------------            ----------------  -------------
 chr21_19617074_19617124_         5.63e-04  39_[+1(1.41e-05)]
-chr21_26934381_26934431_         1.57e-03  27_[+1(3.93e-05)]_12
-chr21_28217753_28217803_         1.00e-01  50
-chr21_31710037_31710087_         2.49e-03  14_[+1(6.24e-05)]_25
-chr21_31744582_31744632_         1.22e-03  12_[+1(3.04e-05)]_27
-chr21_31768316_31768366_         1.47e-03  [+1(3.67e-05)]_39
-chr21_31914206_31914256_         6.45e-04  15_[+1(1.61e-05)]_24
-chr21_31933633_31933683_         2.26e-03  4_[+1(5.65e-05)]_35
-chr21_31962741_31962791_         3.37e-02  50
-chr21_31964683_31964733_         1.95e-04  13_[+1(4.86e-06)]_26
-chr21_31973364_31973414_         5.73e-02  50
-chr21_31992870_31992920_         5.52e-04  16_[+1(1.38e-05)]_23
-chr21_32185595_32185645_         2.59e-04  18_[+1(6.48e-06)]_21
-chr21_32202076_32202126_         1.10e-04  13_[+1(2.74e-06)]_26
-chr21_32253899_32253949_         7.78e-04  17_[+1(1.95e-05)]_22
-chr21_32410820_32410870_         5.52e-04  21_[+1(1.38e-05)]_18
-chr21_36411748_36411798_         2.85e-03  22_[+1(7.15e-05)]_17
-chr21_37838750_37838800_         1.90e-02  50
-chr21_45705687_45705737_         8.63e-04  37_[+1(2.16e-05)]_2
-chr21_45971413_45971463_         1.95e-04  9_[+1(4.86e-06)]_30
-chr21_45978668_45978718_         2.59e-04  4_[+1(6.48e-06)]_35
-chr21_45993530_45993580_         1.95e-04  7_[+1(4.86e-06)]_32
-chr21_46020421_46020471_         7.78e-04  2_[+1(1.95e-05)]_37
-chr21_46031920_46031970_         8.89e-05  15_[+1(2.22e-06)]_24
-chr21_46046964_46047014_         1.80e-05  12_[+1(4.51e-07)]_27
-chr21_46057197_46057247_         1.95e-04  36_[+1(4.86e-06)]_3
-chr21_46086869_46086919_         5.54e-03  50
-chr21_46102103_46102153_         5.54e-03  50
-chr21_47517957_47518007_         2.59e-04  32_[+1(6.48e-06)]_7
-chr21_47575506_47575556_         1.22e-03  30_[+1(3.04e-05)]_9
---------------------------------------------------------------------------------
-
-********************************************************************************
-
-
-********************************************************************************
 Stopped because requested number of motifs (1) found.
-********************************************************************************
-
-CPU: ThinkPad-T450s
-
-********************************************************************************
--- a/test-data/meme_output_test2.xml	Thu May 17 14:10:48 2018 -0400
+++ b/test-data/meme_output_test2.xml	Wed Dec 11 18:05:15 2019 -0500
@@ -10,975 +10,73 @@
 <!ATTLIST MEME 
   version CDATA #REQUIRED
   release CDATA #REQUIRED
->
 <!-- Training-set elements -->
 <!ELEMENT training_set (alphabet, ambigs, sequence*, letter_frequencies)>
-<!ATTLIST training_set datafile CDATA #REQUIRED length CDATA #REQUIRED>
+<!ATTLIST training_set primary_sequences CDATA #REQUIRED primary_count CDATA #REQUIRED primary_positions CDATA #REQUIRED
+  control_sequences CDATA "" control_count CDATA "" control_positions CDATA "">
 <!ELEMENT alphabet (letter*)>
 <!ATTLIST alphabet name CDATA #REQUIRED>
-<!ELEMENT ambigs (letter*)>
-<!ELEMENT letter EMPTY>
-<!ATTLIST letter id ID #REQUIRED>
-<!ATTLIST letter symbol CDATA #REQUIRED>
-<!ATTLIST letter equals CDATA #IMPLIED>
-<!ATTLIST letter aliases CDATA #IMPLIED>
-<!ATTLIST letter complement CDATA #IMPLIED>
-<!ATTLIST letter name CDATA #IMPLIED>
-<!ATTLIST letter colour CDATA #IMPLIED>
-<!ELEMENT sequence EMPTY>
-<!ATTLIST sequence id ID #REQUIRED
-                   name CDATA #REQUIRED
-                   length CDATA #REQUIRED
-                   weight CDATA #REQUIRED
->
 <!ELEMENT letter_frequencies (alphabet_array)>
-
 <!-- Model elements -->
 <!ELEMENT model (
   command_line,
   host,
   type,
   nmotifs,
-  evalue_threshold,
-  object_function,
-  spfun,
-  min_width,
-  max_width,
-  wg,
-  ws,
-  endgaps,
-  minsites,
-  maxsites,
-  wnsites,
-  spmap,
-  spfuzz,
-  prior,
-  beta,
-  maxiter,
-  distance,
-  num_sequences,
-  num_positions,
-  seed,
-  hsfrac,
-  maxwords,
-  maxsize,
-  csites,
-  strands,
-  priors_file,
-  reason_for_stopping,
-  back_order,
-  background_frequencies
 )>
 <!ELEMENT command_line (#PCDATA)*>
-<!ELEMENT host (#PCDATA)*>
-<!ELEMENT type (#PCDATA)*>
-<!ELEMENT nmotifs (#PCDATA)*>
-<!ELEMENT evalue_threshold (#PCDATA)*>
-<!ELEMENT object_function (#PCDATA)*>
-<!ELEMENT spfun (#PCDATA)*>
-<!ELEMENT min_width (#PCDATA)*>
-<!ELEMENT max_width (#PCDATA)*>
-<!ELEMENT wg (#PCDATA)*>
-<!ELEMENT ws (#PCDATA)*>
-<!ELEMENT endgaps (#PCDATA)*>
-<!ELEMENT minsites (#PCDATA)*>
-<!ELEMENT maxsites (#PCDATA)*>
-<!ELEMENT wnsites (#PCDATA)*>
-<!ELEMENT spmap (#PCDATA)*>
-<!ELEMENT spfuzz (#PCDATA)*>
-<!ELEMENT prior (#PCDATA)*>
-<!ELEMENT beta (#PCDATA)*>
-<!ELEMENT maxiter (#PCDATA)*>
-<!ELEMENT distance (#PCDATA)*>
-<!ELEMENT num_sequences (#PCDATA)*>
-<!ELEMENT num_positions (#PCDATA)*>
-<!ELEMENT seed (#PCDATA)*>
-<!ELEMENT hsfrac (#PCDATA)*>
-<!ELEMENT maxwords (#PCDATA)*>
-<!ELEMENT maxsites (#PCDATA)*>
-<!ELEMENT csites (#PCDATA)*>
-<!ELEMENT strands (#PCDATA)*>
-<!ELEMENT priors_file (#PCDATA)*>
-<!ELEMENT reason_for_stopping (#PCDATA)*>
-<!ELEMENT back_order (#PCDATA)*>
-<!ELEMENT background_frequencies (alphabet_array)>
-<!ATTLIST background_frequencies source CDATA #REQUIRED>
-
-<!-- Motif elements -->
 <!ELEMENT motifs (motif*)>
 <!ELEMENT motif (scores, probabilities, regular_expression?, contributing_sites)>
-<!ATTLIST motif id ID #REQUIRED
-                name CDATA #REQUIRED
-                alt CDATA ""
-                width CDATA #REQUIRED
-                sites CDATA #REQUIRED
-                llr CDATA #REQUIRED
-                ic CDATA #REQUIRED
-                re CDATA #REQUIRED
-                bayes_threshold CDATA #REQUIRED
-                e_value CDATA #REQUIRED
-                elapsed_time CDATA #REQUIRED
-                url CDATA ""
->
-<!ELEMENT scores (alphabet_matrix)>
-<!ELEMENT probabilities (alphabet_matrix)>
-<!ELEMENT regular_expression (#PCDATA)*>
-
-<!-- Contributing site elements -->
-<!-- Contributing sites are motif occurences found during the motif discovery phase -->
-<!ELEMENT contributing_sites (contributing_site*)>
-<!ELEMENT contributing_site (left_flank, site, right_flank)>
-<!ATTLIST contributing_site sequence_id IDREF #REQUIRED
-                          position CDATA #REQUIRED
-                          strand (plus|minus|none) 'none'
-                          pvalue CDATA #REQUIRED
->
 <!-- The left_flank contains the sequence for 10 bases to the left of the motif start -->
 <!ELEMENT left_flank (#PCDATA)>
 <!-- The site contains the sequence for the motif instance -->
 <!ELEMENT site (letter_ref*)>
 <!-- The right_flank contains the sequence for 10 bases to the right of the motif end -->
 <!ELEMENT right_flank (#PCDATA)>
-
 <!-- Scanned site elements -->
 <!-- Scanned sites are motif occurences found during the sequence scan phase -->
 <!ELEMENT scanned_sites_summary (scanned_sites*)>
-<!ATTLIST scanned_sites_summary p_thresh CDATA #REQUIRED>
-<!ELEMENT scanned_sites (scanned_site*)>
-<!ATTLIST scanned_sites sequence_id IDREF #REQUIRED
-                        pvalue CDATA #REQUIRED
-                        num_sites CDATA #REQUIRED>
-<!ELEMENT scanned_site EMPTY>
-<!ATTLIST scanned_site  motif_id IDREF #REQUIRED
-                        strand (plus|minus|none) 'none'
-                        position CDATA #REQUIRED
-                        pvalue CDATA #REQUIRED>
-
-<!-- Utility elements -->
-<!-- A reference to a letter in the alphabet -->
-<!ELEMENT letter_ref EMPTY>
-<!ATTLIST letter_ref letter_id IDREF #REQUIRED>
-<!-- A alphabet-array contains one floating point value for each letter in an alphabet -->
-<!ELEMENT alphabet_array (value*)>
-<!ELEMENT value (#PCDATA)>
-<!ATTLIST value letter_id IDREF #REQUIRED>
-
-<!-- A alphabet_matrix contains one alphabet_array for each position in a motif -->
-<!ELEMENT alphabet_matrix (alphabet_array*)>
-
-]>
-<!-- Begin document body -->
-<MEME version="4.12.0" release="Tue Jun 27 16:22:50 2017 -0700">
-<training_set datafile="Galaxy_FASTA_Input" length="30">
+<training_set primary_sequences="Galaxy_FASTA_Input" primary_count="30" primary_positions="1500" control_sequences="--none--" control_count="0" control_positions="0">
 <alphabet name="DNA" like="dna">
 <letter id="A" symbol="A" complement="T" name="Adenine" colour="CC0000"/>
-<letter id="C" symbol="C" complement="G" name="Cytosine" colour="0000CC"/>
-<letter id="G" symbol="G" complement="C" name="Guanine" colour="FFB300"/>
-<letter id="T" symbol="T" aliases="U" complement="A" name="Thymine" colour="008000"/>
-<letter id="N" symbol="N" aliases="X." equals="ACGT" name="Any base"/>
-<letter id="V" symbol="V" equals="ACG" name="Not T"/>
-<letter id="H" symbol="H" equals="ACT" name="Not G"/>
-<letter id="D" symbol="D" equals="AGT" name="Not C"/>
-<letter id="B" symbol="B" equals="CGT" name="Not A"/>
-<letter id="M" symbol="M" equals="AC" name="Amino"/>
-<letter id="R" symbol="R" equals="AG" name="Purine"/>
-<letter id="W" symbol="W" equals="AT" name="Weak"/>
-<letter id="S" symbol="S" equals="CG" name="Strong"/>
-<letter id="Y" symbol="Y" equals="CT" name="Pyrimidine"/>
-<letter id="K" symbol="K" equals="GT" name="Keto"/>
-</alphabet>
 <sequence id="sequence_0" name="chr21_19617074_19617124_+" length="50" weight="1.000000" />
-<sequence id="sequence_1" name="chr21_26934381_26934431_+" length="50" weight="1.000000" />
-<sequence id="sequence_2" name="chr21_28217753_28217803_-" length="50" weight="1.000000" />
-<sequence id="sequence_3" name="chr21_31710037_31710087_-" length="50" weight="1.000000" />
-<sequence id="sequence_4" name="chr21_31744582_31744632_-" length="50" weight="1.000000" />
-<sequence id="sequence_5" name="chr21_31768316_31768366_+" length="50" weight="1.000000" />
-<sequence id="sequence_6" name="chr21_31914206_31914256_-" length="50" weight="1.000000" />
-<sequence id="sequence_7" name="chr21_31933633_31933683_-" length="50" weight="1.000000" />
-<sequence id="sequence_8" name="chr21_31962741_31962791_-" length="50" weight="1.000000" />
-<sequence id="sequence_9" name="chr21_31964683_31964733_+" length="50" weight="1.000000" />
-<sequence id="sequence_10" name="chr21_31973364_31973414_+" length="50" weight="1.000000" />
-<sequence id="sequence_11" name="chr21_31992870_31992920_+" length="50" weight="1.000000" />
-<sequence id="sequence_12" name="chr21_32185595_32185645_-" length="50" weight="1.000000" />
-<sequence id="sequence_13" name="chr21_32202076_32202126_-" length="50" weight="1.000000" />
-<sequence id="sequence_14" name="chr21_32253899_32253949_-" length="50" weight="1.000000" />
-<sequence id="sequence_15" name="chr21_32410820_32410870_-" length="50" weight="1.000000" />
-<sequence id="sequence_16" name="chr21_36411748_36411798_-" length="50" weight="1.000000" />
-<sequence id="sequence_17" name="chr21_37838750_37838800_-" length="50" weight="1.000000" />
-<sequence id="sequence_18" name="chr21_45705687_45705737_+" length="50" weight="1.000000" />
-<sequence id="sequence_19" name="chr21_45971413_45971463_-" length="50" weight="1.000000" />
-<sequence id="sequence_20" name="chr21_45978668_45978718_-" length="50" weight="1.000000" />
-<sequence id="sequence_21" name="chr21_45993530_45993580_+" length="50" weight="1.000000" />
-<sequence id="sequence_22" name="chr21_46020421_46020471_+" length="50" weight="1.000000" />
-<sequence id="sequence_23" name="chr21_46031920_46031970_+" length="50" weight="1.000000" />
-<sequence id="sequence_24" name="chr21_46046964_46047014_+" length="50" weight="1.000000" />
-<sequence id="sequence_25" name="chr21_46057197_46057247_+" length="50" weight="1.000000" />
-<sequence id="sequence_26" name="chr21_46086869_46086919_-" length="50" weight="1.000000" />
-<sequence id="sequence_27" name="chr21_46102103_46102153_-" length="50" weight="1.000000" />
-<sequence id="sequence_28" name="chr21_47517957_47518007_+" length="50" weight="1.000000" />
-<sequence id="sequence_29" name="chr21_47575506_47575556_-" length="50" weight="1.000000" />
-<letter_frequencies>
-<alphabet_array>
-<value letter_id="A">0.294</value>
-<value letter_id="C">0.231</value>
 <value letter_id="G">0.257</value>
 <value letter_id="T">0.217</value>
 </alphabet_array>
-</letter_frequencies>
-</training_set>
 <model>
-<command_line>meme meme_input_1.fasta -o meme_test2_out -nostatus -maxsize 1000000 -sf Galaxy_FASTA_Input -dna -mod zoops -nmotifs 1 -wnsites 0.8 -minw 8 -maxw 50 -wg 11 -ws 1 -maxiter 50 -distance 0.001 -prior dirichlet -b 0.01 -plib prior30.plib -spmap uni -spfuzz 0.5 </command_line>
-<host>ThinkPad-T450s</host>
 <type>zoops</type>
-<nmotifs>1</nmotifs>
-<evalue_threshold>inf</evalue_threshold>
-<object_function>E-value of product of p-values</object_function>
-<use_llr>0</use_llr>
-<min_width>8</min_width>
-<max_width>50</max_width>
-<wg>11</wg>
-<ws>1</ws>
-<endgaps>yes</endgaps>
-<substring>yes</substring>
-<minsites>2</minsites>
-<maxsites>30</maxsites>
-<wnsites>0.8</wnsites>
-<spmap>uni</spmap>
-<spfuzz>0.5</spfuzz>
-<prior>dirichlet</prior>
-<beta>0.01</beta>
-<maxiter>50</maxiter>
-<distance>0.001</distance>
-<num_sequences>30</num_sequences>
-<num_positions>1500</num_positions>
-<seed>0</seed>
-<ctfrac>-1</ctfrac>
-<maxwords>-1</maxwords>
-<strands>forward</strands>
-<priors_file>prior30.plib</priors_file>
-<reason_for_stopping>Stopped because requested number of motifs (1) found.</reason_for_stopping>
-<background_frequencies source="dataset with add-one prior applied">
-<alphabet_array>
-<value letter_id="A">0.294</value>
-<value letter_id="C">0.231</value>
-<value letter_id="G">0.257</value>
-<value letter_id="T">0.217</value>
-</alphabet_array>
-</background_frequencies>
-</model>
-<motifs>
-<motif id="motif_1" name="GGSRTATAAAA" alt="MEME-1" width="11" sites="30" ic="13.0" re="12.2" llr="254" e_value="5.1e-040" bayes_threshold="5.2854" elapsed_time="0.376000">
 <scores>
 <alphabet_matrix>
 <alphabet_array>
 <value letter_id="A">-14</value>
-<value letter_id="C">-179</value>
-<value letter_id="G">114</value>
-<value letter_id="T">-112</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">3</value>
-<value letter_id="C">-1155</value>
-<value letter_id="G">137</value>
-<value letter_id="T">-270</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">-114</value>
-<value letter_id="C">20</value>
-<value letter_id="G">86</value>
-<value letter_id="T">-71</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">3</value>
-<value letter_id="C">-279</value>
-<value letter_id="G">122</value>
-<value letter_id="T">-170</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">-1155</value>
-<value letter_id="C">-1155</value>
-<value letter_id="G">-295</value>
-<value letter_id="T">215</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">156</value>
-<value letter_id="C">-179</value>
-<value letter_id="G">-1155</value>
-<value letter_id="T">-170</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">-1155</value>
-<value letter_id="C">-1155</value>
-<value letter_id="G">-1155</value>
-<value letter_id="T">220</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">172</value>
-<value letter_id="C">-279</value>
-<value letter_id="G">-1155</value>
-<value letter_id="T">-1155</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">125</value>
-<value letter_id="C">-1155</value>
-<value letter_id="G">-1155</value>
-<value letter_id="T">46</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">167</value>
-<value letter_id="C">-179</value>
-<value letter_id="G">-1155</value>
-<value letter_id="T">-1155</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">144</value>
-<value letter_id="C">-1155</value>
-<value letter_id="G">-63</value>
-<value letter_id="T">-270</value>
-</alphabet_array>
-</alphabet_matrix>
-</scores>
-<probabilities>
-<alphabet_matrix>
-<alphabet_array>
 <value letter_id="A">0.266667</value>
-<value letter_id="C">0.066667</value>
-<value letter_id="G">0.566667</value>
-<value letter_id="T">0.100000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.300000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="G">0.666667</value>
-<value letter_id="T">0.033333</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.133333</value>
-<value letter_id="C">0.266667</value>
-<value letter_id="G">0.466667</value>
-<value letter_id="T">0.133333</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.300000</value>
-<value letter_id="C">0.033333</value>
-<value letter_id="G">0.600000</value>
-<value letter_id="T">0.066667</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.000000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="G">0.033333</value>
-<value letter_id="T">0.966667</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.866667</value>
-<value letter_id="C">0.066667</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="T">0.066667</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.000000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="T">1.000000</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.966667</value>
-<value letter_id="C">0.033333</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="T">0.000000</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.700000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="T">0.300000</value>
-</alphabet_array>
-<alphabet_array>
-<value letter_id="A">0.933333</value>
-<value letter_id="C">0.066667</value>
-<value letter_id="G">0.000000</value>
-<value letter_id="T">0.000000</value>
-</alphabet_array>
-<alphabet_array>
 <value letter_id="A">0.800000</value>
-<value letter_id="C">0.000000</value>
-<value letter_id="G">0.166667</value>
-<value letter_id="T">0.033333</value>
-</alphabet_array>
-</alphabet_matrix>
-</probabilities>
-<regular_expression>
-[GA][GA][GC][GA]TATA[AT]AA
-</regular_expression>
-<contributing_sites>
 <contributing_site sequence_id="sequence_24" position="12" strand="plus" pvalue="4.51e-07" >
 <left_flank>AAGGCCAGGA</left_flank>
-<site>
 <letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
 <right_flank>GCCTGAGAGC</right_flank>
-</contributing_site>
 <contributing_site sequence_id="sequence_23" position="15" strand="plus" pvalue="2.22e-06" >
-<left_flank>ATACCCAGGG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>CCTCAGCAGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_13" position="13" strand="plus" pvalue="2.74e-06" >
-<left_flank>CCACCAGCTT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>AGCCCTGTAC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_25" position="36" strand="plus" pvalue="4.86e-06" >
-<left_flank>ACAGGCCCTG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_21" position="7" strand="plus" pvalue="4.86e-06" >
-<left_flank>CCAAGGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCCCCACAAA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_19" position="9" strand="plus" pvalue="4.86e-06" >
-<left_flank>CAGGCCCTG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCCCCAGCAG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_9" position="13" strand="plus" pvalue="4.86e-06" >
-<left_flank>GATTCACTGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GGCCCTCTGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_28" position="32" strand="plus" pvalue="6.48e-06" >
-<left_flank>CCGGCGGGGC</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GGGGCGG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_20" position="4" strand="plus" pvalue="6.48e-06" >
-<left_flank>CAGA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
 <letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GTTCCGACCA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_12" position="18" strand="plus" pvalue="6.48e-06" >
-<left_flank>CACCAGAGCT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>AGAAGGTTCT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_15" position="21" strand="plus" pvalue="1.38e-05" >
-<left_flank>AATCACTGAG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GTCCCAGGGA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_11" position="16" strand="plus" pvalue="1.38e-05" >
-<left_flank>CACTATTGAA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TTTCATTTGC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_0" position="39" strand="plus" pvalue="1.41e-05" >
-<left_flank>CCTCGGGACG</left_flank>
-<site>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank></right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_6" position="15" strand="plus" pvalue="1.61e-05" >
-<left_flank>CCCACTACTT</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TCATTCTGAG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_22" position="2" strand="plus" pvalue="1.95e-05" >
-<left_flank>GA</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GCCAACATCC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_14" position="17" strand="plus" pvalue="1.95e-05" >
-<left_flank>CCCACCAGCA</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>AAGCTCAGGA</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_18" position="37" strand="plus" pvalue="2.16e-05" >
+<contributing_site sequence_id="sequence_13" position="13" strand="plus" pvalue="2.74e-06" >
+<right_flank>AGCCCTGTAC</right_flank>
+<contributing_site sequence_id="sequence_25" position="36" strand="plus" pvalue="4.86e-06" >
 <left_flank>CGTGGTCGCG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-</site>
 <right_flank>GC</right_flank>
-</contributing_site>
 <contributing_site sequence_id="sequence_29" position="30" strand="plus" pvalue="3.04e-05" >
 <left_flank>GCTGCCGGTG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
 <right_flank>GCCCTGGCG</right_flank>
-</contributing_site>
 <contributing_site sequence_id="sequence_4" position="12" strand="plus" pvalue="3.04e-05" >
-<left_flank>CAGGTCTAAG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>CTTGGAGTCC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_5" position="0" strand="plus" pvalue="3.67e-05" >
-<left_flank></left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>ATGGTCCTGT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_1" position="27" strand="plus" pvalue="3.93e-05" >
-<left_flank>AGTCACAAGT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>GGGTCGCACG</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_7" position="4" strand="plus" pvalue="5.65e-05" >
-<left_flank>TCAG</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>ATGTTCCTGT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_3" position="14" strand="plus" pvalue="6.24e-05" >
-<left_flank>CCCAGGTTTC</left_flank>
-<site>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TCGCCGCACC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_16" position="22" strand="plus" pvalue="7.15e-05" >
-<left_flank>AGTTTCAGTT</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>attatataac</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_27" position="36" strand="plus" pvalue="1.39e-04" >
-<left_flank>TGCCTGGGTC</left_flank>
-<site>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GCT</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_26" position="37" strand="plus" pvalue="1.39e-04" >
-<left_flank>TGCCTGGGCC</left_flank>
-<site>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="G"/>
-</site>
-<right_flank>GC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_17" position="2" strand="plus" pvalue="4.81e-04" >
-<left_flank>ga</left_flank>
-<site>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>ggggcctcac</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_8" position="13" strand="plus" pvalue="8.57e-04" >
-<left_flank>TATAACTCAG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>TAATTTGTAC</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_10" position="7" strand="plus" pvalue="1.47e-03" >
-<left_flank>aaactta</left_flank>
-<site>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="A"/>
-</site>
-<right_flank>acttaaaact</right_flank>
-</contributing_site>
-<contributing_site sequence_id="sequence_2" position="26" strand="plus" pvalue="2.64e-03" >
-<left_flank>GGTGGGGGTG</left_flank>
-<site>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="G"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="T"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="A"/>
-<letter_ref letter_id="C"/>
-<letter_ref letter_id="T"/>
-</site>
-<right_flank>GGTCCACTAT</right_flank>
-</contributing_site>
-</contributing_sites>
-</motif>
-</motifs>
 <scanned_sites_summary p_thresh="0.0001">
 <scanned_sites sequence_id="sequence_0" pvalue="5.63e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="39" pvalue="1.41e-05"/>
-</scanned_sites>
 <scanned_sites sequence_id="sequence_1" pvalue="1.57e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="27" pvalue="3.93e-05"/>
-</scanned_sites>
 <scanned_sites sequence_id="sequence_2" pvalue="1.00e-01" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_3" pvalue="2.49e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="14" pvalue="6.24e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_4" pvalue="1.22e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="12" pvalue="3.04e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_5" pvalue="1.47e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="0" pvalue="3.67e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_6" pvalue="6.45e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="15" pvalue="1.61e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_7" pvalue="2.26e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="4" pvalue="5.65e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_8" pvalue="3.37e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_9" pvalue="1.95e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="13" pvalue="4.86e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_10" pvalue="5.73e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_11" pvalue="5.52e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="16" pvalue="1.38e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_12" pvalue="2.59e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="18" pvalue="6.48e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_13" pvalue="1.10e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="13" pvalue="2.74e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_14" pvalue="7.78e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="17" pvalue="1.95e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_15" pvalue="5.52e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="21" pvalue="1.38e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_16" pvalue="2.85e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="22" pvalue="7.15e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_17" pvalue="1.90e-02" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_18" pvalue="8.63e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="37" pvalue="2.16e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_19" pvalue="1.95e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="9" pvalue="4.86e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_20" pvalue="2.59e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="4" pvalue="6.48e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_21" pvalue="1.95e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="7" pvalue="4.86e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_22" pvalue="7.78e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="2" pvalue="1.95e-05"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_23" pvalue="8.89e-05" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="15" pvalue="2.22e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_24" pvalue="1.80e-05" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="12" pvalue="4.51e-07"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_25" pvalue="1.95e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="36" pvalue="4.86e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_26" pvalue="5.54e-03" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_27" pvalue="5.54e-03" num_sites="0"></scanned_sites>
-<scanned_sites sequence_id="sequence_28" pvalue="2.59e-04" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="32" pvalue="6.48e-06"/>
-</scanned_sites>
-<scanned_sites sequence_id="sequence_29" pvalue="1.22e-03" num_sites="1"><scanned_site motif_id="motif_1" strand="plus" position="30" pvalue="3.04e-05"/>
-</scanned_sites>
-</scanned_sites_summary>
 </MEME>