hesamation commited on
Commit
d349c25
·
1 Parent(s): 72a6559

added word-emb-heirarchy visual

Browse files
dist/assets/images/256px-PDF.png DELETED

Git LFS Details

  • SHA256: 48b7ab9362d78d22ca0d66b2943406759e85cffb86b585176990035d12ac2c7d
  • Pointer size: 129 Bytes
  • Size of remote file: 5.46 kB
dist/assets/images/placeholder.png DELETED

Git LFS Details

  • SHA256: c121166b2de694f4bb71dca004c8f413899016751eed5daa1570ba0d5ad9faec
  • Pointer size: 130 Bytes
  • Size of remote file: 53.1 kB
dist/bibliography.bib DELETED
@@ -1,24 +0,0 @@
1
- @article{example2023,
2
- title={Example Paper Title},
3
- author={Example, Author and Another, Author},
4
- journal={Journal of Examples},
5
- volume={1},
6
- number={1},
7
- pages={1--10},
8
- year={2023},
9
- publisher={Example Publisher}
10
- }
11
-
12
- @online{distill,
13
- title={Distill},
14
- url={https://distill.pub},
15
- year={2016},
16
- publisher={Distill Working Group}
17
- }
18
-
19
- @book{textbook2022,
20
- title={An Example Textbook},
21
- author={Author, Example},
22
- year={2022},
23
- publisher={Example Academic Press}
24
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
dist/distill.bundle.js DELETED
The diff for this file is too large to render. See raw diff
 
dist/fragments/banner.html DELETED
The diff for this file is too large to render. See raw diff
 
dist/index.html DELETED
The diff for this file is too large to render. See raw diff
 
dist/main.bundle.js DELETED
@@ -1,106 +0,0 @@
1
- /*
2
- * ATTENTION: An "eval-source-map" devtool has been used.
3
- * This devtool is neither made for production nor for readable output files.
4
- * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
5
- * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
6
- * or disable the default devtool with "devtool: false".
7
- * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
8
- */
9
- /******/ (() => { // webpackBootstrap
10
- /******/ "use strict";
11
- /******/ var __webpack_modules__ = ({
12
-
13
- /***/ "./src/fragmentLoader.js":
14
- /*!*******************************!*\
15
- !*** ./src/fragmentLoader.js ***!
16
- \*******************************/
17
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
18
-
19
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadFragments: () => (/* binding */ loadFragments)\n/* harmony export */ });\nfunction _typeof(o) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o; }, _typeof(o); }\nfunction _regeneratorRuntime() { \"use strict\"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = \"function\" == typeof Symbol ? Symbol : {}, a = i.iterator || \"@@iterator\", c = i.asyncIterator || \"@@asyncIterator\", u = i.toStringTag || \"@@toStringTag\"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, \"\"); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, \"_invoke\", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: \"normal\", arg: t.call(e, r) }; } catch (t) { return { type: \"throw\", arg: t }; } } e.wrap = wrap; var h = \"suspendedStart\", l = \"suspendedYield\", f = \"executing\", s = \"completed\", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { [\"next\", \"throw\", \"return\"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if (\"throw\" !== c.type) { var u = c.arg, h = u.value; return h && \"object\" == _typeof(h) && n.call(h, \"__await\") ? e.resolve(h.__await).then(function (t) { invoke(\"next\", t, i, a); }, function (t) { invoke(\"throw\", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke(\"throw\", t, i, a); }); } a(c.arg); } var r; o(this, \"_invoke\", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw Error(\"Generator is already running\"); if (o === s) { if (\"throw\" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if (\"next\" === n.method) n.sent = n._sent = n.arg;else if (\"throw\" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else \"return\" === n.method && n.abrupt(\"return\", n.arg); o = f; var p = tryCatch(e, r, n); if (\"normal\" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } \"throw\" === p.type && (o = s, n.method = \"throw\", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, \"throw\" === n && e.iterator[\"return\"] && (r.method = \"return\", r.arg = t, maybeInvokeDelegate(e, r), \"throw\" === r.method) || \"return\" !== n && (r.method = \"throw\", r.arg = new TypeError(\"The iterator does not provide a '\" + n + \"' method\")), y; var i = tryCatch(o, e.iterator, r.arg); if (\"throw\" === i.type) return r.method = \"throw\", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, \"return\" !== r.method && (r.method = \"next\", r.arg = t), r.delegate = null, y) : a : (r.method = \"throw\", r.arg = new TypeError(\"iterator result is not an object\"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = \"normal\", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: \"root\" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || \"\" === e) { var r = e[a]; if (r) return r.call(e); if (\"function\" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + \" is not iterable\"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, \"constructor\", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, \"constructor\", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, \"GeneratorFunction\"), e.isGeneratorFunction = function (t) { var e = \"function\" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || \"GeneratorFunction\" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, \"GeneratorFunction\")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, \"Generator\"), define(g, a, function () { return this; }), define(g, \"toString\", function () { return \"[object Generator]\"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) \"t\" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if (\"throw\" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = \"throw\", a.arg = e, r.next = n, o && (r.method = \"next\", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if (\"root\" === i.tryLoc) return handle(\"end\"); if (i.tryLoc <= this.prev) { var c = n.call(i, \"catchLoc\"), u = n.call(i, \"finallyLoc\"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw Error(\"try statement without catch or finally\"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, \"finallyLoc\") && this.prev < o.finallyLoc) { var i = o; break; } } i && (\"break\" === t || \"continue\" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = \"next\", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if (\"throw\" === t.type) throw t.arg; return \"break\" === t.type || \"continue\" === t.type ? this.next = t.arg : \"return\" === t.type ? (this.rval = this.arg = t.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, \"catch\": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if (\"throw\" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw Error(\"illegal catch attempt\"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, \"next\" === this.method && (this.arg = t), y; } }, e; }\nfunction _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError(\"Cannot call a class as a function\"); }\nfunction _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, \"value\" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }\nfunction _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, \"prototype\", { writable: !1 }), e; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == _typeof(i) ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != _typeof(i)) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nfunction asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }\nfunction _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, \"next\", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, \"throw\", n); } _next(void 0); }); }; }\nfunction loadFragments() {\n return _loadFragments.apply(this, arguments);\n}\nfunction _loadFragments() {\n _loadFragments = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee7() {\n var fragmentElements, FetchQueue, fetchQueue, currentIndex, elements;\n return _regeneratorRuntime().wrap(function _callee7$(_context7) {\n while (1) switch (_context7.prev = _context7.next) {\n case 0:\n // Find all elements with ids starting with 'fragment-'\n fragmentElements = Array.from(document.querySelectorAll('[id^=\"fragment-\"]'));\n FetchQueue = /*#__PURE__*/function () {\n function FetchQueue() {\n var maxConcurrent = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 3;\n _classCallCheck(this, FetchQueue);\n this.queue = [];\n this.maxConcurrent = maxConcurrent;\n this.activeFetches = 0;\n this.maxRetries = 3; // Maximum number of retry attempts\n this.baseDelay = 1000; // Base delay in milliseconds (1 second)\n }\n return _createClass(FetchQueue, [{\n key: \"sleep\",\n value: function () {\n var _sleep = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee(ms) {\n return _regeneratorRuntime().wrap(function _callee$(_context) {\n while (1) switch (_context.prev = _context.next) {\n case 0:\n return _context.abrupt(\"return\", new Promise(function (resolve) {\n return setTimeout(resolve, ms);\n }));\n case 1:\n case \"end\":\n return _context.stop();\n }\n }, _callee);\n }));\n function sleep(_x) {\n return _sleep.apply(this, arguments);\n }\n return sleep;\n }()\n }, {\n key: \"fetchWithRetry\",\n value: function () {\n var _fetchWithRetry = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2(fragmentPath) {\n var retryCount,\n response,\n delay,\n _args2 = arguments;\n return _regeneratorRuntime().wrap(function _callee2$(_context2) {\n while (1) switch (_context2.prev = _context2.next) {\n case 0:\n retryCount = _args2.length > 1 && _args2[1] !== undefined ? _args2[1] : 0;\n _context2.prev = 1;\n _context2.next = 4;\n return fetch(fragmentPath);\n case 4:\n response = _context2.sent;\n if (response.ok) {\n _context2.next = 7;\n break;\n }\n throw new Error(\"HTTP error! status: \".concat(response.status));\n case 7:\n _context2.next = 9;\n return response.text();\n case 9:\n return _context2.abrupt(\"return\", _context2.sent);\n case 12:\n _context2.prev = 12;\n _context2.t0 = _context2[\"catch\"](1);\n if (!(retryCount < this.maxRetries)) {\n _context2.next = 20;\n break;\n }\n // Exponential backoff: 1s, 2s, 4s\n delay = this.baseDelay * Math.pow(2, retryCount);\n console.warn(\"Retry \".concat(retryCount + 1, \"/\").concat(this.maxRetries, \" for \").concat(fragmentPath, \" after \").concat(delay, \"ms\"));\n _context2.next = 19;\n return this.sleep(delay);\n case 19:\n return _context2.abrupt(\"return\", this.fetchWithRetry(fragmentPath, retryCount + 1));\n case 20:\n throw _context2.t0;\n case 21:\n case \"end\":\n return _context2.stop();\n }\n }, _callee2, this, [[1, 12]]);\n }));\n function fetchWithRetry(_x2) {\n return _fetchWithRetry.apply(this, arguments);\n }\n return fetchWithRetry;\n }()\n }, {\n key: \"addFetch\",\n value: function () {\n var _addFetch = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee5(element) {\n var _this = this;\n var fragmentName, fragmentPath;\n return _regeneratorRuntime().wrap(function _callee5$(_context5) {\n while (1) switch (_context5.prev = _context5.next) {\n case 0:\n fragmentName = element.id.replace('fragment-', '');\n fragmentPath = \"fragments/\".concat(fragmentName, \".html\");\n return _context5.abrupt(\"return\", new Promise(/*#__PURE__*/function () {\n var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee4(resolve, reject) {\n var fetchPromise;\n return _regeneratorRuntime().wrap(function _callee4$(_context4) {\n while (1) switch (_context4.prev = _context4.next) {\n case 0:\n try {\n fetchPromise = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {\n var html, temp, scripts;\n return _regeneratorRuntime().wrap(function _callee3$(_context3) {\n while (1) switch (_context3.prev = _context3.next) {\n case 0:\n _context3.prev = 0;\n _context3.next = 3;\n return _this.fetchWithRetry(fragmentPath);\n case 3:\n html = _context3.sent;\n // Process the fragment\n temp = document.createElement('div');\n temp.innerHTML = html;\n element.innerHTML = temp.innerHTML;\n\n // Handle scripts\n scripts = temp.getElementsByTagName('script');\n Array.from(scripts).forEach(function (oldScript) {\n var newScript = document.createElement('script');\n Array.from(oldScript.attributes).forEach(function (attr) {\n newScript.setAttribute(attr.name, attr.value);\n });\n newScript.textContent = oldScript.textContent;\n oldScript.parentNode.removeChild(oldScript);\n document.body.appendChild(newScript);\n });\n _this.activeFetches--;\n resolve();\n _context3.next = 18;\n break;\n case 13:\n _context3.prev = 13;\n _context3.t0 = _context3[\"catch\"](0);\n console.error(\"Failed to load fragment \".concat(fragmentPath, \" after \").concat(_this.maxRetries, \" retries:\"), _context3.t0);\n _this.activeFetches--;\n reject(_context3.t0);\n case 18:\n case \"end\":\n return _context3.stop();\n }\n }, _callee3, null, [[0, 13]]);\n }))();\n _this.queue.push(fetchPromise);\n _this.activeFetches++;\n } catch (error) {\n reject(error);\n }\n case 1:\n case \"end\":\n return _context4.stop();\n }\n }, _callee4);\n }));\n return function (_x4, _x5) {\n return _ref.apply(this, arguments);\n };\n }()));\n case 3:\n case \"end\":\n return _context5.stop();\n }\n }, _callee5);\n }));\n function addFetch(_x3) {\n return _addFetch.apply(this, arguments);\n }\n return addFetch;\n }()\n }, {\n key: \"processNext\",\n value: function () {\n var _processNext = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee6(element) {\n return _regeneratorRuntime().wrap(function _callee6$(_context6) {\n while (1) switch (_context6.prev = _context6.next) {\n case 0:\n if (!(this.activeFetches < this.maxConcurrent && element)) {\n _context6.next = 3;\n break;\n }\n _context6.next = 3;\n return this.addFetch(element);\n case 3:\n case \"end\":\n return _context6.stop();\n }\n }, _callee6, this);\n }));\n function processNext(_x6) {\n return _processNext.apply(this, arguments);\n }\n return processNext;\n }()\n }]);\n }(); // Initialize queue\n fetchQueue = new FetchQueue(3);\n currentIndex = 0;\n elements = fragmentElements; // Assuming this is defined elsewhere\n // Initial loading of first 3 elements\n case 5:\n if (!(currentIndex < elements.length && currentIndex < 3)) {\n _context7.next = 11;\n break;\n }\n _context7.next = 8;\n return fetchQueue.processNext(elements[currentIndex]);\n case 8:\n currentIndex++;\n _context7.next = 5;\n break;\n case 11:\n if (!(currentIndex < elements.length)) {\n _context7.next = 20;\n break;\n }\n _context7.next = 14;\n return Promise.race(fetchQueue.queue);\n case 14:\n // Remove completed fetch from queue\n fetchQueue.queue = fetchQueue.queue.filter(function (p) {\n return p.status === 'pending';\n });\n // Add next element to queue\n _context7.next = 17;\n return fetchQueue.processNext(elements[currentIndex]);\n case 17:\n currentIndex++;\n _context7.next = 11;\n break;\n case 20:\n _context7.next = 22;\n return Promise.all(fetchQueue.queue);\n case 22:\n case \"end\":\n return _context7.stop();\n }\n }, _callee7);\n }));\n return _loadFragments.apply(this, arguments);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/fragmentLoader.js","mappings":"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","sources":["webpack://blogpost/./src/fragmentLoader.js?ac33"],"sourcesContent":["async function loadFragments() {\r\n    // Find all elements with ids starting with 'fragment-'\r\n    const fragmentElements = Array.from(document.querySelectorAll('[id^=\"fragment-\"]'));\r\n    \r\n    class FetchQueue {\r\n        constructor(maxConcurrent = 3) {\r\n            this.queue = [];\r\n            this.maxConcurrent = maxConcurrent;\r\n            this.activeFetches = 0;\r\n            this.maxRetries = 3; // Maximum number of retry attempts\r\n            this.baseDelay = 1000; // Base delay in milliseconds (1 second)\r\n        }\r\n\r\n        async sleep(ms) {\r\n            return new Promise(resolve => setTimeout(resolve, ms));\r\n        }\r\n\r\n        async fetchWithRetry(fragmentPath, retryCount = 0) {\r\n            try {\r\n                const response = await fetch(fragmentPath);\r\n                if (!response.ok) {\r\n                    throw new Error(`HTTP error! status: ${response.status}`);\r\n                }\r\n                return await response.text();\r\n            } catch (error) {\r\n                if (retryCount < this.maxRetries) {\r\n                    // Exponential backoff: 1s, 2s, 4s\r\n                    const delay = this.baseDelay * Math.pow(2, retryCount);\r\n                    console.warn(`Retry ${retryCount + 1}/${this.maxRetries} for ${fragmentPath} after ${delay}ms`);\r\n                    await this.sleep(delay);\r\n                    return this.fetchWithRetry(fragmentPath, retryCount + 1);\r\n                }\r\n                throw error;\r\n            }\r\n        }\r\n\r\n        async addFetch(element) {\r\n            const fragmentName = element.id.replace('fragment-', '');\r\n            const fragmentPath = `fragments/${fragmentName}.html`;\r\n            \r\n            return new Promise(async (resolve, reject) => {\r\n                try {\r\n                    const fetchPromise = (async () => {\r\n                        try {\r\n                            const html = await this.fetchWithRetry(fragmentPath);\r\n                            \r\n                            // Process the fragment\r\n                            const temp = document.createElement('div');\r\n                            temp.innerHTML = html;\r\n                            element.innerHTML = temp.innerHTML;\r\n                            \r\n                            // Handle scripts\r\n                            const scripts = temp.getElementsByTagName('script');\r\n                            Array.from(scripts).forEach(oldScript => {\r\n                                const newScript = document.createElement('script');\r\n                                Array.from(oldScript.attributes).forEach(attr => {\r\n                                    newScript.setAttribute(attr.name, attr.value);\r\n                                });\r\n                                newScript.textContent = oldScript.textContent;\r\n                                oldScript.parentNode.removeChild(oldScript);\r\n                                document.body.appendChild(newScript);\r\n                            });\r\n                            \r\n                            this.activeFetches--;\r\n                            resolve();\r\n                        } catch (error) {\r\n                            console.error(`Failed to load fragment ${fragmentPath} after ${this.maxRetries} retries:`, error);\r\n                            this.activeFetches--;\r\n                            reject(error);\r\n                        }\r\n                    })();\r\n\r\n                    this.queue.push(fetchPromise);\r\n                    this.activeFetches++;\r\n                } catch (error) {\r\n                    reject(error);\r\n                }\r\n            });\r\n        }\r\n\r\n        async processNext(element) {\r\n            if (this.activeFetches < this.maxConcurrent && element) {\r\n                await this.addFetch(element);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Initialize queue\r\n    const fetchQueue = new FetchQueue(3);\r\n    let currentIndex = 0;\r\n    const elements = fragmentElements; // Assuming this is defined elsewhere\r\n\r\n    // Initial loading of first 3 elements\r\n    while (currentIndex < elements.length && currentIndex < 3) {\r\n        await fetchQueue.processNext(elements[currentIndex]);\r\n        currentIndex++;\r\n    }\r\n\r\n    // Process remaining elements as fetches complete\r\n    while (currentIndex < elements.length) {\r\n        // Wait for any fetch to complete\r\n        await Promise.race(fetchQueue.queue);\r\n        // Remove completed fetch from queue\r\n        fetchQueue.queue = fetchQueue.queue.filter(p => p.status === 'pending');\r\n        // Add next element to queue\r\n        await fetchQueue.processNext(elements[currentIndex]);\r\n        currentIndex++;\r\n    }\r\n\r\n    // Wait for remaining fetches to complete\r\n    await Promise.all(fetchQueue.queue);\r\n}\r\n\r\nexport { loadFragments }"],"names":["_regeneratorRuntime","e","t","r","Object","prototype","n","hasOwnProperty","o","defineProperty","value","i","Symbol","a","iterator","c","asyncIterator","u","toStringTag","define","enumerable","configurable","writable","wrap","Generator","create","Context","makeInvokeMethod","tryCatch","type","arg","call","h","l","f","s","y","GeneratorFunction","GeneratorFunctionPrototype","p","d","getPrototypeOf","v","values","g","defineIteratorMethods","forEach","_invoke","AsyncIterator","invoke","_typeof","resolve","__await","then","callInvokeWithMethodAndArg","Error","done","method","delegate","maybeInvokeDelegate","sent","_sent","dispatchException","abrupt","TypeError","resultName","next","nextLoc","pushTryEntry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","push","resetTryEntry","completion","reset","isNaN","length","displayName","isGeneratorFunction","constructor","name","mark","setPrototypeOf","__proto__","awrap","async","Promise","keys","reverse","pop","prev","charAt","slice","stop","rval","handle","complete","finish","_catch","delegateYield","_classCallCheck","_defineProperties","_toPropertyKey","key","_createClass","_toPrimitive","toPrimitive","String","Number","asyncGeneratorStep","_asyncToGenerator","arguments","apply","_next","_throw","loadFragments","_loadFragments","_callee7","fragmentElements","FetchQueue","fetchQueue","currentIndex","elements","_callee7$","_context7","Array","from","document","querySelectorAll","maxConcurrent","undefined","queue","activeFetches","maxRetries","baseDelay","_sleep","_callee","ms","_callee$","_context","setTimeout","sleep","_x","_fetchWithRetry","_callee2","fragmentPath","retryCount","response","delay","_args2","_callee2$","_context2","fetch","ok","concat","status","text","t0","Math","pow","console","warn","fetchWithRetry","_x2","_addFetch","_callee5","element","_this","fragmentName","_callee5$","_context5","id","replace","_ref","_callee4","reject","fetchPromise","_callee4$","_context4","_callee3","html","temp","scripts","_callee3$","_context3","createElement","innerHTML","getElementsByTagName","oldScript","newScript","attributes","attr","setAttribute","textContent","parentNode","removeChild","body","appendChild","error","_x4","_x5","addFetch","_x3","_processNext","_callee6","_callee6$","_context6","processNext","_x6","race","filter","all"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/fragmentLoader.js\n");
20
-
21
- /***/ }),
22
-
23
- /***/ "./src/index.js":
24
- /*!**********************!*\
25
- !*** ./src/index.js ***!
26
- \**********************/
27
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
28
-
29
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _fragmentLoader__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./fragmentLoader */ \"./src/fragmentLoader.js\");\n/* harmony import */ var _syncHFSpacesURLHash__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./syncHFSpacesURLHash */ \"./src/syncHFSpacesURLHash.js\");\n// import { plotClusters } from './clusters'\n\n\ndocument.addEventListener(\"DOMContentLoaded\", function () {\n console.log(\"DOMContentLoaded\");\n (0,_fragmentLoader__WEBPACK_IMPORTED_MODULE_0__.loadFragments)();\n // init_memory_plot();\n (0,_syncHFSpacesURLHash__WEBPACK_IMPORTED_MODULE_1__.syncHFSpacesURLHash)();\n}, {\n once: true\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvaW5kZXguanMiLCJtYXBwaW5ncyI6Ijs7O0FBQUE7QUFDZ0Q7QUFDVztBQUUzREUsUUFBUSxDQUFDQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxZQUFNO0VBQ2hEQyxPQUFPLENBQUNDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQztFQUMvQkwsOERBQWEsQ0FBQyxDQUFDO0VBQ2Y7RUFDQUMseUVBQW1CLENBQUMsQ0FBQztBQUN6QixDQUFDLEVBQUU7RUFBRUssSUFBSSxFQUFFO0FBQUssQ0FBQyxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvZ3Bvc3QvLi9zcmMvaW5kZXguanM/YjYzNSJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBpbXBvcnQgeyBwbG90Q2x1c3RlcnMgfSBmcm9tICcuL2NsdXN0ZXJzJ1xyXG5pbXBvcnQgeyBsb2FkRnJhZ21lbnRzIH0gZnJvbSAnLi9mcmFnbWVudExvYWRlcidcclxuaW1wb3J0IHsgc3luY0hGU3BhY2VzVVJMSGFzaCB9IGZyb20gJy4vc3luY0hGU3BhY2VzVVJMSGFzaCdcclxuXHJcbmRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoXCJET01Db250ZW50TG9hZGVkXCIsICgpID0+IHtcclxuICAgIGNvbnNvbGUubG9nKFwiRE9NQ29udGVudExvYWRlZFwiKTtcclxuICAgIGxvYWRGcmFnbWVudHMoKTtcclxuICAgIC8vIGluaXRfbWVtb3J5X3Bsb3QoKTtcclxuICAgIHN5bmNIRlNwYWNlc1VSTEhhc2goKTtcclxufSwgeyBvbmNlOiB0cnVlIH0pO1xyXG4iXSwibmFtZXMiOlsibG9hZEZyYWdtZW50cyIsInN5bmNIRlNwYWNlc1VSTEhhc2giLCJkb2N1bWVudCIsImFkZEV2ZW50TGlzdGVuZXIiLCJjb25zb2xlIiwibG9nIiwib25jZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/index.js\n");
30
-
31
- /***/ }),
32
-
33
- /***/ "./src/syncHFSpacesURLHash.js":
34
- /*!************************************!*\
35
- !*** ./src/syncHFSpacesURLHash.js ***!
36
- \************************************/
37
- /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
38
-
39
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ syncHFSpacesURLHash: () => (/* binding */ syncHFSpacesURLHash)\n/* harmony export */ });\nvar queryArg = \"section\";\nfunction syncHFSpacesURLHash() {\n // Handle explicit section requests (don't update hash automatically on load)\n var hasExplicitRequest = handleExplicitSectionRequest();\n\n // Set up hash change monitoring\n updateHashBasedOnHashChange();\n\n // Always set up scroll monitoring to update hash during scrolling\n setupScrollMonitoring();\n\n // If no explicit request, we don't update the hash on initial load\n // The hash will only start updating when the user scrolls\n}\nfunction handleExplicitSectionRequest() {\n // Check for section parameter in URL\n var urlParams = new URLSearchParams(window.location.search);\n var sectionId = urlParams.get(queryArg);\n\n // If we have an explicit section request\n if (sectionId) {\n var targetElement = document.getElementById(sectionId);\n if (targetElement) {\n // Slight delay to ensure the browser doesn't try to do its own scrolling first\n setTimeout(function () {\n targetElement.scrollIntoView();\n history.replaceState(null, null, \"#\".concat(sectionId));\n }, 100);\n }\n return true;\n }\n\n // No explicit section parameter found\n return false;\n}\nfunction setupScrollMonitoring() {\n // Variables to manage throttling\n var isScrolling = false;\n var lastKnownScrollPosition = 0;\n var initialScroll = true;\n\n // Add the scroll event listener\n window.addEventListener('scroll', function () {\n lastKnownScrollPosition = window.scrollY;\n if (!isScrolling) {\n window.requestAnimationFrame(function () {\n // Skip the first scroll event which might be browser's automatic scroll\n // to a hash on page load\n if (initialScroll) {\n initialScroll = false;\n } else {\n updateHashBasedOnScroll(lastKnownScrollPosition);\n }\n isScrolling = false;\n });\n }\n isScrolling = true;\n });\n}\n\n// Function to update the URL hash based on scroll position\nfunction updateHashBasedOnScroll(scrollPosition) {\n var closestHeading = findClosestHeading(scrollPosition);\n\n // Update the URL hash if we found a closest element\n if (closestHeading && closestHeading.id) {\n // Only update if the hash is different to avoid unnecessary operations\n if (window.location.hash !== \"#\".concat(closestHeading.id)) {\n silentlyUpdateHash(closestHeading.id);\n postMessageToHFSpaces(closestHeading.id);\n }\n }\n}\n\n// Find the closest heading to the current scroll position\nfunction findClosestHeading(scrollPosition) {\n // Get only heading elements with IDs that we want to track\n var headingsWithIds = Array.from(document.querySelectorAll('h1[id], h2[id], h3[id], h4[id], h5[id], h6[id]'));\n\n // Skip if there are no headings with IDs\n if (headingsWithIds.length === 0) return null;\n\n // Find the element closest to the middle of the viewport\n var closestHeading = null;\n var closestDistance = Infinity;\n var viewportMiddle = scrollPosition + window.innerHeight / 2;\n\n // Iterate through all headings to find the closest one\n headingsWithIds.forEach(function (heading) {\n var headingTop = heading.getBoundingClientRect().top + scrollPosition;\n var distance = Math.abs(headingTop - viewportMiddle);\n if (distance < closestDistance) {\n closestDistance = distance;\n closestHeading = heading;\n }\n });\n return closestHeading;\n}\n\n// Update hash without triggering scroll or other side effects\nfunction silentlyUpdateHash(id) {\n history.replaceState(null, null, \"#\".concat(id));\n}\nfunction updateHashBasedOnHashChange() {\n window.addEventListener('hashchange', function () {\n var elementId = window.location.hash.slice(1);\n postMessageToHFSpaces(elementId);\n });\n}\nfunction postMessageToHFSpaces(elementId) {\n var parentOrigin = \"https://huggingface.co\";\n window.parent.postMessage({\n queryString: \"\".concat(queryArg, \"=\").concat(elementId)\n }, parentOrigin);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/syncHFSpacesURLHash.js","mappings":"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","sources":["webpack://blogpost/./src/syncHFSpacesURLHash.js?6727"],"sourcesContent":["const queryArg = \"section\";\r\n\r\nfunction syncHFSpacesURLHash() {\r\n  // Handle explicit section requests (don't update hash automatically on load)\r\n  const hasExplicitRequest = handleExplicitSectionRequest();\r\n  \r\n  // Set up hash change monitoring\r\n  updateHashBasedOnHashChange();\r\n  \r\n  // Always set up scroll monitoring to update hash during scrolling\r\n  setupScrollMonitoring();\r\n  \r\n  // If no explicit request, we don't update the hash on initial load\r\n  // The hash will only start updating when the user scrolls\r\n}\r\n\r\nfunction handleExplicitSectionRequest() {\r\n  // Check for section parameter in URL\r\n  const urlParams = new URLSearchParams(window.location.search);\r\n  const sectionId = urlParams.get(queryArg);\r\n  \r\n  // If we have an explicit section request\r\n  if (sectionId) {\r\n    const targetElement = document.getElementById(sectionId);\r\n    if (targetElement) {\r\n      // Slight delay to ensure the browser doesn't try to do its own scrolling first\r\n      setTimeout(() => {\r\n        targetElement.scrollIntoView();\r\n        history.replaceState(null, null, `#${sectionId}`);\r\n      }, 100);\r\n    }\r\n    return true;\r\n  }\r\n  \r\n  // No explicit section parameter found\r\n  return false;\r\n}\r\n\r\nfunction setupScrollMonitoring() {\r\n  // Variables to manage throttling\r\n  let isScrolling = false;\r\n  let lastKnownScrollPosition = 0;\r\n  let initialScroll = true;\r\n  \r\n  // Add the scroll event listener\r\n  window.addEventListener('scroll', function() {\r\n    lastKnownScrollPosition = window.scrollY;\r\n    \r\n    if (!isScrolling) {\r\n      window.requestAnimationFrame(function() {\r\n        // Skip the first scroll event which might be browser's automatic scroll\r\n        // to a hash on page load\r\n        if (initialScroll) {\r\n          initialScroll = false;\r\n        } else {\r\n          updateHashBasedOnScroll(lastKnownScrollPosition);\r\n        }\r\n        isScrolling = false;\r\n      });\r\n    }\r\n    \r\n    isScrolling = true;\r\n  });\r\n}\r\n\r\n// Function to update the URL hash based on scroll position\r\nfunction updateHashBasedOnScroll(scrollPosition) {\r\n  const closestHeading = findClosestHeading(scrollPosition);\r\n  \r\n  // Update the URL hash if we found a closest element\r\n  if (closestHeading && closestHeading.id) {\r\n    // Only update if the hash is different to avoid unnecessary operations\r\n    if (window.location.hash !== `#${closestHeading.id}`) {\r\n      silentlyUpdateHash(closestHeading.id);\r\n      postMessageToHFSpaces(closestHeading.id);\r\n    }\r\n  }\r\n}\r\n\r\n// Find the closest heading to the current scroll position\r\nfunction findClosestHeading(scrollPosition) {\r\n  // Get only heading elements with IDs that we want to track\r\n  const headingsWithIds = Array.from(document.querySelectorAll('h1[id], h2[id], h3[id], h4[id], h5[id], h6[id]'));\r\n\r\n  // Skip if there are no headings with IDs\r\n  if (headingsWithIds.length === 0) return null;\r\n\r\n  // Find the element closest to the middle of the viewport\r\n  let closestHeading = null;\r\n  let closestDistance = Infinity;\r\n  const viewportMiddle = scrollPosition + window.innerHeight / 2;\r\n  \r\n  // Iterate through all headings to find the closest one\r\n  headingsWithIds.forEach(heading => {\r\n    const headingTop = heading.getBoundingClientRect().top + scrollPosition;\r\n    const distance = Math.abs(headingTop - viewportMiddle);\r\n    \r\n    if (distance < closestDistance) {\r\n      closestDistance = distance;\r\n      closestHeading = heading;\r\n    }\r\n  });\r\n  \r\n  return closestHeading;\r\n}\r\n\r\n// Update hash without triggering scroll or other side effects\r\nfunction silentlyUpdateHash(id) {\r\n  history.replaceState(null, null, `#${id}`);\r\n}\r\n\r\nfunction updateHashBasedOnHashChange() {\r\n  window.addEventListener('hashchange', () => {\r\n    const elementId = window.location.hash.slice(1);\r\n    postMessageToHFSpaces(elementId);\r\n  });\r\n}\r\n\r\nfunction postMessageToHFSpaces(elementId) {\r\n  const parentOrigin = \"https://huggingface.co\";\r\n  window.parent.postMessage({ queryString: `${queryArg}=${elementId}` }, parentOrigin);\r\n}\r\n\r\nexport { syncHFSpacesURLHash };\r\n"],"names":["queryArg","syncHFSpacesURLHash","hasExplicitRequest","handleExplicitSectionRequest","updateHashBasedOnHashChange","setupScrollMonitoring","urlParams","URLSearchParams","window","location","search","sectionId","get","targetElement","document","getElementById","setTimeout","scrollIntoView","history","replaceState","concat","isScrolling","lastKnownScrollPosition","initialScroll","addEventListener","scrollY","requestAnimationFrame","updateHashBasedOnScroll","scrollPosition","closestHeading","findClosestHeading","id","hash","silentlyUpdateHash","postMessageToHFSpaces","headingsWithIds","Array","from","querySelectorAll","length","closestDistance","Infinity","viewportMiddle","innerHeight","forEach","heading","headingTop","getBoundingClientRect","top","distance","Math","abs","elementId","slice","parentOrigin","parent","postMessage","queryString"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/syncHFSpacesURLHash.js\n");
40
-
41
- /***/ })
42
-
43
- /******/ });
44
- /************************************************************************/
45
- /******/ // The module cache
46
- /******/ var __webpack_module_cache__ = {};
47
- /******/
48
- /******/ // The require function
49
- /******/ function __webpack_require__(moduleId) {
50
- /******/ // Check if module is in cache
51
- /******/ var cachedModule = __webpack_module_cache__[moduleId];
52
- /******/ if (cachedModule !== undefined) {
53
- /******/ return cachedModule.exports;
54
- /******/ }
55
- /******/ // Create a new module (and put it into the cache)
56
- /******/ var module = __webpack_module_cache__[moduleId] = {
57
- /******/ // no module.id needed
58
- /******/ // no module.loaded needed
59
- /******/ exports: {}
60
- /******/ };
61
- /******/
62
- /******/ // Execute the module function
63
- /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
64
- /******/
65
- /******/ // Return the exports of the module
66
- /******/ return module.exports;
67
- /******/ }
68
- /******/
69
- /************************************************************************/
70
- /******/ /* webpack/runtime/define property getters */
71
- /******/ (() => {
72
- /******/ // define getter functions for harmony exports
73
- /******/ __webpack_require__.d = (exports, definition) => {
74
- /******/ for(var key in definition) {
75
- /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
76
- /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
77
- /******/ }
78
- /******/ }
79
- /******/ };
80
- /******/ })();
81
- /******/
82
- /******/ /* webpack/runtime/hasOwnProperty shorthand */
83
- /******/ (() => {
84
- /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
85
- /******/ })();
86
- /******/
87
- /******/ /* webpack/runtime/make namespace object */
88
- /******/ (() => {
89
- /******/ // define __esModule on exports
90
- /******/ __webpack_require__.r = (exports) => {
91
- /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
92
- /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
93
- /******/ }
94
- /******/ Object.defineProperty(exports, '__esModule', { value: true });
95
- /******/ };
96
- /******/ })();
97
- /******/
98
- /************************************************************************/
99
- /******/
100
- /******/ // startup
101
- /******/ // Load entry module and return exports
102
- /******/ // This entry module can't be inlined because the eval-source-map devtool is used.
103
- /******/ var __webpack_exports__ = __webpack_require__("./src/index.js");
104
- /******/
105
- /******/ })()
106
- ;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
dist/style.css DELETED
@@ -1,599 +0,0 @@
1
- /* style.css */
2
- /* Define colors */
3
- :root {
4
- --distill-gray: rgb(107, 114, 128);
5
- --distill-gray-light: rgb(185, 185, 185);
6
- --distill-gray-lighter: rgb(228, 228, 228);
7
- --distill-gray-lightest: rgb(245, 245, 245);
8
- --distill-blue: #007BFF;
9
- }
10
-
11
- /* Container for the controls */
12
- [id^="plot-"] {
13
- display: flex;
14
- flex-direction: column;
15
- align-items: center;
16
- gap: 15px; /* Adjust the gap between controls as needed */
17
- }
18
- [id^="plot-"] figure {
19
- margin-bottom: 0px;
20
- margin-top: 0px;
21
- padding: 0px;
22
- }
23
- .plotly_caption {
24
- font-style: italic;
25
- margin-top: 10px;
26
- }
27
-
28
- .plotly_controls {
29
- display: flex;
30
- flex-wrap: wrap;
31
- flex-direction: row;
32
- justify-content: center;
33
- align-items: flex-start;
34
- gap: 30px;
35
- }
36
-
37
-
38
- .plotly_input_container {
39
- display: flex;
40
- align-items: center;
41
- flex-direction: column;
42
- gap: 10px;
43
- }
44
-
45
- /* Style for the select dropdown */
46
- .plotly_input_container > select {
47
- padding: 2px 4px;
48
- /* border: 1px solid #ccc; */
49
- line-height: 1.5em;
50
- text-align: center;
51
- border-radius: 4px;
52
- font-size: 12px;
53
- background-color: var(--distill-gray-lightest);
54
- outline: none;
55
- }
56
-
57
- /* Style for the range input */
58
-
59
- .plotly_slider {
60
- display: flex;
61
- align-items: center;
62
- gap: 10px;
63
- }
64
-
65
- .plotly_slider > input[type="range"] {
66
- -webkit-appearance: none;
67
- height: 2px;
68
- background: var(--distill-gray-light);
69
- border-radius: 5px;
70
- outline: none;
71
- }
72
-
73
- .plotly_slider > span {
74
- font-size: 14px;
75
- line-height: 1.6em;
76
- min-width: 16px;
77
- }
78
-
79
- .plotly_slider > input[type="range"]::-webkit-slider-thumb {
80
- -webkit-appearance: none;
81
- appearance: none;
82
- width: 18px;
83
- height: 18px;
84
- border-radius: 50%;
85
- background: var(--distill-blue);
86
- cursor: pointer;
87
- }
88
-
89
- .plotly_slider > input[type="range"]::-moz-range-thumb {
90
- width: 18px;
91
- height: 18px;
92
- border-radius: 50%;
93
- background: var(--distill-blue);
94
- cursor: pointer;
95
- }
96
-
97
- /* Style for the labels */
98
- .plotly_input_container > label {
99
- font-size: 14px;
100
- font-weight: bold;
101
- }
102
-
103
- .main-plot-container {
104
- margin-top: 21px;
105
- margin-bottom: 35px;
106
- }
107
-
108
- .main-plot-container > figure {
109
- display: block !important;
110
- /* Let this be handled by graph-container */
111
- margin-bottom: 0px;
112
- margin-top: 0px;
113
- }
114
- .main-plot-container > div {
115
- display: none !important;
116
- }
117
-
118
-
119
- @media (min-width: 768px) {
120
- .main-plot-container > figure {
121
- display: none !important;
122
- }
123
- .main-plot-container > div {
124
- display: flex !important;
125
- }
126
- }
127
-
128
- d-byline .byline {
129
- grid-template-columns: 1fr;
130
- grid-column: text;
131
- font-size: 0.9rem;
132
- line-height: 1.8em;
133
- }
134
-
135
- @media (min-width: 768px) {
136
- d-byline .byline {
137
- grid-template-columns: 5fr 1fr 1fr;
138
- }
139
- }
140
-
141
- #title-plot {
142
- margin-top: 0px;
143
- margin-bottom: 0px;
144
- }
145
-
146
- d-contents > nav a.active {
147
- text-decoration: underline;
148
- }
149
-
150
- @media (max-width: 1199px) {
151
- d-contents {
152
- display: none;
153
- background: white;
154
- justify-self: start;
155
- align-self: start;
156
- padding-bottom: 0.5em;
157
- margin-bottom: 1em;
158
- padding-left: 0.25em;
159
- border-bottom: 1px solid rgba(0, 0, 0, 0.1);
160
- border-bottom-width: 1px;
161
- border-bottom-style: solid;
162
- border-bottom-color: rgba(0, 0, 0, 0.1);
163
- overflow-y: scroll;
164
- height: calc(100vh - 40px);
165
- scrollbar-width: none;
166
- z-index: -100;
167
- }
168
- }
169
-
170
- d-contents a:hover {
171
- border-bottom: none;
172
- }
173
-
174
- toc-title {
175
- font-weight: bold;
176
- font-size: 1.2em;
177
- color: #333;
178
- }
179
-
180
- toggle-icon {
181
- transition: transform 0.3s;
182
- }
183
-
184
- toggle-icon.collapsed {
185
- transform: rotate(90deg);
186
- }
187
-
188
- .toc-content {
189
- margin-top: 15px;
190
- overflow: hidden;
191
- /* max-height: 1000px; */
192
- transition: max-height 0.3s ease-out;
193
- }
194
-
195
- .toc-content.collapsed {
196
- max-height: 0;
197
- margin-top: 0;
198
- }
199
-
200
- @media (min-width: 1200px) {
201
- d-article {
202
- /* Ensure d-article does not prevent sticky positioning */
203
- overflow: visible;
204
- }
205
-
206
- d-contents {
207
- align-self: start;
208
- background: white;
209
- grid-column-start: 1 !important;
210
- grid-column-end: 4 !important;
211
- grid-row: auto / span 6;
212
- justify-self: end;
213
- margin-top: 0em;
214
- padding-right: 3em;
215
- padding-left: 2em;
216
- /* border-right: 1px solid rgba(0, 0, 0, 0.1);
217
- border-right-width: 1px;
218
- border-right-style: solid;
219
- border-right-color: rgba(0, 0, 0, 0.1); */
220
- position: -webkit-sticky; /* For Safari */
221
- position: sticky;
222
- top: 10px; /* Adjust this value if needed */
223
- overflow-y: auto;
224
- height: calc(100vh - 40px);
225
- scrollbar-width: none;
226
- transition: max-height 0.3s ease-out;
227
- z-index: -100;
228
- }
229
- }
230
-
231
- d-contents nav h3 {
232
- margin-top: 0;
233
- margin-bottom: 1em;
234
- }
235
-
236
- d-contents nav div div {
237
- color: rgba(0, 0, 0, 0.8);
238
- font-weight: bold;
239
- }
240
-
241
- d-contents nav a {
242
- color: rgba(0, 0, 0, 0.8);
243
- border-bottom: none;
244
- text-decoration: none;
245
- }
246
-
247
- d-contents li {
248
- list-style-type: none;
249
- }
250
-
251
- d-contents ul, d-article d-contents ul {
252
- padding-left: 1em;
253
- }
254
-
255
- d-contents nav ul li {
256
- margin-bottom: .25em;
257
- }
258
-
259
- d-contents nav a:hover {
260
- text-decoration: underline solid rgba(0, 0, 0, 0.6);
261
- }
262
-
263
- d-contents nav ul {
264
- margin-top: 0;
265
- margin-bottom: 6px;
266
- }
267
-
268
-
269
- d-contents nav > div {
270
- display: block;
271
- outline: none;
272
- margin-bottom: 0.5em;
273
- }
274
-
275
- d-contents nav > div > a {
276
- font-size: 13px;
277
- font-weight: 600;
278
- }
279
-
280
- d-article aside {
281
- margin-bottom: 1em;
282
- }
283
-
284
- d-article img {
285
- max-width: 100%;
286
- }
287
-
288
- @media (min-width: 768px) {
289
- d-article aside {
290
- margin-bottom: 0;
291
- }
292
- }
293
-
294
- d-contents nav > div > a:hover,
295
- d-contents nav > ul > li > a:hover {
296
- text-decoration: none;
297
- }
298
-
299
- .note-box {
300
- background-color: #f6f8fa;
301
- border-left: 4px solid #444444;
302
- padding: 1rem;
303
- margin: 1rem 0; /* Keep this modest margin */
304
- border-radius: 6px;
305
- /* Add this to ensure the box only takes up needed space */
306
- display: inline-block;
307
- width: 100%;
308
- }
309
-
310
- .note-box-title {
311
- margin: 0;
312
- color: #444444;
313
- font-weight: 600;
314
- font-size: 1em;
315
- }
316
-
317
- .note-box-content {
318
- margin-top: 0.5rem;
319
- margin-bottom: 0; /* Ensure no bottom margin */
320
- color: #24292f;
321
- font-size: 0.9em;
322
- line-height: 1.5em;
323
- }
324
-
325
- /* For dark mode support */
326
- @media (prefers-color-scheme: dark) {
327
- .note-box {
328
- background-color: #1c1c1c;
329
- border-left-color: #888888;
330
- }
331
- .note-box-title {
332
- color: #888888;
333
- }
334
- .note-box-content {
335
- color: #d4d4d4;
336
- }
337
- }
338
-
339
- d-article {
340
- font-size: 1.0em;
341
- }
342
-
343
- .figure-legend {
344
- font-size: 0.9em;
345
- font-style: italic;
346
- color: var(--distill-gray);
347
- line-height: 1.5em;
348
- }
349
-
350
- d-code {
351
- font-size: 12px;
352
- }
353
-
354
- .large-image-background {
355
- width: 100vw;
356
- padding-top: 10px;
357
- padding-bottom: 10px;
358
- margin-left: calc(-50vw + 50%);
359
- margin-right: calc(-50vw + 50%);
360
- background: white;
361
- height: fit-content; /* This will make it match the image height */
362
- display: flex;
363
- justify-content: center; /* This will center your image */
364
- }
365
-
366
- .large-image-background-transparent {
367
- /* width: 100vw; */
368
- padding-top: 10px;
369
- padding-bottom: 10px;
370
- /* margin-left: calc(-50vw + 50%); */
371
- margin-left:-100px;
372
- margin-right: -100px;
373
- /* margin-right: calc(-50vw + 50%); */
374
- /* background: white; */
375
- height: fit-content; /* This will make it match the image height */
376
- display: flex;
377
- justify-content: center; /* This will center your image */
378
- }
379
-
380
- .boxed-image {
381
- padding: 0.5rem;
382
- background: white;
383
- border-radius: 12px;
384
- border: 1px solid #e5e7eb;
385
- box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
386
- }
387
-
388
- d-article li {
389
- margin-bottom: 0.0em;
390
- }
391
-
392
- d-article ul ul {
393
- margin-bottom: 0.0em;
394
- }
395
-
396
- d-article ol ol {
397
- margin-bottom: 0.0em;
398
- }
399
-
400
- d-article hr {
401
- grid-column: text;
402
- }
403
-
404
- /* Memory visualization */
405
- #graph-all {
406
- min-width: 500px;
407
- margin-right: 10px;
408
- margin-bottom: 2rem;
409
- padding: 0.5rem;
410
- background: #f9fafb;
411
- border-radius: 12px;
412
- border: 1px solid #e5e7eb;
413
- box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
414
- }
415
-
416
-
417
- /* Main container styles */
418
- #controls {
419
- max-width: 1200px;
420
- /* margin: 2rem auto; */
421
- margin-bottom: 2rem;
422
- margin-left: 10px;
423
- padding: 0.6rem;
424
- background: #f9fafb;
425
- border-radius: 12px;
426
- border: 1px solid #e5e7eb;
427
- box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
428
- }
429
-
430
- /* Grid layout */
431
- #controls {
432
- display: grid;
433
- grid-template-columns: 1fr 1fr;
434
- /* gap: 2rem; */
435
- }
436
-
437
- /* Cell styles */
438
- .cell {
439
- margin-bottom: 0.2rem;
440
- }
441
-
442
- /* Label styles */
443
- label {
444
- display: block;
445
- /* margin-bottom: 0.5rem; */
446
- font-size: 0.8rem;
447
- font-weight: 500;
448
- color: #374151;
449
- }
450
-
451
- /* Input container for range + number combination */
452
- .input-container {
453
- display: flex;
454
- gap: 1rem;
455
- align-items: center;
456
- }
457
-
458
- /* Range input styling */
459
- input[type="range"] {
460
- flex: 1;
461
- height: 6px;
462
- background: #e5e7eb;
463
- border-radius: 3px;
464
- appearance: none;
465
- outline: none;
466
- }
467
-
468
- input[type="range"]::-webkit-slider-thumb {
469
- appearance: none;
470
- width: 16px;
471
- height: 16px;
472
- background: #3b82f6;
473
- border-radius: 50%;
474
- cursor: pointer;
475
- transition: background 0.15s ease;
476
- }
477
-
478
- input[type="range"]::-webkit-slider-thumb:hover {
479
- background: #2563eb;
480
- }
481
-
482
- /* Number input styling */
483
- input[type="number"] {
484
- width: 80px;
485
- padding: 0.5rem;
486
- border: 1px solid #e5e7eb;
487
- border-radius: 6px;
488
- font-size: 0.9rem;
489
- color: #374151;
490
- }
491
-
492
- /* Select styling */
493
- select {
494
- width: 100%;
495
- padding: 0.5rem;
496
- border: 1px solid #e5e7eb;
497
- border-radius: 6px;
498
- background: white;
499
- font-size: 0.9rem;
500
- color: #374151;
501
- cursor: pointer;
502
- }
503
-
504
- /* Checkbox styling */
505
- input[type="checkbox"] {
506
- width: 1.2rem;
507
- height: 1.2rem;
508
- margin-right: 0.5rem;
509
- border: 2px solid #e5e7eb;
510
- border-radius: 4px;
511
- cursor: pointer;
512
- }
513
-
514
- /* Column specific styles */
515
- .column-1 {
516
- padding-right: 0.5rem;
517
- }
518
-
519
- .column-2 {
520
- padding-left: 0.5rem;
521
- }
522
-
523
- /* Checkbox container */
524
- .checkbox-container {
525
- display: flex;
526
- align-items: center;
527
- margin-bottom: 1rem;
528
- }
529
-
530
- /* Memory visualization styles */
531
- .memory-block {
532
- background: #fff;
533
- border-radius: 8px;
534
- padding: 1rem;
535
- margin-bottom: 1rem;
536
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
537
- }
538
-
539
- .memory-title {
540
- font-size: 1.1rem;
541
- font-weight: 500;
542
- color: #374151;
543
- margin-bottom: 0.5rem;
544
- }
545
-
546
- .memory-value {
547
- font-size: 1.5rem;
548
- font-weight: 600;
549
- color: #3b82f6;
550
- }
551
-
552
- /* Responsive adjustments */
553
- @media (max-width: 768px) {
554
- #controls {
555
- grid-template-columns: 1fr;
556
- padding: 1rem;
557
- }
558
-
559
- .column-1, .column-2 {
560
- padding: 0;
561
- }
562
- }
563
-
564
- /* Hover states and transitions */
565
- input:hover, select:hover {
566
- border-color: #3b82f6;
567
- }
568
-
569
- input:focus, select:focus {
570
- border-color: #2563eb;
571
- outline: none;
572
- box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
573
- }
574
-
575
- /* Add smooth transitions */
576
- input, select, button {
577
- transition: all 0.15s ease;
578
- }
579
-
580
- /* Preset dropdown special styling */
581
- select[name="presets"] {
582
- background-color: #f3f4f6;
583
- font-weight: 500;
584
- }
585
-
586
- /* Memory graph enhancements */
587
- .activation-memory {
588
- background: #dbeafe;
589
- padding: 1rem;
590
- border-radius: 8px;
591
- margin-bottom: 1rem;
592
- }
593
-
594
- .gradient-memory {
595
- background: #ede9fe;
596
- padding: 1rem;
597
- border-radius: 8px;
598
- }
599
-
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
src/fragments/word-emb-hierarchy.html ADDED
@@ -0,0 +1,167 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!-- The container for your D3 visualization -->
2
+ <div id="my-word-emb-vis" style="height: 500px; width: 1000px;"></div>
3
+
4
+ <!-- Include D3 (if Distill hasn't already) -->
5
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/7.8.5/d3.min.js"></script>
6
+
7
+ <!-- Define your visualization styles, scoping to #my-word-emb-vis -->
8
+ <style>
9
+ /* Scope all rules to the container ID to avoid conflicts */
10
+ #my-word-emb-vis .node circle {
11
+ fill: #fff;
12
+ stroke: #4682b4;
13
+ stroke-width: 2px;
14
+ transition: fill 0.3s, r 0.3s;
15
+ cursor: pointer;
16
+ }
17
+ #my-word-emb-vis .node text {
18
+ font-size: 14px;
19
+ transition: font-size 0.3s, fill 0.3s;
20
+ cursor: pointer;
21
+ pointer-events: none;
22
+ }
23
+ #my-word-emb-vis .link {
24
+ fill: none;
25
+ stroke: #ccc;
26
+ stroke-width: 2px;
27
+ transition: stroke 0.3s, stroke-width 0.3s;
28
+ }
29
+ #my-word-emb-vis .parent {
30
+ font-weight: bold;
31
+ }
32
+ #my-word-emb-vis .node-highlighted circle {
33
+ fill: #d1e7ff;
34
+ r: 8;
35
+ }
36
+ #my-word-emb-vis .node-highlighted text {
37
+ font-size: 16px;
38
+ font-weight: bold;
39
+ fill: #4682b4;
40
+ }
41
+ #my-word-emb-vis .link-highlighted {
42
+ stroke: #4682b4;
43
+ stroke-width: 3px;
44
+ }
45
+ </style>
46
+
47
+ <script type="text/javascript">
48
+ (function() {
49
+ // Data structure representing the hierarchy
50
+ const data = {
51
+ name: "Word Embedding",
52
+ children: [
53
+ {
54
+ name: "Traditional Word Embedding",
55
+ children: [
56
+ { name: "Count Vector" },
57
+ { name: "TF-IDF" },
58
+ { name: "Co-Occurrence Matrix" }
59
+ ]
60
+ },
61
+ {
62
+ name: "Static Word Embedding",
63
+ children: [
64
+ { name: "Word2Vec" },
65
+ { name: "Glove" },
66
+ { name: "Fast Text" }
67
+ ]
68
+ },
69
+ {
70
+ name: "Contextualized Word Embedding",
71
+ children: [
72
+ { name: "ELMo" },
73
+ { name: "GPT & GPT 2" },
74
+ { name: "BERT" }
75
+ ]
76
+ }
77
+ ]
78
+ };
79
+
80
+ // Dimensions
81
+ const margin = { top: 10, right: 10, bottom: 10, left: 10 };
82
+
83
+ // Create tree layout
84
+ const treeLayout = d3.tree()
85
+ .size([height - margin.top - margin.bottom, width - margin.right - margin.left]);
86
+
87
+ // Convert data to hierarchy
88
+ const root = d3.hierarchy(data);
89
+ treeLayout(root);
90
+
91
+ // Create the SVG inside our container
92
+ const svg = d3.select("#my-word-emb-vis")
93
+ .append("svg")
94
+ .attr("width", width)
95
+ .attr("height", height)
96
+ .append("g")
97
+ .attr("transform", `translate(${margin.left},${margin.top})`);
98
+
99
+ // Create links
100
+ svg.selectAll(".link")
101
+ .data(root.links())
102
+ .enter()
103
+ .append("path")
104
+ .attr("class", "link")
105
+ .attr("d", d3.linkHorizontal()
106
+ .x(d => d.y)
107
+ .y(d => d.x)
108
+ );
109
+
110
+ // Create nodes
111
+ const node = svg.selectAll(".node")
112
+ .data(root.descendants())
113
+ .enter()
114
+ .append("g")
115
+ .attr("class", "node")
116
+ .attr("transform", d => `translate(${d.y},${d.x})`)
117
+ .attr("id", d => `node-${d.data.name.replace(/\s+/g, '-').replace(/[&]/g, 'and').toLowerCase()}`)
118
+ .on("mouseover", function(event, d) {
119
+ // Highlight the current node
120
+ d3.select(this).classed("node-highlighted", true);
121
+
122
+ // Highlight all parent links and nodes
123
+ let ancestor = d;
124
+ while (ancestor.parent) {
125
+ const linkIndex = root.links().findIndex(link =>
126
+ link.source === ancestor.parent && link.target === ancestor
127
+ );
128
+ if (linkIndex !== -1) {
129
+ d3.selectAll(".link").each(function(linkData, i) {
130
+ if (i === linkIndex) {
131
+ d3.select(this).classed("link-highlighted", true);
132
+ }
133
+ });
134
+ }
135
+ d3.select(`#node-${ancestor.parent.data.name.replace(/\s+/g, '-').replace(/[&]/g, 'and').toLowerCase()}`)
136
+ .classed("node-highlighted", true);
137
+
138
+ ancestor = ancestor.parent;
139
+ }
140
+ })
141
+ .on("mouseout", function() {
142
+ // Remove all highlights
143
+ d3.selectAll(".node").classed("node-highlighted", false);
144
+ d3.selectAll(".link").classed("link-highlighted", false);
145
+ });
146
+
147
+ // Add circles to nodes
148
+ node.append("circle")
149
+ .attr("r", 6);
150
+
151
+ // Add text labels
152
+ node.append("text")
153
+ .attr("dy", ".35em")
154
+ .attr("x", d => {
155
+ if (d.depth === 0) return -15;
156
+ else if (d.depth === 1) return -15;
157
+ else return 15;
158
+ })
159
+ .attr("text-anchor", d => {
160
+ if (d.depth === 0) return "end";
161
+ else if (d.depth === 1) return "end";
162
+ else return "start";
163
+ })
164
+ .attr("class", d => d.depth <= 1 ? "parent" : "")
165
+ .text(d => d.data.name);
166
+ })();
167
+ </script>
src/index.html CHANGED
@@ -44,7 +44,6 @@
44
  <p style="text-align: cekter; font-style: italic; margin-top: 10px; max-width: 900px; margin-left: auto; margin-right: auto;">
