-
Notifications
You must be signed in to change notification settings - Fork 18
/
index.html
200 lines (148 loc) · 21.4 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>
Home - Documentation
</title>
<link href="https://www.braintreepayments.com/images/favicon-ccda0b14.png" rel="icon" type="image/png">
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.7.0/highlight.min.js"></script>
<script>hljs.initHighlightingOnLoad();</script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
<!-- start Mixpanel -->
<script type="text/javascript">(function(e,a){if(!a.__SV){var b=window;try{var c,l,i,j=b.location,g=j.hash;c=function(a,b){return(l=a.match(RegExp(b+"=([^&]*)")))?l[1]:null};g&&c(g,"state")&&(i=JSON.parse(decodeURIComponent(c(g,"state"))),"mpeditor"===i.action&&(b.sessionStorage.setItem("_mpcehash",g),history.replaceState(i.desiredHash||"",e.title,j.pathname+j.search)))}catch(m){}var k,h;window.mixpanel=a;a._i=[];a.init=function(b,c,f){function e(b,a){var c=a.split(".");2==c.length&&(b=b[c[0]],a=c[1]);b[a]=function(){b.push([a].concat(Array.prototype.slice.call(arguments,
0)))}}var d=a;"undefined"!==typeof f?d=a[f]=[]:f="mixpanel";d.people=d.people||[];d.toString=function(b){var a="mixpanel";"mixpanel"!==f&&(a+="."+f);b||(a+=" (stub)");return a};d.people.toString=function(){return d.toString(1)+".people (stub)"};k="disable time_event track track_pageview track_links track_forms register register_once alias unregister identify name_tag set_config reset people.set people.set_once people.increment people.append people.union people.track_charge people.clear_charges people.delete_user".split(" ");
for(h=0;h<k.length;h++)e(d,k[h]);a._i.push([b,c,f])};a.__SV=1.2;b=e.createElement("script");b.type="text/javascript";b.async=!0;b.src="undefined"!==typeof MIXPANEL_CUSTOM_LIB_URL?MIXPANEL_CUSTOM_LIB_URL:"file:"===e.location.protocol&&"//cdn.mxpnl.com/libs/mixpanel-2-latest.min.js".match(/^\/\//)?"https://cdn.mxpnl.com/libs/mixpanel-2-latest.min.js":"//cdn.mxpnl.com/libs/mixpanel-2-latest.min.js";c=e.getElementsByTagName("script")[0];c.parentNode.insertBefore(b,c)}})(document,window.mixpanel||[]);
mixpanel.init("1919205b2da72e4da3b9b6639b444d59");</script>
<!-- end Mixpanel -->
</head>
<body>
<svg style="display: none;">
<defs>
<symbol id="linkIcon" fill="#706d77" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h24v24H0z" fill="none"/>
<path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z"/>
</symbol>
</defs>
</svg>
<input type="checkbox" id="nav-trigger" class="nav-trigger" />
<label for="nav-trigger" class="navicon-button x">
<div class="navicon"></div>
</label>
<label for="nav-trigger" class="overlay"></label>
<div class="top-nav-wrapper">
<ul>
<li class="active" >
<a href="index.html">
<svg fill="#0095dd" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg">
<path d="M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z"/>
<path d="M0 0h24v24H0z" fill="none"/>
</svg>
</a>
</li>
</ul>
</div>
<nav>
<h3 class="reference-title">
TextAnnotationGraphs
</h3>
<h3>
Resources
</h3>
<a href="https://www.w3.org/TR/SVG/paths.html#PathData">SVG Path Spec<br></a>
<a href="https://codepen.io/explosion/pen/YGApwd">SVG Cubic Bézier Curve Generator</a>
<h3>Classes</h3><ul><li id="Link-nav"><a href="Link.html">Link</a><ul class='methods'><li data-type="method" id="Link-init-nav"><a href="Link.html#init">init</a></li><li data-type="method" id="Link-toggle-nav"><a href="Link.html#toggle">toggle</a></li><li data-type="method" id="Link-show-nav"><a href="Link.html#show">show</a></li><li data-type="method" id="Link-hide-nav"><a href="Link.html#hide">hide</a></li><li data-type="method" id="Link-showMainLabel-nav"><a href="Link.html#showMainLabel">showMainLabel</a></li><li data-type="method" id="Link-hideMainLabel-nav"><a href="Link.html#hideMainLabel">hideMainLabel</a></li><li data-type="method" id="Link-showArgLabels-nav"><a href="Link.html#showArgLabels">showArgLabels</a></li><li data-type="method" id="Link-hideArgLabels-nav"><a href="Link.html#hideArgLabels">hideArgLabels</a></li><li data-type="method" id="Link-draw-nav"><a href="Link.html#draw">draw</a></li><li data-type="method" id="Link-remove-nav"><a href="Link.html#remove">remove</a></li><li data-type="method" id="Link-getLineY-nav"><a href="Link.html#getLineY">getLineY</a></li><li data-type="method" id="Link-calculateSlot-nav"><a href="Link.html#calculateSlot">calculateSlot</a></li><li data-type="method" id="Link-drawBbox-nav"><a href="Link.html#drawBbox">drawBbox</a></li><li data-type="method" id="Link-drawTextBbox-nav"><a href="Link.html#drawTextBbox">drawTextBbox</a></li></ul></li><li id="Handle-nav"><a href="Handle.html">Handle</a><ul class='methods'><li data-type="method" id="Handle-precedes-nav"><a href="Handle.html#precedes">precedes</a></li></ul></li><li id="Label-nav"><a href="Label.html">Label</a><ul class='methods'><li data-type="method" id="Label-show-nav"><a href="Label.html#show">show</a></li><li data-type="method" id="Label-hide-nav"><a href="Label.html#hide">hide</a></li><li data-type="method" id="Label-move-nav"><a href="Label.html#move">move</a></li><li data-type="method" id="Label-centre-nav"><a href="Label.html#centre">centre</a></li><li data-type="method" id="Label-length-nav"><a href="Label.html#length">length</a></li><li data-type="method" id="Label-drawTextBbox-nav"><a href="Label.html#drawTextBbox">drawTextBbox</a></li></ul></li><li id="Row-nav"><a href="Row.html">Row</a><ul class='methods'><li data-type="method" id="Row-svgInit-nav"><a href="Row.html#svgInit">svgInit</a></li><li data-type="method" id="Row-remove-nav"><a href="Row.html#remove">remove</a></li><li data-type="method" id="Row-dy-nav"><a href="Row.html#dy">dy</a></li><li data-type="method" id="Row-move-nav"><a href="Row.html#move">move</a></li><li data-type="method" id="Row-height-nav"><a href="Row.html#height">height</a></li><li data-type="method" id="Row-width-nav"><a href="Row.html#width">width</a></li><li data-type="method" id="Row-addWord-nav"><a href="Row.html#addWord">addWord</a></li><li data-type="method" id="Row-positionWord-nav"><a href="Row.html#positionWord">positionWord</a></li><li data-type="method" id="Row-removeWord-nav"><a href="Row.html#removeWord">removeWord</a></li><li data-type="method" id="Row-removeLastWord-nav"><a href="Row.html#removeLastWord">removeLastWord</a></li><li data-type="method" id="Row-redrawLinksAndClusters-nav"><a href="Row.html#redrawLinksAndClusters">redrawLinksAndClusters</a></li><li data-type="method" id="Row-drawBbox-nav"><a href="Row.html#drawBbox">drawBbox</a></li></ul></li><li id="WordCluster-nav"><a href="WordCluster.html">WordCluster</a><ul class='methods'><li data-type="method" id="WordCluster-addEventId-nav"><a href="WordCluster.html#addEventId">addEventId</a></li><li data-type="method" id="WordCluster-text-nav"><a href="WordCluster.html#text">text</a></li><li data-type="method" id="WordCluster-init-nav"><a href="WordCluster.html#init">init</a></li><li data-type="method" id="WordCluster-draw-nav"><a href="WordCluster.html#draw">draw</a></li><li data-type="method" id="WordCluster-getBaseY-nav"><a href="WordCluster.html#getBaseY">getBaseY</a></li><li data-type="method" id="WordCluster-drawBbox-nav"><a href="WordCluster.html#drawBbox">drawBbox</a></li><li data-type="method" id="WordCluster-drawTextBbox-nav"><a href="WordCluster.html#drawTextBbox">drawTextBbox</a></li></ul></li><li id="WordTag-nav"><a href="WordTag.html">WordTag</a><ul class='methods'><li data-type="method" id="WordTag-draw-nav"><a href="WordTag.html#draw">draw</a></li><li data-type="method" id="WordTag-centre-nav"><a href="WordTag.html#centre">centre</a></li><li data-type="method" id="WordTag-remove-nav"><a href="WordTag.html#remove">remove</a></li><li data-type="method" id="WordTag-drawTagLine-nav"><a href="WordTag.html#drawTagLine">drawTagLine</a></li><li data-type="method" id="WordTag-text-nav"><a href="WordTag.html#text">text</a></li><li data-type="method" id="WordTag-boxWidth-nav"><a href="WordTag.html#boxWidth">boxWidth</a></li><li data-type="method" id="WordTag-drawBbox-nav"><a href="WordTag.html#drawBbox">drawBbox</a></li><li data-type="method" id="WordTag-drawTextBbox-nav"><a href="WordTag.html#drawTextBbox">drawTextBbox</a></li></ul></li><li id="Word-nav"><a href="Word.html">Word</a><ul class='methods'><li data-type="method" id="Word-addEventId-nav"><a href="Word.html#addEventId">addEventId</a></li><li data-type="method" id="Word-registerTag-nav"><a href="Word.html#registerTag">registerTag</a></li><li data-type="method" id="Word-getTagCategories-nav"><a href="Word.html#getTagCategories">getTagCategories</a></li><li data-type="method" id="Word-setTopTagCategory-nav"><a href="Word.html#setTopTagCategory">setTopTagCategory</a></li><li data-type="method" id="Word-setBottomTagCategory-nav"><a href="Word.html#setBottomTagCategory">setBottomTagCategory</a></li><li data-type="method" id="Word-init-nav"><a href="Word.html#init">init</a></li><li data-type="method" id="Word-redrawLinks-nav"><a href="Word.html#redrawLinks">redrawLinks</a></li><li data-type="method" id="Word-redrawClusters-nav"><a href="Word.html#redrawClusters">redrawClusters</a></li><li data-type="method" id="Word-move-nav"><a href="Word.html#move">move</a></li><li data-type="method" id="Word-dx-nav"><a href="Word.html#dx">dx</a></li><li data-type="method" id="Word-alignBox-nav"><a href="Word.html#alignBox">alignBox</a></li><li data-type="method" id="Word-drawBbox-nav"><a href="Word.html#drawBbox">drawBbox</a></li><li data-type="method" id="Word-drawTextBbox-nav"><a href="Word.html#drawTextBbox">drawTextBbox</a></li></ul></li><li id="Config-nav"><a href="Config.html">Config</a></li><li id="Main-nav"><a href="Main.html">Main</a><ul class='methods'><li data-type="method" id="Main-loadData-nav"><a href="Main.html#loadData">loadData</a></li><li data-type="method" id="Main-loadUrlAsync-nav"><a href="Main.html#loadUrlAsync">loadUrlAsync</a></li><li data-type="method" id="Main-loadFilesAsync-nav"><a href="Main.html#loadFilesAsync">loadFilesAsync</a></li><li data-type="method" id="Main-init-nav"><a href="Main.html#init">init</a></li><li data-type="method" id="Main-draw-nav"><a href="Main.html#draw">draw</a></li><li data-type="method" id="Main-clear-nav"><a href="Main.html#clear">clear</a></li><li data-type="method" id="Main-resize-nav"><a href="Main.html#resize">resize</a></li><li data-type="method" id="Main-loadTaxonomyYaml-nav"><a href="Main.html#loadTaxonomyYaml">loadTaxonomyYaml</a></li><li data-type="method" id="Main-getTaxonomyYaml-nav"><a href="Main.html#getTaxonomyYaml">getTaxonomyYaml</a></li><li data-type="method" id="Main-getTaxonomyTree-nav"><a href="Main.html#getTaxonomyTree">getTaxonomyTree</a></li><li data-type="method" id="Main-getColour-nav"><a href="Main.html#getColour">getColour</a></li><li data-type="method" id="Main-setColour-nav"><a href="Main.html#setColour">setColour</a></li><li data-type="method" id="Main-exportSvg-nav"><a href="Main.html#exportSvg">exportSvg</a></li><li data-type="method" id="Main-setOption-nav"><a href="Main.html#setOption">setOption</a></li><li data-type="method" id="Main-getOption-nav"><a href="Main.html#getOption">getOption</a></li><li data-type="method" id="Main-getTopLinkCategories-nav"><a href="Main.html#getTopLinkCategories">getTopLinkCategories</a></li><li data-type="method" id="Main-setTopLinkCategory-nav"><a href="Main.html#setTopLinkCategory">setTopLinkCategory</a></li><li data-type="method" id="Main-getBottomLinkCategories-nav"><a href="Main.html#getBottomLinkCategories">getBottomLinkCategories</a></li><li data-type="method" id="Main-setBottomLinkCategory-nav"><a href="Main.html#setBottomLinkCategory">setBottomLinkCategory</a></li><li data-type="method" id="Main-getTagCategories-nav"><a href="Main.html#getTagCategories">getTagCategories</a></li><li data-type="method" id="Main-setTopTagCategory-nav"><a href="Main.html#setTopTagCategory">setTopTagCategory</a></li><li data-type="method" id="Main-setBottomTagCategory-nav"><a href="Main.html#setBottomTagCategory">setBottomTagCategory</a></li><li data-type="method" id="Main-setTopMainLabelVisibility-nav"><a href="Main.html#setTopMainLabelVisibility">setTopMainLabelVisibility</a></li><li data-type="method" id="Main-setTopArgLabelVisibility-nav"><a href="Main.html#setTopArgLabelVisibility">setTopArgLabelVisibility</a></li><li data-type="method" id="Main-setBottomMainLabelVisibility-nav"><a href="Main.html#setBottomMainLabelVisibility">setBottomMainLabelVisibility</a></li><li data-type="method" id="Main-setBottomArgLabelVisibility-nav"><a href="Main.html#setBottomArgLabelVisibility">setBottomArgLabelVisibility</a></li></ul></li><li id="RowManager-nav"><a href="RowManager.html">RowManager</a><ul class='methods'><li data-type="method" id="RowManager-resizeAll-nav"><a href="RowManager.html#resizeAll">resizeAll</a></li><li data-type="method" id="RowManager-resizeRow-nav"><a href="RowManager.html#resizeRow">resizeRow</a></li><li data-type="method" id="RowManager-width-nav"><a href="RowManager.html#width">width</a></li><li data-type="method" id="RowManager-fitWords-nav"><a href="RowManager.html#fitWords">fitWords</a></li><li data-type="method" id="RowManager-appendRow-nav"><a href="RowManager.html#appendRow">appendRow</a></li><li data-type="method" id="RowManager-removeLastRow-nav"><a href="RowManager.html#removeLastRow">removeLastRow</a></li><li data-type="method" id="RowManager-addWordToRow-nav"><a href="RowManager.html#addWordToRow">addWordToRow</a></li><li data-type="method" id="RowManager-moveWordRight-nav"><a href="RowManager.html#moveWordRight">moveWordRight</a></li><li data-type="method" id="RowManager-moveWordLeft-nav"><a href="RowManager.html#moveWordLeft">moveWordLeft</a></li><li data-type="method" id="RowManager-moveFirstWordUp-nav"><a href="RowManager.html#moveFirstWordUp">moveFirstWordUp</a></li><li data-type="method" id="RowManager-moveLastWordDown-nav"><a href="RowManager.html#moveLastWordDown">moveLastWordDown</a></li></ul></li></ul><h3>Modules</h3><ul><li id="Util-nav"><a href="module-Util.html">Util</a><ul class='methods'><li data-type="method" id="Util-getCssRules-nav"><a href="module-Util.html#.getCssRules">getCssRules</a></li><li data-type="method" id="Util-sortForSlotting-nav"><a href="module-Util.html#.sortForSlotting">sortForSlotting</a></li><li data-type="method" id="Util-difference-nav"><a href="module-Util.html#~difference">difference</a></li></ul></li></ul><h3 id="global-nav">Global</h3><ul><li><a href="global.html#tag">tag</a></li><li><a href="global.html#registerParser">registerParser</a></li></ul>
</nav>
<div id="main">
<section class="readme">
<article>
<h1>TextAnnotationGraphs (TAG)</h1>
<p>A modular annotation system that supports complex, interactive annotation graphs embedded on top of sequences of text. An additional view displays a subgraph of selected connections between words/phrases using an interactive network layout.</p>
<p><img src="figs/OneRow.png" alt="TAG"></p>
<hr>
<p><img src="figs/taxonomyColors.png" alt="TAG"></p>
<hr>
<p><img src="figs/TwoRows.png" alt="TAG"></p>
<hr>
<p><img src="figs/trees.png" alt="TAG"></p>
<h2>Development</h2>
<p>TAG was developed by Angus Forbes (UC Santa Cruz) and Kristine Lee (University of Illinios at Chicago), in collaboration with Gus Hahn-Powell, Marco Antonio Valenzuela Escárcega, Zechy Wong, and Mihai Surdeanu (University of Arizona). Contact angus@ucsc.edu for more information.</p>
<h1>Citing TAG</h1>
<p>If you use TAG in your work, please use the following citation:</p>
<pre class="prettyprint source lang-TeX"><code>@inproceedings{TAG-2018,
author = {Angus Forbes and Kristine Lee and Gus Hahn-Powell and Marco A. Valenzuela-Escárcega and Mihai Surdeanu},
title = {Text Annotation Graphs: Annotating Complex Natural Language Phenomena},
booktitle = {Proceedings of the Eleventh International Conference on Language Resources and Evaluation (LREC'18)},
year = {2018},
month = {May},
date = {7-12},
address = {Miyazaki, Japan},
editor = {Sara Goggi and Hélène Mazo},
publisher = {European Language Resources Association (ELRA)},
language = {english}
}
</code></pre>
<h2>Write-up</h2>
<p>A paper describing TAG was accepted to <a href="http://lrec2018.lrec-conf.org/en/conference-programme/accepted-papers/">LREC'18</a>. A pre-print can be found at <a href="https://arxiv.org/abs/1711.00529">https://arxiv.org/abs/1711.00529</a></p>
<h2>Installation</h2>
<p>TAG can be built and installed using <a href="https://docs.npmjs.com/getting-started/installing-node"><code>npm</code></a>.</p>
<h3>Via <code>npm</code></h3>
<pre class="prettyprint source lang-JavaScript"><code>npm install git+https://github.com/CreativeCodingLab/TextAnnotationGraphs.git
</code></pre>
<h2>Usage</h2>
<p>To use TAG with your own applications, first include the library in your script:</p>
<h4>Browserify (CommonJS)</h4>
<pre class="prettyprint source lang-JavaScript"><code>const TAG = require("text-annotation-graphs");
</code></pre>
<h4>ES6</h4>
<pre class="prettyprint source lang-JavaScript"><code>import TAG from "text-annotation-graphs";
</code></pre>
<p>Next, register one or more annotation format Parsers with the library. TAG comes with parsers for the BRAT and Odin annotation formats -- See the demo sources (<code>demo/src/demo.js</code>) and the Parsers readme (<code>Parsers/README.md</code>) for more information.</p>
<pre class="prettyprint source lang-JavaScript"><code>const OdinParser = require("text-annotation-graphs/Parsers/odin");
TAG.registerParser(new OdinParser(), "odin");
</code></pre>
<p>Then initialise the visualisation on an element, optionally specifying the initial data set to load and any overrides to the default options. For more details, consult the <a href="docs/index.html">full API documentation</a>.</p>
<pre class="prettyprint source lang-JavaScript"><code>const graph = TAG.tag({
container: $container,
data: {...},
format: "odin",
options: {...}
});
</code></pre>
<h2>Development</h2>
<p>Tasks are managed via <a href="https://docs.npmjs.com/misc/scripts"><code>npm</code> scripts</a> and the <a href="https://github.com/pawelgalazka/runjs"><code>runjs</code> build tool</a>. The most commonly used tasks are listed in <code>package.json</code>, and details for the various sub-tasks can be found in <code>tasksfile.js</code>.</p>
<h3>Demo</h3>
<p>See the live demo <a href="../demo/index.html">here</a>.</p>
<p>After cloning the repository and installing the project dependencies via <code>npm install</code>, you can run the interactive demo using <code>npm run demo</code> and directing your browser to <code>localhost:8080</code>.</p>
<p>To run the demo on a different port, set the <code>PORT</code> environmental variable. For example, running <code>PORT=9000 npm run demo</code> will start the demo server on <code>localhost:9000</code> instead.</p>
<h3>Building the source</h3>
<p>TAG is written in ES6, and uses <a href="https://sass-lang.com/">Sass</a> for its styles.</p>
<p>Assuming you've cloned the repository and installed its dependencies, run <code>npm run build</code> to transpile the source to ES2015 and generate the library bundles (<code>dist/tag</code>) and documentation (<code>docs</code>).</p>
<p>To rebuild the sources for the demo, run <code>npm run demo-build</code>.</p>
<h3>Live monitoring of changes</h3>
<p>For convenience, you can monitor changes to the library's sources (in the <code>src</code> folder) with the following <code>npm</code> task, which will regenerate the files in the <code>dist/tag</code> folder:</p>
<pre class="prettyprint source"><code>npm run watch
</code></pre>
<p>If you are experimenting with the demo and would like to monitor changes to the demo sources (in the <code>demo</code> folder), use the following <code>npm</code> task instead:</p>
<pre class="prettyprint source"><code>npm run demo-watch
</code></pre>
<p>The <code>demo-watch</code> task will also catch changes to the library sources and rebuild the demo bundles, but it will <em>not</em> directly rebuild the library bundles in <code>dist/tag</code>, so be sure to run <code>npm run build</code> separately if you intend to redistribute/repackage your changes to the library sources.</p>
<h3>Generating documentation</h3>
<p>TAG uses <a href="http://usejsdoc.org/">JSDoc</a> to generate its documentation. By default, the documentation is generated using the template in <code>src/jsdoc-template</code> (adapted from the <a href="https://github.com/braintree/jsdoc-template">Braintree JSDoc Template</a>) and stored in the <code>docs</code> folder.</p>
<p>To regenerate the documentation, use the following <code>npm</code> task:</p>
<pre class="prettyprint source lang-javscript"><code>npm run generate-docs
</code></pre>
</article>
</section>
</div>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.6.2</a>
</footer>
<script src="scripts/linenumber.js"></script>
<script src="scripts/pagelocation.js"></script>
</body>
</html>