45
  The embedding atlas of 50 random words and their closest tokens in the embedding space of `deepseek-ai/DeepSeek-R1-Distill-Qwen-1.5B`.
46
  </p>
47
-
48
  </div>
49
  </d-title>
50
  <d-byline></d-byline>
@@ -52,7 +51,19 @@
52
  <d-contents>
53
  </d-contents>
54
 
55
- <p>Welcome to the Distill Blog Template! This framework is based on the <a href="https://distill.pub/">distill.pub</a> design and has been adapted to make it easy for you to create beautiful, interactive technical blogs. Whether you're writing about machine learning, data science, physics, or any technical topic, this template provides the structure and components you need.</p>
 
 
 
 
 
 
 
 
 
 
 
 
56
 
57
  <aside>Reading time: 10-15 minutes.</aside>
58
 
 
44
  <p style="text-align: cekter; font-style: italic; margin-top: 10px; max-width: 900px; margin-left: auto; margin-right: auto;">
45
  The embedding atlas of 50 random words and their closest tokens in the embedding space of `deepseek-ai/DeepSeek-R1-Distill-Qwen-1.5B`.
46
  </p>
 
47
  </div>
48
  </d-title>
49
  <d-byline></d-byline>
 
51
  <d-contents>
52
  </d-contents>
53
 
54
+ <p>Large Language Models (LLM) evolve faster than you can blink. The methods you study today will be out the window in a few months.
55
+ But one aspect about LLMs that remains almost unchanged from the early days is the use of embeddings. Embeddings are the semantic backbone of LLMs,
56
+ the gate at which raw text is transformed into vectors of numbers that are understandable by the model. When you ask ChatGPT about the most important
57
+ life decisions, your words and tokens are transformed into a high-dimensional vector space where semantic relationships become mathematical relationships.
58
+ </p>
59
+
60
+ <figure class="fullscreen">
61
+ <div id="image-as-graph" style="display: grid; position: relative; justify-content: center;">
62
+ {{{fragment-word-emb-hierarchy}}}
63
+ </div>
64
+ <figcaption>embedding hierarchy</figcaption>
65
+ </figure>
66
+
67
 
68
  <aside>Reading time: 10-15 minutes.</aside>
69